@nova-design-system/nova-webcomponents 3.0.0 → 3.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/{constants-bcd6b2e2.js → constants-8fb8ccc0.js} +14 -1
- package/dist/cjs/constants-8fb8ccc0.js.map +1 -0
- package/dist/cjs/{index-9bda5507.js → index-108ddff0.js} +22 -6
- package/dist/cjs/index-108ddff0.js.map +1 -0
- package/dist/cjs/index.cjs.js +5 -471
- package/dist/cjs/index.cjs.js.map +1 -1
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/native.cjs.js +2 -2
- package/dist/cjs/nv-alert.cjs.entry.js +6 -6
- package/dist/cjs/nv-alert.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-avatar.cjs.entry.js +2 -2
- package/dist/cjs/nv-badge_2.cjs.entry.js +18 -9
- package/dist/cjs/nv-badge_2.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-breadcrumb.cjs.entry.js +1 -1
- package/dist/cjs/nv-breadcrumbs.cjs.entry.js +1 -1
- package/dist/cjs/nv-button.cjs.entry.js +2 -2
- package/dist/cjs/nv-calendar.cjs.entry.js +821 -843
- package/dist/cjs/nv-calendar.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-col.cjs.entry.js +1 -1
- package/dist/cjs/nv-datagrid.cjs.entry.js +423 -94
- package/dist/cjs/nv-datagrid.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-datagridcolumn.cjs.entry.js +2 -2
- package/dist/cjs/nv-datagridcolumn.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-dialog.cjs.entry.js +19 -13
- package/dist/cjs/nv-dialog.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-dialogfooter_2.cjs.entry.js +2 -2
- package/dist/cjs/nv-fieldcheckbox.cjs.entry.js +1 -1
- package/dist/cjs/nv-fielddate.cjs.entry.js +9 -18
- package/dist/cjs/nv-fielddate.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fielddaterange.cjs.entry.js +85 -32
- package/dist/cjs/nv-fielddaterange.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fielddropdown.cjs.entry.js +88 -57
- package/dist/cjs/nv-fielddropdown.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fielddropdownitem.cjs.entry.js +2 -2
- package/dist/cjs/nv-fieldmultiselect.cjs.entry.js +122 -104
- package/dist/cjs/nv-fieldmultiselect.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldnumber.cjs.entry.js +9 -5
- package/dist/cjs/nv-fieldnumber.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldpassword.cjs.entry.js +9 -5
- package/dist/cjs/nv-fieldpassword.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldradio.cjs.entry.js +4 -4
- package/dist/cjs/nv-fieldselect.cjs.entry.js +11 -7
- package/dist/cjs/nv-fieldselect.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldslider.cjs.entry.js +663 -0
- package/dist/cjs/nv-fieldslider.cjs.entry.js.map +1 -0
- package/dist/cjs/nv-fieldtext.cjs.entry.js +9 -5
- package/dist/cjs/nv-fieldtext.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldtextarea.cjs.entry.js +9 -5
- package/dist/cjs/nv-fieldtextarea.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-fieldtime.cjs.entry.js +16 -13
- package/dist/cjs/nv-fieldtime.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-icon.cjs.entry.js +4 -4
- package/dist/cjs/nv-icon.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-iconbutton_2.cjs.entry.js +3 -3
- package/dist/cjs/nv-menu.cjs.entry.js +4 -2
- package/dist/cjs/nv-menu.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-menuitem.cjs.entry.js +2 -2
- package/dist/cjs/nv-popover.cjs.entry.js +2 -2
- package/dist/cjs/nv-row.cjs.entry.js +2 -2
- package/dist/cjs/nv-stack.cjs.entry.js +2 -2
- package/dist/cjs/nv-table.cjs.entry.js +3 -3
- package/dist/cjs/nv-table.cjs.entry.js.map +1 -1
- package/dist/cjs/nv-tablecolumn.cjs.entry.js +1 -1
- package/dist/cjs/nv-toggle.cjs.entry.js +3 -3
- package/dist/cjs/nv-tooltip.cjs.entry.js +3 -3
- package/dist/cjs/nv-tooltip.cjs.entry.js.map +1 -1
- package/dist/collection/collection-manifest.json +1 -0
- package/dist/collection/components/nv-alert/nv-alert.css +3 -0
- package/dist/collection/components/nv-alert/nv-alert.js +6 -11
- package/dist/collection/components/nv-alert/nv-alert.js.map +1 -1
- package/dist/collection/components/nv-badge/nv-badge.css +181 -1
- package/dist/collection/components/nv-badge/nv-badge.docs.js +20 -1
- package/dist/collection/components/nv-badge/nv-badge.docs.js.map +1 -1
- package/dist/collection/components/nv-badge/nv-badge.js +39 -15
- package/dist/collection/components/nv-badge/nv-badge.js.map +1 -1
- package/dist/collection/components/nv-breadcrumbs/nv-breadcrumbs.docs.js +0 -1
- package/dist/collection/components/nv-breadcrumbs/nv-breadcrumbs.docs.js.map +1 -1
- package/dist/collection/components/nv-calendar/nv-calendar.css +25 -2
- package/dist/collection/components/nv-calendar/nv-calendar.docs.js +33 -38
- package/dist/collection/components/nv-calendar/nv-calendar.docs.js.map +1 -1
- package/dist/collection/components/nv-calendar/nv-calendar.js +659 -897
- package/dist/collection/components/nv-calendar/nv-calendar.js.map +1 -1
- package/dist/collection/components/nv-calendar/nv-calendar.utils.js +202 -0
- package/dist/collection/components/nv-calendar/nv-calendar.utils.js.map +1 -0
- package/dist/collection/components/nv-calendar/test/nv-calendar.utils.test.js +667 -0
- package/dist/collection/components/nv-calendar/test/nv-calendar.utils.test.js.map +1 -0
- package/dist/collection/components/nv-datagrid/nv-datagrid.css +98 -0
- package/dist/collection/components/nv-datagrid/nv-datagrid.docs.js +232 -51
- package/dist/collection/components/nv-datagrid/nv-datagrid.docs.js.map +1 -1
- package/dist/collection/components/nv-datagrid/nv-datagrid.js +437 -160
- package/dist/collection/components/nv-datagrid/nv-datagrid.js.map +1 -1
- package/dist/collection/components/nv-datagridcolumn/nv-datagridcolumn.js +20 -1
- package/dist/collection/components/nv-datagridcolumn/nv-datagridcolumn.js.map +1 -1
- package/dist/collection/components/nv-dialog/nv-dialog.css +29 -5
- package/dist/collection/components/nv-dialog/nv-dialog.docs.js +0 -1
- package/dist/collection/components/nv-dialog/nv-dialog.docs.js.map +1 -1
- package/dist/collection/components/nv-dialog/nv-dialog.js +16 -10
- package/dist/collection/components/nv-dialog/nv-dialog.js.map +1 -1
- package/dist/collection/components/nv-fielddate/nv-fielddate.docs.js +16 -8
- package/dist/collection/components/nv-fielddate/nv-fielddate.docs.js.map +1 -1
- package/dist/collection/components/nv-fielddate/nv-fielddate.js +48 -39
- package/dist/collection/components/nv-fielddate/nv-fielddate.js.map +1 -1
- package/dist/collection/components/nv-fielddate/styles/nv-fielddate.css +14 -1
- package/dist/collection/components/nv-fielddaterange/nv-fielddaterange.docs.js +12 -15
- package/dist/collection/components/nv-fielddaterange/nv-fielddaterange.docs.js.map +1 -1
- package/dist/collection/components/nv-fielddaterange/nv-fielddaterange.js +147 -68
- package/dist/collection/components/nv-fielddaterange/nv-fielddaterange.js.map +1 -1
- package/dist/collection/components/nv-fielddaterange/styles/nv-fielddaterange.css +20 -12
- package/dist/collection/components/nv-fielddropdown/nv-fielddropdown.docs.js +16 -0
- package/dist/collection/components/nv-fielddropdown/nv-fielddropdown.docs.js.map +1 -1
- package/dist/collection/components/nv-fielddropdown/nv-fielddropdown.js +197 -103
- package/dist/collection/components/nv-fielddropdown/nv-fielddropdown.js.map +1 -1
- package/dist/collection/components/nv-fielddropdown/styles/nv-fielddropdown.css +36 -1
- package/dist/collection/components/nv-fielddropdownitem/nv-fielddropdownitem.js +1 -1
- package/dist/collection/components/nv-fielddropdownitemcheck/nv-fielddropdownitemcheck.js +1 -1
- package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.docs.js +8 -1
- package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.docs.js.map +1 -1
- package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.js +228 -190
- package/dist/collection/components/nv-fieldmultiselect/nv-fieldmultiselect.js.map +1 -1
- package/dist/collection/components/nv-fieldmultiselect/{nv-fieldmultiselect.css → styles/nv-fieldmultiselect.css} +36 -1
- package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.css +12 -1
- package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.docs.js +8 -0
- package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.docs.js.map +1 -1
- package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.js +27 -3
- package/dist/collection/components/nv-fieldnumber/nv-fieldnumber.js.map +1 -1
- package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.css +12 -1
- package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.docs.js +8 -0
- package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.docs.js.map +1 -1
- package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.js +27 -3
- package/dist/collection/components/nv-fieldpassword/nv-fieldpassword.js.map +1 -1
- package/dist/collection/components/nv-fieldradio/nv-fieldradio.js +3 -3
- package/dist/collection/components/nv-fieldselect/nv-fieldselect.css +12 -1
- package/dist/collection/components/nv-fieldselect/nv-fieldselect.docs.js +8 -0
- package/dist/collection/components/nv-fieldselect/nv-fieldselect.docs.js.map +1 -1
- package/dist/collection/components/nv-fieldselect/nv-fieldselect.js +29 -5
- package/dist/collection/components/nv-fieldselect/nv-fieldselect.js.map +1 -1
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.docs.js +264 -0
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.docs.js.map +1 -0
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.js +1035 -0
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.js.map +1 -0
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.utils.js +77 -0
- package/dist/collection/components/nv-fieldslider/nv-fieldslider.utils.js.map +1 -0
- package/dist/collection/components/nv-fieldslider/partials/field-input.js +33 -0
- package/dist/collection/components/nv-fieldslider/partials/field-input.js.map +1 -0
- package/dist/collection/components/nv-fieldslider/partials/range-thumb.js +34 -0
- package/dist/collection/components/nv-fieldslider/partials/range-thumb.js.map +1 -0
- package/dist/collection/components/nv-fieldslider/partials/single-thumb.js +18 -0
- package/dist/collection/components/nv-fieldslider/partials/single-thumb.js.map +1 -0
- package/dist/collection/components/nv-fieldslider/partials/tick-marks.js +18 -0
- package/dist/collection/components/nv-fieldslider/partials/tick-marks.js.map +1 -0
- package/dist/collection/components/nv-fieldslider/styles/nv-fieldslider.css +267 -0
- package/dist/collection/components/nv-fieldslider/test/nv-fieldslider.utils.test.js +159 -0
- package/dist/collection/components/nv-fieldslider/test/nv-fieldslider.utils.test.js.map +1 -0
- package/dist/collection/components/nv-fieldtext/nv-fieldtext.css +20 -1
- package/dist/collection/components/nv-fieldtext/nv-fieldtext.docs.js +17 -1
- package/dist/collection/components/nv-fieldtext/nv-fieldtext.docs.js.map +1 -1
- package/dist/collection/components/nv-fieldtext/nv-fieldtext.js +28 -3
- package/dist/collection/components/nv-fieldtext/nv-fieldtext.js.map +1 -1
- package/dist/collection/components/nv-fieldtextarea/nv-fieldtextarea.css +30 -1
- package/dist/collection/components/nv-fieldtextarea/nv-fieldtextarea.docs.js +8 -0
- package/dist/collection/components/nv-fieldtextarea/nv-fieldtextarea.docs.js.map +1 -1
- package/dist/collection/components/nv-fieldtextarea/nv-fieldtextarea.js +27 -3
- package/dist/collection/components/nv-fieldtextarea/nv-fieldtextarea.js.map +1 -1
- package/dist/collection/components/nv-fieldtime/nv-fieldtime.js +13 -10
- package/dist/collection/components/nv-fieldtime/nv-fieldtime.js.map +1 -1
- package/dist/collection/components/nv-fieldtime/styles/nv-fieldtime.css +26 -3
- package/dist/collection/components/nv-icon/nv-icon.js +1 -1
- package/dist/collection/components/nv-icon/nv-icons.js +4 -470
- package/dist/collection/components/nv-icon/nv-icons.js.map +1 -1
- package/dist/collection/components/nv-iconbutton/nv-iconbutton.js +1 -1
- package/dist/collection/components/nv-loader/nv-loader.js +1 -1
- package/dist/collection/components/nv-menu/nv-menu.js +3 -1
- package/dist/collection/components/nv-menu/nv-menu.js.map +1 -1
- package/dist/collection/components/nv-menuitem/nv-menuitem.js +2 -2
- package/dist/collection/components/nv-popover/nv-popover.js +1 -1
- package/dist/collection/components/nv-row/nv-row.js +1 -1
- package/dist/collection/components/nv-stack/nv-stack.js +1 -1
- package/dist/collection/components/nv-table/nv-table.js +8 -11
- package/dist/collection/components/nv-table/nv-table.js.map +1 -1
- package/dist/collection/components/nv-toggle/nv-toggle.js +2 -2
- package/dist/collection/components/nv-tooltip/nv-tooltip.css +1 -0
- package/dist/collection/components/nv-tooltip/nv-tooltip.js +1 -1
- package/dist/collection/index.js.map +1 -1
- package/dist/collection/interfaces/Column.js.map +1 -1
- package/dist/collection/templates/navigation.docs.js +0 -1
- package/dist/collection/templates/navigation.docs.js.map +1 -1
- package/dist/collection/utils/constants.js +11 -0
- package/dist/collection/utils/constants.js.map +1 -1
- package/dist/components/index.js +6 -472
- package/dist/components/index.js.map +1 -1
- package/dist/components/nv-alert.js +7 -7
- package/dist/components/nv-alert.js.map +1 -1
- package/dist/components/nv-avatar.js +3 -3
- package/dist/components/nv-badge.js +1 -1
- package/dist/components/nv-breadcrumb.js +3 -3
- package/dist/components/nv-breadcrumbs.js +1 -1
- package/dist/components/nv-button.js +1 -1
- package/dist/components/nv-calendar.js +1 -1
- package/dist/components/nv-col.js +1 -1
- package/dist/components/nv-datagrid.js +447 -102
- package/dist/components/nv-datagrid.js.map +1 -1
- package/dist/components/nv-datagridcolumn.js +4 -3
- package/dist/components/nv-datagridcolumn.js.map +1 -1
- package/dist/components/nv-dialog.js +24 -18
- package/dist/components/nv-dialog.js.map +1 -1
- package/dist/components/nv-dialogfooter.js +1 -1
- package/dist/components/nv-dialogheader.js +1 -1
- package/dist/components/nv-fieldcheckbox.js +1 -1
- package/dist/components/nv-fielddate.js +19 -27
- package/dist/components/nv-fielddate.js.map +1 -1
- package/dist/components/nv-fielddaterange.js +99 -44
- package/dist/components/nv-fielddaterange.js.map +1 -1
- package/dist/components/nv-fielddropdown.js +103 -69
- package/dist/components/nv-fielddropdown.js.map +1 -1
- package/dist/components/nv-fielddropdownitem.js +1 -1
- package/dist/components/nv-fielddropdownitemcheck.js +1 -1
- package/dist/components/nv-fieldmultiselect.js +139 -120
- package/dist/components/nv-fieldmultiselect.js.map +1 -1
- package/dist/components/nv-fieldnumber.js +14 -9
- package/dist/components/nv-fieldnumber.js.map +1 -1
- package/dist/components/nv-fieldpassword.js +13 -8
- package/dist/components/nv-fieldpassword.js.map +1 -1
- package/dist/components/nv-fieldradio.js +4 -4
- package/dist/components/nv-fieldselect.js +15 -10
- package/dist/components/nv-fieldselect.js.map +1 -1
- package/dist/components/nv-fieldslider.d.ts +11 -0
- package/dist/components/nv-fieldslider.js +726 -0
- package/dist/components/nv-fieldslider.js.map +1 -0
- package/dist/components/nv-fieldtext.js +1 -158
- package/dist/components/nv-fieldtext.js.map +1 -1
- package/dist/components/nv-fieldtextarea.js +11 -6
- package/dist/components/nv-fieldtextarea.js.map +1 -1
- package/dist/components/nv-fieldtime.js +20 -17
- package/dist/components/nv-fieldtime.js.map +1 -1
- package/dist/components/nv-icon.js +1 -1
- package/dist/components/nv-iconbutton.js +1 -1
- package/dist/components/nv-loader.js +1 -1
- package/dist/components/nv-menu.js +7 -5
- package/dist/components/nv-menu.js.map +1 -1
- package/dist/components/nv-menuitem.js +1 -1
- package/dist/components/nv-popover.js +1 -1
- package/dist/components/nv-row.js +2 -2
- package/dist/components/nv-stack.js +2 -2
- package/dist/components/nv-table.js +3 -3
- package/dist/components/nv-table.js.map +1 -1
- package/dist/components/nv-tablecolumn.js +1 -1
- package/dist/components/nv-toggle.js +3 -3
- package/dist/components/nv-tooltip.js +1 -1
- package/dist/components/{p-dc3faba3.js → p-04cb3a6f.js} +5 -5
- package/dist/components/{p-dc3faba3.js.map → p-04cb3a6f.js.map} +1 -1
- package/dist/components/p-07a89754.js +187 -0
- package/dist/components/p-07a89754.js.map +1 -0
- package/dist/components/{p-b7b78e64.js → p-0ab80d95.js} +3 -3
- package/dist/components/{p-b7b78e64.js.map → p-0ab80d95.js.map} +1 -1
- package/dist/components/{p-8348db09.js → p-1f505531.js} +15 -2
- package/dist/components/p-1f505531.js.map +1 -0
- package/dist/components/{p-02752770.js → p-33e231f4.js} +2 -2
- package/dist/components/{p-02752770.js.map → p-33e231f4.js.map} +1 -1
- package/dist/components/p-4656efae.js +1111 -0
- package/dist/components/p-4656efae.js.map +1 -0
- package/dist/components/{p-2012b8ba.js → p-581e67cc.js} +4 -4
- package/dist/components/{p-2012b8ba.js.map → p-581e67cc.js.map} +1 -1
- package/dist/components/{p-1c45c0f2.js → p-679e0fa9.js} +16 -4
- package/dist/components/p-679e0fa9.js.map +1 -0
- package/dist/components/p-76a30bf1.js +88 -0
- package/dist/components/p-76a30bf1.js.map +1 -0
- package/dist/components/{p-150daf68.js → p-83c8873a.js} +3 -3
- package/dist/components/{p-150daf68.js.map → p-83c8873a.js.map} +1 -1
- package/dist/components/{p-c14f6b8e.js → p-c0a91091.js} +5 -5
- package/dist/components/p-c0a91091.js.map +1 -0
- package/dist/components/{p-6c364a23.js → p-cbdc2c8b.js} +6 -6
- package/dist/components/{p-6c364a23.js.map → p-cbdc2c8b.js.map} +1 -1
- package/dist/components/{p-2d9ba7d3.js → p-cbe9521f.js} +4 -4
- package/dist/components/{p-2d9ba7d3.js.map → p-cbe9521f.js.map} +1 -1
- package/dist/components/{p-a30b55fc.js → p-d19b41d2.js} +2 -2
- package/dist/components/{p-a30b55fc.js.map → p-d19b41d2.js.map} +1 -1
- package/dist/components/{p-4d3ec142.js → p-d63f1cbe.js} +4 -4
- package/dist/components/{p-4d3ec142.js.map → p-d63f1cbe.js.map} +1 -1
- package/dist/components/{p-e00cbb8a.js → p-dd2273a3.js} +2 -2
- package/dist/components/{p-e00cbb8a.js.map → p-dd2273a3.js.map} +1 -1
- package/dist/components/p-f0a5e7e4.js +167 -0
- package/dist/components/p-f0a5e7e4.js.map +1 -0
- package/dist/components/{p-f4d86795.js → p-f1859ddc.js} +4 -4
- package/dist/components/{p-f4d86795.js.map → p-f1859ddc.js.map} +1 -1
- package/dist/esm/{constants-98e2dcc2.js → constants-b97e736d.js} +15 -2
- package/dist/esm/constants-b97e736d.js.map +1 -0
- package/dist/esm/{index-1fb7a9a6.js → index-8f0e5f19.js} +22 -6
- package/dist/esm/index-8f0e5f19.js.map +1 -0
- package/dist/esm/index.js +5 -471
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/loader.js +3 -3
- package/dist/esm/native.js +3 -3
- package/dist/esm/nv-alert.entry.js +6 -6
- package/dist/esm/nv-alert.entry.js.map +1 -1
- package/dist/esm/nv-avatar.entry.js +2 -2
- package/dist/esm/nv-badge_2.entry.js +18 -9
- package/dist/esm/nv-badge_2.entry.js.map +1 -1
- package/dist/esm/nv-breadcrumb.entry.js +1 -1
- package/dist/esm/nv-breadcrumbs.entry.js +1 -1
- package/dist/esm/nv-button.entry.js +2 -2
- package/dist/esm/nv-calendar.entry.js +821 -843
- package/dist/esm/nv-calendar.entry.js.map +1 -1
- package/dist/esm/nv-col.entry.js +1 -1
- package/dist/esm/nv-datagrid.entry.js +423 -94
- package/dist/esm/nv-datagrid.entry.js.map +1 -1
- package/dist/esm/nv-datagridcolumn.entry.js +2 -2
- package/dist/esm/nv-datagridcolumn.entry.js.map +1 -1
- package/dist/esm/nv-dialog.entry.js +19 -13
- package/dist/esm/nv-dialog.entry.js.map +1 -1
- package/dist/esm/nv-dialogfooter_2.entry.js +2 -2
- package/dist/esm/nv-fieldcheckbox.entry.js +1 -1
- package/dist/esm/nv-fielddate.entry.js +9 -18
- package/dist/esm/nv-fielddate.entry.js.map +1 -1
- package/dist/esm/nv-fielddaterange.entry.js +85 -32
- package/dist/esm/nv-fielddaterange.entry.js.map +1 -1
- package/dist/esm/nv-fielddropdown.entry.js +88 -57
- package/dist/esm/nv-fielddropdown.entry.js.map +1 -1
- package/dist/esm/nv-fielddropdownitem.entry.js +2 -2
- package/dist/esm/nv-fieldmultiselect.entry.js +122 -104
- package/dist/esm/nv-fieldmultiselect.entry.js.map +1 -1
- package/dist/esm/nv-fieldnumber.entry.js +9 -5
- package/dist/esm/nv-fieldnumber.entry.js.map +1 -1
- package/dist/esm/nv-fieldpassword.entry.js +9 -5
- package/dist/esm/nv-fieldpassword.entry.js.map +1 -1
- package/dist/esm/nv-fieldradio.entry.js +4 -4
- package/dist/esm/nv-fieldselect.entry.js +11 -7
- package/dist/esm/nv-fieldselect.entry.js.map +1 -1
- package/dist/esm/nv-fieldslider.entry.js +659 -0
- package/dist/esm/nv-fieldslider.entry.js.map +1 -0
- package/dist/esm/nv-fieldtext.entry.js +9 -5
- package/dist/esm/nv-fieldtext.entry.js.map +1 -1
- package/dist/esm/nv-fieldtextarea.entry.js +9 -5
- package/dist/esm/nv-fieldtextarea.entry.js.map +1 -1
- package/dist/esm/nv-fieldtime.entry.js +16 -13
- package/dist/esm/nv-fieldtime.entry.js.map +1 -1
- package/dist/esm/nv-icon.entry.js +4 -4
- package/dist/esm/nv-icon.entry.js.map +1 -1
- package/dist/esm/nv-iconbutton_2.entry.js +3 -3
- package/dist/esm/nv-menu.entry.js +4 -2
- package/dist/esm/nv-menu.entry.js.map +1 -1
- package/dist/esm/nv-menuitem.entry.js +2 -2
- package/dist/esm/nv-popover.entry.js +2 -2
- package/dist/esm/nv-row.entry.js +2 -2
- package/dist/esm/nv-stack.entry.js +2 -2
- package/dist/esm/nv-table.entry.js +3 -3
- package/dist/esm/nv-table.entry.js.map +1 -1
- package/dist/esm/nv-tablecolumn.entry.js +1 -1
- package/dist/esm/nv-toggle.entry.js +3 -3
- package/dist/esm/nv-tooltip.entry.js +3 -3
- package/dist/esm/nv-tooltip.entry.js.map +1 -1
- package/dist/native/index.esm.js +1 -1
- package/dist/native/index.esm.js.map +1 -1
- package/dist/native/native.css +1 -1
- package/dist/native/native.esm.js +1 -1
- package/dist/native/native.esm.js.map +1 -1
- package/dist/native/{p-6b348684.entry.js → p-0323daf6.entry.js} +2 -2
- package/dist/native/{p-d5cbf5c8.entry.js → p-05d95d4d.entry.js} +2 -2
- package/dist/native/{p-fb5bddba.entry.js → p-0ec1e2e3.entry.js} +2 -2
- package/dist/native/{p-c7b201cd.entry.js → p-16a4cdf3.entry.js} +2 -2
- package/dist/native/p-19fb0fd0.entry.js +2 -0
- package/dist/native/p-19fb0fd0.entry.js.map +1 -0
- package/dist/native/p-1e3d3374.entry.js +2 -0
- package/dist/native/{p-9135fdf5.entry.js.map → p-1e3d3374.entry.js.map} +1 -1
- package/dist/native/p-21e7132f.entry.js +2 -0
- package/dist/native/p-21e7132f.entry.js.map +1 -0
- package/dist/native/p-221b8f72.entry.js +2 -0
- package/dist/native/p-221b8f72.entry.js.map +1 -0
- package/dist/native/p-2805f9f2.entry.js +2 -0
- package/dist/native/p-2805f9f2.entry.js.map +1 -0
- package/dist/native/p-3f2b6a22.entry.js +2 -0
- package/dist/native/p-3f2b6a22.entry.js.map +1 -0
- package/dist/native/{p-0245863d.entry.js → p-407fc32d.entry.js} +2 -2
- package/dist/native/{p-63e6aed3.entry.js → p-4c0d81b0.entry.js} +2 -2
- package/dist/native/p-4c0d81b0.entry.js.map +1 -0
- package/dist/native/{p-39bb95ff.entry.js → p-519b4819.entry.js} +2 -2
- package/dist/native/{p-fa77a591.entry.js → p-5382eab2.entry.js} +2 -2
- package/dist/native/p-5ba3fc3c.entry.js +2 -0
- package/dist/native/p-5ba3fc3c.entry.js.map +1 -0
- package/dist/native/{p-bad11367.entry.js → p-60b204ac.entry.js} +2 -2
- package/dist/native/p-60b204ac.entry.js.map +1 -0
- package/dist/native/p-7092a675.entry.js +2 -0
- package/dist/native/p-711a7778.js +3 -0
- package/dist/native/p-711a7778.js.map +1 -0
- package/dist/native/p-759c9ce4.entry.js +2 -0
- package/dist/native/p-759c9ce4.entry.js.map +1 -0
- package/dist/native/{p-d7a76400.entry.js → p-7c676f2c.entry.js} +2 -2
- package/dist/native/p-7c6edd1c.entry.js +2 -0
- package/dist/native/p-7c6edd1c.entry.js.map +1 -0
- package/dist/native/p-987c79d8.entry.js +2 -0
- package/dist/native/p-987c79d8.entry.js.map +1 -0
- package/dist/native/{p-f85aca27.entry.js → p-9fba8663.entry.js} +2 -2
- package/dist/native/{p-b094296d.entry.js → p-a2c0f1a7.entry.js} +2 -2
- package/dist/native/p-aa86af25.entry.js +2 -0
- package/dist/native/p-aa86af25.entry.js.map +1 -0
- package/dist/native/p-adc96c3a.entry.js +2 -0
- package/dist/native/p-adc96c3a.entry.js.map +1 -0
- package/dist/native/p-b0fc08e7.entry.js +2 -0
- package/dist/native/p-b0fc08e7.entry.js.map +1 -0
- package/dist/native/{p-6ff228da.entry.js → p-c930adb7.entry.js} +2 -2
- package/dist/native/{p-701b5557.entry.js → p-cfe0a6c6.entry.js} +2 -2
- package/dist/native/p-d07ab618.entry.js +2 -0
- package/dist/native/p-dac0089b.entry.js +2 -0
- package/dist/native/p-dac0089b.entry.js.map +1 -0
- package/dist/native/p-de2c07a6.entry.js +13 -0
- package/dist/native/p-de2c07a6.entry.js.map +1 -0
- package/dist/native/p-ed488498.entry.js +7 -0
- package/dist/native/p-ed488498.entry.js.map +1 -0
- package/dist/native/p-ef76178b.entry.js +2 -0
- package/dist/native/p-ef76178b.entry.js.map +1 -0
- package/dist/native/{p-e5de64d5.entry.js → p-f0ddf60b.entry.js} +2 -2
- package/dist/native/p-f39803d9.entry.js +2 -0
- package/dist/native/p-f39803d9.entry.js.map +1 -0
- package/dist/native/{p-59768ee5.js → p-f85c08f1.js} +2 -2
- package/dist/native/p-f85c08f1.js.map +1 -0
- package/dist/native/p-fb897f7d.entry.js +2 -0
- package/dist/native/p-fb897f7d.entry.js.map +1 -0
- package/dist/native/{p-244f56ac.entry.js → p-fc3bea07.entry.js} +2 -2
- package/dist/types/components/nv-alert/nv-alert.d.ts +1 -1
- package/dist/types/components/nv-badge/nv-badge.d.ts +11 -3
- package/dist/types/components/nv-calendar/nv-calendar.d.ts +70 -112
- package/dist/types/components/nv-calendar/nv-calendar.utils.d.ts +60 -0
- package/dist/types/components/nv-calendar/test/nv-calendar.utils.test.d.ts +1 -0
- package/dist/types/components/nv-datagrid/nv-datagrid.d.ts +47 -26
- package/dist/types/components/nv-datagridcolumn/nv-datagridcolumn.d.ts +4 -0
- package/dist/types/components/nv-dialog/nv-dialog.d.ts +4 -0
- package/dist/types/components/nv-fielddate/nv-fielddate.d.ts +6 -7
- package/dist/types/components/nv-fielddaterange/nv-fielddaterange.d.ts +23 -12
- package/dist/types/components/nv-fielddropdown/nv-fielddropdown.d.ts +51 -26
- package/dist/types/components/nv-fieldmultiselect/nv-fieldmultiselect.d.ts +65 -55
- package/dist/types/components/nv-fieldnumber/nv-fieldnumber.d.ts +4 -0
- package/dist/types/components/nv-fieldpassword/nv-fieldpassword.d.ts +4 -0
- package/dist/types/components/nv-fieldselect/nv-fieldselect.d.ts +4 -0
- package/dist/types/components/nv-fieldslider/nv-fieldslider.d.ts +230 -0
- package/dist/types/components/nv-fieldslider/nv-fieldslider.docs.d.ts +4 -0
- package/dist/types/components/nv-fieldslider/nv-fieldslider.utils.d.ts +46 -0
- package/dist/types/components/nv-fieldslider/partials/field-input.d.ts +45 -0
- package/dist/types/components/nv-fieldslider/partials/range-thumb.d.ts +37 -0
- package/dist/types/components/nv-fieldslider/partials/single-thumb.d.ts +35 -0
- package/dist/types/components/nv-fieldslider/partials/tick-marks.d.ts +28 -0
- package/dist/types/components/nv-fieldslider/test/nv-fieldslider.utils.test.d.ts +1 -0
- package/dist/types/components/nv-fieldtext/nv-fieldtext.d.ts +5 -0
- package/dist/types/components/nv-fieldtextarea/nv-fieldtextarea.d.ts +4 -0
- package/dist/types/components/nv-icon/nv-icons.d.ts +1 -1
- package/dist/types/components/nv-table/nv-table.d.ts +13 -2
- package/dist/types/components.d.ts +656 -154
- package/dist/types/index.d.ts +0 -2
- package/dist/types/interfaces/Column.d.ts +5 -1
- package/dist/types/utils/constants.d.ts +9 -0
- package/dist/vscode-data.json +292 -1546
- package/hydrate/index.js +2715 -1533
- package/hydrate/index.mjs +2715 -1533
- package/package.json +6 -2
- package/dist/cjs/constants-bcd6b2e2.js.map +0 -1
- package/dist/cjs/index-9bda5507.js.map +0 -1
- package/dist/collection/interfaces/actionEvent.js +0 -2
- package/dist/collection/interfaces/actionEvent.js.map +0 -1
- package/dist/collection/interfaces/calendarShortcut.js +0 -2
- package/dist/collection/interfaces/calendarShortcut.js.map +0 -1
- package/dist/collection/interfaces/dateRange.js +0 -2
- package/dist/collection/interfaces/dateRange.js.map +0 -1
- package/dist/components/p-1c45c0f2.js.map +0 -1
- package/dist/components/p-373926aa.js +0 -177
- package/dist/components/p-373926aa.js.map +0 -1
- package/dist/components/p-591730e7.js +0 -88
- package/dist/components/p-591730e7.js.map +0 -1
- package/dist/components/p-8348db09.js.map +0 -1
- package/dist/components/p-c14f6b8e.js.map +0 -1
- package/dist/components/p-f331117c.js +0 -1133
- package/dist/components/p-f331117c.js.map +0 -1
- package/dist/esm/constants-98e2dcc2.js.map +0 -1
- package/dist/esm/index-1fb7a9a6.js.map +0 -1
- package/dist/native/p-0ee428d5.entry.js +0 -2
- package/dist/native/p-0ee428d5.entry.js.map +0 -1
- package/dist/native/p-2691e02d.entry.js +0 -2
- package/dist/native/p-37f0210e.entry.js +0 -2
- package/dist/native/p-37f0210e.entry.js.map +0 -1
- package/dist/native/p-4a440970.entry.js +0 -2
- package/dist/native/p-4a440970.entry.js.map +0 -1
- package/dist/native/p-4ae26462.entry.js +0 -7
- package/dist/native/p-4ae26462.entry.js.map +0 -1
- package/dist/native/p-4d9c4618.entry.js +0 -2
- package/dist/native/p-4d9c4618.entry.js.map +0 -1
- package/dist/native/p-4dc1d036.entry.js +0 -2
- package/dist/native/p-59768ee5.js.map +0 -1
- package/dist/native/p-59e0bd2b.entry.js +0 -2
- package/dist/native/p-59e0bd2b.entry.js.map +0 -1
- package/dist/native/p-5c00f092.entry.js +0 -2
- package/dist/native/p-5c00f092.entry.js.map +0 -1
- package/dist/native/p-63e6aed3.entry.js.map +0 -1
- package/dist/native/p-7f5eb2ac.entry.js +0 -2
- package/dist/native/p-7f5eb2ac.entry.js.map +0 -1
- package/dist/native/p-84a73e2a.entry.js +0 -2
- package/dist/native/p-84a73e2a.entry.js.map +0 -1
- package/dist/native/p-9135fdf5.entry.js +0 -2
- package/dist/native/p-93dc2f47.entry.js +0 -2
- package/dist/native/p-93dc2f47.entry.js.map +0 -1
- package/dist/native/p-9a267f16.entry.js +0 -13
- package/dist/native/p-9a267f16.entry.js.map +0 -1
- package/dist/native/p-9d6431c7.entry.js +0 -2
- package/dist/native/p-9d6431c7.entry.js.map +0 -1
- package/dist/native/p-ab002252.js +0 -3
- package/dist/native/p-ab002252.js.map +0 -1
- package/dist/native/p-b2ce83ad.entry.js +0 -2
- package/dist/native/p-b2ce83ad.entry.js.map +0 -1
- package/dist/native/p-bad11367.entry.js.map +0 -1
- package/dist/native/p-e1a4f776.entry.js +0 -2
- package/dist/native/p-e1a4f776.entry.js.map +0 -1
- package/dist/native/p-e49bbd02.entry.js +0 -2
- package/dist/native/p-e49bbd02.entry.js.map +0 -1
- package/dist/native/p-eee01062.entry.js +0 -2
- package/dist/native/p-eee01062.entry.js.map +0 -1
- package/dist/native/p-f6bdc270.entry.js +0 -2
- package/dist/native/p-f6bdc270.entry.js.map +0 -1
- package/dist/types/interfaces/actionEvent.d.ts +0 -13
- package/dist/types/interfaces/calendarShortcut.d.ts +0 -17
- package/dist/types/interfaces/dateRange.d.ts +0 -13
- /package/dist/native/{p-6b348684.entry.js.map → p-0323daf6.entry.js.map} +0 -0
- /package/dist/native/{p-d5cbf5c8.entry.js.map → p-05d95d4d.entry.js.map} +0 -0
- /package/dist/native/{p-fb5bddba.entry.js.map → p-0ec1e2e3.entry.js.map} +0 -0
- /package/dist/native/{p-c7b201cd.entry.js.map → p-16a4cdf3.entry.js.map} +0 -0
- /package/dist/native/{p-0245863d.entry.js.map → p-407fc32d.entry.js.map} +0 -0
- /package/dist/native/{p-39bb95ff.entry.js.map → p-519b4819.entry.js.map} +0 -0
- /package/dist/native/{p-fa77a591.entry.js.map → p-5382eab2.entry.js.map} +0 -0
- /package/dist/native/{p-2691e02d.entry.js.map → p-7092a675.entry.js.map} +0 -0
- /package/dist/native/{p-d7a76400.entry.js.map → p-7c676f2c.entry.js.map} +0 -0
- /package/dist/native/{p-f85aca27.entry.js.map → p-9fba8663.entry.js.map} +0 -0
- /package/dist/native/{p-b094296d.entry.js.map → p-a2c0f1a7.entry.js.map} +0 -0
- /package/dist/native/{p-6ff228da.entry.js.map → p-c930adb7.entry.js.map} +0 -0
- /package/dist/native/{p-701b5557.entry.js.map → p-cfe0a6c6.entry.js.map} +0 -0
- /package/dist/native/{p-4dc1d036.entry.js.map → p-d07ab618.entry.js.map} +0 -0
- /package/dist/native/{p-e5de64d5.entry.js.map → p-f0ddf60b.entry.js.map} +0 -0
- /package/dist/native/{p-244f56ac.entry.js.map → p-fc3bea07.entry.js.map} +0 -0
|
@@ -0,0 +1,667 @@
|
|
|
1
|
+
import { describe, it, expect, vi } from "vitest";
|
|
2
|
+
import { getWeekNumber, parseDate, isSameDate, isSameOrAfter, isSameOrBefore, formatDate, } from "../nv-calendar.utils";
|
|
3
|
+
describe('nv-calendar -> utils', () => {
|
|
4
|
+
describe('getWeekNumber', () => {
|
|
5
|
+
it('should return the correct week number for the first day of the year', () => {
|
|
6
|
+
const date = new Date(2023, 0, 1); // January 1, 2023
|
|
7
|
+
expect(getWeekNumber(date)).toBe(1);
|
|
8
|
+
});
|
|
9
|
+
it('should return the correct week number for a day in the middle of the year', () => {
|
|
10
|
+
const date = new Date(2023, 6, 15); // July 15, 2023
|
|
11
|
+
expect(getWeekNumber(date)).toBe(28);
|
|
12
|
+
});
|
|
13
|
+
it('should return the correct week number for the last day of the year', () => {
|
|
14
|
+
const date = new Date(2023, 11, 31); // December 31, 2023
|
|
15
|
+
expect(getWeekNumber(date)).toBe(53);
|
|
16
|
+
});
|
|
17
|
+
it('should handle leap years correctly', () => {
|
|
18
|
+
const date = new Date(2024, 1, 29); // February 29, 2024 (leap year)
|
|
19
|
+
expect(getWeekNumber(date)).toBe(9);
|
|
20
|
+
});
|
|
21
|
+
it('should handle years where January 1 is not a Sunday', () => {
|
|
22
|
+
// January 1, 2022 was a Saturday, which affects week calculations
|
|
23
|
+
const date = new Date(2022, 0, 1); // January 1, 2022
|
|
24
|
+
expect(getWeekNumber(date)).toBe(1);
|
|
25
|
+
const secondWeek = new Date(2022, 0, 9); // January 9, 2022
|
|
26
|
+
expect(getWeekNumber(secondWeek)).toBe(3);
|
|
27
|
+
});
|
|
28
|
+
it('should handle edge cases between years', () => {
|
|
29
|
+
// Last few days of December and first few days of January
|
|
30
|
+
const dec31 = new Date(2022, 11, 31); // December 31, 2022
|
|
31
|
+
const jan1 = new Date(2023, 0, 1); // January 1, 2023
|
|
32
|
+
expect(getWeekNumber(dec31)).toBe(53);
|
|
33
|
+
expect(getWeekNumber(jan1)).toBe(1);
|
|
34
|
+
});
|
|
35
|
+
it('should return consistent results for the same date in different time zones', () => {
|
|
36
|
+
const date = new Date(2023, 5, 15);
|
|
37
|
+
const originalHours = date.getHours();
|
|
38
|
+
// Simulate different times on the same day
|
|
39
|
+
date.setHours(0);
|
|
40
|
+
const earlyResult = getWeekNumber(date);
|
|
41
|
+
date.setHours(23);
|
|
42
|
+
const lateResult = getWeekNumber(date);
|
|
43
|
+
expect(earlyResult).toBe(lateResult);
|
|
44
|
+
// Reset to avoid affecting other tests
|
|
45
|
+
date.setHours(originalHours);
|
|
46
|
+
});
|
|
47
|
+
it('should handle historic dates correctly', () => {
|
|
48
|
+
const historicDate = new Date(2000, 0, 1); // January 1, 2000
|
|
49
|
+
expect(getWeekNumber(historicDate)).toBe(1);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
describe('parseDate', () => {
|
|
53
|
+
// Date object handling
|
|
54
|
+
it('should return the original Date when a Date object is passed', () => {
|
|
55
|
+
const date = new Date(2023, 5, 15); // June 15, 2023
|
|
56
|
+
const result = parseDate(date, 'YYYY-MM-DD');
|
|
57
|
+
expect(result).toBe(date); // Check it's the same object reference
|
|
58
|
+
expect(result === null || result === void 0 ? void 0 : result.getTime()).toBe(date.getTime()); // Double-check timestamp equality
|
|
59
|
+
});
|
|
60
|
+
// ISO 8601 format detection
|
|
61
|
+
it('should automatically detect and parse ISO 8601 format', () => {
|
|
62
|
+
const isoString = '2023-06-15T12:30:45.123Z';
|
|
63
|
+
const result = parseDate(isoString, 'any-format');
|
|
64
|
+
expect(result).toBeInstanceOf(Date);
|
|
65
|
+
expect(result === null || result === void 0 ? void 0 : result.toISOString()).toBe(isoString);
|
|
66
|
+
});
|
|
67
|
+
it('should handle ISO 8601 parsing errors gracefully', () => {
|
|
68
|
+
// Mock console.error to prevent actual errors in test output
|
|
69
|
+
const consoleSpy = vi
|
|
70
|
+
.spyOn(console, 'error')
|
|
71
|
+
.mockImplementation(() => { });
|
|
72
|
+
// Invalid ISO string that looks close but is malformed
|
|
73
|
+
const invalidIsoString = '2023-06-15T25:30:45.123Z'; // 25 hours is invalid
|
|
74
|
+
const result = parseDate(invalidIsoString, 'YYYY-MM-DD');
|
|
75
|
+
expect(result).toBeNull();
|
|
76
|
+
expect(consoleSpy).toHaveBeenCalled();
|
|
77
|
+
consoleSpy.mockRestore();
|
|
78
|
+
});
|
|
79
|
+
// Unix timestamp formats
|
|
80
|
+
it('should parse Unix seconds (X format)', () => {
|
|
81
|
+
const unixSeconds = '1623760245'; // June 15, 2021, 12:30:45 UTC
|
|
82
|
+
const result = parseDate(unixSeconds, 'X');
|
|
83
|
+
expect(result).toBeInstanceOf(Date);
|
|
84
|
+
expect(result === null || result === void 0 ? void 0 : result.getTime()).toBe(1623760245000);
|
|
85
|
+
});
|
|
86
|
+
it('should parse Unix milliseconds (x format)', () => {
|
|
87
|
+
const unixMilliseconds = '1623760245123'; // June 15, 2021, 12:30:45.123 UTC
|
|
88
|
+
const result = parseDate(unixMilliseconds, 'x');
|
|
89
|
+
expect(result).toBeInstanceOf(Date);
|
|
90
|
+
expect(result === null || result === void 0 ? void 0 : result.getTime()).toBe(1623760245123);
|
|
91
|
+
});
|
|
92
|
+
it('should handle invalid Unix timestamps', () => {
|
|
93
|
+
const consoleSpy = vi
|
|
94
|
+
.spyOn(console, 'error')
|
|
95
|
+
.mockImplementation(() => { });
|
|
96
|
+
// Non-numeric Unix timestamp
|
|
97
|
+
const invalidUnixSeconds = 'abc';
|
|
98
|
+
const result = parseDate(invalidUnixSeconds, 'X');
|
|
99
|
+
expect(result).toBeNull();
|
|
100
|
+
consoleSpy.mockRestore();
|
|
101
|
+
});
|
|
102
|
+
// C# Ticks format
|
|
103
|
+
it('should parse C# Ticks format', () => {
|
|
104
|
+
// Test the actual implementation with a known Ticks value
|
|
105
|
+
// .NET Ticks value (621355968000000000 is the offset for Unix epoch)
|
|
106
|
+
const csharpTicks = '637593021450000000';
|
|
107
|
+
const result = parseDate(csharpTicks, 'Ticks');
|
|
108
|
+
expect(result).toBeInstanceOf(Date);
|
|
109
|
+
// Instead of comparing to a specific date, let's verify the result is reasonable
|
|
110
|
+
// by checking basic properties
|
|
111
|
+
if (result) {
|
|
112
|
+
expect(result.getFullYear()).toBeGreaterThan(2000); // Should be a date after 2000
|
|
113
|
+
expect(result.getFullYear()).toBeLessThan(2030); // Should be a date before 2030
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
it('should handle invalid Ticks format', () => {
|
|
117
|
+
const consoleSpy = vi
|
|
118
|
+
.spyOn(console, 'error')
|
|
119
|
+
.mockImplementation(() => { });
|
|
120
|
+
const invalidTicks = 'abc';
|
|
121
|
+
const result = parseDate(invalidTicks, 'Ticks');
|
|
122
|
+
expect(result).toBeNull();
|
|
123
|
+
consoleSpy.mockRestore();
|
|
124
|
+
});
|
|
125
|
+
// Common date formats
|
|
126
|
+
it('should parse YYYY-MM-DD format', () => {
|
|
127
|
+
const dateStr = '2023-06-15';
|
|
128
|
+
const result = parseDate(dateStr, 'YYYY-MM-DD');
|
|
129
|
+
expect(result).toBeInstanceOf(Date);
|
|
130
|
+
expect(result === null || result === void 0 ? void 0 : result.getFullYear()).toBe(2023);
|
|
131
|
+
expect(result === null || result === void 0 ? void 0 : result.getMonth()).toBe(5); // 0-based, so June is 5
|
|
132
|
+
expect(result === null || result === void 0 ? void 0 : result.getDate()).toBe(15);
|
|
133
|
+
});
|
|
134
|
+
it('should parse DD-MM-YYYY format', () => {
|
|
135
|
+
const dateStr = '15-06-2023';
|
|
136
|
+
const result = parseDate(dateStr, 'DD-MM-YYYY');
|
|
137
|
+
expect(result).toBeInstanceOf(Date);
|
|
138
|
+
expect(result === null || result === void 0 ? void 0 : result.getFullYear()).toBe(2023);
|
|
139
|
+
expect(result === null || result === void 0 ? void 0 : result.getMonth()).toBe(5);
|
|
140
|
+
expect(result === null || result === void 0 ? void 0 : result.getDate()).toBe(15);
|
|
141
|
+
});
|
|
142
|
+
it('should parse MM/DD/YYYY format', () => {
|
|
143
|
+
const dateStr = '06/15/2023';
|
|
144
|
+
const result = parseDate(dateStr, 'MM/DD/YYYY');
|
|
145
|
+
expect(result).toBeInstanceOf(Date);
|
|
146
|
+
expect(result === null || result === void 0 ? void 0 : result.getFullYear()).toBe(2023);
|
|
147
|
+
expect(result === null || result === void 0 ? void 0 : result.getMonth()).toBe(5);
|
|
148
|
+
expect(result === null || result === void 0 ? void 0 : result.getDate()).toBe(15);
|
|
149
|
+
});
|
|
150
|
+
// Date with time formats
|
|
151
|
+
it('should parse YYYY-MM-DD HH:mm:ss format', () => {
|
|
152
|
+
const dateStr = '2023-06-15 14:30:45';
|
|
153
|
+
const result = parseDate(dateStr, 'YYYY-MM-DD HH:mm:ss');
|
|
154
|
+
expect(result).toBeInstanceOf(Date);
|
|
155
|
+
expect(result === null || result === void 0 ? void 0 : result.getFullYear()).toBe(2023);
|
|
156
|
+
expect(result === null || result === void 0 ? void 0 : result.getMonth()).toBe(5);
|
|
157
|
+
expect(result === null || result === void 0 ? void 0 : result.getDate()).toBe(15);
|
|
158
|
+
expect(result === null || result === void 0 ? void 0 : result.getHours()).toBe(14);
|
|
159
|
+
expect(result === null || result === void 0 ? void 0 : result.getMinutes()).toBe(30);
|
|
160
|
+
expect(result === null || result === void 0 ? void 0 : result.getSeconds()).toBe(45);
|
|
161
|
+
});
|
|
162
|
+
// UTC handling
|
|
163
|
+
it('should handle UTC mode correctly', () => {
|
|
164
|
+
// Looking at the implementation, the 'Z' in the format tells parseDate
|
|
165
|
+
// to use UTC mode, but doesn't require the dateStr to have a Z
|
|
166
|
+
const isoString = '2023-06-15T14:30:45.000Z';
|
|
167
|
+
const result = parseDate(isoString, 'YYYY-MM-DDTHH:mm:ss.SSSZ');
|
|
168
|
+
expect(result.getFullYear()).toBe(2023);
|
|
169
|
+
expect(result.getMonth()).toBe(5); // June
|
|
170
|
+
expect(result.getDate()).toBe(15);
|
|
171
|
+
});
|
|
172
|
+
// Invalid date handling
|
|
173
|
+
it('should return null for invalid dates', () => {
|
|
174
|
+
const consoleSpy = vi
|
|
175
|
+
.spyOn(console, 'error')
|
|
176
|
+
.mockImplementation(() => { });
|
|
177
|
+
// Invalid day (June 31 doesn't exist)
|
|
178
|
+
const invalidDate = '2023-06-31';
|
|
179
|
+
const result = parseDate(invalidDate, 'YYYY-MM-DD');
|
|
180
|
+
expect(result).toBeNull();
|
|
181
|
+
expect(consoleSpy).toHaveBeenCalled();
|
|
182
|
+
consoleSpy.mockRestore();
|
|
183
|
+
});
|
|
184
|
+
it("should return null when format doesn't match input", () => {
|
|
185
|
+
const consoleSpy = vi
|
|
186
|
+
.spyOn(console, 'error')
|
|
187
|
+
.mockImplementation(() => { });
|
|
188
|
+
// Format expects MM/DD/YYYY but input is YYYY-MM-DD
|
|
189
|
+
const mismatchFormat = '2023-06-15';
|
|
190
|
+
const result = parseDate(mismatchFormat, 'MM/DD/YYYY');
|
|
191
|
+
expect(result).toBeNull();
|
|
192
|
+
expect(consoleSpy).toHaveBeenCalled();
|
|
193
|
+
consoleSpy.mockRestore();
|
|
194
|
+
});
|
|
195
|
+
// Edge cases
|
|
196
|
+
it('should handle leap years correctly', () => {
|
|
197
|
+
// February 29 in a leap year
|
|
198
|
+
const leapYearDate = '2024-02-29';
|
|
199
|
+
const result = parseDate(leapYearDate, 'YYYY-MM-DD');
|
|
200
|
+
expect(result).toBeInstanceOf(Date);
|
|
201
|
+
expect(result === null || result === void 0 ? void 0 : result.getFullYear()).toBe(2024);
|
|
202
|
+
expect(result === null || result === void 0 ? void 0 : result.getMonth()).toBe(1); // February
|
|
203
|
+
expect(result === null || result === void 0 ? void 0 : result.getDate()).toBe(29);
|
|
204
|
+
});
|
|
205
|
+
it('should handle daylight saving time transitions', () => {
|
|
206
|
+
// A date during DST transition (will depend on locale)
|
|
207
|
+
// This test might behave differently in different timezones
|
|
208
|
+
const dstDate = '2023-03-12 02:30:00'; // Around when DST starts in the US
|
|
209
|
+
const result = parseDate(dstDate, 'YYYY-MM-DD HH:mm:ss');
|
|
210
|
+
expect(result).toBeInstanceOf(Date);
|
|
211
|
+
// We're not checking specific times because behavior varies by timezone
|
|
212
|
+
// Just ensuring it parses to a valid date
|
|
213
|
+
expect(result === null || result === void 0 ? void 0 : result.getFullYear()).toBe(2023);
|
|
214
|
+
expect(result === null || result === void 0 ? void 0 : result.getMonth()).toBe(2); // March
|
|
215
|
+
expect(result === null || result === void 0 ? void 0 : result.getDate()).toBe(12);
|
|
216
|
+
});
|
|
217
|
+
// Test complex formats
|
|
218
|
+
it('should parse formats with month names and AM/PM markers', () => {
|
|
219
|
+
// Dayjs supports these format tokens, but not the ordinal 'Do'
|
|
220
|
+
// or day names like 'dddd' in strict mode
|
|
221
|
+
const dateStr = 'June 15 2023, 2:30:45 PM';
|
|
222
|
+
const format = 'MMMM D YYYY, h:mm:ss A';
|
|
223
|
+
const result = parseDate(dateStr, format);
|
|
224
|
+
expect(result).toBeInstanceOf(Date);
|
|
225
|
+
expect(result === null || result === void 0 ? void 0 : result.getFullYear()).toBe(2023);
|
|
226
|
+
expect(result === null || result === void 0 ? void 0 : result.getMonth()).toBe(5); // June
|
|
227
|
+
expect(result === null || result === void 0 ? void 0 : result.getDate()).toBe(15);
|
|
228
|
+
expect(result === null || result === void 0 ? void 0 : result.getHours()).toBe(14); // 2 PM = 14:00
|
|
229
|
+
expect(result === null || result === void 0 ? void 0 : result.getMinutes()).toBe(30);
|
|
230
|
+
expect(result === null || result === void 0 ? void 0 : result.getSeconds()).toBe(45);
|
|
231
|
+
});
|
|
232
|
+
});
|
|
233
|
+
describe('isSameDate', () => {
|
|
234
|
+
// Test with local dates
|
|
235
|
+
it('should return true for identical local dates', () => {
|
|
236
|
+
const date1 = new Date(2023, 5, 15, 10, 30, 0); // June 15, 2023, 10:30:00
|
|
237
|
+
const date2 = new Date(2023, 5, 15, 14, 45, 0); // June 15, 2023, 14:45:00 (different time)
|
|
238
|
+
const result = isSameDate(date1, date2, { isUTCMode: false });
|
|
239
|
+
expect(result).toBe(true);
|
|
240
|
+
});
|
|
241
|
+
it('should return false for different local dates', () => {
|
|
242
|
+
const date1 = new Date(2023, 5, 15); // June 15, 2023
|
|
243
|
+
const date2 = new Date(2023, 5, 16); // June 16, 2023
|
|
244
|
+
const result = isSameDate(date1, date2, { isUTCMode: false });
|
|
245
|
+
expect(result).toBe(false);
|
|
246
|
+
});
|
|
247
|
+
// Test with UTC dates
|
|
248
|
+
it('should return true for identical UTC dates', () => {
|
|
249
|
+
// Create dates with the same UTC date but different times
|
|
250
|
+
const date1 = new Date(Date.UTC(2023, 5, 15, 10, 30, 0)); // June 15, 2023, 10:30:00 UTC
|
|
251
|
+
const date2 = new Date(Date.UTC(2023, 5, 15, 14, 45, 0)); // June 15, 2023, 14:45:00 UTC
|
|
252
|
+
const result = isSameDate(date1, date2, { isUTCMode: true });
|
|
253
|
+
expect(result).toBe(true);
|
|
254
|
+
});
|
|
255
|
+
it('should return false for different UTC dates', () => {
|
|
256
|
+
const date1 = new Date(Date.UTC(2023, 5, 15)); // June 15, 2023 UTC
|
|
257
|
+
const date2 = new Date(Date.UTC(2023, 5, 16)); // June 16, 2023 UTC
|
|
258
|
+
const result = isSameDate(date1, date2, { isUTCMode: true });
|
|
259
|
+
expect(result).toBe(false);
|
|
260
|
+
});
|
|
261
|
+
// Test with dates that would be the same in one mode but different in another
|
|
262
|
+
it('should handle date differences across timezone boundaries when using local mode', () => {
|
|
263
|
+
// Create a date near midnight in UTC
|
|
264
|
+
const date1 = new Date(Date.UTC(2023, 5, 15, 23, 0, 0)); // June 15, 2023, 23:00 UTC
|
|
265
|
+
// This could be June 16 in local time depending on timezone
|
|
266
|
+
const date2 = new Date(date1);
|
|
267
|
+
date2.setUTCHours(date1.getUTCHours() + 2); // June 16, 2023, 01:00 UTC
|
|
268
|
+
// In local mode, these might be the same date depending on timezone
|
|
269
|
+
// We're just checking that the function respects the isUTCMode flag
|
|
270
|
+
const localResult = isSameDate(date1, date2, { isUTCMode: false });
|
|
271
|
+
const utcResult = isSameDate(date1, date2, { isUTCMode: true });
|
|
272
|
+
// The dates should be different in UTC mode (since we crossed UTC midnight)
|
|
273
|
+
expect(utcResult).toBe(false);
|
|
274
|
+
// The local result will depend on timezone, but we're just verifying
|
|
275
|
+
// that the function uses the correct getters based on isUTCMode
|
|
276
|
+
if (date1.getDate() === date2.getDate()) {
|
|
277
|
+
expect(localResult).toBe(true);
|
|
278
|
+
}
|
|
279
|
+
else {
|
|
280
|
+
expect(localResult).toBe(false);
|
|
281
|
+
}
|
|
282
|
+
});
|
|
283
|
+
// Test null handling
|
|
284
|
+
it('should return false if either date is null', () => {
|
|
285
|
+
const date = new Date(2023, 5, 15);
|
|
286
|
+
expect(isSameDate(null, date, { isUTCMode: false })).toBe(false);
|
|
287
|
+
expect(isSameDate(date, null, { isUTCMode: false })).toBe(false);
|
|
288
|
+
expect(isSameDate(null, null, { isUTCMode: false })).toBe(false);
|
|
289
|
+
});
|
|
290
|
+
// Test that the function only compares the date part
|
|
291
|
+
it('should ignore time differences in local mode', () => {
|
|
292
|
+
const morning = new Date(2023, 5, 15, 8, 0, 0); // 8:00 AM
|
|
293
|
+
const evening = new Date(2023, 5, 15, 20, 0, 0); // 8:00 PM
|
|
294
|
+
const result = isSameDate(morning, evening, { isUTCMode: false });
|
|
295
|
+
expect(result).toBe(true);
|
|
296
|
+
});
|
|
297
|
+
it('should ignore time differences in UTC mode', () => {
|
|
298
|
+
const morning = new Date(Date.UTC(2023, 5, 15, 8, 0, 0)); // 8:00 AM UTC
|
|
299
|
+
const evening = new Date(Date.UTC(2023, 5, 15, 20, 0, 0)); // 8:00 PM UTC
|
|
300
|
+
const result = isSameDate(morning, evening, { isUTCMode: true });
|
|
301
|
+
expect(result).toBe(true);
|
|
302
|
+
});
|
|
303
|
+
// Test edge cases
|
|
304
|
+
it('should correctly handle month/year boundaries', () => {
|
|
305
|
+
const lastDayOfMonth = new Date(2023, 5, 30); // June 30, 2023
|
|
306
|
+
const firstDayOfNextMonth = new Date(2023, 6, 1); // July 1, 2023
|
|
307
|
+
expect(isSameDate(lastDayOfMonth, firstDayOfNextMonth, { isUTCMode: false })).toBe(false);
|
|
308
|
+
const lastDayOfYear = new Date(2023, 11, 31); // December 31, 2023
|
|
309
|
+
const firstDayOfNextYear = new Date(2024, 0, 1); // January 1, 2024
|
|
310
|
+
expect(isSameDate(lastDayOfYear, firstDayOfNextYear, { isUTCMode: false })).toBe(false);
|
|
311
|
+
});
|
|
312
|
+
it('should handle leap year dates', () => {
|
|
313
|
+
const leapYearDay = new Date(2024, 1, 29); // February 29, 2024 (leap year)
|
|
314
|
+
const nonLeapYearDay = new Date(2023, 1, 28); // February 28, 2023 (non-leap year)
|
|
315
|
+
expect(isSameDate(leapYearDay, nonLeapYearDay, { isUTCMode: false })).toBe(false);
|
|
316
|
+
});
|
|
317
|
+
});
|
|
318
|
+
describe('isSameOrAfter', () => {
|
|
319
|
+
// Test cases for local mode (isUTCMode: false)
|
|
320
|
+
it('should return true when the date is the same in local mode', () => {
|
|
321
|
+
const date1 = new Date(2023, 5, 15, 10, 30); // June 15, 2023, 10:30
|
|
322
|
+
const date2 = new Date(2023, 5, 15, 14, 45); // June 15, 2023, 14:45 (same date, different time)
|
|
323
|
+
const result = isSameOrAfter(date1, date2, { isUTCMode: false });
|
|
324
|
+
// Should return true because the dates are the same (ignoring time)
|
|
325
|
+
expect(result).toBe(true);
|
|
326
|
+
});
|
|
327
|
+
it('should return true when the date is after in local mode', () => {
|
|
328
|
+
const later = new Date(2023, 5, 16); // June 16, 2023
|
|
329
|
+
const earlier = new Date(2023, 5, 15); // June 15, 2023
|
|
330
|
+
const result = isSameOrAfter(later, earlier, { isUTCMode: false });
|
|
331
|
+
expect(result).toBe(true);
|
|
332
|
+
});
|
|
333
|
+
it('should return false when the date is before in local mode', () => {
|
|
334
|
+
const earlier = new Date(2023, 5, 15); // June 15, 2023
|
|
335
|
+
const later = new Date(2023, 5, 16); // June 16, 2023
|
|
336
|
+
const result = isSameOrAfter(earlier, later, { isUTCMode: false });
|
|
337
|
+
expect(result).toBe(false);
|
|
338
|
+
});
|
|
339
|
+
// Test cases for UTC mode (isUTCMode: true)
|
|
340
|
+
it('should return true when the date is the same in UTC mode', () => {
|
|
341
|
+
const date1 = new Date(Date.UTC(2023, 5, 15, 10, 30)); // June 15, 2023, 10:30 UTC
|
|
342
|
+
const date2 = new Date(Date.UTC(2023, 5, 15, 14, 45)); // June 15, 2023, 14:45 UTC (same date, different time)
|
|
343
|
+
const result = isSameOrAfter(date1, date2, { isUTCMode: true });
|
|
344
|
+
// Should return true because the dates are the same (ignoring time)
|
|
345
|
+
expect(result).toBe(true);
|
|
346
|
+
});
|
|
347
|
+
it('should return true when the date is after in UTC mode', () => {
|
|
348
|
+
const later = new Date(Date.UTC(2023, 5, 16)); // June 16, 2023 UTC
|
|
349
|
+
const earlier = new Date(Date.UTC(2023, 5, 15)); // June 15, 2023 UTC
|
|
350
|
+
const result = isSameOrAfter(later, earlier, { isUTCMode: true });
|
|
351
|
+
expect(result).toBe(true);
|
|
352
|
+
});
|
|
353
|
+
it('should return false when the date is before in UTC mode', () => {
|
|
354
|
+
const earlier = new Date(Date.UTC(2023, 5, 15)); // June 15, 2023 UTC
|
|
355
|
+
const later = new Date(Date.UTC(2023, 5, 16)); // June 16, 2023 UTC
|
|
356
|
+
const result = isSameOrAfter(earlier, later, { isUTCMode: true });
|
|
357
|
+
expect(result).toBe(false);
|
|
358
|
+
});
|
|
359
|
+
// Test cases for different years and months
|
|
360
|
+
it('should return true when the year is after in local mode', () => {
|
|
361
|
+
const laterYear = new Date(2024, 0, 1); // January 1, 2024
|
|
362
|
+
const earlierYear = new Date(2023, 11, 31); // December 31, 2023
|
|
363
|
+
const result = isSameOrAfter(laterYear, earlierYear, {
|
|
364
|
+
isUTCMode: false,
|
|
365
|
+
});
|
|
366
|
+
expect(result).toBe(true);
|
|
367
|
+
});
|
|
368
|
+
it('should return true when the month is after in the same year in local mode', () => {
|
|
369
|
+
const laterMonth = new Date(2023, 6, 1); // July 1, 2023
|
|
370
|
+
const earlierMonth = new Date(2023, 5, 30); // June 30, 2023
|
|
371
|
+
const result = isSameOrAfter(laterMonth, earlierMonth, {
|
|
372
|
+
isUTCMode: false,
|
|
373
|
+
});
|
|
374
|
+
expect(result).toBe(true);
|
|
375
|
+
});
|
|
376
|
+
it('should return false when the year is before in UTC mode', () => {
|
|
377
|
+
const earlierYear = new Date(Date.UTC(2022, 11, 31)); // December 31, 2022 UTC
|
|
378
|
+
const laterYear = new Date(Date.UTC(2023, 0, 1)); // January 1, 2023 UTC
|
|
379
|
+
const result = isSameOrAfter(earlierYear, laterYear, { isUTCMode: true });
|
|
380
|
+
expect(result).toBe(false);
|
|
381
|
+
});
|
|
382
|
+
it('should return false when the month is before in the same year in UTC mode', () => {
|
|
383
|
+
const earlierMonth = new Date(Date.UTC(2023, 4, 31)); // May 31, 2023 UTC
|
|
384
|
+
const laterMonth = new Date(Date.UTC(2023, 5, 1)); // June 1, 2023 UTC
|
|
385
|
+
const result = isSameOrAfter(earlierMonth, laterMonth, {
|
|
386
|
+
isUTCMode: true,
|
|
387
|
+
});
|
|
388
|
+
expect(result).toBe(false);
|
|
389
|
+
});
|
|
390
|
+
// Edge cases
|
|
391
|
+
it('should handle same date with different times correctly in local mode', () => {
|
|
392
|
+
const morningDate = new Date(2023, 5, 15, 8, 0); // June 15, 2023, 8:00 AM
|
|
393
|
+
const eveningDate = new Date(2023, 5, 15, 20, 0); // June 15, 2023, 8:00 PM
|
|
394
|
+
// Since we're only comparing dates (not times), both should be "same or after" each other
|
|
395
|
+
expect(isSameOrAfter(morningDate, eveningDate, { isUTCMode: false })).toBe(true);
|
|
396
|
+
expect(isSameOrAfter(eveningDate, morningDate, { isUTCMode: false })).toBe(true);
|
|
397
|
+
});
|
|
398
|
+
it('should handle same date with different times correctly in UTC mode', () => {
|
|
399
|
+
const morningDate = new Date(Date.UTC(2023, 5, 15, 8, 0)); // June 15, 2023, 8:00 AM UTC
|
|
400
|
+
const eveningDate = new Date(Date.UTC(2023, 5, 15, 20, 0)); // June 15, 2023, 8:00 PM UTC
|
|
401
|
+
// Since we're only comparing dates (not times), both should be "same or after" each other
|
|
402
|
+
expect(isSameOrAfter(morningDate, eveningDate, { isUTCMode: true })).toBe(true);
|
|
403
|
+
expect(isSameOrAfter(eveningDate, morningDate, { isUTCMode: true })).toBe(true);
|
|
404
|
+
});
|
|
405
|
+
it('should handle leap year dates correctly', () => {
|
|
406
|
+
const leapYearDate = new Date(2024, 1, 29); // February 29, 2024 (leap year)
|
|
407
|
+
const nonLeapYearDate = new Date(2023, 1, 28); // February 28, 2023 (non-leap year)
|
|
408
|
+
// A date in a later year should be "after" regardless of the month/day
|
|
409
|
+
expect(isSameOrAfter(leapYearDate, nonLeapYearDate, { isUTCMode: false })).toBe(true);
|
|
410
|
+
expect(isSameOrAfter(nonLeapYearDate, leapYearDate, { isUTCMode: false })).toBe(false);
|
|
411
|
+
});
|
|
412
|
+
it('should handle edge cases between months correctly', () => {
|
|
413
|
+
const lastDayOfMonth = new Date(2023, 5, 30); // June 30, 2023
|
|
414
|
+
const firstDayOfNextMonth = new Date(2023, 6, 1); // July 1, 2023
|
|
415
|
+
expect(isSameOrAfter(lastDayOfMonth, firstDayOfNextMonth, {
|
|
416
|
+
isUTCMode: false,
|
|
417
|
+
})).toBe(false);
|
|
418
|
+
expect(isSameOrAfter(firstDayOfNextMonth, lastDayOfMonth, {
|
|
419
|
+
isUTCMode: false,
|
|
420
|
+
})).toBe(true);
|
|
421
|
+
});
|
|
422
|
+
it('should handle null dates gracefully', () => {
|
|
423
|
+
const date = new Date(2023, 5, 15);
|
|
424
|
+
const nullDate = null;
|
|
425
|
+
// Check if the function handles null inputs gracefully
|
|
426
|
+
// Note: Your implementation might need to be updated to handle this case
|
|
427
|
+
expect(() => isSameOrAfter(date, nullDate, { isUTCMode: false })).not.toThrow();
|
|
428
|
+
expect(() => isSameOrAfter(nullDate, date, { isUTCMode: false })).not.toThrow();
|
|
429
|
+
});
|
|
430
|
+
});
|
|
431
|
+
describe('isSameOrBefore', () => {
|
|
432
|
+
// Test cases for local mode (isUTCMode: false)
|
|
433
|
+
it('should return true when the date is the same in local mode', () => {
|
|
434
|
+
const date1 = new Date(2023, 5, 15, 10, 30); // June 15, 2023, 10:30
|
|
435
|
+
const date2 = new Date(2023, 5, 15, 14, 45); // June 15, 2023, 14:45 (same date, different time)
|
|
436
|
+
const result = isSameOrBefore(date1, date2, { isUTCMode: false });
|
|
437
|
+
// Should return true because the dates are the same (ignoring time)
|
|
438
|
+
expect(result).toBe(true);
|
|
439
|
+
});
|
|
440
|
+
it('should return true when the date is before in local mode', () => {
|
|
441
|
+
const earlier = new Date(2023, 5, 15); // June 15, 2023
|
|
442
|
+
const later = new Date(2023, 5, 16); // June 16, 2023
|
|
443
|
+
const result = isSameOrBefore(earlier, later, { isUTCMode: false });
|
|
444
|
+
expect(result).toBe(true);
|
|
445
|
+
});
|
|
446
|
+
it('should return false when the date is after in local mode', () => {
|
|
447
|
+
const later = new Date(2023, 5, 16); // June 16, 2023
|
|
448
|
+
const earlier = new Date(2023, 5, 15); // June 15, 2023
|
|
449
|
+
const result = isSameOrBefore(later, earlier, { isUTCMode: false });
|
|
450
|
+
expect(result).toBe(false);
|
|
451
|
+
});
|
|
452
|
+
// Test cases for UTC mode (isUTCMode: true)
|
|
453
|
+
it('should return true when the date is the same in UTC mode', () => {
|
|
454
|
+
const date1 = new Date(Date.UTC(2023, 5, 15, 10, 30)); // June 15, 2023, 10:30 UTC
|
|
455
|
+
const date2 = new Date(Date.UTC(2023, 5, 15, 14, 45)); // June 15, 2023, 14:45 UTC (same date, different time)
|
|
456
|
+
const result = isSameOrBefore(date1, date2, { isUTCMode: true });
|
|
457
|
+
// Should return true because the dates are the same (ignoring time)
|
|
458
|
+
expect(result).toBe(true);
|
|
459
|
+
});
|
|
460
|
+
it('should return true when the date is before in UTC mode', () => {
|
|
461
|
+
const earlier = new Date(Date.UTC(2023, 5, 15)); // June 15, 2023 UTC
|
|
462
|
+
const later = new Date(Date.UTC(2023, 5, 16)); // June 16, 2023 UTC
|
|
463
|
+
const result = isSameOrBefore(earlier, later, { isUTCMode: true });
|
|
464
|
+
expect(result).toBe(true);
|
|
465
|
+
});
|
|
466
|
+
it('should return false when the date is after in UTC mode', () => {
|
|
467
|
+
const later = new Date(Date.UTC(2023, 5, 16)); // June 16, 2023 UTC
|
|
468
|
+
const earlier = new Date(Date.UTC(2023, 5, 15)); // June 15, 2023 UTC
|
|
469
|
+
const result = isSameOrBefore(later, earlier, { isUTCMode: true });
|
|
470
|
+
expect(result).toBe(false);
|
|
471
|
+
});
|
|
472
|
+
// Test cases for different years and months
|
|
473
|
+
it('should return true when the year is before in local mode', () => {
|
|
474
|
+
const earlierYear = new Date(2022, 11, 31); // December 31, 2022
|
|
475
|
+
const laterYear = new Date(2023, 0, 1); // January 1, 2023
|
|
476
|
+
const result = isSameOrBefore(earlierYear, laterYear, {
|
|
477
|
+
isUTCMode: false,
|
|
478
|
+
});
|
|
479
|
+
expect(result).toBe(true);
|
|
480
|
+
});
|
|
481
|
+
it('should return true when the month is before in the same year in local mode', () => {
|
|
482
|
+
const earlierMonth = new Date(2023, 4, 31); // May 31, 2023
|
|
483
|
+
const laterMonth = new Date(2023, 5, 1); // June 1, 2023
|
|
484
|
+
const result = isSameOrBefore(earlierMonth, laterMonth, {
|
|
485
|
+
isUTCMode: false,
|
|
486
|
+
});
|
|
487
|
+
expect(result).toBe(true);
|
|
488
|
+
});
|
|
489
|
+
it('should return false when the year is after in UTC mode', () => {
|
|
490
|
+
const laterYear = new Date(Date.UTC(2023, 0, 1)); // January 1, 2023 UTC
|
|
491
|
+
const earlierYear = new Date(Date.UTC(2022, 11, 31)); // December 31, 2022 UTC
|
|
492
|
+
const result = isSameOrBefore(laterYear, earlierYear, {
|
|
493
|
+
isUTCMode: true,
|
|
494
|
+
});
|
|
495
|
+
expect(result).toBe(false);
|
|
496
|
+
});
|
|
497
|
+
it('should return false when the month is after in the same year in UTC mode', () => {
|
|
498
|
+
const laterMonth = new Date(Date.UTC(2023, 5, 1)); // June 1, 2023 UTC
|
|
499
|
+
const earlierMonth = new Date(Date.UTC(2023, 4, 31)); // May 31, 2023 UTC
|
|
500
|
+
const result = isSameOrBefore(laterMonth, earlierMonth, {
|
|
501
|
+
isUTCMode: true,
|
|
502
|
+
});
|
|
503
|
+
expect(result).toBe(false);
|
|
504
|
+
});
|
|
505
|
+
// Edge cases
|
|
506
|
+
it('should handle same date with different times correctly in local mode', () => {
|
|
507
|
+
const morningDate = new Date(2023, 5, 15, 8, 0); // June 15, 2023, 8:00 AM
|
|
508
|
+
const eveningDate = new Date(2023, 5, 15, 20, 0); // June 15, 2023, 8:00 PM
|
|
509
|
+
// Since we're only comparing dates (not times), both should be "same or before" each other
|
|
510
|
+
expect(isSameOrBefore(morningDate, eveningDate, { isUTCMode: false })).toBe(true);
|
|
511
|
+
expect(isSameOrBefore(eveningDate, morningDate, { isUTCMode: false })).toBe(true);
|
|
512
|
+
});
|
|
513
|
+
it('should handle same date with different times correctly in UTC mode', () => {
|
|
514
|
+
const morningDate = new Date(Date.UTC(2023, 5, 15, 8, 0)); // June 15, 2023, 8:00 AM UTC
|
|
515
|
+
const eveningDate = new Date(Date.UTC(2023, 5, 15, 20, 0)); // June 15, 2023, 8:00 PM UTC
|
|
516
|
+
// Since we're only comparing dates (not times), both should be "same or before" each other
|
|
517
|
+
expect(isSameOrBefore(morningDate, eveningDate, { isUTCMode: true })).toBe(true);
|
|
518
|
+
expect(isSameOrBefore(eveningDate, morningDate, { isUTCMode: true })).toBe(true);
|
|
519
|
+
});
|
|
520
|
+
it('should handle leap year dates correctly', () => {
|
|
521
|
+
const leapYearDate = new Date(2024, 1, 29); // February 29, 2024 (leap year)
|
|
522
|
+
const nonLeapYearDate = new Date(2023, 1, 28); // February 28, 2023 (non-leap year)
|
|
523
|
+
// A date in an earlier year should be "before" regardless of the month/day
|
|
524
|
+
expect(isSameOrBefore(nonLeapYearDate, leapYearDate, { isUTCMode: false })).toBe(true);
|
|
525
|
+
expect(isSameOrBefore(leapYearDate, nonLeapYearDate, { isUTCMode: false })).toBe(false);
|
|
526
|
+
});
|
|
527
|
+
it('should handle edge cases between months correctly', () => {
|
|
528
|
+
const lastDayOfMonth = new Date(2023, 5, 30); // June 30, 2023
|
|
529
|
+
const firstDayOfNextMonth = new Date(2023, 6, 1); // July 1, 2023
|
|
530
|
+
expect(isSameOrBefore(lastDayOfMonth, firstDayOfNextMonth, {
|
|
531
|
+
isUTCMode: false,
|
|
532
|
+
})).toBe(true);
|
|
533
|
+
expect(isSameOrBefore(firstDayOfNextMonth, lastDayOfMonth, {
|
|
534
|
+
isUTCMode: false,
|
|
535
|
+
})).toBe(false);
|
|
536
|
+
});
|
|
537
|
+
it('should handle null dates gracefully', () => {
|
|
538
|
+
const date = new Date(2023, 5, 15);
|
|
539
|
+
const nullDate = null;
|
|
540
|
+
// The function already has null checks, so these should return false
|
|
541
|
+
expect(isSameOrBefore(date, nullDate, { isUTCMode: false })).toBe(false);
|
|
542
|
+
expect(isSameOrBefore(nullDate, date, { isUTCMode: false })).toBe(false);
|
|
543
|
+
expect(isSameOrBefore(nullDate, nullDate, { isUTCMode: false })).toBe(false);
|
|
544
|
+
});
|
|
545
|
+
});
|
|
546
|
+
describe('formatDate', () => {
|
|
547
|
+
// Basic test for null input
|
|
548
|
+
it('should return empty string for null date', () => {
|
|
549
|
+
expect(formatDate(null, { dateFormat: 'YYYY-MM-DD' })).toBe('');
|
|
550
|
+
});
|
|
551
|
+
// ISO 8601 format
|
|
552
|
+
it('should format using toISOString() for ISO 8601 format', () => {
|
|
553
|
+
const date = new Date(2023, 5, 15, 12, 30, 45, 123); // June 15, 2023, 12:30:45.123
|
|
554
|
+
const result = formatDate(date, {
|
|
555
|
+
dateFormat: 'YYYY-MM-DD[T]HH:mm:ss[Z]',
|
|
556
|
+
});
|
|
557
|
+
expect(result).toBe(date.toISOString());
|
|
558
|
+
});
|
|
559
|
+
// Ticks format
|
|
560
|
+
it('should convert to C# ticks for "Ticks" format', () => {
|
|
561
|
+
const date = new Date(2023, 5, 15); // June 15, 2023
|
|
562
|
+
const milliseconds = date.getTime();
|
|
563
|
+
const expectedTicks = milliseconds * 10000 + 621355968000000000;
|
|
564
|
+
const result = formatDate(date, { dateFormat: 'Ticks' });
|
|
565
|
+
expect(result).toBe(expectedTicks.toString());
|
|
566
|
+
});
|
|
567
|
+
// Unix seconds format
|
|
568
|
+
it('should convert to Unix seconds for "X" format', () => {
|
|
569
|
+
const date = new Date(2023, 5, 15); // June 15, 2023
|
|
570
|
+
const unixSeconds = Math.floor(date.getTime() / 1000);
|
|
571
|
+
const result = formatDate(date, { dateFormat: 'X' });
|
|
572
|
+
expect(result).toBe(unixSeconds.toString());
|
|
573
|
+
});
|
|
574
|
+
// Unix milliseconds format
|
|
575
|
+
it('should convert to Unix milliseconds for "x" format', () => {
|
|
576
|
+
const date = new Date(2023, 5, 15); // June 15, 2023
|
|
577
|
+
const milliseconds = date.getTime();
|
|
578
|
+
const result = formatDate(date, { dateFormat: 'x' });
|
|
579
|
+
expect(result).toBe(milliseconds.toString());
|
|
580
|
+
});
|
|
581
|
+
// Standard date formats in local mode
|
|
582
|
+
it('should format date according to "YYYY-MM-DD" format in local mode', () => {
|
|
583
|
+
const date = new Date(2023, 5, 15); // June 15, 2023
|
|
584
|
+
const expected = '2023-06-15';
|
|
585
|
+
const result = formatDate(date, { dateFormat: 'YYYY-MM-DD' });
|
|
586
|
+
expect(result).toBe(expected);
|
|
587
|
+
});
|
|
588
|
+
it('should format date according to "DD/MM/YYYY" format in local mode', () => {
|
|
589
|
+
const date = new Date(2023, 5, 15); // June 15, 2023
|
|
590
|
+
const expected = '15/06/2023';
|
|
591
|
+
const result = formatDate(date, { dateFormat: 'DD/MM/YYYY' });
|
|
592
|
+
expect(result).toBe(expected);
|
|
593
|
+
});
|
|
594
|
+
it('should format date according to "MM-DD-YYYY" format in local mode', () => {
|
|
595
|
+
const date = new Date(2023, 5, 15); // June 15, 2023
|
|
596
|
+
const expected = '06-15-2023';
|
|
597
|
+
const result = formatDate(date, { dateFormat: 'MM-DD-YYYY' });
|
|
598
|
+
expect(result).toBe(expected);
|
|
599
|
+
});
|
|
600
|
+
// Date formats with time in local mode
|
|
601
|
+
it('should format date and time in local mode', () => {
|
|
602
|
+
const date = new Date(2023, 5, 15, 14, 30, 45); // June 15, 2023, 14:30:45
|
|
603
|
+
const expected = '2023-06-15 14:30:45';
|
|
604
|
+
const result = formatDate(date, { dateFormat: 'YYYY-MM-DD HH:mm:ss' });
|
|
605
|
+
expect(result).toBe(expected);
|
|
606
|
+
});
|
|
607
|
+
// Standard date formats in UTC mode
|
|
608
|
+
it('should format date according to format in UTC mode', () => {
|
|
609
|
+
const date = new Date(Date.UTC(2023, 5, 15, 14, 30, 45)); // June 15, 2023, 14:30:45 UTC
|
|
610
|
+
// When 'Z' is in the format, dayjs adds the timezone offset (+00:00)
|
|
611
|
+
const expected = '2023-06-15+00:00';
|
|
612
|
+
const result = formatDate(date, { dateFormat: 'YYYY-MM-DDZ' });
|
|
613
|
+
expect(result).toBe(expected);
|
|
614
|
+
});
|
|
615
|
+
// Date formats with time in UTC mode
|
|
616
|
+
it('should format date and time in UTC mode', () => {
|
|
617
|
+
// Create a specific date with known UTC time
|
|
618
|
+
const date = new Date(Date.UTC(2023, 5, 15, 14, 30, 45)); // June 15, 2023, 14:30:45 UTC
|
|
619
|
+
// When 'Z' is in the format, dayjs adds the timezone offset (+00:00)
|
|
620
|
+
const expected = '2023-06-15 14:30:45+00:00';
|
|
621
|
+
const result = formatDate(date, { dateFormat: 'YYYY-MM-DD HH:mm:ssZ' });
|
|
622
|
+
expect(result).toBe(expected);
|
|
623
|
+
});
|
|
624
|
+
// Test with 12-hour format
|
|
625
|
+
it('should format date with AM/PM markers', () => {
|
|
626
|
+
const morningDate = new Date(2023, 5, 15, 9, 30); // June 15, 2023, 9:30 AM
|
|
627
|
+
const eveningDate = new Date(2023, 5, 15, 21, 30); // June 15, 2023, 9:30 PM
|
|
628
|
+
const morningResult = formatDate(morningDate, { dateFormat: 'hh:mm A' });
|
|
629
|
+
const eveningResult = formatDate(eveningDate, { dateFormat: 'hh:mm A' });
|
|
630
|
+
expect(morningResult).toBe('09:30 AM');
|
|
631
|
+
expect(eveningResult).toBe('09:30 PM');
|
|
632
|
+
});
|
|
633
|
+
// Test with month name format
|
|
634
|
+
it('should format date with month names', () => {
|
|
635
|
+
const date = new Date(2023, 5, 15); // June 15, 2023
|
|
636
|
+
const resultFull = formatDate(date, { dateFormat: 'MMMM D, YYYY' });
|
|
637
|
+
const resultAbbr = formatDate(date, { dateFormat: 'MMM D, YYYY' });
|
|
638
|
+
expect(resultFull).toBe('June 15, 2023');
|
|
639
|
+
expect(resultAbbr).toBe('Jun 15, 2023');
|
|
640
|
+
});
|
|
641
|
+
// Test with day of week format
|
|
642
|
+
it('should format date with day of week', () => {
|
|
643
|
+
const date = new Date(2023, 5, 15); // June 15, 2023, was a Thursday
|
|
644
|
+
const resultFull = formatDate(date, { dateFormat: 'dddd, MMMM D, YYYY' });
|
|
645
|
+
const resultAbbr = formatDate(date, { dateFormat: 'ddd, MMM D, YYYY' });
|
|
646
|
+
expect(resultFull).toBe('Thursday, June 15, 2023');
|
|
647
|
+
expect(resultAbbr).toBe('Thu, Jun 15, 2023');
|
|
648
|
+
});
|
|
649
|
+
// Edge cases
|
|
650
|
+
it('should handle leap year dates', () => {
|
|
651
|
+
const leapYearDate = new Date(2024, 1, 29); // February 29, 2024 (leap year)
|
|
652
|
+
const result = formatDate(leapYearDate, { dateFormat: 'YYYY-MM-DD' });
|
|
653
|
+
expect(result).toBe('2024-02-29');
|
|
654
|
+
});
|
|
655
|
+
it('should handle historic dates', () => {
|
|
656
|
+
const historicDate = new Date(1776, 6, 4); // July 4, 1776
|
|
657
|
+
const result = formatDate(historicDate, { dateFormat: 'MMMM D, YYYY' });
|
|
658
|
+
expect(result).toBe('July 4, 1776');
|
|
659
|
+
});
|
|
660
|
+
it('should handle future dates', () => {
|
|
661
|
+
const futureDate = new Date(2100, 11, 31); // December 31, 2100
|
|
662
|
+
const result = formatDate(futureDate, { dateFormat: 'YYYY-MM-DD' });
|
|
663
|
+
expect(result).toBe('2100-12-31');
|
|
664
|
+
});
|
|
665
|
+
});
|
|
666
|
+
});
|
|
667
|
+
//# sourceMappingURL=nv-calendar.utils.test.js.map
|