Calendar – Change Log
Version 6.0.6
2024-09-13STYLING CHANGES
- Predefined colors available as
eventColor
has been normalized betweenScheduler
,Calendar
andTaskBoard
BUG FIXES
- 9884 – TypeScript Event tooltip type should accept tools config
- 9904 –
ResourceView
TimeAxis
always shows current time pill ifshowTime
is set - 9909 – Moving an infinitely weekly repeating event by drag & drop fails
- 9930 – Cannot read properties of undefined (reading ‘then’)
- 9939 – Calendar crashes when
autoRowHeight
andhideOtherMonthCells
set totrue
- 9949 – Repeat event error when selecting option first day in month
- 9956 –
AgendaView
has incorrect row heights ifhideNonWorkingDays
changed while hidden
FRAMEWORK SUPPORT
- NodeJS:
>= 20.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 6.0.5
2024-08-30DEMOS
- Custom theme demo (JavaScript) shows how to create a custom theme by modifying scss varibales. New demo is located in
custom-theme
folder (9762)
BUG FIXES
- 5233 – ANGULAR Frameworks wrappers components not triggering some events
- 9378 – HIGH PRIO
RecurrenceConfirmationPopup
reconfiguration should be easy - 9718 – VUE-3 Preventable events don’t work in Vue wrapper
- 9726 – HIGH PRIO Reassigning resource of one event within series triggers incorrect
CrudManager
operations - 9752 –
autoCreate
Calendar setting not propagated to sub views byresourceView
- 9794 –
shortEventDuration
not calculated correctly if customhourHeight
used - 9809 – Error on
EventEdit
close whenrecurrenceCombo
is set tonull
- 9811 –
minDate
/maxDate
not processed correctly - 9829 – HIGH PRIO JS error thrown when
EventEdit
popup is modal and delete button pressed
FRAMEWORK SUPPORT
- NodeJS:
>= 20.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 6.0.4
2024-08-02BUG FIXES
- 8626 –
startDate
andendDate
areundefined
inbeforeDragMoveEnd
listener - 9687 – Incorrect localization in Calendar
- 9690 –
LoadOnDemand
feature withResourceView
causes infinite load loop - 9699 –
alwaysShowCurrentDate
doesn’t work when the Agenda store is filtered - 9702 –
CalendarDrag
resizable:false
doesn’t disable the edge hover effect
FRAMEWORK SUPPORT
- NodeJS:
>= 20.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 6.0.3
2024-07-26FEATURES / ENHANCEMENTS
- The Calendar
Drag
feature now fires vetoable events before the dragging starts. The event names arebeforeDragCreate
,beforeDragMove
,beforeDragResize
- The plugin processing has been updated to correctly handle multiple plugin configurations
BUG FIXES
- 9388 – Event changes background color while resizing + dragging
FRAMEWORK SUPPORT
- NodeJS:
>= 20.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 6.0.2
2024-07-24FEATURES / ENHANCEMENTS
- Bumped the built-in version of FontAwesome Free to
v6.6.0
, which includes a new table-cells-row-unlock icon sponsored by Bryntum DayView
s (WeekView
is aDayView
) now can show the current time as a pill in the time axis. TheshowCurrentTime
config may be an object containingshowTime : true/false
andfullWidth : true/false
. ThefullWidth
property causes the current timeline to cover the full view width, including all days that the view contains
DEMOS
- REACT-REMIX "Basic" (React + Remix) demo shows using Calendar component in Remix. The demo is located in
frameworks/react-remix/basic
folder (4912) - SHAREPOINT Added a new demo for SharePoint Framework (SPFx) in the
frameworks/react/typescript/sharepoint-fabric
folder (9224) - Calendar
radio-schedule
demos has been updated (9620)
BUG FIXES
- 9434 –
TimeRanges
do not render if'day'
is default mode - 9443 –
dblClick
to create after23:00
inDayView
results in a day-crossing event - 9513 – Event start date is one day before for zero-duration all-day events
- 9532 – Bug with
timeRanges
afterdayEndTime
- 9547 –
alwaysShowCurrentDate
setting needed forAgendaView
- 9600 –
eventColor
not applied correctly inTimeline
mode - 9606 –
autoCreate
event close to midnight throws error in shifted day example - 9616 – Refocus after mouse-based event delete should only scroll is using keyboard
- 9631 –
ModeSelector
has smaller font-size than others
FRAMEWORK SUPPORT
- NodeJS:
>= 20.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 6.0.1
2024-07-05BUG FIXES
- 9198 – Grid printing does not handle auto height rows
- 9457 – Incorrect selected date in
WeekView
header on first load
FRAMEWORK SUPPORT
- NodeJS:
>= 20.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 6.0.0
2024-06-28We are thrilled to announce version 6.0
of our Calendar product. This release marks a significant milestone for us after more than two years of dedicated development. In this update, we are excited to bring you:
- Copy paste of events
- Improved TypeScript typings
- A new code editor in the examples for easy fiddling
- Cool new demos
- Bug fixes and other enhancements requested by our community
A special thanks to everyone who helped us by testing our alpha and beta versions. Your feedback and support have been invaluable
FEATURES / ENHANCEMENTS
EventCopyPaste
feature adds copy-paste capabilities to events. Both via context menu and keyboard actions (4728)- All Calendar modes now expose an
eventCount
property, which yields the number of visible events, which intersect the view’s date range. This is a convenience property for creating view description (8758) - The code editor in examples is now implemented with the VS Code engine. Code folding, search and replace, full undo/redo is now available when editing examples
- The
List
widget now handles a tree store and will indent and expand/collapse nodes on click of an inline toggle button - TypeScript Class configs
Config
(e.g.ButtonConfig
) now provide type declarations forlisteners
parameter in.d.ts
files - TypeScript Class configs
Config
(e.g.ButtonConfig
) types now have optional parameters in.d.ts
files.*Config
type can be used instead ofPartial<*Config>
declaration - Bumped the built-in version of FontAwesome Free to
v6.5.2
, which includes a new table-cells-row-lock icon sponsored by Bryntum - Angular Bryntum Angular wrapper now exports
Bryntum...Props
types (e.g.BryntumCalendarProps
) which match the configs available for a wrapper component (e.g.BryntumCalendarComponent
). Wrappers code is now delivered with documentation inside, that helps in setting up the components EventHelper
no longer mutates the DOM event object to fix browser quirks and add utility properties. It now wraps the DOM event with a Proxy, which exposes all the properties of the DOM event and also accepts any new properties added to it. The original DOM event is available in thebrowserEvent
property
API CHANGES
- VUE-3 Bryntum Vue-3 wrapper now exports
Bryntum...Props
types (e.g.BryntumCalendarProps
) which match the configs available for a wrapper component (e.g.<bryntum-calendar>
). Wrappers code is now delivered with documentation and TypeScript sources inside (3085) - DEPRECATED The
WidgetHelper
utility class has been deprecated and will be removed in a future release. Use the corresponding widget class instead –Widget
,Toast
orMask
(6103) - BREAKING The
drop
events in theExternalEventSource
feature have been renamed to conform to the wider Bryntum product standard:dropExternal
was renamed tobeforeDropExternal
, andafterDropExternal
todropExternal
(7491) - BREAKING The
useRawData
setting onStore
is now enabled by default, but with all sub-settings disabled. This means that the incoming data object will be used as is, without being cloned. Which will boost data loading performance, but is potentially a breaking change if the data object is reused / used in other parts of the application (8335) - BREAKING In
6.0.0-alpha-2
we changed the default value foruseRawData
on stores totrue
. This boosted record creation performance by not cloning the incoming data object. However, this change has lead to some issues, and we are now taking a step back. It will once again default tofalse
when supplying data inline, and instead only totrue
when data is loaded remotely using anAjaxStore
or aCrudManager
(9289) - DEPRECATED
@bryntum/babel-preset-react-app
,@bryntum/cra-template-typescript-calendar
,@bryntum/cra-template-javascript-calendar
npm packages are deprecated, and will not get any further updates. Versions prior to6.0.0
are still accessible - BREAKING ANGULAR REACT VUE
BryntumProjectModel
framework wrapper is no longer available since6.0.0
. UseBryntumCalendarProProjectModel
instead. Check the upgrade guide for the details - DEPRECATED The
count
property ofEventList
is deprecated in favour of the more descriptiveeventCount
property, which now exists in all Calendar modes. allowOverlap
flag was made private. Functionality is not yet implemented, will be public once it is fully supported
STYLING CHANGES
- The Stockholm theme got some slight tweaks to panel header (removed bottom border) and tab panel styling (replaced active tab background with thick bottom border) for a more modern look (8440)
DEMOS
- New
exporttoexcel
demo showing how to export the Calendar events to Excel (1567) - New
action-buttons
demo showing how to render icon buttons inside DayView events
BUG FIXES
- 6261 – Drag proxy not aligned under cursor when dragging overlapping event
- 6441 – Instance config values should not be overridden by responsive configs
- 7141 – Event drag proxy has overlapping text when event is small
- 7760 – HIGH PRIO TypeScript Type intersection with
any
might be wrong - 7808 – Cannot configure mode selector as minified
- 8657 –
ResourceFilter
List
widget does not correctly handle tree structure - 8891 – Change Range for
DayResource
andResourceView
at runtime - 9110 – Calendar crashes when zooming multiple times
- 9299 – Copy pasting a multi-assigned event pastes to "random" resource
- 9316 – Calendar zoom stops working once zoom level has hit minimum
- 9415 – Contextual recurrence options not shown when EventEditor docked
- 9418 – Event Editor should not hide when clicking modal mask with recurrence prompt open
- 9448 – Delete dialog for recurrent events disappears automatically
FRAMEWORK SUPPORT
- NodeJS:
>= 20.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.13
2024-06-26BUG FIXES
- 9299 – Copy/pasting a multi-assigned event pastes to "random" resource
- 9368 –
NumberField.wrapAround
processed incorrectly when spin down goes below the min
FRAMEWORK SUPPORT
- NodeJS:
>= 14.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.12
2024-06-13FEATURES / ENHANCEMENTS
- You can now configure Calendar’s
enableRecurringEvents
with adefaultAction
property, to always choose a predefined action. Usesingle
to always only process the selected event, orfuture
to change all future events (7606) DayView
andWeekView
now accept acolumnHeaderRenderer
configuration. This is a callback function that can be used to create custom header content at the top of day columns (9260)
API CHANGES
- VUE REACT When using wrappers for Vue or React,
syncDataOnLoad
is by default set totrue
on all stores configured on the wrapped Widget. Starting from5.6.12
, stores with a configuredreadUrl
or that belongs to a project configured with aloadUrl
, will have theirsyncDataOnLoad
default tonull
BUG FIXES
- 9025 –
calendar.createEvent
with empty date triggers an error - 9231 – Disable recurring event confirmation pop-up does not work
- 9317 –
Agenda
view flickers when pasting events - 9348 – External drag back into Calendar does not correctly update the event’s
startDate
- 9361 – Calendar event edit button sometimes is hidden after creating a new event
FRAMEWORK SUPPORT
- NodeJS:
>= 14.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.11
2024-05-21FEATURES / ENHANCEMENTS
- A new static boolean property,
Widget.accessibility
was added, which, when set totrue
causes tooltips to be activated onfocus
in addition tomouseover
(5539) - Vanilla JavaScript documentation has a new section on Multiple Products, showing how to use multiple components in a single page using
thin
components (8756)
API CHANGES
- After a docs regression, several APIs flagged to be hidden in subclasses were still visible in the docs. These APIs are now correctly hidden (9140)
DEMOS
- Added new
multiassign-resourceids
demo showing eventresourceIds
field usage (9187)
BUG FIXES
- 8783 – Occurrences should not be skipped for COUNT-based rules when changing
exceptionDates
at the data level - 8927 – HIGH PRIO
CrudManager
sync does not clear changes for updated recurring event - 8972 – MonthView error when
sixWeeks: false
,autoRowHeight: true
- 9039 – HIGH PRIO Window Freezes when resolving recurrence confirmation popup
- 9143 –
startDate
is overridden upon editing other fields of an event inEventEdit
- 9151 – HIGH PRIO New events disappear from
timezone
demo when changing date - 9157 – Deleting last recurring event resulting in new event on the following day
- 9185 –
contextMenuTriggerEvent: 'click'
does not work for calendar
FRAMEWORK SUPPORT
- NodeJS:
>= 14.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.10
2024-04-24FEATURES / ENHANCEMENTS
CalendarPanel
(and its subclassDatePicker
) may now be configured with anonWorkingDays
object which is separate from weekend days while weekend days continue to exist in their fixed position. (8914)
BUG FIXES
- 8972 – MonthView error when sixWeeks : false, autoRowHeight : true
- 8987 – DayView.scrollTo function does not work more than one time
- 8992 – ANGULAR implement support of
ViewEncapsulation.ShadowDom
- 9012 – Calendar: Multi-day recurring event over weekend throws errors
- 9022 – AgendaView shows inconsistent "Ends" date relative to how the tooltip shows it
FRAMEWORK SUPPORT
- NodeJS:
>= 14.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.9
2024-04-09FEATURES / ENHANCEMENTS
DayView
(WeekView
is aDayView
) can now show both event start time and event end time in the event block header. Configure theshowTime
property as{ startTime : true, endTime : true }
(8886)
LOCALE UPDATES
- Added Brazilian Portuguese translation (
'PtBr'
) (8747)
BUG FIXES
- 8730 – Event renderer uses single
DomConfig
object incorrectly - 8787 – Recurring events, which cross a midnight boundary can cause extra cells in
AgendaView
- 8792 – Step does not work for
startTimeField
in event editor - 8795 – New recurrence popup created on window focus out
- 8862 –
ListView
does not generate correctstepUnit
for a range - 8863 – Drag snapping should snap relative to hour start, not current position
- 8948 – Undefined variable
$cal-intraday-event-color
FRAMEWORK SUPPORT
- NodeJS:
>= 14.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.8
2024-03-04FEATURES / ENHANCEMENTS
- The
DayView
(Calendar modeday
orweek
) now offers aneventHeaderRenderer
property, which is a callback to be configured by applications which need to customize the header portion of an event block. By default, the event’sstartTime
time is displayed according to the configuredtimeFormat
. This setting allows applications to place any content in the event block’s header. - The
DayView
(Calendar modeday
orweek
) now offers atimeAxisTimeFormat
property which is aDateHelper
format string to format the time ticks in the time axis on the left side of the view.
DEMOS
- New
filtering-advanced
example showing how to add additional filtering fields to theSideBar
BUG FIXES
- 8642 –
DayView
‘stimeFormat
is used in event header and in the time axis generation - 8688 –
dblclick
beforeAutoCreate
event does not receive aresourceRecord
property - 8702 – HIGH PRIO Dragged event bar does not have identical content to event being moved
FRAMEWORK SUPPORT
- NodeJS:
>= 14.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.7
2024-02-22FEATURES / ENHANCEMENTS
- The
DayResourceView
(Calendar modedayresource
) now offers aresourceDateFilter
property, which is a callback implemented by applications, which allows applications to filter out resource columns for dates depending upon any conditions the application requires. The callback is passed context about the resource and date. It must returntrue
orfalse
to show or not show the resource column for the passed resource and date - The
DayView
(Calendar modeday
) now offers adateFilter
property, which is a callback implemented by applications, which allows applications to filter out columns for dates depending upon any conditions the application requires. The callback is passed context including the date. It must returntrue
orfalse
to show or not show the day column for the passed date DayView
(WeekView
is a subclass ofDayView
) has a new config propertyshowDayStartHour
which causes the zero-minute tick of the configured day start (usually 12:00 AM) to be shown at the top of the time axis (8420)- Calendar views now have a
syncCalendarDate
property, which prevents the Calendar date from the following view date clicks (8501)
BUG FIXES
- 8415 –
highlightSelectedWeek
makes week rows jump 1px - 8423 – HIGH PRIO LWC Engine performance is too low with LWS enabled
- 8455 – Crash when drag creating in event-items demo
- 8458 – Tools should have white color in tooltip header
- 8539 – Crash when toggling full screen
- 8540 – Crash when adding new event via context menu
- 8564 – Returning false from
beforeDragCreateEnd
listener leaves the drag-create element in place - 8603 – Agenda View – Incorrect Order of Events after updating one event when recurring events are present
- 8640 – REACT Update
EquipmentStore
toStore
type in all demos, fixed grid store to be unchained and only combo store should be chained in all framework demos
FRAMEWORK SUPPORT
- NodeJS:
>= 14.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.6
2024-01-31FEATURES / ENHANCEMENTS
- Bumped built-in FontAwesome Free to version
6.5.1
- All frameworks demo applications have been verified and updated to be compatible with Node.js 20
API CHANGES
- To boost record creation performance, records now cache their
id
(it is accessed very frequently, helps performance a bit) and join their store(s) in a more efficient way. As a side effect, a record no longer has astores
array prior to joining a store, previously it was there as an empty array from start. We don’t think this will affect any code, but wanted to share the change in case it does - DEPRECATED ANGULAR REACT VUE
BryntumProjectModel
framework wrapper will be removed starting from6.0.0
version. UseBryntumCalendarProjectModel
instead. Check the upgrade guide for the details
BUG FIXES
- 4605 –
EventRenderer
renders html as raw string when name isnull
- 5639 – Calendar drag create should fire
beforeEventAdd
like Scheduler - 8196 –
displayName
config has no effect for Scheduler as a Calendar mode - 8200 – Webpack build failed with
.min.css
file - 8337 –
EventRenderer
does not share well withresourceAvatars
FRAMEWORK SUPPORT
- NodeJS:
>= 14.0.0
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.5
2024-01-09FEATURES / ENHANCEMENTS
DayView
andWeekView
now accept a new config,dashedSubticks
which cause minor tick lines (at 30 and 15 minutes etc.) to be rendered as dashed lines
API CHANGES
- DEPRECATED The Calendar
tbar
itemtoggleSideBar
has been renamedtoggleSidebar
for naming consistency. The old name will continue to be recognized untilv7.0
, but it is recommended that if your app customizes that item in thetbar
, you update your app to use the correct name
DEMOS
- ANGULAR New "Drag equipment onto tasks" demo (Angular) demonstrates how to drag any DOM node and drop it onto a task to update some aspect of it. The demo is located in
frameworks/angular/drag-onto-tasks
folder (7985) - ANGULAR New "List view" demo (Angular) demonstrates the ‘list’ view type. The demo is located in
frameworks/angular/listview
folder (8106) - ANGULAR New "Using TimeRanges" demo (Angular) shows how to use the TimeRanges feature to add vertical zones to the calendar. The demo is located in
frameworks/angular/timeranges
folder (8075) - REACT + VITE New "Drag equipment onto tasks demo" (React + Vite) demonstrates how to drag any DOM node and drop it onto a task to update some aspect of it. The demo is located in
frameworks/react-vite/drag-onto-tasks
folder (7984) - REACT + VITE New "List view" demo (React + Vite) demonstrates the ‘list’ view type. The demo is located in
frameworks/react-vite/listview
folder (8105) - REACT + VITE New "Using TimeRanges" demo (React + Vite) shows how to use the TimeRanges feature to add vertical zones to the calendar. The demo is located in
frameworks/react-vite/timeranges
folder (8032) - VUE 3 + VITE New "List view" demo (Vue 3 + Vite) demonstrates the ‘list’ view type. The demo is located in
frameworks/vue-3-vite/listview
folder - VUE-3 + VITE New "Using TimeRanges" demo (Vue 3 + Vite) shows how to use the TimeRanges feature to add vertical zones to the calendar. The demo is located in
frameworks/vue-3-vite/timeranges
folder (8033)
BUG FIXES
- 4500 –
allDay
event with long duration may become interday when dragged to main schedule - 7403 – Make a guide on how to make a theme selector in frameworks
- 7947 – Setting
defaultCalendar : null
makes the ‘add event’ item of scheduleMenu disabled - 7964 – REACT JSX doesn’t work in Popups
- 8104 –
onEventClick
is not called by events relayed fromDayView
child views - 8140 – Modes should refresh when
eventRenderer
changed - 8144 – Setting
highlightSelectedWeek
totrue
isn’t working - 8145 –
toggleSidebar
item has not consistent naming. - 8149 –
LoadOnDemand
should not request subsets of a range which is already loaded - 8157 – Crash in event tooltip when hovering one event and moving directly to another
- 8158 –
Tooltip
realign crash
FRAMEWORK SUPPORT
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.4
2023-12-21BUG FIXES
- 8066 –
ResourceFilter
throws an error ondeselectAll
when it has achange
listener - 8080 – Missing
TimelineHistogram
component in Angular / React / Vue packages - 8081 – Missing
TreeGrid
component in Angular / React / Vue packages - 8087 – Angular
drag-from-grid
demo broken
FRAMEWORK SUPPORT
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.3
2023-12-13FEATURES / ENHANCEMENTS
DayView
zooming now also works using pinch-zoom gestures on touch devices. This is still controlled by thezoomOnMouseWheel
config property- REACT New Resource view demo (React + Vite) shows per-resource calendar views. The demo is located in
frameworks/react-vite/resourceview
folder (7857) - VUE-3-VITE New Resource view demo (Vue 3 + Vite) shows per-resource calendar views. The demo is located in
frameworks/vue-3-vite/resourceview
folder (7890) - VUE-3-VITE New Drag equipment onto tasks demo (Vue 3 + Vite) demonstrates how to drag any DOM node and drop it onto a task to update some aspect of it. The demo is located in
frameworks/vue-3-vite/drag-onto-tasks
folder (7464) - REACT Documentation in "Quick start" and "Guide" is now updated with how to build a React application using Vite for higher efficiency and better performance in development
API CHANGES
- DEPRECATED Please kindly note that
@bryntum/babel-preset-react-app
and@bryntum/cra-template-typescript-calendar
,@bryntum/cra-template-javascript-calendar
packages will not get any updates after6.0.0
version
BUG FIXES
- 6125 –
EventTooltip
hides when event menu shows - 7937 – Drag-create’s
newName
function call needs more context - 7978 –
nextActiveView is undefined
error on deleting last visible event when sidebar date picker is showing events as dots - 7987 – List stops reacting to selection change if selection is programmatically updated
- 7988 –
EventTip
adds its "reveal" class to itsoverTarget
before the vetoable show event is fired - 7991 – List view event tooltip not always displaying
- 8003 –
minWidth
of aligned widget calculated wrong when percentage is involved - 8004 – All-day bar created from resizing intra-day event does not inherit the event’s resource/color
- 8036 – Copy to clipboard doesn’t work in some code blocks
FRAMEWORK SUPPORT
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.2
2023-11-24FEATURES / ENHANCEMENTS
- VUE-3 New List view demo (Vue 3 + Vite) demonstrates the ‘list’ view type. The demo is located in
frameworks/vue-3-vite/listview
folder (7463)
BUG FIXES
- 7092 – Feature mixin on-owner events are not exposed on class
- 7725 – Grid cells in an event list do not stretch grid row elements
FRAMEWORK SUPPORT
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.1
2023-11-17FEATURES / ENHANCEMENTS
- ANGULAR New "Resource view" demo shows per-resource calendar views. The demo is located in
frameworks/angular/resourceview
folder (7441) DayView
now has ahideEmptyDays
option which hides date columns for dates which contain no events. Note that this should be used with care. It may result in no visible date columns if there are no events in the view’s date range. This is in allDayView
subclasses such asWeekView
andDayResourceView
(7804)DayResourceView
now has ahideEmptyResources
option which hides resource columns for resources which have no scheduled events for the date- The
WeekExpander
feature now cooperates with theMonthView
‘sautoRowHeight
property. Empty week rows flex-shrink to a minimum height when a week row is expanded to show all events. Vertical overflow is avoided where possible (7854)
BUG FIXES
- 5719 – YARN Can not install
@bryntum
product packages using yarn v2/v3 - 7703 –
NumberField
limits typed input tominimumFractionDigits
notmaximumFractionDigits
- 7750 – Vite error
@charset must precede all other statements
- 7754 – Frameworks Thin packages not working with
pnpm
- 7767 – List groups which start collapsed cannot be expanded using the UI
- 7775 – Setting
autoCreate
to false doesn’t prevent the dblclick event creation - 7820 –
globalThis
should be defined in locales to support LWC - 7823 – Inconsistent drag creation behavior in Calendar year view
- 7846 – Clicking on event, changes the start date of the view
FRAMEWORK SUPPORT
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.6.0
2023-10-26FEATURES / ENHANCEMENTS
- This release introduces a new set of npm packages and framework components, that allows combining multiple Bryntum products in the same application. These packages contain the product specific code only, as opposed to the current packages that has all code for the products each product builds upon (for example Scheduler contains Grid & Core). The new packages are called
thin
packages, and moving forward it will be the recommended way of using Bryntum products in npm based applications (for all supported frameworks). See the "What’s new" guide for more information @bryntum/calendar-thin
bundle includes scss theme files insass/themes
folder (7445)- Time ranges now support recurrence out of the box, you no longer have to subclass and mix
RecurringTimeSpan
manually (7217) - Calendar print feature allows printing Agenda View (3884)
- There is a new event,
dayCellPopulated
which fires when an array of events has been gathered for a certain date. This event may be used to mutate theevents
array for that date (7715) - TypeScript Functions and events declarations in typings were improved to contain all available parameters and return type (6961, 4456)
API CHANGES
- BREAKING
Core.util.helper.Point
class has been moved to solve circular module dependencies. It is now a named export of theCore.util.helper.Rectangle
module. Check upgrading guide for the details - BREAKING TypeScript
ScrollOptions
typedef has been renamed toBryntumScrollOptions
to not interfere with TypeScript interfaceScrollOptions
. Check upgrading guide for the details (7385) - FRAMEWORKSDEPRECATED
BryntumProjectModel
wrapper component has been renamed toBryntumCalendarProjectModel
. Please see the upgrade guide for details
BUG FIXES
- 6619 – Calendar’s
inline-data
demo should useProjectModel
wrapper - 7739 – Events with 0 duration still not displaying side by side
FRAMEWORK SUPPORT
- TypeScript:
>= 3.6.0
- Angular:
>= 9.0.0
- React:
>= 16.0.0
- Vue:
>= 2.0.0
- Ionic:
>= 5.0.0
- Vite:
>= 4.0.0
- Webpack:
>= 4.0.0
Version 5.5.5
2023-10-23BUG FIXES
- 1317 – Calendar fires 2 refresh events on adding a new event record
- 4727 – Documentation for Calendar
EventMenu
items missing - 6206 – Wrong guide for customizing context menu
- 7587 –
onBeforeDragMoveEnd
returns incorrect datetime on event record - 7607 – List should allow easy setting of selected items
- 7666 –
DayLayout
not laying out zero-duration events - 7673 – Events not rendering after switching to Russian locale
- 7678 –
titleRenderer
not honoured if editor is not floating - 7679 – Event blinks after drag create is completed
- 7693 – Align anchor arrow colour detection wrong when mouse is over adjacent element
- 7706 –
EventEdit
does not exit when clicking on sidebarDatePicker
Version 5.5.4
2023-10-05FEATURES / ENHANCEMENTS
- There is a new Calendar config
activeDateCls
which is a CSS class name which gets added to the currently active date’s cell in all modes (7535)
BUG FIXES
- 7478 – Unable to scroll after quickly navigating in Agenda view
- 7487 –
DateResourceView
does not renderResourceTimeRanges
- Partially fixed 7491 –
ExternalEventSource
dropExternal
event should be preventable - 7512 –
ExternalEventSource: eventRecord
not always set inexternalDrop
event - 7513 – Calendar tries to sync assignments on drag-create start
- 7520 –
viewContainer
should be a config to allow reconfiguration - 7553 – Incorrect Swedish translation in Calendar
- 7567 –
overflowPopup
should inherit theeventSorter
of its owner - 7599 –
autoRowHeight
andmaxEventsPerCell
do not work together - 7600 – Event filter is not working when Calendar is read only
Version 5.5.3
2023-09-15BUG FIXES
Version 5.5.2
2023-08-30FEATURES / ENHANCEMENTS
- New demo
drag-onto-tasks
showing how to drag custom objects onto an event YearView
may now show "No events" in its cell tooltip (5530)
LOCALE UPDATES
- There is a new locale key
noEvents : 'No events'
which may be used byYearView
‘s cell tooltip
BUG FIXES
Version 5.5.1
2023-08-16BUG FIXES
Version 5.5.0
2023-07-31This release is a replacement for the 5.4.3 patch release. It was changed to a minor version because of some larger changes behind the scenes to pave the way for future support for live updates in Scheduler Pro and Gantt.
BUG FIXES
Version 5.4.2
2023-07-26BUG FIXES
- 4163 – Inconsistent undo/redo behavior in calendar demo
- 6995 – VUE An exception when use
workingTime
config in calendar timeline view - 7127 – Id collision error when creating new event using an external button on
EventList
mode - 7166 – Properly maintain
b-selected-date
class inResourceView
day headers - 7169 – Events hidden behind other events when switching modes
- 7185 – Event sort works incorrect in Month View
- 7196 –
autoCreate
step not always propagated intoTimeField
step - 7208 – Calendar’s active date not changing with
Datepicker
Version 5.4.1
2023-07-13FEATURES / ENHANCEMENTS
- We have created a public repository to showcase Salesforce demos. All previous demos are merged into one Lightning Application which is easy to install to a new scratch org. You can find more information in updated guides and in this repository: https://github.com/bryntum/bryntum-salesforce-showcase#bryntum-salesforce-showcase
- We have created a public Salesforce org where this app is preinstalled. You can find link to it and login credentials on the updated examples page
BUG FIXES
- 6077 – TypeScript
Model
constructors should allow second param - 7085 –
beforeEventEdit
event should handle async handlers - 7106 –
ExternalEventResource
drag drop crashes if no resource onDayResourceView
- 7107 – Extra horizontal scrollbars shown in
resourceview
in narrow window - 7132 – Calendar
ResourceFilter
change listener has wrong ‘oldValue’ on select
Version 5.4.0
2023-06-30FEATURES / ENHANCEMENTS
Widget
has a new config,maximizeOnMobile
which takes effect only onfloating
widgets on a mobile device. It causes the widget to be maximized instead of positioned in order to accommodate the mobile virtual keyboard. This will make event editing much easier to use on mobile devices (6522)- On mobile devices,
type : 'checkbox'
is rendered as aslidetoggle
widget. The API and value is the same, it is just a more appropriate UI for the platform - Calendar has a new mode,
dayresourceview
which shows columns of events for each selected resource for each day in its range. Check it out in the newdate-resource
example - The
CalendarDrag
feature now has a new configremoveFromExternalStore
. It defaults totrue
meaning that when an event is dropped on the Calendar from an outside event store, the record is removed from that store. If set tofalse
, the record is not removed, and a clone of the dragged record is inserted at the drop position. - The
ExternalEventSource
feature now allows adroppable
property to be specified. If agrid
is configured as the external UI, then dropping will Just Work. If the event source is just DOM elements, there aredragMoveExternal
anddropExternal
events. (6826) - For a slightly better docs experience for most users, the docs browser now by default hides some more obscure APIs normally only used when implementing own widgets and features. Advanced users in need of these APIs can still opt in to see them using the
Show
menu in the docs browser
BUG FIXES
- 6957 – Unexpected drag proxy in
dragfromgrid
demo - 6963 – Drag from Grid demo exception when dragging
- 7002 – Clarify granularity level of
dayStartTime
anddayEndTime
in API docs - 7003 – Set
coreHours
to thedayStart
and end if they went through rounding - 7007 – ResourceView overwrites configuration with values from itself.
- 7019 – Align constrained doesn’t work in some cases.
- 7020 – Drag from
ExternalEventSource
into Calendar with no resources throws Error - 7057 – CalendarRow cell width mismatch on narrow Calendars
- 7068 – The "Select all" item in List is not internationalized
Version 5.3.8
2023-06-28BUG FIXES
- 6981 – Applying german locale after init makes
ResourceView
show wrong week
Version 5.3.7
2023-06-20FEATURES / ENHANCEMENTS
- New Event items demo. The example shows how to attach an arbitrary list of items (guests) to an event. The demo is located in
examples/event-items
folder
API CHANGES
- When changing
timeZone
on a Calendar, the date range that the Calendar is currently displaying will not change unless the active view is aDayView
and the selected days events center point will, when converted to a different time zone, be changed to a different day - The
DayView
methodszoomTo
andzoomBy
now return aPromise
that may be awaited if postprocessing the updated UI state is required
BUG FIXES
- 6467 – Replace separate view live demos to enable drag drop
- 6839 – Calendar
currentTime
indicator is not converted totimeZone
- 6871 –
overflowPopup : null
should makeYearView
switch toDayView
in Calendar - 6872 –
FilterField
should tolerate its field value beingnull
/undefined
- 6880 –
WeekView
‘s all day row horizontal scroll may become out of sync if no all day events exist and theminDayWidth
is set to cause horizontal overflow. - 6973 – Calendar
editEvent(eventRecord)
crashes withoutstartDate
andendDate
Version 5.3.6
2023-05-26API CHANGES
- Event bar colors are set in an event element using the
--cal-event-color
CSS property, not by setting a color name CSS class - All day event bars (and all event bars which are rendered using the renderData option
solidBar : true
) which do not have aniconCls
may now show the default circular "bullet" icon before the text. To enable this, configure that mode (or the Calendar’smodeDefaults
) withshowBullet : { bar : true }
- The
durationUnit
used in the new record when drag-creating events now matches the unit specified in thedragUnit
property of the active view. The defaults have not changed, so in aDayView
, the duration of drag-created events will be inhours
and in all other views, (including the all dayCalendarRow
in aDayView
) indays
(6798) - The
EventTooltip
feature may now be configured withrevealEventsInCluster : false
which means that when hovering a narrow event which is sharing day column width with other, overlapping events the hovered event does not expand to the full width (6410)
LOCALE UPDATES
DayView
andWeekView
may now be configured with how to snap an autoCreate pointer date to anautoCreate.step
point. TheautoCreate.snapType
may be configured as'round'
(the default),'floor'
or'ceil'
(6739)
BUG FIXES
- 6771 – No cell content should be shown for "other month" cells in
MonthView
- 6772 – Event colour source should be taken from correct resource
- 6779 –
MonthView
events bars not conforming toeventColor
renderer values. - 6781 – Remove erroneous
dayCellRenderer
docs fromAgendaView
- 6828 –
CalendarDrag
should not create anAllDayZone
if theallDayEvents
widget has been configured away
Version 5.3.5
2023-05-11FEATURES / ENHANCEMENTS
- The
ResourceFilter
widget may now be configured to also filter theresourceStore
by configuringfilterResources
astrue
(6698) DayView
andWeekView
event renderers now accept abodyColor
property to therenderData
which specifies the background color of the body part of the event block (6690)- The
EventStore
settingremoveUnassignedEvent
now defaults tofalse
for the Calendar product. This means that removing all assignments from an event will not remove it from the event store (6732)
BUG FIXES
- 6093 – Resource filter not respected on initial loading
- 6516 – Calendar state save and restore may include the date
- 6683 – Calendar sidebar collapses when
Combo
dropdown clicked - 6701 – IONIC
Scrollbar
width could not be determined under Ionic framework - 6702 – Setting EventList
listRangeItems
item tonull
causes error - 6705 – Crash in
shifted
demo - 6708 –
showEvents : 'count'
inYearView
doesn’t work - 6714 – When
DayView
hasdaySelector : true
, the time axis is not accounted for - 6733 – Crash if calendar sidebar is destroyed while loading
- 6744 –
DayView
allDayEvents
should be able to be configured as expanded
Version 5.3.4
2023-04-28BUG FIXES
- 4631 –
eventDrag
not working well if data mapping used for start/end dates - 6588 –
ListView
bugs when asked to display arbitrary date range as opposed to range config - 6627 – Zero duration all Day Event shown incorrectly
- 6629 – Fix hiding context menus inside LWC components on scroll
- 6633 –
PickerField
editable:false
doesn’t work inside WebComponent - 6651 – Calendar: after zoom, scroll jumps on click-n-drag event creation
- 6652 – Minified UMD bundle does not export
bryntum
namespace
Version 5.3.3
2023-04-21FEATURES / ENHANCEMENTS
- VUE-3 Added a new Vue-3 demo, "Scheduler Timeline". Demo is located in the
examples/frameworks/vue-3/calendar-scheduler
folder - VUE-3 Added a new Vue-3 demo showing binding to inline data arrays, "Scheduler Timeline Inline data". Demo is located in the
examples/frameworks/vue-3/calendar-scheduler-inline
folder CalendarDatePicker
now offers aneventFilter
config to match other Calendar widgets (6591)- ANGULAR Bryntum Calendar now ships with two npm Angular wrapper packages to support different versions of Angular framework. Existing
@bryntum/calendar-angular
package is now designed to work with Angular 12 and newer versions, which use the IVY rendering engine. New@bryntum/calendar-angular-view
package is designed to work with Angular 11 and older versions, which use the View Engine rendering. Check Upgrading and Angular integration guides in documentation for more information (6270) - ANGULAR
angular-7
demo has been upgraded to use Angular 11 and@bryntum/calendar-angular-view
package. Demo is located inexamples/frameworks/angular/angular-11
folder
BUG FIXES
- 4516 – Calendar doesn’t accept
project
instance - 5532 – Fix documentation of Vue 3 demo documentation
- 6498 – Allow application intervention in event positioning within
DayView
- 6583 –
YearView
doesn’t render recurring events which areallDay
- 6612 – Duplicate tooltip renderer called
- 6614 – + n more count incorrect when overflowing events start below the bottom of the cell
- 6622 –
DayView
does not change date on header click
Version 5.3.2
2023-04-04FEATURES / ENHANCEMENTS
- Elements rendered by the
TaskNonWorkingTime
feature elements now triggertaskNonWorkingTimeClick
,taskNonWorkingTimeDblClick
andtaskNonWorkingTimeContextMenu
events on the Gantt instance. (5679) - There is a new
Calendar
event:beforeAutoCreate
. This is a preventable event which fires before a UI-initiated create gesture is actioned. This allows a single point of validation for UI-initiated event creation (6472) - ScheduleMenu is now enabled by default, allowing easier event creation using context menu on empty schedule space.
BUG FIXES
- 6395 – ANGULAR Cannot use
StateProvider
with a production build - 6417 –
schedule<DomEvent>
events do not bubble out ofResourceView
to the Calendar - 6458 – Event dragging in Scheduler child mode does not relay onBeforeEventDrag event correctly
- 6513 – Event tooltip should not show when double clicking event inside scheduler
- 6514 –
ScheduleMenu
not working inside Scheduler mode - 6515 – Clicking
EventList
row for event who’sstartDate
is before visible range changes visible range
Version 5.3.1
2023-03-17API CHANGES
- Date parsing was made more forgiving in regard to character used to separate date parts. For example these strings are now all acceptable as
HH:mm
:10:20
,10 20
,10-20
,10/20
(6344)
BUG FIXES
Version 5.3.0
2023-03-02FEATURES / ENHANCEMENTS
- CSS changes in Scheduler has cut the size of Calendar’s standalone CSS-bundles roughly in half (Calendar includes Schedulers styling to allow using Scheduler as a mode). See Schedulers upgrade guide for more information
- Support for Time zone conversion has been added to all Bryntum scheduling products. Simply set a IANA time zone identifier as value for the
timeZone
config and that’s it. But, since time zones is not supported natively in JavaScript we strongly recommend to read our Time zone guide (1533) - Localization demos updated to show up-to-date localization approach
- New
TimeRanges
feature, that shades time ranges and displays a header in the gutter of day and week views. Try it out in the newtimeranges
demo (5113) AjaxHelper.fetch
now supports using request body to pass parameters for non-GET requests. Please checkaddQueryParamsToBody
argument in the method documentation (2855)- We have added support for
resourceTimeRanges
to be added to a project. These are rendered only into subviews of aResourceView
which have matching resource ids (5835) DayView
andWeekView
have a newsixMinuteTicks
config. When set to true, the time axis is subdivided into six minute ticks instead of the default five minute ticks (5645)- Lots (but not all) of the not so informative
object
types in our TypeScript typings have been replaced with more specific types. Objects that in our JavaScript are used as maps are now declared asRecord<keyType, valueType>
, and for functions that accept object arguments many are replaced with anonymous type declarations, such as{ foo: string, bar: number }
(Partially fixed 5176) YearView
and the Calendar’sdatePicker
may now show more than 4 dots whenshowEvents
is'dots'
by setting themaxDots
config on theyear
mode or thedatePicker
config. Note that increasing this value may produce a cluttered UI (6238)YearView
and the Calendar’sdatePicker
may now be configured witheventCountTip : true
which causes a tooltip to appear to display the event count for the day when a cell is hovered
API CHANGES
- DEPRECATED
LocaleManager.registerLocale
andLocaleManager.extendLocale
are deprecated.LocaleHelper.publishLocale
should be used instead. DayView
‘shourHeightBreakpoints
now accepts an array of heights instead of an object. The object form is still supported, but might get deprecated in the future
LOCALE UPDATES
- Locales format and process for applying locales have been simplified
- New locales for 31 languages have been added. Currently available languages are listed in the localization guide (Guides/Customization/Localization)
BUG FIXES
Version 5.2.10
2023-02-17FEATURES / ENHANCEMENTS
- Added support for adding different core hours times for each day (6043)
API CHANGES
- Recently browsers have added support for Unicode 15, which changes the output of
Intl.DateTimeFormat
when formatting time to includeAM
/PM
. Those browsers now use "thin space" (\u202f
) instead of regular space. This affects theDateHelper.format()
function, but likely you do not need to take any action in your application. It also affectsDateHelper.parse()
, which has been updated to support the new unicode space (6193)
BUG FIXES
Version 5.2.9
2023-01-30FEATURES / ENHANCEMENTS
- The event editor of the
EventEdit
feature may be reconfigured to not be a popup by configuring theeditorConfig
withfloating : false
or by adding anappendTo
config. In this situation, the editor is displayed as a side-docked overlay. See the new docked-editor example. (5873)
BUG FIXES
- 6019 – TypeScript Feature classes and configs have
on
event handlers exposed on owner class
Version 5.2.8
2023-01-19BUG FIXES
Version 5.2.7
2023-01-11FEATURES / ENHANCEMENTS
- Internal code improvements and bugfixes
Version 5.2.6
2022-12-28FEATURES / ENHANCEMENTS
- REACT React wrapper now supports React components in widgets and tooltips (774)
BUG FIXES
Version 5.2.5
2022-12-16FEATURES / ENHANCEMENTS
ListView
now offers aresourceColumn
in which is displayed a read-onlyChipView
depicting the resources assigned to the event
API CHANGES
- The
EventStore
loadDateRange
event would previously only fire when a different date range of events was requested from the store. Not as the documentation states "when a range of events is requested". This now fires whenever a date range of events is requested. Achanged
flag is set in the event if the range is a new date range
BUG FIXES
- 3954 – Fixed dragging all-day events with
dayStartShift
in effect. - 4530 –
loadOnDemand
with sidebar date picker usingshowEvents : true
causes an infinite loop - 4920 – Calendar throws error when dragging event from overflow popup
- 5672 – Double click on calendar date throws exception
- 5685 – Non-draggable events are draggable in overflow popup
- 5763 –
loadOnDemand
feature needsrefresh
method - 5780 – ICS export datetime stamp is not UTC
Version 5.2.4
2022-11-28FEATURES / ENHANCEMENTS
- We recently launched a new homepage over at bryntum.com, and have now slightly updated the styling for demos and docs to better match it (new logo, new header color, new font). Please note that this is not a change to our themes, only the look of the demos, and it won’t affect your application
BUG FIXES
Version 5.2.3
2022-11-17BUG FIXES
Version 5.2.2
2022-11-08FEATURES / ENHANCEMENTS
- In
DayView
s, events with a duration such that relative to thehourHeight
, the element is too small to contain wrapped text will automatically change to a compact rendition. If thehourHeight
changes (such as by zooming), the rendition will be corrected as appropriate (1948) DayView
now has acurrentTimeIndicatorRenderer
which allows a customized current time indicator to be used (4972)- The
emptyText
config of theagenda
mode may now be an HTML string (5046)
API CHANGES
- DEPRECATED The behaviour of the
store.data
getter will be changed in 6.0. Currently, it returns the initial raw dataset, in 6.0 it will be changed to have the more expected behaviour of returning the data objects for the current state instead. See Grid’s upgrade guide for more information (5499)
BUG FIXES
- 5484 – Add day of week indicator class name to Calendar cells
- 5495 –
AgendaColumn
needs to beautoHeight
if using a customeventRenderer
- 5528 –
dayNumberClick
andmonthNameClick
events are not firing for specific modes - 5536 –
allDayEvents : null
inDayView
children ofresourceView
leaves all day rows in the timeaxes
Version 5.2.1
2022-10-28FEATURES / ENHANCEMENTS
DatePicker
now fully supports two modes ofmultiSelect
. Setting it totrue
means that multiple, discontinuous ranges may be selected. Setting it to'range'
means that one single range of one or more consecutive dates may be selected. (5368)
API CHANGES
- Added
includeWeekendsButton
toCalendar
with default value offalse
. Changed text of button to "Weekends" from "Full". (5459)
BUG FIXES
- 5149 – Angular demos now use component-local styles using
ViewEncapsulation.None
- 5374 – Text cropped in calendar events
- 5392 – Crash when clicking mode selector button in small screen in web component
- 5433 – Today button does not reset small and large calendar to today
- 5440 – Allow custom
eventSorter
function for views includingOverflowPopup
- 5455 – LTS date format does not parse seconds
- 5460 – The duplicate event option breaks assignment of events to resources
Version 5.2.0
2022-10-13FEATURES / ENHANCEMENTS
- Calendar
DayView
now shows all week days above the detail area (2899) - Calendar responds to platform differences (via the
Responsive
mixin) and provides a significantly improved User Experience on small screens. This responsive behavior is also compatible with saving the calendar state In particular, on small screens: * The calendar sidebar automatically switches to overlay mode * The mode selection area switches to a menu button with radio items instead of the button group * The calendar description text is shortened * Improved year view layout (4617) - Calendar uses a new
Calendar.widget.ModeSelector
instead of aCore.widget.ButtonGroup
on its toolbar * TheModeSelector
supports apopup
mode which, whenpopup: true
, displays the available calendar modes in a menu instead of the regular button group. This switch is made by default on small displays via the newresponsive
behavior described above. * When the active mode of the calendar supports it, the mode selector displays aFull
button to allow the user to toggle between full weeks and work weeks. - Calendar views now have a
descriptionFormat
config to simplify changing the description responsively. If adescriptionRenderer
is provided, it takes precedence over thedescriptionFormat
- Calendar added the
navigatorPlacement
config to allow the forward/backward/Today buttons to appear on the sidebar instead of the toolbar - Menu has a
separator
config to make it easier to visually separate menu items - The responsive state objects used in the
responsive
config of theResponsive
mixin now support aonce
property to allow configs to only be set on first activation of the state - The
Core.helper.DateHelper
class has a new methodformatRange
method which can format date ranges, as well as new formatting options for week numbers - A new config,
emptyCellRenderer
allowsMonthView
andCalendarRow
(The all day row in aDayView
orWeekView
) to display a clickable button in cells which contain no events. There is a newemptyCellClick
event. (4413)
Version 5.1.5
2022-10-12FEATURES / ENHANCEMENTS
DatePicker
now fully supports two modes ofmultiSelect
. Setting it totrue
means that multiple, discontinuous ranges may be selected. Setting it to'range'
means that one single range of one or more consecutive dates may be selected. (5368)- New records are assigned a generated
id
if none is provided. The generatedid
is meant to be temporary (a phantomid
), and should be replaced by the backend on commit. Previously theid
was based on a global counter incremented with each assignment. That simplistic scheme assured no two records got the sameid
during a session, but if an application serialized the generatedid
(note, they should not) and then reloaded it, it would eventually collide with a new generatedid
. To prevent this, the generatedid
s are now based on a random UUID instead - Stores now by default show a warning on console when loading records that has generated
id
s, as a reminder that it should be replaced by the backend on commit
BUG FIXES
- 4434 – The
EventMenu
context menu’s "Delete event" option doesn’t handle recurring events properly - 4488 – Overflowed events with custom
propagateEndDate
not marked with right arrow - 4645 – Improve error message "Bryntum bundle included twice"
- 4654 – REACT Bryntum widget wrappers don’t accept all component properties in React 18
- 4729 – Can’t clear multi-select options in combo with keyboard navigation only
- 5333 –
syncCurrentTimeIndicator
throws an error if "today" is a hidden non working day - 5346 – Deleting the base of a repeating event causes exception
- 5347 – Allow
defaultCalendar
to be explicitly configured asnull
- 5370 –
EventEditor
resourceField
store cannot be reconfigured
Version 5.1.4
2022-09-29FEATURES / ENHANCEMENTS
- The
showEvents
config of Calendar’s sidebarDatePicker
and Calendar’sYearView
may now be'dots'
to show events as a series of event-coloured dots. Maximum of three inYearView
and four inDatePicker
. (5234)
API CHANGES
- DEPRECATED The
events
config of the sidebarDatePicker
has been renamed toshowEvents
. Theevents
property is deprecated but will continue to work during its deprecation period
BUG FIXES
Older versions
- Full release version history can be found here.