@wisemen/datewise 0.0.1
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/README.md +307 -0
- package/dist/common/constants.d.ts +9 -0
- package/dist/common/constants.js +10 -0
- package/dist/common/constants.js.map +1 -0
- package/dist/common/date-period.enum.d.ts +7 -0
- package/dist/common/date-period.enum.js +15 -0
- package/dist/common/date-period.enum.js.map +1 -0
- package/dist/common/exhaustive-check.helper.d.ts +1 -0
- package/dist/common/exhaustive-check.helper.js +4 -0
- package/dist/common/exhaustive-check.helper.js.map +1 -0
- package/dist/common/inclusivity.d.ts +8 -0
- package/dist/common/inclusivity.js +23 -0
- package/dist/common/inclusivity.js.map +1 -0
- package/dist/common/index.d.ts +4 -0
- package/dist/common/index.js +5 -0
- package/dist/common/index.js.map +1 -0
- package/dist/common/init-dayjs.d.ts +1 -0
- package/dist/common/init-dayjs.js +31 -0
- package/dist/common/init-dayjs.js.map +1 -0
- package/dist/common/month.d.ts +15 -0
- package/dist/common/month.js +21 -0
- package/dist/common/month.js.map +1 -0
- package/dist/common/timezone.d.ts +600 -0
- package/dist/common/timezone.js +614 -0
- package/dist/common/timezone.js.map +1 -0
- package/dist/common/typeorm/adjacent-to.d.ts +5 -0
- package/dist/common/typeorm/adjacent-to.js +7 -0
- package/dist/common/typeorm/adjacent-to.js.map +1 -0
- package/dist/common/typeorm/ends-before.d.ts +5 -0
- package/dist/common/typeorm/ends-before.js +7 -0
- package/dist/common/typeorm/ends-before.js.map +1 -0
- package/dist/common/typeorm/index.d.ts +10 -0
- package/dist/common/typeorm/index.js +11 -0
- package/dist/common/typeorm/index.js.map +1 -0
- package/dist/common/typeorm/is-preceded-by.d.ts +5 -0
- package/dist/common/typeorm/is-preceded-by.js +7 -0
- package/dist/common/typeorm/is-preceded-by.js.map +1 -0
- package/dist/common/typeorm/is-succeeded-by.d.ts +5 -0
- package/dist/common/typeorm/is-succeeded-by.js +7 -0
- package/dist/common/typeorm/is-succeeded-by.js.map +1 -0
- package/dist/common/typeorm/overlaps-with.d.ts +5 -0
- package/dist/common/typeorm/overlaps-with.js +7 -0
- package/dist/common/typeorm/overlaps-with.js.map +1 -0
- package/dist/common/typeorm/precedes.d.ts +5 -0
- package/dist/common/typeorm/precedes.js +7 -0
- package/dist/common/typeorm/precedes.js.map +1 -0
- package/dist/common/typeorm/starts-after.d.ts +5 -0
- package/dist/common/typeorm/starts-after.js +7 -0
- package/dist/common/typeorm/starts-after.js.map +1 -0
- package/dist/common/typeorm/strictly-left-of.d.ts +5 -0
- package/dist/common/typeorm/strictly-left-of.js +7 -0
- package/dist/common/typeorm/strictly-left-of.js.map +1 -0
- package/dist/common/typeorm/strictly-right-of.d.ts +5 -0
- package/dist/common/typeorm/strictly-right-of.js +7 -0
- package/dist/common/typeorm/strictly-right-of.js.map +1 -0
- package/dist/common/typeorm/succeeds.d.ts +5 -0
- package/dist/common/typeorm/succeeds.js +7 -0
- package/dist/common/typeorm/succeeds.js.map +1 -0
- package/dist/date-range/date-range-errors.d.ts +9 -0
- package/dist/date-range/date-range-errors.js +17 -0
- package/dist/date-range/date-range-errors.js.map +1 -0
- package/dist/date-range/date-range.d.ts +43 -0
- package/dist/date-range/date-range.dto-builder.d.ts +8 -0
- package/dist/date-range/date-range.dto-builder.js +21 -0
- package/dist/date-range/date-range.dto-builder.js.map +1 -0
- package/dist/date-range/date-range.dto.d.ts +7 -0
- package/dist/date-range/date-range.dto.js +31 -0
- package/dist/date-range/date-range.dto.js.map +1 -0
- package/dist/date-range/date-range.js +153 -0
- package/dist/date-range/date-range.js.map +1 -0
- package/dist/date-range/date-range.response.d.ts +6 -0
- package/dist/date-range/date-range.response.js +27 -0
- package/dist/date-range/date-range.response.js.map +1 -0
- package/dist/date-range/index.d.ts +7 -0
- package/dist/date-range/index.js +8 -0
- package/dist/date-range/index.js.map +1 -0
- package/dist/date-range/is-date-range.decorator.d.ts +19 -0
- package/dist/date-range/is-date-range.decorator.js +68 -0
- package/dist/date-range/is-date-range.decorator.js.map +1 -0
- package/dist/date-range/tests/date-range.unit.test.d.ts +1 -0
- package/dist/date-range/tests/date-range.unit.test.js +412 -0
- package/dist/date-range/tests/date-range.unit.test.js.map +1 -0
- package/dist/date-range/tests/is-date-range.decorator.unit.test.d.ts +1 -0
- package/dist/date-range/tests/is-date-range.decorator.unit.test.js +120 -0
- package/dist/date-range/tests/is-date-range.decorator.unit.test.js.map +1 -0
- package/dist/date-range/typeorm/contains-plain-date.d.ts +4 -0
- package/dist/date-range/typeorm/contains-plain-date.js +8 -0
- package/dist/date-range/typeorm/contains-plain-date.js.map +1 -0
- package/dist/date-range/typeorm/date-range-column.d.ts +11 -0
- package/dist/date-range/typeorm/date-range-column.js +32 -0
- package/dist/date-range/typeorm/date-range-column.js.map +1 -0
- package/dist/date-range/typeorm/index.d.ts +2 -0
- package/dist/date-range/typeorm/index.js +3 -0
- package/dist/date-range/typeorm/index.js.map +1 -0
- package/dist/date-time-range/date-time-range.command-builder.d.ts +8 -0
- package/dist/date-time-range/date-time-range.command-builder.js +21 -0
- package/dist/date-time-range/date-time-range.command-builder.js.map +1 -0
- package/dist/date-time-range/date-time-range.command.d.ts +7 -0
- package/dist/date-time-range/date-time-range.command.js +30 -0
- package/dist/date-time-range/date-time-range.command.js.map +1 -0
- package/dist/date-time-range/date-time-range.d.ts +93 -0
- package/dist/date-time-range/date-time-range.errors.d.ts +10 -0
- package/dist/date-time-range/date-time-range.errors.js +19 -0
- package/dist/date-time-range/date-time-range.errors.js.map +1 -0
- package/dist/date-time-range/date-time-range.js +205 -0
- package/dist/date-time-range/date-time-range.js.map +1 -0
- package/dist/date-time-range/date-time-range.response.d.ts +6 -0
- package/dist/date-time-range/date-time-range.response.js +27 -0
- package/dist/date-time-range/date-time-range.response.js.map +1 -0
- package/dist/date-time-range/index.d.ts +7 -0
- package/dist/date-time-range/index.js +8 -0
- package/dist/date-time-range/index.js.map +1 -0
- package/dist/date-time-range/is-date-time-range.decorator.d.ts +15 -0
- package/dist/date-time-range/is-date-time-range.decorator.js +58 -0
- package/dist/date-time-range/is-date-time-range.decorator.js.map +1 -0
- package/dist/date-time-range/tests/date-time-range.column.integration.test.d.ts +1 -0
- package/dist/date-time-range/tests/date-time-range.column.integration.test.js +442 -0
- package/dist/date-time-range/tests/date-time-range.column.integration.test.js.map +1 -0
- package/dist/date-time-range/tests/date-time-range.unit.test.d.ts +1 -0
- package/dist/date-time-range/tests/date-time-range.unit.test.js +775 -0
- package/dist/date-time-range/tests/date-time-range.unit.test.js.map +1 -0
- package/dist/date-time-range/tests/is-date-time-range.decorator.unit.test.d.ts +1 -0
- package/dist/date-time-range/tests/is-date-time-range.decorator.unit.test.js +74 -0
- package/dist/date-time-range/tests/is-date-time-range.decorator.unit.test.js.map +1 -0
- package/dist/date-time-range/tests/sql/datasource.d.ts +2 -0
- package/dist/date-time-range/tests/sql/datasource.js +16 -0
- package/dist/date-time-range/tests/sql/datasource.js.map +1 -0
- package/dist/date-time-range/tests/sql/date-time-range-test.entity.d.ts +5 -0
- package/dist/date-time-range/tests/sql/date-time-range-test.entity.js +29 -0
- package/dist/date-time-range/tests/sql/date-time-range-test.entity.js.map +1 -0
- package/dist/date-time-range/tests/sql/multi-date-time-range-test.entity.d.ts +5 -0
- package/dist/date-time-range/tests/sql/multi-date-time-range-test.entity.js +28 -0
- package/dist/date-time-range/tests/sql/multi-date-time-range-test.entity.js.map +1 -0
- package/dist/date-time-range/typeorm/contains-timestamp.d.ts +4 -0
- package/dist/date-time-range/typeorm/contains-timestamp.js +8 -0
- package/dist/date-time-range/typeorm/contains-timestamp.js.map +1 -0
- package/dist/date-time-range/typeorm/date-time-range-column.d.ts +11 -0
- package/dist/date-time-range/typeorm/date-time-range-column.js +32 -0
- package/dist/date-time-range/typeorm/date-time-range-column.js.map +1 -0
- package/dist/date-time-range/typeorm/index.d.ts +3 -0
- package/dist/date-time-range/typeorm/index.js +4 -0
- package/dist/date-time-range/typeorm/index.js.map +1 -0
- package/dist/date-time-range/typeorm/multi-date-time-range.column.d.ts +3 -0
- package/dist/date-time-range/typeorm/multi-date-time-range.column.js +47 -0
- package/dist/date-time-range/typeorm/multi-date-time-range.column.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/multi-date-time-range/multi-date-time-range.d.ts +20 -0
- package/dist/multi-date-time-range/multi-date-time-range.js +51 -0
- package/dist/multi-date-time-range/multi-date-time-range.js.map +1 -0
- package/dist/multi-date-time-range/tests/multi-date-time-range.unit.test.d.ts +1 -0
- package/dist/multi-date-time-range/tests/multi-date-time-range.unit.test.js +129 -0
- package/dist/multi-date-time-range/tests/multi-date-time-range.unit.test.js.map +1 -0
- package/dist/plain-date/api-property/index.d.ts +1 -0
- package/dist/plain-date/api-property/index.js +2 -0
- package/dist/plain-date/api-property/index.js.map +1 -0
- package/dist/plain-date/api-property/plain-date.api-property.d.ts +2 -0
- package/dist/plain-date/api-property/plain-date.api-property.js +12 -0
- package/dist/plain-date/api-property/plain-date.api-property.js.map +1 -0
- package/dist/plain-date/dayjs-plain-date.d.ts +57 -0
- package/dist/plain-date/dayjs-plain-date.js +170 -0
- package/dist/plain-date/dayjs-plain-date.js.map +1 -0
- package/dist/plain-date/future-infinity-date.d.ts +38 -0
- package/dist/plain-date/future-infinity-date.js +100 -0
- package/dist/plain-date/future-infinity-date.js.map +1 -0
- package/dist/plain-date/index.d.ts +8 -0
- package/dist/plain-date/index.js +9 -0
- package/dist/plain-date/index.js.map +1 -0
- package/dist/plain-date/invalid-date.d.ts +5 -0
- package/dist/plain-date/invalid-date.js +8 -0
- package/dist/plain-date/invalid-date.js.map +1 -0
- package/dist/plain-date/max.d.ts +2 -0
- package/dist/plain-date/max.js +15 -0
- package/dist/plain-date/max.js.map +1 -0
- package/dist/plain-date/min.d.ts +2 -0
- package/dist/plain-date/min.js +16 -0
- package/dist/plain-date/min.js.map +1 -0
- package/dist/plain-date/past-infinity-date.d.ts +39 -0
- package/dist/plain-date/past-infinity-date.js +100 -0
- package/dist/plain-date/past-infinity-date.js.map +1 -0
- package/dist/plain-date/plain-date-object.d.ts +6 -0
- package/dist/plain-date/plain-date-object.js +2 -0
- package/dist/plain-date/plain-date-object.js.map +1 -0
- package/dist/plain-date/plain-date.d.ts +44 -0
- package/dist/plain-date/plain-date.factory.d.ts +16 -0
- package/dist/plain-date/plain-date.factory.js +41 -0
- package/dist/plain-date/plain-date.factory.js.map +1 -0
- package/dist/plain-date/plain-date.fn.d.ts +16 -0
- package/dist/plain-date/plain-date.fn.js +14 -0
- package/dist/plain-date/plain-date.fn.js.map +1 -0
- package/dist/plain-date/plain-date.js +2 -0
- package/dist/plain-date/plain-date.js.map +1 -0
- package/dist/plain-date/plain-date.units.d.ts +4 -0
- package/dist/plain-date/plain-date.units.js +2 -0
- package/dist/plain-date/plain-date.units.js.map +1 -0
- package/dist/plain-date/tests/plain-date.accessors.unit.test.d.ts +1 -0
- package/dist/plain-date/tests/plain-date.accessors.unit.test.js +22 -0
- package/dist/plain-date/tests/plain-date.accessors.unit.test.js.map +1 -0
- package/dist/plain-date/tests/plain-date.constructor.unit.test.d.ts +1 -0
- package/dist/plain-date/tests/plain-date.constructor.unit.test.js +40 -0
- package/dist/plain-date/tests/plain-date.constructor.unit.test.js.map +1 -0
- package/dist/plain-date/tests/plain-date.factory.unit.test.d.ts +1 -0
- package/dist/plain-date/tests/plain-date.factory.unit.test.js +136 -0
- package/dist/plain-date/tests/plain-date.factory.unit.test.js.map +1 -0
- package/dist/plain-date/tests/plain-date.manipulation.unit.test.d.ts +1 -0
- package/dist/plain-date/tests/plain-date.manipulation.unit.test.js +93 -0
- package/dist/plain-date/tests/plain-date.manipulation.unit.test.js.map +1 -0
- package/dist/plain-date/tests/wise-date.ordering.unit.test.d.ts +1 -0
- package/dist/plain-date/tests/wise-date.ordering.unit.test.js +174 -0
- package/dist/plain-date/tests/wise-date.ordering.unit.test.js.map +1 -0
- package/dist/plain-date/typeorm/index.d.ts +1 -0
- package/dist/plain-date/typeorm/index.js +2 -0
- package/dist/plain-date/typeorm/index.js.map +1 -0
- package/dist/plain-date/typeorm/plain-date.column.d.ts +3 -0
- package/dist/plain-date/typeorm/plain-date.column.js +24 -0
- package/dist/plain-date/typeorm/plain-date.column.js.map +1 -0
- package/dist/plain-date/validators/index.d.ts +1 -0
- package/dist/plain-date/validators/index.js +2 -0
- package/dist/plain-date/validators/index.js.map +1 -0
- package/dist/plain-date/validators/is-plain-date.validator.d.ts +7 -0
- package/dist/plain-date/validators/is-plain-date.validator.js +34 -0
- package/dist/plain-date/validators/is-plain-date.validator.js.map +1 -0
- package/dist/plain-time/api-property/index.d.ts +1 -0
- package/dist/plain-time/api-property/index.js +2 -0
- package/dist/plain-time/api-property/index.js.map +1 -0
- package/dist/plain-time/api-property/plain-time.api-property.d.ts +2 -0
- package/dist/plain-time/api-property/plain-time.api-property.js +5 -0
- package/dist/plain-time/api-property/plain-time.api-property.js.map +1 -0
- package/dist/plain-time/constants.d.ts +4 -0
- package/dist/plain-time/constants.js +5 -0
- package/dist/plain-time/constants.js.map +1 -0
- package/dist/plain-time/index.d.ts +8 -0
- package/dist/plain-time/index.js +8 -0
- package/dist/plain-time/index.js.map +1 -0
- package/dist/plain-time/is-valid-time-string.d.ts +2 -0
- package/dist/plain-time/is-valid-time-string.js +5 -0
- package/dist/plain-time/is-valid-time-string.js.map +1 -0
- package/dist/plain-time/max.d.ts +2 -0
- package/dist/plain-time/max.js +15 -0
- package/dist/plain-time/max.js.map +1 -0
- package/dist/plain-time/min.d.ts +2 -0
- package/dist/plain-time/min.js +15 -0
- package/dist/plain-time/min.js.map +1 -0
- package/dist/plain-time/plain-time-entry.d.ts +18 -0
- package/dist/plain-time/plain-time-entry.js +11 -0
- package/dist/plain-time/plain-time-entry.js.map +1 -0
- package/dist/plain-time/plain-time-error.d.ts +12 -0
- package/dist/plain-time/plain-time-error.js +19 -0
- package/dist/plain-time/plain-time-error.js.map +1 -0
- package/dist/plain-time/plain-time-object.type.d.ts +6 -0
- package/dist/plain-time/plain-time-object.type.js +2 -0
- package/dist/plain-time/plain-time-object.type.js.map +1 -0
- package/dist/plain-time/plain-time.d.ts +44 -0
- package/dist/plain-time/plain-time.factory.d.ts +12 -0
- package/dist/plain-time/plain-time.factory.js +10 -0
- package/dist/plain-time/plain-time.factory.js.map +1 -0
- package/dist/plain-time/plain-time.js +160 -0
- package/dist/plain-time/plain-time.js.map +1 -0
- package/dist/plain-time/seconds-in-unit.d.ts +11 -0
- package/dist/plain-time/seconds-in-unit.js +13 -0
- package/dist/plain-time/seconds-in-unit.js.map +1 -0
- package/dist/plain-time/tests/is-plain-time-after.validator.test.d.ts +1 -0
- package/dist/plain-time/tests/is-plain-time-after.validator.test.js +49 -0
- package/dist/plain-time/tests/is-plain-time-after.validator.test.js.map +1 -0
- package/dist/plain-time/tests/is-plain-time.validator.test.d.ts +1 -0
- package/dist/plain-time/tests/is-plain-time.validator.test.js +45 -0
- package/dist/plain-time/tests/is-plain-time.validator.test.js.map +1 -0
- package/dist/plain-time/tests/plain-time.unit.test.d.ts +1 -0
- package/dist/plain-time/tests/plain-time.unit.test.js +323 -0
- package/dist/plain-time/tests/plain-time.unit.test.js.map +1 -0
- package/dist/plain-time/time-unit.d.ts +1 -0
- package/dist/plain-time/time-unit.js +2 -0
- package/dist/plain-time/time-unit.js.map +1 -0
- package/dist/plain-time/typeorm/index.d.ts +1 -0
- package/dist/plain-time/typeorm/index.js +2 -0
- package/dist/plain-time/typeorm/index.js.map +1 -0
- package/dist/plain-time/typeorm/plain-time-column.d.ts +3 -0
- package/dist/plain-time/typeorm/plain-time-column.js +26 -0
- package/dist/plain-time/typeorm/plain-time-column.js.map +1 -0
- package/dist/plain-time/validators/index.d.ts +6 -0
- package/dist/plain-time/validators/index.js +7 -0
- package/dist/plain-time/validators/index.js.map +1 -0
- package/dist/plain-time/validators/is-plain-time-after.validator.d.ts +5 -0
- package/dist/plain-time/validators/is-plain-time-after.validator.js +47 -0
- package/dist/plain-time/validators/is-plain-time-after.validator.js.map +1 -0
- package/dist/plain-time/validators/is-plain-time-before.validator.d.ts +5 -0
- package/dist/plain-time/validators/is-plain-time-before.validator.js +47 -0
- package/dist/plain-time/validators/is-plain-time-before.validator.js.map +1 -0
- package/dist/plain-time/validators/is-plain-time-between.validator.d.ts +6 -0
- package/dist/plain-time/validators/is-plain-time-between.validator.js +52 -0
- package/dist/plain-time/validators/is-plain-time-between.validator.js.map +1 -0
- package/dist/plain-time/validators/is-plain-time-same-or-after.validator.d.ts +5 -0
- package/dist/plain-time/validators/is-plain-time-same-or-after.validator.js +47 -0
- package/dist/plain-time/validators/is-plain-time-same-or-after.validator.js.map +1 -0
- package/dist/plain-time/validators/is-plain-time-same-or-before.validator.d.ts +5 -0
- package/dist/plain-time/validators/is-plain-time-same-or-before.validator.js +47 -0
- package/dist/plain-time/validators/is-plain-time-same-or-before.validator.js.map +1 -0
- package/dist/plain-time/validators/is-plain-time.validator.d.ts +3 -0
- package/dist/plain-time/validators/is-plain-time.validator.js +7 -0
- package/dist/plain-time/validators/is-plain-time.validator.js.map +1 -0
- package/dist/rrule/frequency.d.ts +12 -0
- package/dist/rrule/frequency.js +25 -0
- package/dist/rrule/frequency.js.map +1 -0
- package/dist/rrule/index.d.ts +16 -0
- package/dist/rrule/index.js +7 -0
- package/dist/rrule/index.js.map +1 -0
- package/dist/rrule/rrule.d.ts +23 -0
- package/dist/rrule/rrule.factory.d.ts +20 -0
- package/dist/rrule/rrule.factory.js +8 -0
- package/dist/rrule/rrule.factory.js.map +1 -0
- package/dist/rrule/rrule.js +114 -0
- package/dist/rrule/rrule.js.map +1 -0
- package/dist/rrule/rrule.once.d.ts +14 -0
- package/dist/rrule/rrule.once.js +19 -0
- package/dist/rrule/rrule.once.js.map +1 -0
- package/dist/rrule/tests/rrule.once.unit.test.d.ts +1 -0
- package/dist/rrule/tests/rrule.once.unit.test.js +19 -0
- package/dist/rrule/tests/rrule.once.unit.test.js.map +1 -0
- package/dist/rrule/tests/rrule.unit.test.d.ts +1 -0
- package/dist/rrule/tests/rrule.unit.test.js +202 -0
- package/dist/rrule/tests/rrule.unit.test.js.map +1 -0
- package/dist/rrule/typeorm/index.d.ts +1 -0
- package/dist/rrule/typeorm/index.js +2 -0
- package/dist/rrule/typeorm/index.js.map +1 -0
- package/dist/rrule/typeorm/rrule-column.d.ts +2 -0
- package/dist/rrule/typeorm/rrule-column.js +6 -0
- package/dist/rrule/typeorm/rrule-column.js.map +1 -0
- package/dist/timestamp/api-property/index.d.ts +1 -0
- package/dist/timestamp/api-property/index.js +2 -0
- package/dist/timestamp/api-property/index.js.map +1 -0
- package/dist/timestamp/api-property/timestamp.api-property.d.ts +2 -0
- package/dist/timestamp/api-property/timestamp.api-property.js +12 -0
- package/dist/timestamp/api-property/timestamp.api-property.js.map +1 -0
- package/dist/timestamp/dayjs-timestamp.d.ts +59 -0
- package/dist/timestamp/dayjs-timestamp.js +205 -0
- package/dist/timestamp/dayjs-timestamp.js.map +1 -0
- package/dist/timestamp/future-infinity.d.ts +48 -0
- package/dist/timestamp/future-infinity.js +128 -0
- package/dist/timestamp/future-infinity.js.map +1 -0
- package/dist/timestamp/index.d.ts +30 -0
- package/dist/timestamp/index.js +15 -0
- package/dist/timestamp/index.js.map +1 -0
- package/dist/timestamp/max.d.ts +2 -0
- package/dist/timestamp/max.js +15 -0
- package/dist/timestamp/max.js.map +1 -0
- package/dist/timestamp/min.d.ts +2 -0
- package/dist/timestamp/min.js +15 -0
- package/dist/timestamp/min.js.map +1 -0
- package/dist/timestamp/past-infinity.d.ts +48 -0
- package/dist/timestamp/past-infinity.js +128 -0
- package/dist/timestamp/past-infinity.js.map +1 -0
- package/dist/timestamp/tests/dayjs-timestamp.unit.test.d.ts +1 -0
- package/dist/timestamp/tests/dayjs-timestamp.unit.test.js +18 -0
- package/dist/timestamp/tests/dayjs-timestamp.unit.test.js.map +1 -0
- package/dist/timestamp/tests/timestamp.factory.unit.test.d.ts +1 -0
- package/dist/timestamp/tests/timestamp.factory.unit.test.js +16 -0
- package/dist/timestamp/tests/timestamp.factory.unit.test.js.map +1 -0
- package/dist/timestamp/timestamp.d.ts +83 -0
- package/dist/timestamp/timestamp.factory.d.ts +18 -0
- package/dist/timestamp/timestamp.factory.js +36 -0
- package/dist/timestamp/timestamp.factory.js.map +1 -0
- package/dist/timestamp/timestamp.js +2 -0
- package/dist/timestamp/timestamp.js.map +1 -0
- package/dist/timestamp/typeorm/index.d.ts +1 -0
- package/dist/timestamp/typeorm/index.js +2 -0
- package/dist/timestamp/typeorm/index.js.map +1 -0
- package/dist/timestamp/typeorm/timestamp.column.d.ts +3 -0
- package/dist/timestamp/typeorm/timestamp.column.js +25 -0
- package/dist/timestamp/typeorm/timestamp.column.js.map +1 -0
- package/dist/timestamp/validators/index.d.ts +1 -0
- package/dist/timestamp/validators/index.js +2 -0
- package/dist/timestamp/validators/index.js.map +1 -0
- package/dist/timestamp/validators/is-timestamp.validator.d.ts +7 -0
- package/dist/timestamp/validators/is-timestamp.validator.js +34 -0
- package/dist/timestamp/validators/is-timestamp.validator.js.map +1 -0
- package/package.json +46 -0
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { registerDecorator, ValidatorConstraint } from 'class-validator';
|
|
8
|
+
import { plainTime } from '../plain-time-entry.js';
|
|
9
|
+
export function IsPlainTimeSameOrAfter(timeCallback, validationOptions) {
|
|
10
|
+
return function (object, propertyName) {
|
|
11
|
+
registerDecorator({
|
|
12
|
+
name: 'isPlainTimeSameOrAfter',
|
|
13
|
+
target: object.constructor,
|
|
14
|
+
propertyName,
|
|
15
|
+
constraints: [timeCallback],
|
|
16
|
+
options: validationOptions,
|
|
17
|
+
validator: IsPlainTimeSameOrAfterValidator
|
|
18
|
+
});
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
let IsPlainTimeSameOrAfterValidator = class IsPlainTimeSameOrAfterValidator {
|
|
22
|
+
validate(timeString, args) {
|
|
23
|
+
try {
|
|
24
|
+
const time = plainTime(timeString);
|
|
25
|
+
const target = args.constraints[0](args.object);
|
|
26
|
+
return time.isSameOrAfter(target);
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
defaultMessage(args) {
|
|
33
|
+
const input = args.constraints[0](args.object);
|
|
34
|
+
let target;
|
|
35
|
+
try {
|
|
36
|
+
target = plainTime(input).toString();
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
target = 'INVALID TIME INPUT';
|
|
40
|
+
}
|
|
41
|
+
return `${args.property} must be a plain time string same or after ${target}`;
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
IsPlainTimeSameOrAfterValidator = __decorate([
|
|
45
|
+
ValidatorConstraint({ name: 'isPlainTimeSameOrAfter', async: false })
|
|
46
|
+
], IsPlainTimeSameOrAfterValidator);
|
|
47
|
+
//# sourceMappingURL=is-plain-time-same-or-after.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-plain-time-same-or-after.validator.js","sourceRoot":"","sources":["../../../lib/plain-time/validators/is-plain-time-same-or-after.validator.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,iBAAiB,EAA0C,mBAAmB,EAAgC,MAAM,iBAAiB,CAAA;AAE9I,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAA;AAIlD,MAAM,UAAU,sBAAsB,CACpC,YAAoC,EACpC,iBAAqC;IAErC,OAAO,UAAU,MAAc,EAAE,YAAoB;QACnD,iBAAiB,CAAC;YAChB,IAAI,EAAE,wBAAwB;YAC9B,MAAM,EAAE,MAAM,CAAC,WAAW;YAC1B,YAAY;YACZ,WAAW,EAAE,CAAC,YAAY,CAAC;YAC3B,OAAO,EAAE,iBAAiB;YAC1B,SAAS,EAAE,+BAA+B;SAC3C,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC;AAGD,IAAM,+BAA+B,GAArC,MAAM,+BAA+B;IACnC,QAAQ,CAAE,UAAmB,EAAE,IAAyB;QACtD,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,SAAS,CAAC,UAA4B,CAAC,CAAA;YACpD,MAAM,MAAM,GAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAA4B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;YAE3E,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAA;QACnC,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAA;QACd,CAAC;IACH,CAAC;IAED,cAAc,CAAE,IAAyB;QACvC,MAAM,KAAK,GAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAA4B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAC1E,IAAI,MAAM,CAAA;QAEV,IAAI,CAAC;YACH,MAAM,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAA;QACtC,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,GAAG,oBAAoB,CAAA;QAC/B,CAAC;QAED,OAAO,GAAG,IAAI,CAAC,QAAQ,8CAA8C,MAAM,EAAE,CAAA;IAC/E,CAAC;CACF,CAAA;AAxBK,+BAA+B;IADpC,mBAAmB,CAAC,EAAE,IAAI,EAAE,wBAAwB,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;GAChE,+BAA+B,CAwBpC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ValidationOptions } from 'class-validator';
|
|
2
|
+
import { PlainTimeInput } from '../plain-time.js';
|
|
3
|
+
type PlainTimeSameOrBeforeFn = (dto: object) => PlainTimeInput;
|
|
4
|
+
export declare function IsPlainTimeSameOrBefore(timeCallback: PlainTimeSameOrBeforeFn, validationOptions?: ValidationOptions): PropertyDecorator;
|
|
5
|
+
export {};
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { registerDecorator, ValidatorConstraint } from 'class-validator';
|
|
8
|
+
import { plainTime } from '../plain-time-entry.js';
|
|
9
|
+
export function IsPlainTimeSameOrBefore(timeCallback, validationOptions) {
|
|
10
|
+
return function (object, propertyName) {
|
|
11
|
+
registerDecorator({
|
|
12
|
+
name: 'isPlainTimeSameOrBefore',
|
|
13
|
+
target: object.constructor,
|
|
14
|
+
propertyName,
|
|
15
|
+
constraints: [timeCallback],
|
|
16
|
+
options: validationOptions,
|
|
17
|
+
validator: IsPlainTimeSameOrBeforeValidator
|
|
18
|
+
});
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
let IsPlainTimeSameOrBeforeValidator = class IsPlainTimeSameOrBeforeValidator {
|
|
22
|
+
validate(timeString, args) {
|
|
23
|
+
try {
|
|
24
|
+
const time = plainTime(timeString);
|
|
25
|
+
const target = args.constraints[0](args.object);
|
|
26
|
+
return time.isSameOrBefore(target);
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
defaultMessage(args) {
|
|
33
|
+
const input = args.constraints[0](args.object);
|
|
34
|
+
let target;
|
|
35
|
+
try {
|
|
36
|
+
target = plainTime(input).toString();
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
target = 'INVALID TIME INPUT';
|
|
40
|
+
}
|
|
41
|
+
return `${args.property} must be a plain time string same or before ${target}`;
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
IsPlainTimeSameOrBeforeValidator = __decorate([
|
|
45
|
+
ValidatorConstraint({ name: 'isAfterTimeString', async: false })
|
|
46
|
+
], IsPlainTimeSameOrBeforeValidator);
|
|
47
|
+
//# sourceMappingURL=is-plain-time-same-or-before.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-plain-time-same-or-before.validator.js","sourceRoot":"","sources":["../../../lib/plain-time/validators/is-plain-time-same-or-before.validator.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,iBAAiB,EAA0C,mBAAmB,EAAgC,MAAM,iBAAiB,CAAA;AAE9I,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAA;AAIlD,MAAM,UAAU,uBAAuB,CACrC,YAAqC,EACrC,iBAAqC;IAErC,OAAO,UAAU,MAAc,EAAE,YAAoB;QACnD,iBAAiB,CAAC;YAChB,IAAI,EAAE,yBAAyB;YAC/B,MAAM,EAAE,MAAM,CAAC,WAAW;YAC1B,YAAY;YACZ,WAAW,EAAE,CAAC,YAAY,CAAC;YAC3B,OAAO,EAAE,iBAAiB;YAC1B,SAAS,EAAE,gCAAgC;SAC5C,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC;AAGD,IAAM,gCAAgC,GAAtC,MAAM,gCAAgC;IACpC,QAAQ,CAAE,UAAmB,EAAE,IAAyB;QACtD,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,SAAS,CAAC,UAA4B,CAAC,CAAA;YACpD,MAAM,MAAM,GAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAA6B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;YAE5E,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;QACpC,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAA;QACd,CAAC;IACH,CAAC;IAED,cAAc,CAAE,IAAyB;QACvC,MAAM,KAAK,GAAI,IAAI,CAAC,WAAW,CAAC,CAAC,CAA6B,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAC3E,IAAI,MAAM,CAAA;QAEV,IAAI,CAAC;YACH,MAAM,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAA;QACtC,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,GAAG,oBAAoB,CAAA;QAC/B,CAAC;QAED,OAAO,GAAG,IAAI,CAAC,QAAQ,+CAA+C,MAAM,EAAE,CAAA;IAChF,CAAC;CACF,CAAA;AAxBK,gCAAgC;IADrC,mBAAmB,CAAC,EAAE,IAAI,EAAE,mBAAmB,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;GAC3D,gCAAgC,CAwBrC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Matches } from 'class-validator';
|
|
2
|
+
import { TIME_REGEX } from '../is-valid-time-string.js';
|
|
3
|
+
/** Validate that the value is a string with format hh:mm:ss */
|
|
4
|
+
export function IsPlainTime(validationOptions) {
|
|
5
|
+
return Matches(TIME_REGEX, validationOptions);
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=is-plain-time.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-plain-time.validator.js","sourceRoot":"","sources":["../../../lib/plain-time/validators/is-plain-time.validator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAA;AAEvD,+DAA+D;AAC/D,MAAM,UAAU,WAAW,CAAE,iBAAqC;IAChE,OAAO,OAAO,CAAC,UAAU,EAAE,iBAAiB,CAAC,CAAA;AAC/C,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ApiPropertyOptions } from '@nestjs/swagger';
|
|
2
|
+
import { ColumnOptions } from 'typeorm';
|
|
3
|
+
export declare enum RRuleFrequency {
|
|
4
|
+
DAILY = "day",
|
|
5
|
+
WEEKLY = "week",
|
|
6
|
+
MONTHLY = "month",
|
|
7
|
+
YEARLY = "year"
|
|
8
|
+
}
|
|
9
|
+
export declare function RRuleFrequencyApiProperty(options?: ApiPropertyOptions): PropertyDecorator;
|
|
10
|
+
type RRuleFrequencyColumnOptions = Omit<ColumnOptions, 'type' | 'enum' | 'enumName'>;
|
|
11
|
+
export declare function RRuleFrequencyColumn(options?: RRuleFrequencyColumnOptions): PropertyDecorator;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { ApiProperty } from '@nestjs/swagger';
|
|
2
|
+
import { Column } from 'typeorm';
|
|
3
|
+
export var RRuleFrequency;
|
|
4
|
+
(function (RRuleFrequency) {
|
|
5
|
+
RRuleFrequency["DAILY"] = "day";
|
|
6
|
+
RRuleFrequency["WEEKLY"] = "week";
|
|
7
|
+
RRuleFrequency["MONTHLY"] = "month";
|
|
8
|
+
RRuleFrequency["YEARLY"] = "year";
|
|
9
|
+
})(RRuleFrequency || (RRuleFrequency = {}));
|
|
10
|
+
export function RRuleFrequencyApiProperty(options) {
|
|
11
|
+
return ApiProperty({
|
|
12
|
+
...options,
|
|
13
|
+
enum: RRuleFrequency,
|
|
14
|
+
enumName: 'RRuleFrequency'
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
export function RRuleFrequencyColumn(options) {
|
|
18
|
+
return Column({
|
|
19
|
+
...options,
|
|
20
|
+
type: 'enum',
|
|
21
|
+
enum: RRuleFrequency,
|
|
22
|
+
enumName: 'rrule_frequency'
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=frequency.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"frequency.js","sourceRoot":"","sources":["../../lib/rrule/frequency.ts"],"names":[],"mappings":"AAAA,OAAO,EAAsB,WAAW,EAAE,MAAM,iBAAiB,CAAA;AACjE,OAAO,EAAiB,MAAM,EAAE,MAAM,SAAS,CAAA;AAE/C,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,+BAAa,CAAA;IACb,iCAAe,CAAA;IACf,mCAAiB,CAAA;IACjB,iCAAe,CAAA;AACjB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB;AAED,MAAM,UAAU,yBAAyB,CAAE,OAA4B;IACrE,OAAO,WAAW,CAAC;QACjB,GAAG,OAAO;QACV,IAAI,EAAE,cAAc;QACpB,QAAQ,EAAE,gBAAgB;KAC3B,CAAC,CAAA;AACJ,CAAC;AAGD,MAAM,UAAU,oBAAoB,CAClC,OAAqC;IAErC,OAAO,MAAM,CAAC;QACZ,GAAG,OAAO;QACV,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,cAAc;QACpB,QAAQ,EAAE,iBAAiB;KAC5B,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { DateTimeRange } from '../date-time-range/date-time-range.js';
|
|
2
|
+
import { RRuleOptions } from './rrule.factory.js';
|
|
3
|
+
import { RRule } from './rrule.js';
|
|
4
|
+
import { RRuleOnceOptions } from './rrule.once.js';
|
|
5
|
+
export * from './frequency.js';
|
|
6
|
+
export * from './typeorm/index.js';
|
|
7
|
+
export { RRule } from './rrule.js';
|
|
8
|
+
export interface RRuleFn {
|
|
9
|
+
(options: null): null;
|
|
10
|
+
(options: RRuleOptions): RRule;
|
|
11
|
+
(options: RRuleOptions | null): RRule | null;
|
|
12
|
+
once(range: DateTimeRange): RRule;
|
|
13
|
+
once(options: RRuleOnceOptions): RRule;
|
|
14
|
+
once(options: DateTimeRange | RRuleOnceOptions): RRule;
|
|
15
|
+
}
|
|
16
|
+
export declare const rrule: RRuleFn;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../lib/rrule/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAgB,MAAM,oBAAoB,CAAA;AAE1D,OAAO,EAAE,IAAI,EAAoB,MAAM,iBAAiB,CAAA;AAExD,cAAc,gBAAgB,CAAA;AAC9B,cAAc,oBAAoB,CAAA;AAalC,MAAM,CAAC,MAAM,KAAK,GAAG,OAAkB,CAAA;AAEvC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Duration } from '@wisemen/quantity';
|
|
2
|
+
import { DateTimeRange } from '../date-time-range/date-time-range.js';
|
|
3
|
+
import { PlainTime } from '../plain-time/plain-time.js';
|
|
4
|
+
import { PlainDate } from '../plain-date/plain-date.js';
|
|
5
|
+
import { Timestamp } from '../timestamp/index.js';
|
|
6
|
+
import { TimezoneInput } from '../common/timezone.js';
|
|
7
|
+
import { RRuleFrequency as RRuleFrequency } from './frequency.js';
|
|
8
|
+
export type RRule = RRuleImpl;
|
|
9
|
+
export declare class RRuleImpl {
|
|
10
|
+
range: DateTimeRange;
|
|
11
|
+
timezone: TimezoneInput;
|
|
12
|
+
startDate: PlainDate;
|
|
13
|
+
startTime: PlainTime;
|
|
14
|
+
duration: Duration;
|
|
15
|
+
frequency: RRuleFrequency;
|
|
16
|
+
interval: number;
|
|
17
|
+
exceptions: Timestamp[];
|
|
18
|
+
static create(range: DateTimeRange, timezone: TimezoneInput, startDate: PlainDate, startTime: PlainTime, duration: Duration, frequency: RRuleFrequency, interval: number, exceptions: Timestamp[]): RRule;
|
|
19
|
+
/** Generate the occurrences during a given range */
|
|
20
|
+
occurrences(during?: DateTimeRange): Generator<DateTimeRange>;
|
|
21
|
+
private nextDate;
|
|
22
|
+
private isExcepted;
|
|
23
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Duration } from '@wisemen/quantity';
|
|
2
|
+
import { TimezoneInput } from '../common/timezone.js';
|
|
3
|
+
import { DateTimeRange } from '../date-time-range/date-time-range.js';
|
|
4
|
+
import { PlainDate } from '../plain-date/plain-date.js';
|
|
5
|
+
import { PlainTime } from '../plain-time/plain-time.js';
|
|
6
|
+
import { Timestamp } from '../timestamp/timestamp.js';
|
|
7
|
+
import { RRuleFrequency } from './frequency.js';
|
|
8
|
+
import { RRule } from './rrule.js';
|
|
9
|
+
export interface RRuleOptions {
|
|
10
|
+
range: DateTimeRange;
|
|
11
|
+
timezone: TimezoneInput;
|
|
12
|
+
startDate: PlainDate;
|
|
13
|
+
startTime: PlainTime;
|
|
14
|
+
duration: Duration;
|
|
15
|
+
frequency: RRuleFrequency;
|
|
16
|
+
interval: number;
|
|
17
|
+
exceptions: Timestamp[];
|
|
18
|
+
}
|
|
19
|
+
export declare function factory(options: null): null;
|
|
20
|
+
export declare function factory(options: RRuleOptions): RRule;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { RRuleImpl } from './rrule.js';
|
|
2
|
+
export function factory(options) {
|
|
3
|
+
if (options === null) {
|
|
4
|
+
return null;
|
|
5
|
+
}
|
|
6
|
+
return RRuleImpl.create(options.range, options.timezone, options.startDate, options.startTime, options.duration, options.frequency, options.interval, options.exceptions);
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=rrule.factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rrule.factory.js","sourceRoot":"","sources":["../../lib/rrule/rrule.factory.ts"],"names":[],"mappings":"AAOA,OAAO,EAAS,SAAS,EAAE,MAAM,YAAY,CAAA;AAe7C,MAAM,UAAU,OAAO,CAAE,OAA4B;IACnD,IAAI,OAAO,KAAK,IAAI,EAAE,CAAC;QACrB,OAAO,IAAI,CAAA;IACb,CAAC;IAED,OAAO,SAAS,CAAC,MAAM,CACrB,OAAO,CAAC,KAAK,EACb,OAAO,CAAC,QAAQ,EAChB,OAAO,CAAC,SAAS,EACjB,OAAO,CAAC,SAAS,EACjB,OAAO,CAAC,QAAQ,EAChB,OAAO,CAAC,SAAS,EACjB,OAAO,CAAC,QAAQ,EAChB,OAAO,CAAC,UAAU,CACnB,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
import { Duration, DurationColumn, DurationUnit } from '@wisemen/quantity';
|
|
11
|
+
import { Column } from 'typeorm';
|
|
12
|
+
import { DateTimeRange } from '../date-time-range/date-time-range.js';
|
|
13
|
+
import { timestamp, TimestampColumn } from '../timestamp/index.js';
|
|
14
|
+
import { exhaustiveCheck } from '../common/exhaustive-check.helper.js';
|
|
15
|
+
import { TimezoneColumn } from '../common/timezone.js';
|
|
16
|
+
import { DateTimeRangeColumn } from '../date-time-range/typeorm/date-time-range-column.js';
|
|
17
|
+
import { PlainDateColumn } from '../plain-date/index.js';
|
|
18
|
+
import { PlainTimeColumn } from '../plain-time/index.js';
|
|
19
|
+
import { RRuleFrequency as RRuleFrequency, RRuleFrequencyColumn } from './frequency.js';
|
|
20
|
+
export class RRuleImpl {
|
|
21
|
+
range;
|
|
22
|
+
timezone;
|
|
23
|
+
startDate;
|
|
24
|
+
startTime;
|
|
25
|
+
duration;
|
|
26
|
+
frequency;
|
|
27
|
+
interval;
|
|
28
|
+
exceptions;
|
|
29
|
+
static create(range, timezone, startDate, startTime, duration, frequency, interval, exceptions) {
|
|
30
|
+
const rrule = new RRuleImpl();
|
|
31
|
+
rrule.range = range;
|
|
32
|
+
rrule.timezone = timezone;
|
|
33
|
+
rrule.startDate = startDate;
|
|
34
|
+
rrule.startTime = startTime;
|
|
35
|
+
rrule.duration = duration;
|
|
36
|
+
rrule.frequency = frequency;
|
|
37
|
+
rrule.interval = interval;
|
|
38
|
+
rrule.exceptions = exceptions;
|
|
39
|
+
return rrule;
|
|
40
|
+
}
|
|
41
|
+
/** Generate the occurrences during a given range */
|
|
42
|
+
*occurrences(during = new DateTimeRange(-Infinity, Infinity)) {
|
|
43
|
+
if (!this.range.overlaps(during)) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
if (this.interval === 0) {
|
|
47
|
+
const occurrenceStart = timestamp(this.startDate, this.startTime, this.timezone);
|
|
48
|
+
if (!this.isExcepted(occurrenceStart)) {
|
|
49
|
+
const occurrenceEnd = occurrenceStart.addDuration(this.duration);
|
|
50
|
+
const occurrenceRange = new DateTimeRange(occurrenceStart, occurrenceEnd, '[)');
|
|
51
|
+
yield occurrenceRange;
|
|
52
|
+
}
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
const range = this.range.overlap(during);
|
|
56
|
+
const distance = Math.ceil(range.from.diff(this.range.from, this.frequency));
|
|
57
|
+
let date = this.startDate.add(distance, this.frequency);
|
|
58
|
+
let occurrenceStart = timestamp(date, this.startTime, this.timezone);
|
|
59
|
+
while (range.contains(occurrenceStart)) {
|
|
60
|
+
if (!this.isExcepted(occurrenceStart)) {
|
|
61
|
+
const occurrenceEnd = occurrenceStart.addDuration(this.duration);
|
|
62
|
+
const occurrenceRange = new DateTimeRange(occurrenceStart, occurrenceEnd, '[)');
|
|
63
|
+
yield occurrenceRange;
|
|
64
|
+
}
|
|
65
|
+
date = this.nextDate(date);
|
|
66
|
+
occurrenceStart = timestamp(date, this.startTime, this.timezone);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
nextDate(date) {
|
|
70
|
+
switch (this.frequency) {
|
|
71
|
+
case RRuleFrequency.DAILY: return date.add(this.interval, 'days');
|
|
72
|
+
case RRuleFrequency.WEEKLY: return date.add(this.interval, 'weeks');
|
|
73
|
+
case RRuleFrequency.MONTHLY: return date.add(this.interval, 'months');
|
|
74
|
+
case RRuleFrequency.YEARLY: return date.add(this.interval, 'years');
|
|
75
|
+
default: return exhaustiveCheck(this.frequency);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
isExcepted(occurrenceStart) {
|
|
79
|
+
return this.exceptions.some(ex => ex.isSame(occurrenceStart));
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
__decorate([
|
|
83
|
+
DateTimeRangeColumn(),
|
|
84
|
+
__metadata("design:type", DateTimeRange)
|
|
85
|
+
], RRuleImpl.prototype, "range", void 0);
|
|
86
|
+
__decorate([
|
|
87
|
+
TimezoneColumn(),
|
|
88
|
+
__metadata("design:type", String)
|
|
89
|
+
], RRuleImpl.prototype, "timezone", void 0);
|
|
90
|
+
__decorate([
|
|
91
|
+
PlainDateColumn(),
|
|
92
|
+
__metadata("design:type", Object)
|
|
93
|
+
], RRuleImpl.prototype, "startDate", void 0);
|
|
94
|
+
__decorate([
|
|
95
|
+
PlainTimeColumn(),
|
|
96
|
+
__metadata("design:type", Object)
|
|
97
|
+
], RRuleImpl.prototype, "startTime", void 0);
|
|
98
|
+
__decorate([
|
|
99
|
+
DurationColumn(DurationUnit.SECONDS, {}),
|
|
100
|
+
__metadata("design:type", Duration)
|
|
101
|
+
], RRuleImpl.prototype, "duration", void 0);
|
|
102
|
+
__decorate([
|
|
103
|
+
RRuleFrequencyColumn(),
|
|
104
|
+
__metadata("design:type", String)
|
|
105
|
+
], RRuleImpl.prototype, "frequency", void 0);
|
|
106
|
+
__decorate([
|
|
107
|
+
Column({ type: 'int' }),
|
|
108
|
+
__metadata("design:type", Number)
|
|
109
|
+
], RRuleImpl.prototype, "interval", void 0);
|
|
110
|
+
__decorate([
|
|
111
|
+
TimestampColumn({ array: true }),
|
|
112
|
+
__metadata("design:type", Array)
|
|
113
|
+
], RRuleImpl.prototype, "exceptions", void 0);
|
|
114
|
+
//# sourceMappingURL=rrule.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rrule.js","sourceRoot":"","sources":["../../lib/rrule/rrule.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Duration } from '@wisemen/quantity';
|
|
2
|
+
import { DateTimeRange } from '../date-time-range/date-time-range.js';
|
|
3
|
+
import { PlainDate } from '../plain-date/plain-date.js';
|
|
4
|
+
import { PlainTime } from '../plain-time/plain-time.js';
|
|
5
|
+
import { TimezoneInput } from '../common/timezone.js';
|
|
6
|
+
import { RRule } from './rrule.js';
|
|
7
|
+
export interface RRuleOnceOptions {
|
|
8
|
+
startDate: PlainDate;
|
|
9
|
+
startTime: PlainTime;
|
|
10
|
+
duration: Duration;
|
|
11
|
+
timezone: TimezoneInput;
|
|
12
|
+
}
|
|
13
|
+
export declare function once(range: DateTimeRange): RRule;
|
|
14
|
+
export declare function once(options: RRuleOnceOptions): RRule;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Duration, DurationUnit } from '@wisemen/quantity';
|
|
2
|
+
import { DateTimeRange } from '../date-time-range/date-time-range.js';
|
|
3
|
+
import { timestamp } from '../timestamp/index.js';
|
|
4
|
+
import { RRuleImpl } from './rrule.js';
|
|
5
|
+
import { RRuleFrequency } from './frequency.js';
|
|
6
|
+
export function once(options) {
|
|
7
|
+
if (options instanceof DateTimeRange) {
|
|
8
|
+
return rruleFromRange(options);
|
|
9
|
+
}
|
|
10
|
+
const start = timestamp(options.startDate, options.startTime, options.timezone);
|
|
11
|
+
const end = start.addDuration(options.duration);
|
|
12
|
+
const range = new DateTimeRange(start, end);
|
|
13
|
+
return RRuleImpl.create(range, options.timezone, options.startDate, options.startTime, options.duration, RRuleFrequency.DAILY, 0, []);
|
|
14
|
+
}
|
|
15
|
+
function rruleFromRange(range) {
|
|
16
|
+
const utcStart = range.from.setTimezone('UTC');
|
|
17
|
+
return RRuleImpl.create(range, 'UTC', utcStart.toPlainDate(), utcStart.toPlainTime(), new Duration(range.hours, DurationUnit.HOURS), RRuleFrequency.DAILY, 0, []);
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=rrule.once.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rrule.once.js","sourceRoot":"","sources":["../../lib/rrule/rrule.once.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,uCAAuC,CAAA;AAIrE,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAA;AACjD,OAAO,EAAS,SAAS,EAAE,MAAM,YAAY,CAAA;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAW/C,MAAM,UAAU,IAAI,CAAE,OAAyC;IAC7D,IAAI,OAAO,YAAY,aAAa,EAAE,CAAC;QACrC,OAAO,cAAc,CAAC,OAAO,CAAC,CAAA;IAChC,CAAC;IAED,MAAM,KAAK,GAAG,SAAS,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAA;IAC/E,MAAM,GAAG,GAAG,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IAC/C,MAAM,KAAK,GAAG,IAAI,aAAa,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;IAE3C,OAAO,SAAS,CAAC,MAAM,CACrB,KAAK,EACL,OAAO,CAAC,QAAQ,EAChB,OAAO,CAAC,SAAS,EACjB,OAAO,CAAC,SAAS,EACjB,OAAO,CAAC,QAAQ,EAChB,cAAc,CAAC,KAAK,EACpB,CAAC,EACD,EAAE,CACH,CAAA;AACH,CAAC;AAED,SAAS,cAAc,CAAE,KAAoB;IAC3C,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;IAE9C,OAAO,SAAS,CAAC,MAAM,CACrB,KAAK,EACL,KAAK,EACL,QAAQ,CAAC,WAAW,EAAE,EACtB,QAAQ,CAAC,WAAW,EAAE,EACtB,IAAI,QAAQ,CAAC,KAAK,CAAC,KAAK,EAAE,YAAY,CAAC,KAAK,CAAC,EAC7C,cAAc,CAAC,KAAK,EACpB,CAAC,EACD,EAAE,CACH,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { before, describe, it } from 'node:test';
|
|
2
|
+
import { expect } from 'expect';
|
|
3
|
+
import { initDayjs } from '../../common/init-dayjs.js';
|
|
4
|
+
import { DateTimeRange } from '../../date-time-range/date-time-range.js';
|
|
5
|
+
import { timestamp } from '../../timestamp/index.js';
|
|
6
|
+
import { rrule } from '../index.js';
|
|
7
|
+
describe('RRule once unit tests', () => {
|
|
8
|
+
before(() => {
|
|
9
|
+
initDayjs();
|
|
10
|
+
});
|
|
11
|
+
it('generates the same range from the rule as the input range', () => {
|
|
12
|
+
const range = new DateTimeRange(timestamp(), timestamp().add(8, 'hours'));
|
|
13
|
+
const rule = rrule.once(range);
|
|
14
|
+
const occurrences = Array.from(rule.occurrences());
|
|
15
|
+
expect(occurrences).toHaveLength(1);
|
|
16
|
+
expect(occurrences[0].isSame(range)).toBe(true);
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
//# sourceMappingURL=rrule.once.unit.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rrule.once.unit.test.js","sourceRoot":"","sources":["../../../lib/rrule/tests/rrule.once.unit.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,WAAW,CAAA;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAA;AACpD,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AAEnC,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,MAAM,CAAC,GAAG,EAAE;QACV,SAAS,EAAE,CAAA;IACb,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,MAAM,KAAK,GAAG,IAAI,aAAa,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAA;QACzE,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAE9B,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAA;QAElD,MAAM,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;QAEnC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACjD,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|