org.primefaces.model.DefaultScheduleEvent Maven / Gradle / Ivy
/*
* The MIT License
*
* Copyright (c) 2009-2024 PrimeTek Informatics
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
package org.primefaces.model;
import java.io.Serializable;
import java.time.LocalDateTime;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
public class DefaultScheduleEvent implements ScheduleEvent, Serializable {
private static final long serialVersionUID = 1L;
private String id;
private T data;
private String groupId;
private String title;
private LocalDateTime startDate;
private LocalDateTime endDate;
private boolean allDay;
private boolean overlapAllowed;
private Boolean resizable;
private Boolean draggable;
private String styleClass;
private String description;
private String url;
private ScheduleDisplayMode display;
private String backgroundColor;
private String borderColor;
private String textColor;
private Map dynamicProperties;
public DefaultScheduleEvent() {
}
@Override
public String getId() {
return id;
}
@Override
public void setId(String id) {
this.id = id;
}
@Override
public String getGroupId() {
return groupId;
}
public void setGroupId(String groupId) {
this.groupId = groupId;
}
@Override
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
@Override
public LocalDateTime getStartDate() {
return startDate;
}
@Override
public void setStartDate(LocalDateTime startDate) {
this.startDate = startDate;
}
@Override
public LocalDateTime getEndDate() {
return endDate;
}
@Override
public void setEndDate(LocalDateTime endDate) {
this.endDate = endDate;
}
@Override
public boolean isAllDay() {
return allDay;
}
@Override
public void setAllDay(boolean allDay) {
this.allDay = allDay;
}
public void setStyleClass(String styleClass) {
this.styleClass = styleClass;
}
@Override
public String getStyleClass() {
return styleClass;
}
@Override
public T getData() {
return data;
}
public void setData(T data) {
this.data = data;
}
@Override
public Boolean isDraggable() {
return draggable;
}
@Override
public Boolean isResizable() {
return resizable;
}
@Override
public boolean isOverlapAllowed() {
return overlapAllowed;
}
public void setOverlapAllowed(boolean overlapAllowed) {
this.overlapAllowed = overlapAllowed;
}
/**
* Shortcut for calling both {@link #setDraggable(Boolean)} and
* {@link #setResizable(Boolean)}.
*/
public void setEditable(boolean editable) {
this.draggable = editable;
this.resizable = editable;
}
/**
* @param draggable Whether the event should be draggable. Setting
* {@code null} means that the default of the schedule is applied.
* Otherwise, this setting overrides the default of the schedule.
*/
public void setDraggable(Boolean draggable) {
this.draggable = draggable;
}
/**
* @param resizable Whether the event should be resizable. Setting
* {@code null} means that the default of the schedule is applied.
* Otherwise, this setting overrides the default of the schedule.
*/
public void setResizable(Boolean resizable) {
this.resizable = resizable;
}
@Override
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
@Override
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
@Override
public ScheduleDisplayMode getDisplay() {
return display;
}
public void setDisplay(ScheduleDisplayMode display) {
this.display = display;
}
@Override
public String getBackgroundColor() {
return backgroundColor;
}
public void setBackgroundColor(String backgroundColor) {
this.backgroundColor = backgroundColor;
}
@Override
public String getBorderColor() {
return borderColor;
}
public void setBorderColor(String borderColor) {
this.borderColor = borderColor;
}
@Override
public String getTextColor() {
return textColor;
}
public void setTextColor(String textColor) {
this.textColor = textColor;
}
@Override
public Map getDynamicProperties() {
return dynamicProperties;
}
public Object setDynamicProperty(String key, Object value) {
if (dynamicProperties == null) {
dynamicProperties = new HashMap<>();
}
return dynamicProperties.put(key, value);
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
DefaultScheduleEvent> that = (DefaultScheduleEvent>) o;
return Objects.equals(title, that.title) &&
Objects.equals(startDate, that.startDate) &&
Objects.equals(endDate, that.endDate);
}
@Override
public int hashCode() {
return Objects.hash(title, startDate, endDate);
}
@Override
public String toString() {
return "DefaultScheduleEvent{title=" + title + ",startDate=" + startDate + ",endDate=" + endDate + "}";
}
public static Builder builder() {
return new Builder<>();
}
public static final class Builder {
private final DefaultScheduleEvent scheduleEvent;
private Builder() {
scheduleEvent = new DefaultScheduleEvent<>();
}
public DefaultScheduleEvent.Builder id(String id) {
scheduleEvent.setId(id);
return this;
}
public DefaultScheduleEvent.Builder groupId(String groupId) {
scheduleEvent.setGroupId(groupId);
return this;
}
public DefaultScheduleEvent.Builder title(String title) {
scheduleEvent.setTitle(title);
return this;
}
public DefaultScheduleEvent.Builder startDate(LocalDateTime startDate) {
scheduleEvent.setStartDate(startDate);
return this;
}
public DefaultScheduleEvent.Builder endDate(LocalDateTime endDate) {
scheduleEvent.setEndDate(endDate);
return this;
}
public DefaultScheduleEvent.Builder allDay(boolean allDay) {
scheduleEvent.setAllDay(allDay);
return this;
}
public DefaultScheduleEvent.Builder styleClass(String styleClass) {
scheduleEvent.setStyleClass(styleClass);
return this;
}
public DefaultScheduleEvent.Builder data(T data) {
scheduleEvent.setData(data);
return this;
}
/**
* Makes the event both resizable and draggable.This is a shortcut
* for calling {@link #resizable(Boolean)} and
* {@link #draggable(Boolean)}.
* @param editable Whether the event should be editable.
*/
public DefaultScheduleEvent.Builder editable(boolean editable) {
scheduleEvent.setEditable(editable);
return this;
}
/**
* @param draggable Whether the event should be draggable. Passing
* {@code null} means that the default of the schedule is applied.
* Otherwise, this setting overrides the default of the schedule.
*/
public DefaultScheduleEvent.Builder draggable(Boolean draggable) {
scheduleEvent.setDraggable(draggable);
return this;
}
/**
* @param resizable Whether the event should be resizable. Passing
* {@code null} means that the default of the schedule is applied.
* Otherwise, this setting overrides the default of the schedule.
*/
public DefaultScheduleEvent.Builder resizable(Boolean resizable) {
scheduleEvent.setResizable(resizable);
return this;
}
public DefaultScheduleEvent.Builder overlapAllowed(boolean overlapAllowed) {
scheduleEvent.setOverlapAllowed(overlapAllowed);
return this;
}
public DefaultScheduleEvent.Builder description(String description) {
scheduleEvent.setDescription(description);
return this;
}
public DefaultScheduleEvent.Builder url(String url) {
scheduleEvent.setUrl(url);
return this;
}
public DefaultScheduleEvent.Builder dynamicProperty(String key, Object value) {
scheduleEvent.setDynamicProperty(key, value);
return this;
}
public DefaultScheduleEvent.Builder display(ScheduleDisplayMode display) {
scheduleEvent.setDisplay(display);
return this;
}
public DefaultScheduleEvent.Builder backgroundColor(String backgroundColor) {
scheduleEvent.setBackgroundColor(backgroundColor);
return this;
}
public DefaultScheduleEvent.Builder borderColor(String borderColor) {
scheduleEvent.setBorderColor(borderColor);
return this;
}
public DefaultScheduleEvent.Builder textColor(String textColor) {
scheduleEvent.setTextColor(textColor);
return this;
}
public DefaultScheduleEvent build() {
return scheduleEvent;
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy