var DemoApp = angular.module('DemoApp', ['dx']);
DemoApp.controller('DemoController', function DemoController($scope) {
$scope.scheduler = null;
$scope.schedulerOptions = {
timeZone: "America/Los_Angeles",
dataSource: data,
views: ["week", "month"],
adaptivityEnabled: true,
currentView: "month",
startDayHour: 9,
currentDate: new Date(2021, 4, 25),
height: 590,
resources: [{
fieldExpr: "priorityId",
dataSource: priorities,
label: "Priority"
}],
};
$scope.speedDialActionOptions = {
icon: "plus",
onClick: showAppointmentPopup
}
function showAppointmentPopup() {
var scheduler = $('#scheduler').dxScheduler('instance');
scheduler.showAppointmentPopup();
}
});
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>DevExtreme Demo</title>
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script>window.jQuery || document.write(decodeURIComponent('%3Cscript src="js/jquery.min.js"%3E%3C/script%3E'))</script>
<link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/20.2.4/css/dx.common.css" />
<link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/20.2.4/css/dx.light.css" />
<link rel="stylesheet" type="text/css" href="styles.css" />
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.16/angular.min.js"></script>
<script>window.angular || document.write(decodeURIComponent('%3Cscript src="js/angular.min.js"%3E%3C/script%3E'))</script>
<script src="https://cdn3.devexpress.com/jslib/20.2.4/js/dx.all.js"></script>
<script src="data.js"></script>
<script src="index.js"></script>
</head>
<body class="dx-viewport">
<div class="demo-container" ng-app="DemoApp" ng-controller="DemoController">
<div id="scheduler" dx-scheduler="schedulerOptions"></div>
<div id="speed-dial-action" dx-speed-dial-action="speedDialActionOptions"></div>
</div>
</body>
</html>
@media only screen and (max-width: 370px) {
.dx-popup:not(.dx-scheduler-appointment-popup) .dx-dialog .dx-popup-bottom.dx-toolbar .dx-toolbar-items-container {
height: auto;
}
.dx-popup:not(.dx-scheduler-appointment-popup) .dx-dialog .dx-toolbar-items-container .dx-toolbar-center {
display: flex;
flex-direction: column;
}
.dx-popup:not(.dx-scheduler-appointment-popup) .dx-dialog .dx-toolbar-items-container .dx-toolbar-center .dx-toolbar-button {
padding: 0;
}
.dx-popup:not(.dx-scheduler-appointment-popup) .dx-dialog .dx-toolbar-items-container .dx-toolbar-center .dx-toolbar-button .dx-button {
width: 200px;
}
.dx-popup:not(.dx-scheduler-appointment-popup) .dx-dialog .dx-toolbar-items-container .dx-toolbar-center .dx-toolbar-button:nth-child(1) {
margin-bottom: 12px;
}
}
var data = [
{
text: "Website Re-Design Plan",
startDate: new Date("2021-04-26T16:30:00.000Z"),
endDate: new Date("2021-04-26T18:30:00.000Z"),
recurrenceRule: "FREQ=WEEKLY;BYDAY=MO,FR;WKST=TU;INTERVAL=2;COUNT=32",
}, {
text: "Book Flights to San Fran for Sales Trip",
startDate: new Date("2021-04-26T16:30:00.000Z"),
endDate: new Date("2021-04-26T18:30:00.000Z"),
recurrenceRule: "FREQ=WEEKLY;BYDAY=MO,FR;INTERVAL=4;COUNT=32",
allDay: true,
priorityId: [1]
}, {
text: "Install New Router in Dev Room",
startDate: new Date("2021-04-26T16:30:00.000Z"),
endDate: new Date("2021-04-26T18:30:00.000Z"),
recurrenceRule: "FREQ=WEEKLY;BYDAY=FR;INTERVAL=2;COUNT=32"
}, {
text: "Approve Personal Computer Upgrade Plan",
startDate: new Date("2021-04-05T17:00:00.000Z"),
endDate: new Date("2021-04-05T18:00:00.000Z"),
recurrenceRule: "FREQ=WEEKLY;BYDAY=WE;INTERVAL=2;COUNT=32",
priorityId: [2]
}, {
text: "Final Budget Review",
startDate: new Date("2021-05-27T19:00:00.000Z"),
endDate: new Date("2021-05-27T20:35:00.000Z")
}, {
text: "New Brochures",
startDate: new Date("2021-05-27T21:30:00.000Z"),
endDate: new Date("2021-05-27T22:45:00.000Z")
}, {
text: "Install New Database",
startDate: new Date("2021-05-27T16:45:00.000Z"),
endDate: new Date("2021-05-27T18:15:00.000Z")
}, {
text: "Approve New Online Marketing Strategy",
startDate: new Date("2021-05-27T19:00:00.000Z"),
endDate: new Date("2021-05-27T21:00:00.000Z")
}, {
text: "Upgrade Personal Computers",
startDate: new Date("2021-05-27T22:15:00.000Z"),
endDate: new Date("2021-05-27T23:30:00.000Z")
}, {
text: "Upgrade Personal Computers",
startDate: new Date("2021-05-28T22:15:00.000Z"),
endDate: new Date("2021-05-28T23:30:00.000Z")
}
];
var priorities = [
{
text: "High priority",
id: 1,
color: "#cc5c53"
}, {
text: "Low priority",
id: 2,
color: "#ff9747"
}
];