com.idega.block.cal.renderer.AbstractCompactScheduleRenderer.java Source code

Java tutorial

Introduction

Here is the source code for com.idega.block.cal.renderer.AbstractCompactScheduleRenderer.java

Source

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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 com.idega.block.cal.renderer;

import java.io.IOException;
import java.io.Serializable;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.Iterator;
import java.util.Map;
import java.util.TimeZone;
import java.util.TreeSet;

import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.context.ResponseWriter;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.myfaces.custom.schedule.model.ScheduleDay;
import org.apache.myfaces.custom.schedule.model.ScheduleEntry;
import org.apache.myfaces.custom.schedule.util.ScheduleUtil;
import org.apache.myfaces.shared_tomahawk.renderkit.RendererUtils;
import org.apache.myfaces.shared_tomahawk.renderkit.html.HTML;
import org.apache.myfaces.shared_tomahawk.renderkit.html.util.FormInfo;

import com.idega.block.cal.business.CalendarConstants;
import com.idega.block.cal.business.HtmlSchedule;

/**
 * <p>
 * Abstract superclass for the week and month view renderers.
 * </p>
 * 
 * @author Jurgen Lust (latest modification by $Author: civilis $)
 * @author Bruno Aranda (adaptation of Jurgen's code to myfaces)
 * @version $Revision: 1.11 $
 */
public abstract class AbstractCompactScheduleRenderer extends AbstractScheduleRenderer implements Serializable {
    private static final Log log = LogFactory.getLog(AbstractCompactScheduleRenderer.class);

    // ~ Methods
    // ----------------------------------------------------------------

    /**
     * @see javax.faces.render.Renderer#encodeChildren(javax.faces.context.FacesContext,
     *      javax.faces.component.UIComponent)
     */
    @Override
    public void encodeChildren(FacesContext context, UIComponent component) throws IOException {
        // the children are rendered in the encodeBegin phase
    }

    /**
     * @see javax.faces.render.Renderer#encodeEnd(javax.faces.context.FacesContext,
     *      javax.faces.component.UIComponent)
     */
    @Override
    public void encodeEnd(FacesContext context, UIComponent component) throws IOException {
        // all rendering is done in the begin phase
    }

    /**
     * @return The default height, in pixels, of one row in the schedule grid
     */
    @Override
    protected abstract int getDefaultRowHeight();

    /**
     * @return The name of the property that determines the row height
     */
    @Override
    protected abstract String getRowHeightProperty();

    /**
     * @param attributes
     *            The attributes
     * 
     * @return The row height, in pixels
     */
    @Override
    protected int getRowHeight(Map attributes) {
        int rowHeight = 0;

        try {
            rowHeight = Integer.valueOf((String) attributes.get(getRowHeightProperty())).intValue();
        } catch (Exception e) {
            rowHeight = 0;
        }

        if (rowHeight == 0) {
            rowHeight = getDefaultRowHeight();
        }

        return rowHeight;
    }

    /**
     * <p>
     * Draw one day in the schedule
     * </p>
     * 
     * @param context
     *            the FacesContext
     * @param writer
     *            the ResponseWriter
     * @param schedule
     *            the schedule
     * @param day
     *            the day that should be drawn
     * @param cellWidth
     *            the width of the cell
     * @param dayOfWeek
     *            the day of the week
     * @param dayOfMonth
     *            the day of the month
     * @param isWeekend
     *            is it a weekend day?
     * @param isCurrentMonth
     *            is the day in the currently selected month?
     * @param rowspan
     *            the rowspan for the table cell
     * 
     * @throws IOException
     *             when the cell could not be drawn
     */
    protected void writeDayCell(FacesContext context, ResponseWriter writer, HtmlSchedule schedule, ScheduleDay day,
            float cellWidth, int dayOfWeek, int dayOfMonth, boolean isWeekend, boolean isCurrentMonth, int rowspan)
            throws IOException {

        final String clientId = schedule.getClientId(context);
        final Map<String, Object> attributes = schedule.getAttributes();
        final FormInfo parentFormInfo = RendererUtils.findNestingForm(schedule, context);
        final String formId = parentFormInfo == null ? null : parentFormInfo.getFormName();

        TimeZone tz = TimeZone.getDefault();
        final String dayHeaderId = clientId + "_header_" + ScheduleUtil.getDateId(day.getDate(), tz);
        final String dayBodyId = clientId + "_body_" + ScheduleUtil.getDateId(day.getDate(), tz);

        boolean isMonthMode = false;
        boolean isWeekMode = false;

        boolean isFirstInARow = false;

        if (cellWidth == 100f / 6) {
            isMonthMode = true;
        } else if (cellWidth == 50f) {
            isWeekMode = true;
        }

        if ((dayOfWeek != Calendar.SUNDAY) && isMonthMode) {
            writer.startElement(HTML.DIV_ELEM, schedule);
        }
        if (isWeekMode && (dayOfWeek != Calendar.SUNDAY)) {
            writer.startElement(HTML.DIV_ELEM, schedule);
        }
        String dayClass = null;
        if (isWeekMode) {
            dayClass = "";
        } else {
            dayClass = getStyleClass(schedule, isCurrentMonth ? "day" : "inactive-day") + " "
                    + getStyleClass(schedule, isWeekend ? "weekend" : "workday");
        }

        // add class for sunday

        if ((dayOfWeek == Calendar.MONDAY) || (dayOfWeek == Calendar.WEDNESDAY) || (dayOfWeek == Calendar.FRIDAY)// ||
        ) {
            isFirstInARow = true;
        }

        if (dayOfWeek == Calendar.SUNDAY) {
            dayClass += " sunday";
        }

        if (dayOfWeek == Calendar.SATURDAY) {
            dayClass += " saturday";
        }

        if ((dayOfWeek != Calendar.SUNDAY) && isMonthMode) {
            writer.writeAttribute(HTML.CLASS_ATTR, "workdaytest", null);

        }
        if ((dayOfWeek != Calendar.SUNDAY) && isWeekMode) {
            if (isFirstInARow) {
                writer.writeAttribute(HTML.CLASS_ATTR, "weekTest firstInAWeekRow", null);
            } else {
                writer.writeAttribute(HTML.CLASS_ATTR, "weekTest secondInAWeekRow", null);
            }
        }

        // determine the height of the day in pixels
        StringBuffer styleBuffer = new StringBuffer();

        int rowHeight = getRowHeight(attributes);
        String myRowHeight = "height: ";
        String myContentHeight = "height: ";

        if (rowHeight > 0) {
            if (isWeekend) {
                myRowHeight += (rowHeight / 2) + "px;";
                myContentHeight += ((rowHeight / 2) - 19) + "px;";
            } else {
                myRowHeight += (rowHeight + 1) + "px;"; //need to add 1 to get the weekends right
                myContentHeight += ((rowHeight + 1) - 18) + "px;"; //18 instead of 19, to get the weekends right
            }
        } else {
            myRowHeight += "100%;";
            myContentHeight += "100%;";
        }

        styleBuffer.append(myRowHeight);

        writer.startElement(HTML.DIV_ELEM, schedule);

        if (cellWidth == 50f) {
            writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "day weekMode"), null);
        } else {
            writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "day monthMode"), null);
        }

        // day header
        writer.startElement(HTML.DIV_ELEM, schedule);

        if (isMonthMode) {
            writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "headerForMonthDay"), null);
        } else if (isWeekMode) {
            writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "headerForWeekDay"), null);
        }

        writer.startElement(HTML.DIV_ELEM, schedule);
        writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "header"), null);
        writer.writeAttribute(HTML.STYLE_ATTR, "height: 18px; width: 100%; overflow: hidden", null);
        writer.writeAttribute(HTML.ID_ATTR, dayHeaderId, null);
        //register an onclick event listener to a day header which will capture
        //the date
        if (!schedule.isReadonly() && schedule.isSubmitOnClick()) {
            writer.writeAttribute(HTML.ONMOUSEUP_ATTR,
                    "fireScheduleDateClicked(this, event, '" + formId + "', '" + clientId + "');", null);
        }

        writer.writeText(getDateString(context, schedule, day.getDate()), null);
        writer.endElement(HTML.DIV_ELEM);
        writer.endElement(HTML.DIV_ELEM);

        // day content
        writer.startElement(HTML.DIV_ELEM, schedule);
        writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "contentForMonthDay"), null);
        writer.startElement(HTML.DIV_ELEM, schedule);
        if (isMonthMode) {

            if ((dayOfWeek == Calendar.SUNDAY) || (dayOfWeek == Calendar.SATURDAY)) {
                writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "weekendContent content"), null);
            } else {
                writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "workdayContent content"), null);
            }

        } else {
            if ((dayOfWeek == Calendar.SUNDAY) || (dayOfWeek == Calendar.SATURDAY)) {
                writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "weekendContentWeekMode content"),
                        null);
            } else {
                writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "workdayContentWeekMode content"),
                        null);
            }
        }

        // determine the height of the day content in pixels
        StringBuffer contentStyleBuffer = new StringBuffer();
        contentStyleBuffer.append(myContentHeight);
        //        contentStyleBuffer.append(" width: 100%;");
        writer.writeAttribute(HTML.STYLE_ATTR, contentStyleBuffer.toString(), null);

        writer.startElement(HTML.DIV_ELEM, schedule);
        writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "contentview"), null);

        //this extra div is required, because when a scrollbar is visible and
        //it is clicked, the fireScheduleTimeClicked() method is fired.
        writer.startElement(HTML.DIV_ELEM, schedule);
        writer.writeAttribute(HTML.STYLE_ATTR, "height: 100%; vertical-align: top;", null);

        writer.writeAttribute(HTML.ID_ATTR, dayBodyId, null);

        //register an onclick event listener to a day cell which will capture
        //the date
        if (!schedule.isReadonly() && schedule.isSubmitOnClick()) {
            writer.writeAttribute(HTML.ONMOUSEUP_ATTR,
                    "fireScheduleTimeClicked(this, event, '" + formId + "', '" + clientId + "');", null);
        }

        writer.startElement(HTML.DIV_ELEM, schedule);
        writer.writeAttribute(HTML.STYLE_ATTR, "width: 100%;", null);

        writeEntries(context, schedule, day, writer);

        writer.endElement(HTML.DIV_ELEM);
        writer.endElement(HTML.DIV_ELEM);
        writer.endElement(HTML.DIV_ELEM);
        writer.endElement(HTML.DIV_ELEM);
        writer.endElement(HTML.DIV_ELEM);
        writer.endElement(HTML.DIV_ELEM);

        if ((dayOfWeek != Calendar.SATURDAY) && isMonthMode) {
            writer.endElement(HTML.DIV_ELEM);
        }
        if (cellWidth == 50f && dayOfWeek != Calendar.SATURDAY) {
            writer.endElement(HTML.DIV_ELEM);
        }
    }

    /**
     * <p>
     * Draw the schedule entries in the specified day cell
     * </p>
     * 
     * @param context
     *            the FacesContext
     * @param schedule
     *            the schedule
     * @param day
     *            the day
     * @param writer
     *            the ResponseWriter
     * 
     * @throws IOException
     *             when the entries could not be drawn
     */
    protected void writeEntries(FacesContext context, HtmlSchedule schedule, ScheduleDay day, ResponseWriter writer)
            throws IOException {
        //final String clientId = schedule.getClientId(context);
        //final FormInfo parentFormInfo = RendererUtils.findNestingForm(schedule, context);
        //final String formId = parentFormInfo == null ? null : parentFormInfo.getFormName();
        final TreeSet entrySet = new TreeSet(comparator);

        for (Iterator entryIterator = day.iterator(); entryIterator.hasNext();) {
            ScheduleEntry entry = (ScheduleEntry) entryIterator.next();
            entrySet.add(entry);
        }

        for (Iterator entryIterator = entrySet.iterator(); entryIterator.hasNext();) {
            ScheduleEntry entry = (ScheduleEntry) entryIterator.next();
            writer.startElement(HTML.DIV_ELEM, schedule);
            writer.startElement(HTML.DIV_ELEM, schedule);

            if (isSelected(schedule, entry)) {
                writer.writeAttribute(HTML.CLASS_ATTR, getStyleClass(schedule, "selected"), null);
            }

            //compose the CSS style for the entry box
            StringBuffer entryStyle = new StringBuffer();
            entryStyle.append("width: 100%;");
            String entryColor = getEntryRenderer(schedule).getColor(context, schedule, entry,
                    isSelected(schedule, entry));
            if (isSelected(schedule, entry) && entryColor != null) {
                entryStyle.append(" background-color: ");
                entryStyle.append(entryColor);
                entryStyle.append(";");
                entryStyle.append(" border-color: ");
                entryStyle.append(entryColor);
                entryStyle.append(";");
            }

            writer.writeAttribute(HTML.STYLE_ATTR, entryStyle.toString(), null);

            // draw the tooltip
            if (showTooltip(schedule)) {
                getEntryRenderer(schedule).renderToolTip(context, writer, schedule, entry,
                        isSelected(schedule, entry));
            }

            if (!isSelected(schedule, entry) && !schedule.isReadonly()) {
                writer.startElement("a", schedule);
                writer.writeAttribute(HTML.CLASS_ATTR, CalendarConstants.SCHEDULE_ENTRY_STYLE_CLASS, null);
                writer.writeAttribute(HTML.HREF_ATTR, "javascript:void(0)", null);
                writer.writeAttribute("entryid", entry.getId(), null);

                DateFormat format;
                String pattern = null;

                if ((pattern != null) && (pattern.length() > 0)) {
                    format = new SimpleDateFormat(pattern);
                } else {
                    if (context.getApplication().getDefaultLocale() != null) {
                        format = DateFormat.getDateInstance(DateFormat.MEDIUM,
                                context.getApplication().getDefaultLocale());
                    } else {
                        format = DateFormat.getDateInstance(DateFormat.MEDIUM);
                    }
                }

                String startTime = format.format(entry.getStartTime());
                startTime += " ";
                startTime += entry.getStartTime().getHours();
                startTime += ":";
                if (entry.getStartTime().getMinutes() < 10) {
                    startTime += "0";
                    startTime += entry.getStartTime().getMinutes();
                } else {
                    startTime += entry.getStartTime().getMinutes();
                }

                String endTime = "";
                endTime += entry.getEndTime().getHours();
                endTime += ":";
                if (entry.getEndTime().getMinutes() < 10) {
                    endTime += "0";
                    endTime += entry.getEndTime().getMinutes();
                } else {
                    endTime += entry.getEndTime().getMinutes();
                }
            }

            // draw the content
            getEntryRenderer(schedule).renderContent(context, writer, schedule, day, entry, true,
                    isSelected(schedule, entry));

            if (!isSelected(schedule, entry) && !schedule.isReadonly()) {
                writer.endElement("a");
            }

            writer.endElement(HTML.DIV_ELEM);
            writer.endElement(HTML.DIV_ELEM);
        }
    }

    private boolean isSelected(HtmlSchedule schedule, ScheduleEntry entry) {
        ScheduleEntry selectedEntry = schedule.getModel().getSelectedEntry();

        if (selectedEntry == null) {
            return false;
        }

        return selectedEntry.getId().equals(entry.getId());
    }

    /**
     * In the compact renderer, we don't take the y coordinate of the mouse
     * into account when determining the last clicked date.
     */
    @Override
    protected Date determineLastClickedDate(HtmlSchedule schedule, String dateId, String yPos) {
        Calendar cal = Calendar.getInstance();
        //the dateId is the schedule client id + "_" + yyyyMMdd 
        String day = dateId.substring(dateId.lastIndexOf("_") + 1);

        Date date = ScheduleUtil.getDateFromId(day, TimeZone.getDefault());

        if (date != null)
            cal.setTime(date);
        cal.set(Calendar.HOUR_OF_DAY, schedule.getVisibleStartHour());
        cal.set(Calendar.MINUTE, 0);
        cal.set(Calendar.SECOND, 0);
        cal.set(Calendar.MILLISECOND, 0);
        log.debug("last clicked datetime: " + cal.getTime());
        return cal.getTime();
    }

}
// The End