Zum Hauptinhalt springen

Using DHTMLX Scheduler Properties in ReactScheduler

This page describes the props accepted by React Scheduler and how they map to DHTMLX Scheduler APIs.

Available props

PropTypeDescription
eventsEvent[]Scheduler events to render.
view"day" | "week" | "month" | "year" | ...Active Scheduler view.
dateDateActive date used to render the selected view.
templatesSchedulerTemplatesMaps to Scheduler templates (for example, event style/text rendering).
configSchedulerConfigMaps to Scheduler configuration options.
xyRecord<string, number>UI sizing settings (for example, hiding built-in nav with nav_height: 0).
data{ load?: string | (() => Promise<any>); save?: string | SaveHandler; batchSave?: BatchSaveHandler }Data loading and change handling callbacks/URLs.
customLightboxReactElement | nullReplaces built-in Lightbox with your React component.
modalsSchedulerModalsOverrides built-in confirmation dialogs (for example, event delete confirmation).
filter(event: Event) => booleanFilters events displayed in Scheduler.
on<EventName> props(...args) => anyEvent handlers mapped to Scheduler events (onViewChange, onBeforeLightbox, etc.).

Basic example

import ReactScheduler, {
type Event,
type SchedulerConfig,
type SchedulerTemplates,
} from "@dhtmlx/trial-react-scheduler";
import "@dhtmlx/trial-react-scheduler/dist/react-scheduler.css";

const events: Event[] = [
{
id: 1,
text: "Planning",
start_date: new Date("2025-12-08T09:00:00Z"),
end_date: new Date("2025-12-08T10:00:00Z"),
},
];

const templates: SchedulerTemplates = {
event_class: (_start, _end, event) => event.classname || "",
};

const config: SchedulerConfig = {
first_hour: 6,
last_hour: 22,
hour_size_px: 60,
};

export default function Demo() {
return (
<ReactScheduler
events={events}
view="week"
date={new Date("2025-12-08T00:00:00Z")}
templates={templates}
config={config}
/>
);
}

Data prop (load, save, batchSave)

Use the data prop to connect Scheduler to your backend or to React-managed state.

Using backend URLs

<ReactScheduler
data={{
load: "/api/scheduler/load",
save: "/api/scheduler/save",
}}
/>

Using callback handlers

<ReactScheduler
data={{
save: async (entity, action, item, id) => {
if (entity !== "event") return;

if (action === "create") {
const response = await fetch("/api/events", {
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify(item),
});

const created = await response.json();
return { id: created.id };
}

if (action === "update") {
await fetch(`/api/events/${id}`, {
method: "PUT",
headers: { "Content-Type": "application/json" },
body: JSON.stringify(item),
});
}

if (action === "delete") {
await fetch(`/api/events/${id}`, { method: "DELETE" });
}
},
}}
/>

Template and config mapping

templates maps to Scheduler template functions, while config maps to Scheduler configuration options.

<ReactScheduler
templates={{
event_class: (_start, _end, event) =>
event.classname === "important" ? "event-important" : "",
}}
config={{
first_hour: 7,
last_hour: 21,
time_step: 15,
}}
/>

Event props

You can pass Scheduler events as React props.

<ReactScheduler
onViewChange={(mode, date) => {
console.log("View changed:", mode, date);
}}
onBeforeLightbox={(eventId) => {
console.log("Opening editor for", eventId);
return true;
}}
/>

For the full list of supported events and callbacks, see:

customLightbox and modals

Use customLightbox when you want to replace the built-in event editor with your own React component. Use modals when you want custom confirmation dialogs.

<ReactScheduler
customLightbox={<MyLightbox />}
modals={{
onBeforeEventDelete: ({ event, callback }) => {
if (window.confirm(`Delete "${event.text}"?`)) {
callback();
}
},
}}
/>

Filtering events

<ReactScheduler
events={events}
filter={(event) => event.text.toLowerCase().includes(search.toLowerCase())}
/>

Direct API access through ref

If a use case is not covered by props, use a ref to get the underlying Scheduler instance.

import { useEffect, useRef } from "react";
import ReactScheduler, { type ReactSchedulerRef } from "@dhx/react-scheduler";

export default function DirectApiDemo() {
const schedulerRef = useRef<ReactSchedulerRef>(null);

useEffect(() => {
const scheduler = schedulerRef.current?.instance;
if (!scheduler) return;

console.log(scheduler.getEvents());
scheduler.setCurrentView(new Date());
}, []);

return <ReactScheduler ref={schedulerRef} events={[]} />;
}
Need help?
Got a question about the documentation? Reach out to our technical support team for help and guidance. For custom component solutions, visit the Services page.