Template
8 Mar 201824 minutes to read
Template is applicable to all the below specified elements of the Scheduler,
- Appointments
- Cells
- Resource header
- Date header
- Priority field
- TimeScale
- Date and time columns in Agenda view
- Tooltip
Appointment Template
The template design that applies on for the Scheduler appointments. The field names that are mapped from the dataSource to the appropriate field properties within the appointmentSettings can be accessed within the template.
Apart from the dataSource field names, the template can also access the current view of the Scheduler using the name View – which can contain either of the following values in lowercase.
- day
- week
- workweek
- agenda
- month
- custom view
It is controlled by an API named appointmentTemplateId which accepts the id value of the template design block preceded by a symbol #.
Usually, the appointments are displayed with its Subject and Start/End time on the Scheduler. If suppose, the subject needs to be accompanied with location text, it can be done with the following code example.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>" appointmentTemplateId="#appTemplate">
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule"></ej:schedule-appointmentSettings>
</ej:schedule>
<script id="appTemplate" type="text/x-jsrender">
{{if View !== "agenda"}}
<div style="height:100%; background-color:orange; margin-left: 5px;">
<div style="margin-left: 2px;">{{:Subject}}</div>
<div style="margin-left: 2px;">{{:Location}}</div>
</div>
{{else}}
<div>{{:Subject}}, {{:Location}}</div>
{{/if"}}
</script>
Cell Templates
The template design that applies on the Scheduler elements such as all-day cells, work cells and month cells which allows the customization to be done based on the date, view, resources and timescale. The cells can be customized to add images, colors, and other elements etc and can also access the current view of the Scheduler using the name view.
All-day cells - An API named allDayCellsTemplateId can be used to customize the all-day cells, which accepts the id of the template design block preceded with a symbol #.
Work cells and Month cells - An API named workCellsTemplateId can be used to customize the work cells in all the views, which accepts the id of the template design block preceded by a symbol #.
The cells can be customized with the following code example.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>" allDayCellsTemplateId="#allDayTemplate" workCellsTemplateId="#workTemplate">
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule"></ej:schedule-appointmentSettings>
</ej:schedule>
<!-- Template for All-day cells -->
<script id="allDayTemplate" type="text/x-jsrender">
<div class="e-icon e-scheduleallday" style="opacity:0.5"></div>
<span style="opacity:0.5">AllDay</span>
</script>
<!-- Template for Workcells and Monthcells -->
<script id="workTemplate" type="text/x-jsrender">
{{if resource.classname == 'e-parentnode'}}
{{:resource.text}}
{{else}}
{{if date.getDay() == 0 || date.getDay() == 6}}
<div style="background-color:lightblue">Weekend</div>
{{else}}
{{if view == 'month' && resource.text == 'Party Hall-A' && date.getDay() == 5}}
<div style="background-color:burlywood">Meeting</div>
{{else resource.text != 'Party Hall-B' && date.getDate() == 15}}
<div style="background-color:thistle">Holiday</div>
{{else view != 'month' && resource.text == 'Party Hall-A' && date.getDay() == 5 && date.getHours() == 10}}
<div style="background-color:burlywood">Meeting</div>
{{else view == 'month' && resource.text == 'Party Hall-B' && date.getDay() == 5}}
<div style="background-color:lightblue">Conf.</div>
{{else resource.text == 'Party Hall-B' && date.getDate() == 16}}
<div style="background-color:darkkhaki">HappyDay</div>
{{else view != 'month' && resource.text == 'Party Hall-B' && date.getDay() == 5 && date.getHours() == 12}}
<div style="background-color:goldenrod">Conf.</div>
{{else date.getDate() == 10 && date.getMonth() == 11}}
<div style="background-color:palegreen">Day Special</div>
{{else date.getDate() == 25 && date.getMonth() == 11}}
<div style="background-color:sandybrown">Christmas</div>
{{/if}}
{{/if}}
{{/if}}
</script>
Date Header Template
The template design that applies on for the date header part of the Scheduler. An API named dateHeaderTemplateId can be used to customize the date header which accepts the id value of the template design block preceded by a symbol #. The template can also access the current view of the Scheduler in using the name view.
The Date header can be customized with the following code example.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>" dateHeaderTemplateId="#dateTemplate">
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule"></ej:schedule-appointmentSettings>
</ej:schedule>
<!-- Template for Dateheader -->
<script id="dateTemplate" type="text/x-jsrender">
<div>{{:~dTemplate(date)}}</div>
</script>
function _dateFormat(date) {
var dFormat = ej.format(new Date(date), "dd/MM");
return dFormat;
}
$.views.helpers({ dTemplate: _dateFormat });
Resource Header Template
The template structure that applies on the resource headers of the Scheduler. By default, only the resource names will be displayed on the resource header bar. Also, the way of rendering resource headers on the Scheduler is comparatively different for both the vertical and horizontal scheduler views.
The field names that are mapped from the dataSource to the appropriate field properties within the resourceSettings can be accessed within the resource header template.
Resource Header Template in Vertical View
To customize the resource header with some additional images or other customizations in vertical Scheduler View – refer the below code example.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
String[] group = { "Owners" };
ArrayList<HashMap<String, Object>> resourceData = new ArrayList<HashMap<String, Object>>();
HashMap<String, Object> res1 = new HashMap<String, Object>();
res1.put("text", "Nancy");
res1.put("id", 1);
res1.put("color", "#f8a398");
resourceData.add(res1);
HashMap<String, Object> res2 = new HashMap<String, Object>();
res2.put("text", "Steven");
res2.put("id", 3);
res2.put("color", "#56ca85");
resourceData.add(res2);
HashMap<String, Object> res3 = new HashMap<String, Object>();
res3.put("text", "Michael");
res3.put("id", 5);
res3.put("color", "#51a0ed");
resourceData.add(res3);
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>" resourceHeaderTemplateId="#resTemplate">
<ej:schedule-group resources="<%=group%>"></ej:schedule-group>
<ej:schedule-resources>
<ej:schedule-resource allowMultiple="true" field="ownerId" name="Owners" title="Owner">
<ej:schedule-resources-resourceSettings id="id" color="color" text="text" dataSource="<%=resourceData%>"></ej:schedule-resources-resourceSettings>
</ej:schedule-resource>
</ej:schedule-resources>
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule" resourceFields="ownerId"></ej:schedule-appointmentSettings>
</ej:schedule>
<script id="resTemplate" type="text/x-jsrender">
<div style="height:100%">
<div style="width:15px;height:15px;margin-left:275px;margin-top:2px;float:left;background:{{:ResourceColor}};"></div>
<div style="float:left;margin-left:5px;">{{:ResourceText}}</div>
</div>
</script>
Resource Header Template in Horizontal View
To perform the above specified same customization in horizontal Scheduler view, the template structure varies a little bit as depicted below.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
String[] group = { "Owners" };
ArrayList<HashMap<String, Object>> resourceData = new ArrayList<HashMap<String, Object>>();
HashMap<String, Object> res1 = new HashMap<String, Object>();
res1.put("text", "Nancy");
res1.put("id", 1);
res1.put("color", "#f8a398");
resourceData.add(res1);
HashMap<String, Object> res2 = new HashMap<String, Object>();
res2.put("text", "Steven");
res2.put("id", 3);
res2.put("color", "#56ca85");
resourceData.add(res2);
HashMap<String, Object> res3 = new HashMap<String, Object>();
res3.put("text", "Michael");
res3.put("id", 5);
res3.put("color", "#51a0ed");
resourceData.add(res3);
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>" orientation="horizontal" resourceHeaderTemplateId="#resTemplate">
<ej:schedule-group resources="<%=group%>"></ej:schedule-group>
<ej:schedule-resources>
<ej:schedule-resource allowMultiple="true" field="ownerId" name="Owners" title="Owner">
<ej:schedule-resources-resourceSettings id="id" color="color" text="text" dataSource="<%=resourceData%>"></ej:schedule-resources-resourceSettings>
</ej:schedule-resource>
</ej:schedule-resources>
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule" resourceFields="ownerId"></ej:schedule-appointmentSettings>
</ej:schedule>
<script id="resTemplate" type="text/x-jsrender">
<div style="height:100%">
<div style="width:15px;height:15px;margin-right:5px;margin-top:2px;float:left;background:{{:ResColor}};"></div><div>{{:ResText}}</div>
</div>
</script>
NOTE
In horizontal Scheduler, the header template makes use of an additional field namely classname which holds either e-parentnode or e-childnode value. The field classname can be used in the application scenario to check for the parent or child header node. You can apply the different template customization accordingly based on it.
TimeScale Templates
The TimeScale is also availed with template options to allow customization. It includes the following 2 properties for customization -
- majorSlotTemplateId - Accepts the id value of the template design block preceded by a symbol #, which gets applied for the major time slots.
- minorSlotTemplateId - Accepts the id value of the template design block preceded by a symbol #, which gets applied for the minor time slots.
The template customization for major and minor timeslots can be referred from the following code example.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>">
<ej:schedule-timeScale enable="true" majorSlot="60" majorSlotTemplateId="#majorTemplate" minorSlotCount="6" minorSlotTemplateId="#minorTemplate"></ej:schedule-timeScale>
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule"></ej:schedule-appointmentSettings>
</ej:schedule>
<!-- Template for Majorslot -->
<script id="majorTemplate" type="text/x-jsrender">
<div>{{:~major(date)}}</div>
</script>
<!-- Template for Minorslot -->
<script id="minorTemplate" type="text/x-jsrender">
<div>{{:~minor(date)}}</div>
</script>
function _majorFormat(date) {
var dFormat = ej.format(new Date(date), "hh:mm:ss");
return dFormat;
}
function _minorFormat(date) {
var dFormat = ej.format(new Date(date), "hh:mm:ss");
return dFormat;
}
$.views.helpers({
major: _majorFormat,
minor: _minorFormat
});
Priority Settings Template
The template design which can be applied to the content of the priority field in the appointment window. By default, the appropriate icons are displayed for each priority options such as None, High, Medium and Low.
When template is applied for the prioritySettings, these default icons will be replaced by the custom icons or styles defined newly. The following code example depicts the way to enable the priority settings and to define the new custom styles to replace the default icons in the Priority field.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
ArrayList<HashMap<String, Object>> priorityData = new ArrayList<HashMap<String, Object>>();
HashMap<String, Object> priority1 = new HashMap<String, Object>();
priority1.put("text", "None");
priority1.put("id", 1);
priority1.put("value", "none");
priorityData.add(priority1);
HashMap<String, Object> priority1 = new HashMap<String, Object>();
priority1.put("text", "Critical");
priority1.put("id", 2);
priority1.put("value", "critical");
priorityData.add(priority1);
HashMap<String, Object> priority1 = new HashMap<String, Object>();
priority1.put("text", "Ultra Critical");
priority1.put("id", 3);
priority1.put("value", "ultra-critical");
priorityData.add(priority1);
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>">
<ej:schedule-prioritySettings enable="true" template="<div class='${value}'></div>" dataSource="<%=priorityData%>"></ej:schedule-prioritySettings>
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule" priority="Priority"></ej:schedule-appointmentSettings>
</ej:schedule>
<style type="text/css">
.critical,
.ultra-critical,
.none {
height: 13px;
width: 13px;
float: left;
margin-right: 4px;
background-repeat: no-repeat;
background-size: 60px;
padding: 1px;
margin-top: 2px;
}
.critical {
background-color: orange;
background-position: -13px;
}
.ultra-critical {
background-color: #56ca85;
background-position: -59px;
}
</style>
The custom style class names defined for the priority template should be same as that of the values defined for each priority option within the dataSource, so that it applies properly.
NOTE
Additionally, the priority field within the appointmentSettings should be defined with appropriate dataSource field name. When an appointment is assigned with a priority value, the custom style/icon defined for that priority option will get applied over that appointment.
Tooltip Template
The tooltip can be applied with the customized template design. Currently the tooltip support is provided only for the appointments and the default tooltip displays the Subject and duration on hovering across the appointments.
By making use of template feature with tooltip, all the field names that are mapped from the dataSource to the appropriate field properties within the appointmentSettings can be accessed.
To define the template option for tooltip, the tooltipSettings must be enabled first. The following code example depicts the way to add the tooltip template.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>">
<ej:schedule-tooltipSettings enable="true" templateId="#tooltipTemplate"></ej:schedule-tooltipSettings>
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule"></ej:schedule-appointmentSettings>
</ej:schedule>
<script id="tooltipTemplate" type="text/x-jsrender">
<div style="width:145px">
<div style="padding-top:3px;">
<div style="float:left; font:13px Segoe UI; font-weight:bold;">Subject : </div>
<div style="padding-top:2px; font:12px Segoe UI SemiBold;">{{:Subject}}</div>
</div>
<div style="padding-top:3px">
<div style="float:left; font:13px Segoe UI; font-weight:bold;">Location: </div>
<div style="padding-top:2px; font:12px Segoe UI SemiBold;">{{:Location}}</div>
</div>
</div>
</script>
Agenda View Templates
Agenda View provides two separate templates – one for date column and another for time column. These templates allows the customization of the content of both the date and time columns. Apart from this, the event column can also be customized through the existing API named appointmentTemplateId.
The following code snippet shows how to customize the content of the date, time and event column.
<%@ page import="datasource.schedule.*"%>
<%@ page import="java.util.ArrayList"%>
<%@ page import="java.util.Date"%>
<%@ page import="java.text.SimpleDateFormat"%>
<%
ScheduleGetDataSource obj = new ScheduleGetDataSource();
ArrayList<ScheduleDataSource> scheduleData = obj.getData();
request.setAttribute("scheduleData", scheduleData);
Date currentDate = new SimpleDateFormat("yyyy/MM/dd").parse("2016/5/4");
%>
<!--Container for ejScheduler widget-->
<ej:schedule id="Schedule1" width="100%" currentDate="<%=currentDate%>" orientation="horizontal" appointmentTemplateId="#appTemplate">
<ej:schedule-agendaViewSettings dateColumnTemplateId="#dateTemplate" timeColumnTemplateId="#timeTemplate"></ej:schedule-agendaViewSettings>
<ej:schedule-appointmentSettings dataSource="${scheduleData}" id="Id" subject="Subject" description="Description" startTime="StartTime" endTime="EndTime" allDay="AllDay" recurrence="Recurrence" recurrenceRule="RecurrenceRule"></ej:schedule-appointmentSettings>
</ej:schedule>
// Template for date column
<script id="dateTemplate" type="text/x-jsrender">
<div style="height:100%">
<div>
<div>{{:~dateDisplay(StartTime)}}</div>
</div>
</div>
</script>
// Template for time column
<script id="timeTemplate" type="text/x-jsrender">
<div style="height:100%">
<div>
<div>{{:~timeDisplay(StartTime)}}</div>
</div>
</div>
</script>
// Template for appointment which applies for event column in agenda view.
<script id="appTemplate" type="text/x-jsrender">
{{if View !== "agenda"}}
<div style="height:100%; background-color:orange; margin-left: 5px;">
<div style="margin-left: 2px;">{{:Subject}}</div>
<div style="margin-left: 2px;">{{:Location}}</div>
</div>
{{else}}
<div>{{:Subject}}, {{:Location}}</div>
{{/if}}
</script>
function _getDate(date) {
var dateCol = new Date(date);
return dateCol.toDateString();
}
function _getTime(date) {
var time = new Date(date);
return time.toLocaleTimeString();
}
//Here, used the helper function to get the date and time value part from the StartTime.
$.views.helpers({
dateDisplay: _getDate,
timeDisplay: _getTime
});