@activecollab/components 2.0.270 → 2.0.271
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/components/Steppers/DateStepper/DateStepper.js +31 -10
- package/dist/cjs/components/Steppers/DateStepper/DateStepper.js.map +1 -1
- package/dist/esm/components/Steppers/DateStepper/DateStepper.d.ts +2 -0
- package/dist/esm/components/Steppers/DateStepper/DateStepper.d.ts.map +1 -1
- package/dist/esm/components/Steppers/DateStepper/DateStepper.js +30 -10
- package/dist/esm/components/Steppers/DateStepper/DateStepper.js.map +1 -1
- package/dist/index.js +31 -10
- package/dist/index.js.map +1 -1
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +1 -1
- package/package.json +1 -1
|
@@ -48,7 +48,9 @@ var DateStepper = exports.DateStepper = function DateStepper(_ref) {
|
|
|
48
48
|
_ref$mode = _ref.mode,
|
|
49
49
|
mode = _ref$mode === void 0 ? "outlined" : _ref$mode,
|
|
50
50
|
_ref$alwaysShowDate = _ref.alwaysShowDate,
|
|
51
|
-
alwaysShowDate = _ref$alwaysShowDate === void 0 ? false : _ref$alwaysShowDate
|
|
51
|
+
alwaysShowDate = _ref$alwaysShowDate === void 0 ? false : _ref$alwaysShowDate,
|
|
52
|
+
_ref$disableArrows = _ref.disableArrows,
|
|
53
|
+
disableArrows = _ref$disableArrows === void 0 ? false : _ref$disableArrows;
|
|
52
54
|
var _useState = (0, _react.useState)(_momentTimezone.default.utc(from)),
|
|
53
55
|
_useState2 = _slicedToArray(_useState, 2),
|
|
54
56
|
fromDate = _useState2[0],
|
|
@@ -74,9 +76,17 @@ var DateStepper = exports.DateStepper = function DateStepper(_ref) {
|
|
|
74
76
|
} else if (step === "yearly") {
|
|
75
77
|
date.add(interval, "years");
|
|
76
78
|
return [date.clone().startOf("year"), date.clone().endOf("year")];
|
|
79
|
+
} else if (step === "range") {
|
|
80
|
+
// For range step, calculate N days based on current selection
|
|
81
|
+
var daysDiff = toDate.diff(fromDate, "days");
|
|
82
|
+
// If same day selected (daysDiff = 0), move by 1 day
|
|
83
|
+
var daysToMove = daysDiff === 0 ? 1 : daysDiff + 1;
|
|
84
|
+
var newFromDate = fromDate.clone().add(interval * daysToMove, "days");
|
|
85
|
+
var newToDate = daysDiff === 0 ? newFromDate.clone() : toDate.clone().add(interval * daysToMove, "days");
|
|
86
|
+
return [newFromDate, newToDate];
|
|
77
87
|
}
|
|
78
88
|
return [date, date];
|
|
79
|
-
}, [fromDate, period, step]);
|
|
89
|
+
}, [fromDate, toDate, period, step]);
|
|
80
90
|
var getDateFormatted = (0, _react.useMemo)(function () {
|
|
81
91
|
if (formatCallback) {
|
|
82
92
|
return formatCallback(fromDate, toDate);
|
|
@@ -105,6 +115,20 @@ var DateStepper = exports.DateStepper = function DateStepper(_ref) {
|
|
|
105
115
|
} else if (step === "yearly") {
|
|
106
116
|
return fromDate.utc().format("YYYY");
|
|
107
117
|
} else if (step === "range") {
|
|
118
|
+
// For range step, if toDate is invalid or at epoch (1970), only show fromDate
|
|
119
|
+
if (!toDate.isValid() || toDate.year() === 1970) {
|
|
120
|
+
if (fromDate.year() === actualYear) {
|
|
121
|
+
return fromDate.utc().format("MMM DD");
|
|
122
|
+
}
|
|
123
|
+
return fromDate.utc().format("MMM DD YYYY");
|
|
124
|
+
}
|
|
125
|
+
// If from and to are the same date, show only once
|
|
126
|
+
if (fromDate.format("YYYY-MM-DD") === toDate.format("YYYY-MM-DD")) {
|
|
127
|
+
if (fromDate.year() === actualYear) {
|
|
128
|
+
return fromDate.utc().format("MMM DD");
|
|
129
|
+
}
|
|
130
|
+
return fromDate.utc().format("MMM DD YYYY");
|
|
131
|
+
}
|
|
108
132
|
return showWeekOrCustomDateFormat(fromDate, toDate);
|
|
109
133
|
}
|
|
110
134
|
return "";
|
|
@@ -154,7 +178,7 @@ var DateStepper = exports.DateStepper = function DateStepper(_ref) {
|
|
|
154
178
|
setFromDate(_momentTimezone.default.utc(newFrom));
|
|
155
179
|
setToDate(_momentTimezone.default.utc(newTo));
|
|
156
180
|
if (onChange) {
|
|
157
|
-
onChange(_momentTimezone.default.utc(newFrom), _momentTimezone.default.utc(newTo));
|
|
181
|
+
onChange(_momentTimezone.default.utc(newFrom).toDate(), _momentTimezone.default.utc(newTo).toDate());
|
|
158
182
|
}
|
|
159
183
|
if (onForward) {
|
|
160
184
|
onForward(_momentTimezone.default.utc(newFrom).toDate(), _momentTimezone.default.utc(newTo).toDate());
|
|
@@ -171,15 +195,12 @@ var DateStepper = exports.DateStepper = function DateStepper(_ref) {
|
|
|
171
195
|
setFromDate(_momentTimezone.default.utc(newFrom));
|
|
172
196
|
setToDate(_momentTimezone.default.utc(newTo));
|
|
173
197
|
if (onChange) {
|
|
174
|
-
onChange(_momentTimezone.default.utc(newFrom), _momentTimezone.default.utc(newTo));
|
|
198
|
+
onChange(_momentTimezone.default.utc(newFrom).toDate(), _momentTimezone.default.utc(newTo).toDate());
|
|
175
199
|
}
|
|
176
200
|
if (onBack) {
|
|
177
201
|
onBack(_momentTimezone.default.utc(newFrom).toDate(), _momentTimezone.default.utc(newTo).toDate());
|
|
178
202
|
}
|
|
179
203
|
}, [isBeforeMinDate, getDatesByPeriod, onChange, onBack]);
|
|
180
|
-
var renderLeftRightButtons = (0, _react.useMemo)(function () {
|
|
181
|
-
return step !== "range";
|
|
182
|
-
}, [step]);
|
|
183
204
|
(0, _react.useEffect)(function () {
|
|
184
205
|
setFromDate(_momentTimezone.default.utc(from));
|
|
185
206
|
setToDate(_momentTimezone.default.utc(to));
|
|
@@ -238,14 +259,14 @@ var DateStepper = exports.DateStepper = function DateStepper(_ref) {
|
|
|
238
259
|
}, [isDisabled]);
|
|
239
260
|
return /*#__PURE__*/_react.default.createElement(_Styles.StyledButtonGroup, {
|
|
240
261
|
className: (0, _classnames.default)("c-date-stepper", className)
|
|
241
|
-
},
|
|
262
|
+
}, !disableArrows ? /*#__PURE__*/_react.default.createElement(_Styles.StyledControl, {
|
|
242
263
|
type: "button",
|
|
243
264
|
variant: mode === "flat" ? "text gray" : "secondary",
|
|
244
265
|
onClick: onLeftClickHandler,
|
|
245
266
|
disabled: isBeforeMinDate
|
|
246
267
|
}, /*#__PURE__*/_react.default.createElement(_ArrowLeft.default, null)) : null, /*#__PURE__*/_react.default.createElement(_Styles.StyledDiv, {
|
|
247
268
|
$isTargetable: step === "yearly" || !withDatePicker,
|
|
248
|
-
$isRounded:
|
|
269
|
+
$isRounded: disableArrows,
|
|
249
270
|
$mode: mode,
|
|
250
271
|
$alwaysShowDate: alwaysShowDate,
|
|
251
272
|
style: dateStepperWidth(fromDate, toDate, step)
|
|
@@ -270,7 +291,7 @@ var DateStepper = exports.DateStepper = function DateStepper(_ref) {
|
|
|
270
291
|
key: datePickerMode,
|
|
271
292
|
instant: true,
|
|
272
293
|
required: true
|
|
273
|
-
}) : /*#__PURE__*/_react.default.createElement(_Styles.StyledSpan, null, getDateFormatted)),
|
|
294
|
+
}) : /*#__PURE__*/_react.default.createElement(_Styles.StyledSpan, null, getDateFormatted)), !disableArrows ? /*#__PURE__*/_react.default.createElement(_Styles.StyledControl, {
|
|
274
295
|
type: "button",
|
|
275
296
|
variant: mode === "flat" ? "text gray" : "secondary",
|
|
276
297
|
onClick: onRightClickHandler,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DateStepper.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_momentTimezone","_Styles","_DatePicker","_Icons","_ArrowLeft","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_slicedToArray","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","a","_arrayLikeToArray","toString","slice","constructor","name","Array","from","test","length","l","Symbol","iterator","u","next","done","push","value","return","isArray","DateStepper","exports","_ref","step","formatCallback","onChange","to","onBack","onForward","minValue","maxValue","className","_ref$period","period","_ref$withDatePicker","withDatePicker","_ref$defaultMonth","defaultMonth","moment","enableYearPicker","_ref$position","position","popperClassName","_ref$mode","mode","_ref$alwaysShowDate","alwaysShowDate","_useState","useState","utc","_useState2","fromDate","setFromDate","_useState3","_useState4","toDate","setToDate","getDatesByPeriod","useCallback","interval","date","add","clone","startOf","endOf","getDateFormatted","useMemo","actualYear","year","showWeekOrCustomDateFormat","start","end","format","startDate","endDate","concat","quarter","datePickerMode","onDatePickerChange","dates","fromDateTemp","Number","toDateTemp","isMoment","isAfterMaxDate","isSameOrBefore","isBeforeMinDate","isSameOrAfter","useEffect","onRightClickHandler","_getDatesByPeriod","_getDatesByPeriod2","newFrom","newTo","onLeftClickHandler","_getDatesByPeriod3","_getDatesByPeriod4","renderLeftRightButtons","dateStepperWidth","fromDay","toDay","range","minWidth","isDisabled","day","dayFormat","isBefore","isAfter","modifiers","disabled","matched","title","nonWorkingDay","createElement","StyledButtonGroup","classNames","StyledControl","type","variant","onClick","StyledDiv","$isTargetable","$isRounded","$mode","$alwaysShowDate","style","DatePicker","month","target","StyledButton","selected","unix","firstDayOfWeek","disabledDaysAfter","disabledDaysBefore","disableYearPicker","key","instant","required","StyledSpan","ArrowRightIcon","displayName"],"sources":["../../../../../src/components/Steppers/DateStepper/DateStepper.tsx"],"sourcesContent":["import React, { FC, useCallback, useMemo, useState, useEffect } from \"react\";\n\nimport { Placement } from \"@popperjs/core\";\nimport classNames from \"classnames\";\nimport { Moment } from \"moment\";\nimport moment from \"moment-timezone\";\n\nimport {\n StyledButton,\n StyledButtonGroup,\n StyledDiv,\n StyledSpan,\n StyledControl,\n} from \"./Styles\";\nimport { DatePicker, TimestampDateRange } from \"../../DatePicker/DatePicker\";\nimport { ArrowRightIcon } from \"../../Icons\";\nimport ArrowLeftIcon from \"../../Icons/collection/ArrowLeft\";\nimport { InputMode } from \"../../Input/types\";\n\nexport interface IDateStepperProps {\n /** One of the possible steps for this component */\n step: \"daily\" | \"weekly\" | \"monthly\" | \"quarterly\" | \"yearly\" | \"range\";\n /** Callback function that will be called after the changed range */\n onChange?: (from: Date, to: Date) => void;\n /** Start date of the range */\n from: Moment | string;\n /** End date of the range */\n to: Moment | string;\n /** Callback function that will format the text label */\n formatCallback?: (from: string | Moment, to: string | Moment) => string;\n /** Default month */\n defaultMonth?: Moment;\n /** Callback function onBack */\n onBack?: (from: Date, to: Date) => void;\n /** Callback function onForward */\n onForward?: (from: Date, to: Date) => void;\n /** Min date */\n minValue?: Moment;\n /** Max fate */\n maxValue?: Moment;\n /** html class */\n className?: string;\n /** Period for calculating week (isoWeek) */\n period?: \"week\" | \"isoWeek\";\n /** Classes for datePicker */\n datePickerClass?: string;\n /** Show datePicker in the middle button */\n withDatePicker?: boolean;\n /** Popper class name*/\n popperClassName?: string;\n /** DatePicker menu position */\n position?: Placement;\n /** Enable year picker in DatePicker */\n enableYearPicker?: boolean;\n /** conditional border & button variant styles */\n mode?: InputMode;\n /** preserve date on smaller screens */\n alwaysShowDate?: boolean;\n}\n\n/**\n * This component allow you to select date range. It accepts two parameters \"from\" and \"to\" as valid format\n * onChange and onBack and onForward it will return \"from: Date\" and \"to: Date\" as function arguments\n */\n\nexport const DateStepper: FC<IDateStepperProps> = ({\n step,\n formatCallback,\n onChange,\n from,\n to,\n onBack,\n onForward,\n minValue,\n maxValue,\n className,\n period = \"week\",\n withDatePicker = true,\n defaultMonth = moment(),\n enableYearPicker,\n position = \"bottom\",\n popperClassName,\n mode = \"outlined\",\n alwaysShowDate = false,\n}) => {\n const [fromDate, setFromDate] = useState<Moment>(moment.utc(from));\n const [toDate, setToDate] = useState<Moment>(moment.utc(to));\n\n const getDatesByPeriod = useCallback(\n (interval: number): Moment[] => {\n const date = fromDate ? fromDate : moment();\n if (step === \"daily\") {\n date.add(interval, \"days\");\n return [date, date.clone()];\n } else if (step === \"weekly\") {\n date.add(interval, \"weeks\");\n return [date.clone().startOf(period), date.clone().endOf(period)];\n } else if (step === \"monthly\") {\n date.add(interval, \"months\");\n return [date.clone().startOf(\"month\"), date.clone().endOf(\"month\")];\n } else if (step === \"quarterly\") {\n date.add(interval, \"quarters\");\n return [date.clone().startOf(\"quarter\"), date.clone().endOf(\"quarter\")];\n } else if (step === \"yearly\") {\n date.add(interval, \"years\");\n return [date.clone().startOf(\"year\"), date.clone().endOf(\"year\")];\n }\n return [date, date];\n },\n [fromDate, period, step]\n );\n\n const getDateFormatted = useMemo(() => {\n if (formatCallback) {\n return formatCallback(fromDate, toDate);\n }\n\n const actualYear = moment().year();\n\n const showWeekOrCustomDateFormat = (start, end): string => {\n if (start.year() === actualYear && end.year() === actualYear) {\n return (\n start.utc().format(\"MMM DD\") + \" - \" + end.utc().format(\"MMM DD\")\n );\n } else {\n return (\n start.utc().format(\"MMM DD YYYY\") +\n \" - \" +\n end.utc().format(\"MMM DD YYYY\")\n );\n }\n };\n\n if (step === \"daily\") {\n if (fromDate.year() === actualYear) {\n return fromDate.utc().format(\"MMM DD\");\n }\n return fromDate.utc().format(\"MMM DD YYYY\");\n } else if (step === \"weekly\") {\n const startDate = fromDate.clone().utc().startOf(period);\n const endDate = startDate.clone().utc().endOf(period);\n return showWeekOrCustomDateFormat(startDate, endDate);\n } else if (step === \"monthly\") {\n return fromDate.utc().format(\"MMM YYYY\");\n } else if (step === \"quarterly\") {\n return `Q${fromDate.utc().quarter()}/${fromDate.utc().format(\"YYYY\")}`;\n } else if (step === \"yearly\") {\n return fromDate.utc().format(\"YYYY\");\n } else if (step === \"range\") {\n return showWeekOrCustomDateFormat(fromDate, toDate);\n }\n\n return \"\";\n }, [fromDate, toDate, step, formatCallback, period]);\n\n const datePickerMode = useMemo(() => {\n if (step === \"range\") return \"custom\";\n if (step === \"yearly\") return \"custom\";\n return step;\n }, [step]);\n\n const onDatePickerChange = useCallback(\n (dates?: TimestampDateRange) => {\n const fromDateTemp: Moment = moment.utc(Number(dates?.from) * 1000);\n const toDateTemp: Moment = moment.utc(Number(dates?.to) * 1000);\n\n setFromDate(fromDateTemp);\n setToDate(toDateTemp);\n\n if (\n onChange &&\n moment.isMoment(fromDateTemp) &&\n moment.isMoment(toDateTemp)\n ) {\n onChange(fromDateTemp.toDate(), toDateTemp.toDate());\n }\n },\n [onChange, setFromDate, setToDate]\n );\n\n const isAfterMaxDate = useMemo(() => {\n return (\n moment.isMoment(maxValue) &&\n moment(moment.utc(maxValue).format(\"YYYY-MM-DD\")).isSameOrBefore(\n toDate.utc().format(\"YYYY-MM-DD\")\n )\n );\n }, [maxValue, toDate]);\n\n const isBeforeMinDate = useMemo(() => {\n return (\n moment.isMoment(minValue) &&\n moment\n .utc(moment.utc(minValue).format(\"YYYY-MM-DD\"))\n .isSameOrAfter(toDate.utc().format(\"YYYY-MM-DD\"))\n );\n }, [minValue, toDate]);\n\n useEffect(() => {\n if (isBeforeMinDate) {\n if (step === \"daily\") {\n setFromDate(moment.utc(minValue));\n setToDate(moment.utc(minValue));\n }\n }\n if (isAfterMaxDate) {\n if (step === \"daily\") {\n setFromDate(moment.utc(maxValue));\n setToDate(moment.utc(maxValue));\n }\n }\n }, [step, minValue, maxValue, isBeforeMinDate, isAfterMaxDate]);\n\n const onRightClickHandler = useCallback(() => {\n if (isAfterMaxDate) {\n return;\n }\n\n const [newFrom, newTo] = getDatesByPeriod(1);\n setFromDate(moment.utc(newFrom));\n setToDate(moment.utc(newTo));\n\n if (onChange) {\n onChange(moment.utc(newFrom), moment.utc(newTo));\n }\n\n if (onForward) {\n onForward(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n }, [isAfterMaxDate, getDatesByPeriod, onChange, onForward]);\n\n const onLeftClickHandler = useCallback(() => {\n if (isBeforeMinDate) {\n return;\n }\n\n const [newFrom, newTo] = getDatesByPeriod(-1);\n setFromDate(moment.utc(newFrom));\n setToDate(moment.utc(newTo));\n\n if (onChange) {\n onChange(moment.utc(newFrom), moment.utc(newTo));\n }\n if (onBack) {\n onBack(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n }, [isBeforeMinDate, getDatesByPeriod, onChange, onBack]);\n\n const renderLeftRightButtons = useMemo(() => {\n return step !== \"range\";\n }, [step]);\n\n useEffect(() => {\n setFromDate(moment.utc(from));\n setToDate(moment.utc(to));\n }, [from, to]);\n\n const dateStepperWidth = (\n fromDay: Moment,\n toDay: Moment,\n range: string\n ): { minWidth: string } => {\n if (\n fromDay.utc().year() !== moment.utc().year() ||\n toDay.utc().year() !== moment.utc().year()\n ) {\n switch (range) {\n case \"daily\":\n case \"monthly\":\n return { minWidth: \"122px\" };\n case \"weekly\":\n case \"custom\":\n return { minWidth: \"232px\" };\n }\n }\n switch (range) {\n case \"monthly\":\n return { minWidth: \"122px\" };\n case \"weekly\":\n case \"custom\":\n return { minWidth: \"182px\" };\n }\n\n return { minWidth: \"102px\" };\n };\n const isDisabled = useCallback(\n (day: Moment): boolean => {\n const dayFormat = moment.utc(day).format(\"YYYY-MM-DD\");\n\n const isBefore =\n moment.isMoment(maxValue) &&\n moment(moment.utc(maxValue).format(\"YYYY-MM-DD\")).isBefore(dayFormat);\n const isAfter =\n moment.isMoment(minValue) &&\n moment(moment.utc(minValue).format(\"YYYY-MM-DD\")).isAfter(dayFormat);\n\n return isBefore || isAfter;\n },\n [maxValue, minValue]\n );\n\n const modifiers = useMemo(\n () => ({\n disabled: (day: Moment) => ({ matched: isDisabled(day), title: null }),\n nonWorkingDay: (day: Moment) => ({\n matched: isDisabled(day),\n title: null,\n }),\n }),\n [isDisabled]\n );\n\n return (\n <StyledButtonGroup className={classNames(\"c-date-stepper\", className)}>\n {renderLeftRightButtons ? (\n <StyledControl\n type=\"button\"\n variant={mode === \"flat\" ? \"text gray\" : \"secondary\"}\n onClick={onLeftClickHandler}\n disabled={isBeforeMinDate}\n >\n <ArrowLeftIcon />\n </StyledControl>\n ) : null}\n <StyledDiv\n $isTargetable={step === \"yearly\" || !withDatePicker}\n $isRounded={step === \"range\"}\n $mode={mode}\n $alwaysShowDate={alwaysShowDate}\n style={dateStepperWidth(fromDate, toDate, step)}\n >\n {withDatePicker && step !== \"yearly\" ? (\n <DatePicker\n month={defaultMonth}\n target={\n <StyledButton type=\"button\">{getDateFormatted}</StyledButton>\n }\n mode={datePickerMode}\n selected={{\n from: moment.utc(fromDate).unix(),\n to: moment.utc(toDate).unix(),\n }}\n onChange={onDatePickerChange}\n firstDayOfWeek={period === \"week\" ? 0 : 1}\n modifiers={modifiers}\n disabledDaysAfter={maxValue}\n disabledDaysBefore={minValue}\n disableYearPicker={!enableYearPicker}\n popperClassName={popperClassName}\n position={position}\n key={datePickerMode}\n instant\n required\n />\n ) : (\n <StyledSpan>{getDateFormatted}</StyledSpan>\n )}\n </StyledDiv>\n {renderLeftRightButtons ? (\n <StyledControl\n type=\"button\"\n variant={mode === \"flat\" ? \"text gray\" : \"secondary\"}\n onClick={onRightClickHandler}\n disabled={isAfterMaxDate}\n >\n <ArrowRightIcon />\n </StyledControl>\n ) : null}\n </StyledButtonGroup>\n );\n};\n\nDateStepper.displayName = \"DateStepper\";\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"DateStepper.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_momentTimezone","_Styles","_DatePicker","_Icons","_ArrowLeft","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","_t","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_slicedToArray","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","a","_arrayLikeToArray","toString","slice","constructor","name","Array","from","test","length","l","Symbol","iterator","u","next","done","push","value","return","isArray","DateStepper","exports","_ref","step","formatCallback","onChange","to","onBack","onForward","minValue","maxValue","className","_ref$period","period","_ref$withDatePicker","withDatePicker","_ref$defaultMonth","defaultMonth","moment","enableYearPicker","_ref$position","position","popperClassName","_ref$mode","mode","_ref$alwaysShowDate","alwaysShowDate","_ref$disableArrows","disableArrows","_useState","useState","utc","_useState2","fromDate","setFromDate","_useState3","_useState4","toDate","setToDate","getDatesByPeriod","useCallback","interval","date","add","clone","startOf","endOf","daysDiff","diff","daysToMove","newFromDate","newToDate","getDateFormatted","useMemo","actualYear","year","showWeekOrCustomDateFormat","start","end","format","startDate","endDate","concat","quarter","isValid","datePickerMode","onDatePickerChange","dates","fromDateTemp","Number","toDateTemp","isMoment","isAfterMaxDate","isSameOrBefore","isBeforeMinDate","isSameOrAfter","useEffect","onRightClickHandler","_getDatesByPeriod","_getDatesByPeriod2","newFrom","newTo","onLeftClickHandler","_getDatesByPeriod3","_getDatesByPeriod4","dateStepperWidth","fromDay","toDay","range","minWidth","isDisabled","day","dayFormat","isBefore","isAfter","modifiers","disabled","matched","title","nonWorkingDay","createElement","StyledButtonGroup","classNames","StyledControl","type","variant","onClick","StyledDiv","$isTargetable","$isRounded","$mode","$alwaysShowDate","style","DatePicker","month","target","StyledButton","selected","unix","firstDayOfWeek","disabledDaysAfter","disabledDaysBefore","disableYearPicker","key","instant","required","StyledSpan","ArrowRightIcon","displayName"],"sources":["../../../../../src/components/Steppers/DateStepper/DateStepper.tsx"],"sourcesContent":["import React, { FC, useCallback, useMemo, useState, useEffect } from \"react\";\n\nimport { Placement } from \"@popperjs/core\";\nimport classNames from \"classnames\";\nimport { Moment } from \"moment\";\nimport moment from \"moment-timezone\";\n\nimport {\n StyledButton,\n StyledButtonGroup,\n StyledDiv,\n StyledSpan,\n StyledControl,\n} from \"./Styles\";\nimport { DatePicker, TimestampDateRange } from \"../../DatePicker/DatePicker\";\nimport { ArrowRightIcon } from \"../../Icons\";\nimport ArrowLeftIcon from \"../../Icons/collection/ArrowLeft\";\nimport { InputMode } from \"../../Input/types\";\n\nexport interface IDateStepperProps {\n /** One of the possible steps for this component */\n step: \"daily\" | \"weekly\" | \"monthly\" | \"quarterly\" | \"yearly\" | \"range\";\n /** Callback function that will be called after the changed range */\n onChange?: (from: Date, to: Date) => void;\n /** Start date of the range */\n from: Moment | string;\n /** End date of the range */\n to: Moment | string;\n /** Callback function that will format the text label */\n formatCallback?: (from: string | Moment, to: string | Moment) => string;\n /** Default month */\n defaultMonth?: Moment;\n /** Callback function onBack */\n onBack?: (from: Date, to: Date) => void;\n /** Callback function onForward */\n onForward?: (from: Date, to: Date) => void;\n /** Min date */\n minValue?: Moment;\n /** Max fate */\n maxValue?: Moment;\n /** html class */\n className?: string;\n /** Period for calculating week (isoWeek) */\n period?: \"week\" | \"isoWeek\";\n /** Classes for datePicker */\n datePickerClass?: string;\n /** Show datePicker in the middle button */\n withDatePicker?: boolean;\n /** Popper class name*/\n popperClassName?: string;\n /** DatePicker menu position */\n position?: Placement;\n /** Enable year picker in DatePicker */\n enableYearPicker?: boolean;\n /** conditional border & button variant styles */\n mode?: InputMode;\n /** preserve date on smaller screens */\n alwaysShowDate?: boolean;\n /** Hide navigation arrows */\n disableArrows?: boolean;\n}\n\n/**\n * This component allow you to select date range. It accepts two parameters \"from\" and \"to\" as valid format\n * onChange and onBack and onForward it will return \"from: Date\" and \"to: Date\" as function arguments\n */\n\nexport const DateStepper: FC<IDateStepperProps> = ({\n step,\n formatCallback,\n onChange,\n from,\n to,\n onBack,\n onForward,\n minValue,\n maxValue,\n className,\n period = \"week\",\n withDatePicker = true,\n defaultMonth = moment(),\n enableYearPicker,\n position = \"bottom\",\n popperClassName,\n mode = \"outlined\",\n alwaysShowDate = false,\n disableArrows = false,\n}) => {\n const [fromDate, setFromDate] = useState<Moment>(moment.utc(from));\n const [toDate, setToDate] = useState<Moment>(moment.utc(to));\n\n const getDatesByPeriod = useCallback(\n (interval: number): Moment[] => {\n const date = fromDate ? fromDate : moment();\n if (step === \"daily\") {\n date.add(interval, \"days\");\n return [date, date.clone()];\n } else if (step === \"weekly\") {\n date.add(interval, \"weeks\");\n return [date.clone().startOf(period), date.clone().endOf(period)];\n } else if (step === \"monthly\") {\n date.add(interval, \"months\");\n return [date.clone().startOf(\"month\"), date.clone().endOf(\"month\")];\n } else if (step === \"quarterly\") {\n date.add(interval, \"quarters\");\n return [date.clone().startOf(\"quarter\"), date.clone().endOf(\"quarter\")];\n } else if (step === \"yearly\") {\n date.add(interval, \"years\");\n return [date.clone().startOf(\"year\"), date.clone().endOf(\"year\")];\n } else if (step === \"range\") {\n // For range step, calculate N days based on current selection\n const daysDiff = toDate.diff(fromDate, \"days\");\n // If same day selected (daysDiff = 0), move by 1 day\n const daysToMove = daysDiff === 0 ? 1 : daysDiff + 1;\n const newFromDate = fromDate.clone().add(interval * daysToMove, \"days\");\n const newToDate =\n daysDiff === 0\n ? newFromDate.clone()\n : toDate.clone().add(interval * daysToMove, \"days\");\n return [newFromDate, newToDate];\n }\n return [date, date];\n },\n [fromDate, toDate, period, step]\n );\n\n const getDateFormatted = useMemo(() => {\n if (formatCallback) {\n return formatCallback(fromDate, toDate);\n }\n\n const actualYear = moment().year();\n\n const showWeekOrCustomDateFormat = (start, end): string => {\n if (start.year() === actualYear && end.year() === actualYear) {\n return (\n start.utc().format(\"MMM DD\") + \" - \" + end.utc().format(\"MMM DD\")\n );\n } else {\n return (\n start.utc().format(\"MMM DD YYYY\") +\n \" - \" +\n end.utc().format(\"MMM DD YYYY\")\n );\n }\n };\n\n if (step === \"daily\") {\n if (fromDate.year() === actualYear) {\n return fromDate.utc().format(\"MMM DD\");\n }\n return fromDate.utc().format(\"MMM DD YYYY\");\n } else if (step === \"weekly\") {\n const startDate = fromDate.clone().utc().startOf(period);\n const endDate = startDate.clone().utc().endOf(period);\n return showWeekOrCustomDateFormat(startDate, endDate);\n } else if (step === \"monthly\") {\n return fromDate.utc().format(\"MMM YYYY\");\n } else if (step === \"quarterly\") {\n return `Q${fromDate.utc().quarter()}/${fromDate.utc().format(\"YYYY\")}`;\n } else if (step === \"yearly\") {\n return fromDate.utc().format(\"YYYY\");\n } else if (step === \"range\") {\n // For range step, if toDate is invalid or at epoch (1970), only show fromDate\n if (!toDate.isValid() || toDate.year() === 1970) {\n if (fromDate.year() === actualYear) {\n return fromDate.utc().format(\"MMM DD\");\n }\n return fromDate.utc().format(\"MMM DD YYYY\");\n }\n // If from and to are the same date, show only once\n if (fromDate.format(\"YYYY-MM-DD\") === toDate.format(\"YYYY-MM-DD\")) {\n if (fromDate.year() === actualYear) {\n return fromDate.utc().format(\"MMM DD\");\n }\n return fromDate.utc().format(\"MMM DD YYYY\");\n }\n return showWeekOrCustomDateFormat(fromDate, toDate);\n }\n\n return \"\";\n }, [fromDate, toDate, step, formatCallback, period]);\n\n const datePickerMode = useMemo(() => {\n if (step === \"range\") return \"custom\";\n if (step === \"yearly\") return \"custom\";\n return step;\n }, [step]);\n\n const onDatePickerChange = useCallback(\n (dates?: TimestampDateRange) => {\n const fromDateTemp: Moment = moment.utc(Number(dates?.from) * 1000);\n const toDateTemp: Moment = moment.utc(Number(dates?.to) * 1000);\n\n setFromDate(fromDateTemp);\n setToDate(toDateTemp);\n\n if (\n onChange &&\n moment.isMoment(fromDateTemp) &&\n moment.isMoment(toDateTemp)\n ) {\n onChange(fromDateTemp.toDate(), toDateTemp.toDate());\n }\n },\n [onChange, setFromDate, setToDate]\n );\n\n const isAfterMaxDate = useMemo(() => {\n return (\n moment.isMoment(maxValue) &&\n moment(moment.utc(maxValue).format(\"YYYY-MM-DD\")).isSameOrBefore(\n toDate.utc().format(\"YYYY-MM-DD\")\n )\n );\n }, [maxValue, toDate]);\n\n const isBeforeMinDate = useMemo(() => {\n return (\n moment.isMoment(minValue) &&\n moment\n .utc(moment.utc(minValue).format(\"YYYY-MM-DD\"))\n .isSameOrAfter(toDate.utc().format(\"YYYY-MM-DD\"))\n );\n }, [minValue, toDate]);\n\n useEffect(() => {\n if (isBeforeMinDate) {\n if (step === \"daily\") {\n setFromDate(moment.utc(minValue));\n setToDate(moment.utc(minValue));\n }\n }\n if (isAfterMaxDate) {\n if (step === \"daily\") {\n setFromDate(moment.utc(maxValue));\n setToDate(moment.utc(maxValue));\n }\n }\n }, [step, minValue, maxValue, isBeforeMinDate, isAfterMaxDate]);\n\n const onRightClickHandler = useCallback(() => {\n if (isAfterMaxDate) {\n return;\n }\n\n const [newFrom, newTo] = getDatesByPeriod(1);\n setFromDate(moment.utc(newFrom));\n setToDate(moment.utc(newTo));\n\n if (onChange) {\n onChange(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n\n if (onForward) {\n onForward(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n }, [isAfterMaxDate, getDatesByPeriod, onChange, onForward]);\n\n const onLeftClickHandler = useCallback(() => {\n if (isBeforeMinDate) {\n return;\n }\n\n const [newFrom, newTo] = getDatesByPeriod(-1);\n setFromDate(moment.utc(newFrom));\n setToDate(moment.utc(newTo));\n\n if (onChange) {\n onChange(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n if (onBack) {\n onBack(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n }, [isBeforeMinDate, getDatesByPeriod, onChange, onBack]);\n\n useEffect(() => {\n setFromDate(moment.utc(from));\n setToDate(moment.utc(to));\n }, [from, to]);\n\n const dateStepperWidth = (\n fromDay: Moment,\n toDay: Moment,\n range: string\n ): { minWidth: string } => {\n if (\n fromDay.utc().year() !== moment.utc().year() ||\n toDay.utc().year() !== moment.utc().year()\n ) {\n switch (range) {\n case \"daily\":\n case \"monthly\":\n return { minWidth: \"122px\" };\n case \"weekly\":\n case \"custom\":\n return { minWidth: \"232px\" };\n }\n }\n switch (range) {\n case \"monthly\":\n return { minWidth: \"122px\" };\n case \"weekly\":\n case \"custom\":\n return { minWidth: \"182px\" };\n }\n\n return { minWidth: \"102px\" };\n };\n const isDisabled = useCallback(\n (day: Moment): boolean => {\n const dayFormat = moment.utc(day).format(\"YYYY-MM-DD\");\n\n const isBefore =\n moment.isMoment(maxValue) &&\n moment(moment.utc(maxValue).format(\"YYYY-MM-DD\")).isBefore(dayFormat);\n const isAfter =\n moment.isMoment(minValue) &&\n moment(moment.utc(minValue).format(\"YYYY-MM-DD\")).isAfter(dayFormat);\n\n return isBefore || isAfter;\n },\n [maxValue, minValue]\n );\n\n const modifiers = useMemo(\n () => ({\n disabled: (day: Moment) => ({ matched: isDisabled(day), title: null }),\n nonWorkingDay: (day: Moment) => ({\n matched: isDisabled(day),\n title: null,\n }),\n }),\n [isDisabled]\n );\n\n return (\n <StyledButtonGroup className={classNames(\"c-date-stepper\", className)}>\n {!disableArrows ? (\n <StyledControl\n type=\"button\"\n variant={mode === \"flat\" ? \"text gray\" : \"secondary\"}\n onClick={onLeftClickHandler}\n disabled={isBeforeMinDate}\n >\n <ArrowLeftIcon />\n </StyledControl>\n ) : null}\n <StyledDiv\n $isTargetable={step === \"yearly\" || !withDatePicker}\n $isRounded={disableArrows}\n $mode={mode}\n $alwaysShowDate={alwaysShowDate}\n style={dateStepperWidth(fromDate, toDate, step)}\n >\n {withDatePicker && step !== \"yearly\" ? (\n <DatePicker\n month={defaultMonth}\n target={\n <StyledButton type=\"button\">{getDateFormatted}</StyledButton>\n }\n mode={datePickerMode}\n selected={{\n from: moment.utc(fromDate).unix(),\n to: moment.utc(toDate).unix(),\n }}\n onChange={onDatePickerChange}\n firstDayOfWeek={period === \"week\" ? 0 : 1}\n modifiers={modifiers}\n disabledDaysAfter={maxValue}\n disabledDaysBefore={minValue}\n disableYearPicker={!enableYearPicker}\n popperClassName={popperClassName}\n position={position}\n key={datePickerMode}\n instant\n required\n />\n ) : (\n <StyledSpan>{getDateFormatted}</StyledSpan>\n )}\n </StyledDiv>\n {!disableArrows ? (\n <StyledControl\n type=\"button\"\n variant={mode === \"flat\" ? \"text gray\" : \"secondary\"}\n onClick={onRightClickHandler}\n disabled={isAfterMaxDate}\n >\n <ArrowRightIcon />\n </StyledControl>\n ) : null}\n </StyledButtonGroup>\n );\n};\n\nDateStepper.displayName = \"DateStepper\";\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -41,6 +41,8 @@ export interface IDateStepperProps {
|
|
|
41
41
|
mode?: InputMode;
|
|
42
42
|
/** preserve date on smaller screens */
|
|
43
43
|
alwaysShowDate?: boolean;
|
|
44
|
+
/** Hide navigation arrows */
|
|
45
|
+
disableArrows?: boolean;
|
|
44
46
|
}
|
|
45
47
|
/**
|
|
46
48
|
* This component allow you to select date range. It accepts two parameters "from" and "to" as valid format
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DateStepper.d.ts","sourceRoot":"","sources":["../../../../../src/components/Steppers/DateStepper/DateStepper.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,EAAE,EAA6C,MAAM,OAAO,CAAC;AAE7E,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAahC,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,MAAM,WAAW,iBAAiB;IAChC,mDAAmD;IACnD,IAAI,EAAE,OAAO,GAAG,QAAQ,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,OAAO,CAAC;IACxE,oEAAoE;IACpE,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,KAAK,IAAI,CAAC;IAC1C,8BAA8B;IAC9B,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC;IACtB,4BAA4B;IAC5B,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC;IACpB,wDAAwD;IACxD,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,KAAK,MAAM,CAAC;IACxE,oBAAoB;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,+BAA+B;IAC/B,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,KAAK,IAAI,CAAC;IACxC,kCAAkC;IAClC,SAAS,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,KAAK,IAAI,CAAC;IAC3C,eAAe;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,eAAe;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,4CAA4C;IAC5C,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,6BAA6B;IAC7B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,2CAA2C;IAC3C,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,uBAAuB;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,+BAA+B;IAC/B,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,uCAAuC;IACvC,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,iDAAiD;IACjD,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,uCAAuC;IACvC,cAAc,CAAC,EAAE,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"DateStepper.d.ts","sourceRoot":"","sources":["../../../../../src/components/Steppers/DateStepper/DateStepper.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,EAAE,EAA6C,MAAM,OAAO,CAAC;AAE7E,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAahC,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,MAAM,WAAW,iBAAiB;IAChC,mDAAmD;IACnD,IAAI,EAAE,OAAO,GAAG,QAAQ,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,OAAO,CAAC;IACxE,oEAAoE;IACpE,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,KAAK,IAAI,CAAC;IAC1C,8BAA8B;IAC9B,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC;IACtB,4BAA4B;IAC5B,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC;IACpB,wDAAwD;IACxD,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,KAAK,MAAM,CAAC;IACxE,oBAAoB;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,+BAA+B;IAC/B,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,KAAK,IAAI,CAAC;IACxC,kCAAkC;IAClC,SAAS,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,KAAK,IAAI,CAAC;IAC3C,eAAe;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,eAAe;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,4CAA4C;IAC5C,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,6BAA6B;IAC7B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,2CAA2C;IAC3C,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,uBAAuB;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,+BAA+B;IAC/B,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,uCAAuC;IACvC,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,iDAAiD;IACjD,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,uCAAuC;IACvC,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,6BAA6B;IAC7B,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED;;;GAGG;AAEH,eAAO,MAAM,WAAW,EAAE,EAAE,CAAC,iBAAiB,CAuU7C,CAAC"}
|
|
@@ -29,7 +29,8 @@ export const DateStepper = _ref => {
|
|
|
29
29
|
position = "bottom",
|
|
30
30
|
popperClassName,
|
|
31
31
|
mode = "outlined",
|
|
32
|
-
alwaysShowDate = false
|
|
32
|
+
alwaysShowDate = false,
|
|
33
|
+
disableArrows = false
|
|
33
34
|
} = _ref;
|
|
34
35
|
const [fromDate, setFromDate] = useState(moment.utc(from));
|
|
35
36
|
const [toDate, setToDate] = useState(moment.utc(to));
|
|
@@ -50,9 +51,17 @@ export const DateStepper = _ref => {
|
|
|
50
51
|
} else if (step === "yearly") {
|
|
51
52
|
date.add(interval, "years");
|
|
52
53
|
return [date.clone().startOf("year"), date.clone().endOf("year")];
|
|
54
|
+
} else if (step === "range") {
|
|
55
|
+
// For range step, calculate N days based on current selection
|
|
56
|
+
const daysDiff = toDate.diff(fromDate, "days");
|
|
57
|
+
// If same day selected (daysDiff = 0), move by 1 day
|
|
58
|
+
const daysToMove = daysDiff === 0 ? 1 : daysDiff + 1;
|
|
59
|
+
const newFromDate = fromDate.clone().add(interval * daysToMove, "days");
|
|
60
|
+
const newToDate = daysDiff === 0 ? newFromDate.clone() : toDate.clone().add(interval * daysToMove, "days");
|
|
61
|
+
return [newFromDate, newToDate];
|
|
53
62
|
}
|
|
54
63
|
return [date, date];
|
|
55
|
-
}, [fromDate, period, step]);
|
|
64
|
+
}, [fromDate, toDate, period, step]);
|
|
56
65
|
const getDateFormatted = useMemo(() => {
|
|
57
66
|
if (formatCallback) {
|
|
58
67
|
return formatCallback(fromDate, toDate);
|
|
@@ -81,6 +90,20 @@ export const DateStepper = _ref => {
|
|
|
81
90
|
} else if (step === "yearly") {
|
|
82
91
|
return fromDate.utc().format("YYYY");
|
|
83
92
|
} else if (step === "range") {
|
|
93
|
+
// For range step, if toDate is invalid or at epoch (1970), only show fromDate
|
|
94
|
+
if (!toDate.isValid() || toDate.year() === 1970) {
|
|
95
|
+
if (fromDate.year() === actualYear) {
|
|
96
|
+
return fromDate.utc().format("MMM DD");
|
|
97
|
+
}
|
|
98
|
+
return fromDate.utc().format("MMM DD YYYY");
|
|
99
|
+
}
|
|
100
|
+
// If from and to are the same date, show only once
|
|
101
|
+
if (fromDate.format("YYYY-MM-DD") === toDate.format("YYYY-MM-DD")) {
|
|
102
|
+
if (fromDate.year() === actualYear) {
|
|
103
|
+
return fromDate.utc().format("MMM DD");
|
|
104
|
+
}
|
|
105
|
+
return fromDate.utc().format("MMM DD YYYY");
|
|
106
|
+
}
|
|
84
107
|
return showWeekOrCustomDateFormat(fromDate, toDate);
|
|
85
108
|
}
|
|
86
109
|
return "";
|
|
@@ -127,7 +150,7 @@ export const DateStepper = _ref => {
|
|
|
127
150
|
setFromDate(moment.utc(newFrom));
|
|
128
151
|
setToDate(moment.utc(newTo));
|
|
129
152
|
if (onChange) {
|
|
130
|
-
onChange(moment.utc(newFrom), moment.utc(newTo));
|
|
153
|
+
onChange(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());
|
|
131
154
|
}
|
|
132
155
|
if (onForward) {
|
|
133
156
|
onForward(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());
|
|
@@ -141,15 +164,12 @@ export const DateStepper = _ref => {
|
|
|
141
164
|
setFromDate(moment.utc(newFrom));
|
|
142
165
|
setToDate(moment.utc(newTo));
|
|
143
166
|
if (onChange) {
|
|
144
|
-
onChange(moment.utc(newFrom), moment.utc(newTo));
|
|
167
|
+
onChange(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());
|
|
145
168
|
}
|
|
146
169
|
if (onBack) {
|
|
147
170
|
onBack(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());
|
|
148
171
|
}
|
|
149
172
|
}, [isBeforeMinDate, getDatesByPeriod, onChange, onBack]);
|
|
150
|
-
const renderLeftRightButtons = useMemo(() => {
|
|
151
|
-
return step !== "range";
|
|
152
|
-
}, [step]);
|
|
153
173
|
useEffect(() => {
|
|
154
174
|
setFromDate(moment.utc(from));
|
|
155
175
|
setToDate(moment.utc(to));
|
|
@@ -202,14 +222,14 @@ export const DateStepper = _ref => {
|
|
|
202
222
|
}), [isDisabled]);
|
|
203
223
|
return /*#__PURE__*/React.createElement(StyledButtonGroup, {
|
|
204
224
|
className: classNames("c-date-stepper", className)
|
|
205
|
-
},
|
|
225
|
+
}, !disableArrows ? /*#__PURE__*/React.createElement(StyledControl, {
|
|
206
226
|
type: "button",
|
|
207
227
|
variant: mode === "flat" ? "text gray" : "secondary",
|
|
208
228
|
onClick: onLeftClickHandler,
|
|
209
229
|
disabled: isBeforeMinDate
|
|
210
230
|
}, /*#__PURE__*/React.createElement(ArrowLeftIcon, null)) : null, /*#__PURE__*/React.createElement(StyledDiv, {
|
|
211
231
|
$isTargetable: step === "yearly" || !withDatePicker,
|
|
212
|
-
$isRounded:
|
|
232
|
+
$isRounded: disableArrows,
|
|
213
233
|
$mode: mode,
|
|
214
234
|
$alwaysShowDate: alwaysShowDate,
|
|
215
235
|
style: dateStepperWidth(fromDate, toDate, step)
|
|
@@ -234,7 +254,7 @@ export const DateStepper = _ref => {
|
|
|
234
254
|
key: datePickerMode,
|
|
235
255
|
instant: true,
|
|
236
256
|
required: true
|
|
237
|
-
}) : /*#__PURE__*/React.createElement(StyledSpan, null, getDateFormatted)),
|
|
257
|
+
}) : /*#__PURE__*/React.createElement(StyledSpan, null, getDateFormatted)), !disableArrows ? /*#__PURE__*/React.createElement(StyledControl, {
|
|
238
258
|
type: "button",
|
|
239
259
|
variant: mode === "flat" ? "text gray" : "secondary",
|
|
240
260
|
onClick: onRightClickHandler,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DateStepper.js","names":["React","useCallback","useMemo","useState","useEffect","classNames","moment","StyledButton","StyledButtonGroup","StyledDiv","StyledSpan","StyledControl","DatePicker","ArrowRightIcon","ArrowLeftIcon","DateStepper","_ref","step","formatCallback","onChange","from","to","onBack","onForward","minValue","maxValue","className","period","withDatePicker","defaultMonth","enableYearPicker","position","popperClassName","mode","alwaysShowDate","fromDate","setFromDate","utc","toDate","setToDate","getDatesByPeriod","interval","date","add","clone","startOf","endOf","getDateFormatted","actualYear","year","showWeekOrCustomDateFormat","start","end","format","startDate","endDate","quarter","datePickerMode","onDatePickerChange","dates","fromDateTemp","Number","toDateTemp","isMoment","isAfterMaxDate","isSameOrBefore","isBeforeMinDate","isSameOrAfter","onRightClickHandler","newFrom","newTo","onLeftClickHandler","renderLeftRightButtons","dateStepperWidth","fromDay","toDay","range","minWidth","isDisabled","day","dayFormat","isBefore","isAfter","modifiers","disabled","matched","title","nonWorkingDay","createElement","type","variant","onClick","$isTargetable","$isRounded","$mode","$alwaysShowDate","style","month","target","selected","unix","firstDayOfWeek","disabledDaysAfter","disabledDaysBefore","disableYearPicker","key","instant","required","displayName"],"sources":["../../../../../src/components/Steppers/DateStepper/DateStepper.tsx"],"sourcesContent":["import React, { FC, useCallback, useMemo, useState, useEffect } from \"react\";\n\nimport { Placement } from \"@popperjs/core\";\nimport classNames from \"classnames\";\nimport { Moment } from \"moment\";\nimport moment from \"moment-timezone\";\n\nimport {\n StyledButton,\n StyledButtonGroup,\n StyledDiv,\n StyledSpan,\n StyledControl,\n} from \"./Styles\";\nimport { DatePicker, TimestampDateRange } from \"../../DatePicker/DatePicker\";\nimport { ArrowRightIcon } from \"../../Icons\";\nimport ArrowLeftIcon from \"../../Icons/collection/ArrowLeft\";\nimport { InputMode } from \"../../Input/types\";\n\nexport interface IDateStepperProps {\n /** One of the possible steps for this component */\n step: \"daily\" | \"weekly\" | \"monthly\" | \"quarterly\" | \"yearly\" | \"range\";\n /** Callback function that will be called after the changed range */\n onChange?: (from: Date, to: Date) => void;\n /** Start date of the range */\n from: Moment | string;\n /** End date of the range */\n to: Moment | string;\n /** Callback function that will format the text label */\n formatCallback?: (from: string | Moment, to: string | Moment) => string;\n /** Default month */\n defaultMonth?: Moment;\n /** Callback function onBack */\n onBack?: (from: Date, to: Date) => void;\n /** Callback function onForward */\n onForward?: (from: Date, to: Date) => void;\n /** Min date */\n minValue?: Moment;\n /** Max fate */\n maxValue?: Moment;\n /** html class */\n className?: string;\n /** Period for calculating week (isoWeek) */\n period?: \"week\" | \"isoWeek\";\n /** Classes for datePicker */\n datePickerClass?: string;\n /** Show datePicker in the middle button */\n withDatePicker?: boolean;\n /** Popper class name*/\n popperClassName?: string;\n /** DatePicker menu position */\n position?: Placement;\n /** Enable year picker in DatePicker */\n enableYearPicker?: boolean;\n /** conditional border & button variant styles */\n mode?: InputMode;\n /** preserve date on smaller screens */\n alwaysShowDate?: boolean;\n}\n\n/**\n * This component allow you to select date range. It accepts two parameters \"from\" and \"to\" as valid format\n * onChange and onBack and onForward it will return \"from: Date\" and \"to: Date\" as function arguments\n */\n\nexport const DateStepper: FC<IDateStepperProps> = ({\n step,\n formatCallback,\n onChange,\n from,\n to,\n onBack,\n onForward,\n minValue,\n maxValue,\n className,\n period = \"week\",\n withDatePicker = true,\n defaultMonth = moment(),\n enableYearPicker,\n position = \"bottom\",\n popperClassName,\n mode = \"outlined\",\n alwaysShowDate = false,\n}) => {\n const [fromDate, setFromDate] = useState<Moment>(moment.utc(from));\n const [toDate, setToDate] = useState<Moment>(moment.utc(to));\n\n const getDatesByPeriod = useCallback(\n (interval: number): Moment[] => {\n const date = fromDate ? fromDate : moment();\n if (step === \"daily\") {\n date.add(interval, \"days\");\n return [date, date.clone()];\n } else if (step === \"weekly\") {\n date.add(interval, \"weeks\");\n return [date.clone().startOf(period), date.clone().endOf(period)];\n } else if (step === \"monthly\") {\n date.add(interval, \"months\");\n return [date.clone().startOf(\"month\"), date.clone().endOf(\"month\")];\n } else if (step === \"quarterly\") {\n date.add(interval, \"quarters\");\n return [date.clone().startOf(\"quarter\"), date.clone().endOf(\"quarter\")];\n } else if (step === \"yearly\") {\n date.add(interval, \"years\");\n return [date.clone().startOf(\"year\"), date.clone().endOf(\"year\")];\n }\n return [date, date];\n },\n [fromDate, period, step]\n );\n\n const getDateFormatted = useMemo(() => {\n if (formatCallback) {\n return formatCallback(fromDate, toDate);\n }\n\n const actualYear = moment().year();\n\n const showWeekOrCustomDateFormat = (start, end): string => {\n if (start.year() === actualYear && end.year() === actualYear) {\n return (\n start.utc().format(\"MMM DD\") + \" - \" + end.utc().format(\"MMM DD\")\n );\n } else {\n return (\n start.utc().format(\"MMM DD YYYY\") +\n \" - \" +\n end.utc().format(\"MMM DD YYYY\")\n );\n }\n };\n\n if (step === \"daily\") {\n if (fromDate.year() === actualYear) {\n return fromDate.utc().format(\"MMM DD\");\n }\n return fromDate.utc().format(\"MMM DD YYYY\");\n } else if (step === \"weekly\") {\n const startDate = fromDate.clone().utc().startOf(period);\n const endDate = startDate.clone().utc().endOf(period);\n return showWeekOrCustomDateFormat(startDate, endDate);\n } else if (step === \"monthly\") {\n return fromDate.utc().format(\"MMM YYYY\");\n } else if (step === \"quarterly\") {\n return `Q${fromDate.utc().quarter()}/${fromDate.utc().format(\"YYYY\")}`;\n } else if (step === \"yearly\") {\n return fromDate.utc().format(\"YYYY\");\n } else if (step === \"range\") {\n return showWeekOrCustomDateFormat(fromDate, toDate);\n }\n\n return \"\";\n }, [fromDate, toDate, step, formatCallback, period]);\n\n const datePickerMode = useMemo(() => {\n if (step === \"range\") return \"custom\";\n if (step === \"yearly\") return \"custom\";\n return step;\n }, [step]);\n\n const onDatePickerChange = useCallback(\n (dates?: TimestampDateRange) => {\n const fromDateTemp: Moment = moment.utc(Number(dates?.from) * 1000);\n const toDateTemp: Moment = moment.utc(Number(dates?.to) * 1000);\n\n setFromDate(fromDateTemp);\n setToDate(toDateTemp);\n\n if (\n onChange &&\n moment.isMoment(fromDateTemp) &&\n moment.isMoment(toDateTemp)\n ) {\n onChange(fromDateTemp.toDate(), toDateTemp.toDate());\n }\n },\n [onChange, setFromDate, setToDate]\n );\n\n const isAfterMaxDate = useMemo(() => {\n return (\n moment.isMoment(maxValue) &&\n moment(moment.utc(maxValue).format(\"YYYY-MM-DD\")).isSameOrBefore(\n toDate.utc().format(\"YYYY-MM-DD\")\n )\n );\n }, [maxValue, toDate]);\n\n const isBeforeMinDate = useMemo(() => {\n return (\n moment.isMoment(minValue) &&\n moment\n .utc(moment.utc(minValue).format(\"YYYY-MM-DD\"))\n .isSameOrAfter(toDate.utc().format(\"YYYY-MM-DD\"))\n );\n }, [minValue, toDate]);\n\n useEffect(() => {\n if (isBeforeMinDate) {\n if (step === \"daily\") {\n setFromDate(moment.utc(minValue));\n setToDate(moment.utc(minValue));\n }\n }\n if (isAfterMaxDate) {\n if (step === \"daily\") {\n setFromDate(moment.utc(maxValue));\n setToDate(moment.utc(maxValue));\n }\n }\n }, [step, minValue, maxValue, isBeforeMinDate, isAfterMaxDate]);\n\n const onRightClickHandler = useCallback(() => {\n if (isAfterMaxDate) {\n return;\n }\n\n const [newFrom, newTo] = getDatesByPeriod(1);\n setFromDate(moment.utc(newFrom));\n setToDate(moment.utc(newTo));\n\n if (onChange) {\n onChange(moment.utc(newFrom), moment.utc(newTo));\n }\n\n if (onForward) {\n onForward(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n }, [isAfterMaxDate, getDatesByPeriod, onChange, onForward]);\n\n const onLeftClickHandler = useCallback(() => {\n if (isBeforeMinDate) {\n return;\n }\n\n const [newFrom, newTo] = getDatesByPeriod(-1);\n setFromDate(moment.utc(newFrom));\n setToDate(moment.utc(newTo));\n\n if (onChange) {\n onChange(moment.utc(newFrom), moment.utc(newTo));\n }\n if (onBack) {\n onBack(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n }, [isBeforeMinDate, getDatesByPeriod, onChange, onBack]);\n\n const renderLeftRightButtons = useMemo(() => {\n return step !== \"range\";\n }, [step]);\n\n useEffect(() => {\n setFromDate(moment.utc(from));\n setToDate(moment.utc(to));\n }, [from, to]);\n\n const dateStepperWidth = (\n fromDay: Moment,\n toDay: Moment,\n range: string\n ): { minWidth: string } => {\n if (\n fromDay.utc().year() !== moment.utc().year() ||\n toDay.utc().year() !== moment.utc().year()\n ) {\n switch (range) {\n case \"daily\":\n case \"monthly\":\n return { minWidth: \"122px\" };\n case \"weekly\":\n case \"custom\":\n return { minWidth: \"232px\" };\n }\n }\n switch (range) {\n case \"monthly\":\n return { minWidth: \"122px\" };\n case \"weekly\":\n case \"custom\":\n return { minWidth: \"182px\" };\n }\n\n return { minWidth: \"102px\" };\n };\n const isDisabled = useCallback(\n (day: Moment): boolean => {\n const dayFormat = moment.utc(day).format(\"YYYY-MM-DD\");\n\n const isBefore =\n moment.isMoment(maxValue) &&\n moment(moment.utc(maxValue).format(\"YYYY-MM-DD\")).isBefore(dayFormat);\n const isAfter =\n moment.isMoment(minValue) &&\n moment(moment.utc(minValue).format(\"YYYY-MM-DD\")).isAfter(dayFormat);\n\n return isBefore || isAfter;\n },\n [maxValue, minValue]\n );\n\n const modifiers = useMemo(\n () => ({\n disabled: (day: Moment) => ({ matched: isDisabled(day), title: null }),\n nonWorkingDay: (day: Moment) => ({\n matched: isDisabled(day),\n title: null,\n }),\n }),\n [isDisabled]\n );\n\n return (\n <StyledButtonGroup className={classNames(\"c-date-stepper\", className)}>\n {renderLeftRightButtons ? (\n <StyledControl\n type=\"button\"\n variant={mode === \"flat\" ? \"text gray\" : \"secondary\"}\n onClick={onLeftClickHandler}\n disabled={isBeforeMinDate}\n >\n <ArrowLeftIcon />\n </StyledControl>\n ) : null}\n <StyledDiv\n $isTargetable={step === \"yearly\" || !withDatePicker}\n $isRounded={step === \"range\"}\n $mode={mode}\n $alwaysShowDate={alwaysShowDate}\n style={dateStepperWidth(fromDate, toDate, step)}\n >\n {withDatePicker && step !== \"yearly\" ? (\n <DatePicker\n month={defaultMonth}\n target={\n <StyledButton type=\"button\">{getDateFormatted}</StyledButton>\n }\n mode={datePickerMode}\n selected={{\n from: moment.utc(fromDate).unix(),\n to: moment.utc(toDate).unix(),\n }}\n onChange={onDatePickerChange}\n firstDayOfWeek={period === \"week\" ? 0 : 1}\n modifiers={modifiers}\n disabledDaysAfter={maxValue}\n disabledDaysBefore={minValue}\n disableYearPicker={!enableYearPicker}\n popperClassName={popperClassName}\n position={position}\n key={datePickerMode}\n instant\n required\n />\n ) : (\n <StyledSpan>{getDateFormatted}</StyledSpan>\n )}\n </StyledDiv>\n {renderLeftRightButtons ? (\n <StyledControl\n type=\"button\"\n variant={mode === \"flat\" ? \"text gray\" : \"secondary\"}\n onClick={onRightClickHandler}\n disabled={isAfterMaxDate}\n >\n <ArrowRightIcon />\n </StyledControl>\n ) : null}\n </StyledButtonGroup>\n );\n};\n\nDateStepper.displayName = \"DateStepper\";\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"DateStepper.js","names":["React","useCallback","useMemo","useState","useEffect","classNames","moment","StyledButton","StyledButtonGroup","StyledDiv","StyledSpan","StyledControl","DatePicker","ArrowRightIcon","ArrowLeftIcon","DateStepper","_ref","step","formatCallback","onChange","from","to","onBack","onForward","minValue","maxValue","className","period","withDatePicker","defaultMonth","enableYearPicker","position","popperClassName","mode","alwaysShowDate","disableArrows","fromDate","setFromDate","utc","toDate","setToDate","getDatesByPeriod","interval","date","add","clone","startOf","endOf","daysDiff","diff","daysToMove","newFromDate","newToDate","getDateFormatted","actualYear","year","showWeekOrCustomDateFormat","start","end","format","startDate","endDate","quarter","isValid","datePickerMode","onDatePickerChange","dates","fromDateTemp","Number","toDateTemp","isMoment","isAfterMaxDate","isSameOrBefore","isBeforeMinDate","isSameOrAfter","onRightClickHandler","newFrom","newTo","onLeftClickHandler","dateStepperWidth","fromDay","toDay","range","minWidth","isDisabled","day","dayFormat","isBefore","isAfter","modifiers","disabled","matched","title","nonWorkingDay","createElement","type","variant","onClick","$isTargetable","$isRounded","$mode","$alwaysShowDate","style","month","target","selected","unix","firstDayOfWeek","disabledDaysAfter","disabledDaysBefore","disableYearPicker","key","instant","required","displayName"],"sources":["../../../../../src/components/Steppers/DateStepper/DateStepper.tsx"],"sourcesContent":["import React, { FC, useCallback, useMemo, useState, useEffect } from \"react\";\n\nimport { Placement } from \"@popperjs/core\";\nimport classNames from \"classnames\";\nimport { Moment } from \"moment\";\nimport moment from \"moment-timezone\";\n\nimport {\n StyledButton,\n StyledButtonGroup,\n StyledDiv,\n StyledSpan,\n StyledControl,\n} from \"./Styles\";\nimport { DatePicker, TimestampDateRange } from \"../../DatePicker/DatePicker\";\nimport { ArrowRightIcon } from \"../../Icons\";\nimport ArrowLeftIcon from \"../../Icons/collection/ArrowLeft\";\nimport { InputMode } from \"../../Input/types\";\n\nexport interface IDateStepperProps {\n /** One of the possible steps for this component */\n step: \"daily\" | \"weekly\" | \"monthly\" | \"quarterly\" | \"yearly\" | \"range\";\n /** Callback function that will be called after the changed range */\n onChange?: (from: Date, to: Date) => void;\n /** Start date of the range */\n from: Moment | string;\n /** End date of the range */\n to: Moment | string;\n /** Callback function that will format the text label */\n formatCallback?: (from: string | Moment, to: string | Moment) => string;\n /** Default month */\n defaultMonth?: Moment;\n /** Callback function onBack */\n onBack?: (from: Date, to: Date) => void;\n /** Callback function onForward */\n onForward?: (from: Date, to: Date) => void;\n /** Min date */\n minValue?: Moment;\n /** Max fate */\n maxValue?: Moment;\n /** html class */\n className?: string;\n /** Period for calculating week (isoWeek) */\n period?: \"week\" | \"isoWeek\";\n /** Classes for datePicker */\n datePickerClass?: string;\n /** Show datePicker in the middle button */\n withDatePicker?: boolean;\n /** Popper class name*/\n popperClassName?: string;\n /** DatePicker menu position */\n position?: Placement;\n /** Enable year picker in DatePicker */\n enableYearPicker?: boolean;\n /** conditional border & button variant styles */\n mode?: InputMode;\n /** preserve date on smaller screens */\n alwaysShowDate?: boolean;\n /** Hide navigation arrows */\n disableArrows?: boolean;\n}\n\n/**\n * This component allow you to select date range. It accepts two parameters \"from\" and \"to\" as valid format\n * onChange and onBack and onForward it will return \"from: Date\" and \"to: Date\" as function arguments\n */\n\nexport const DateStepper: FC<IDateStepperProps> = ({\n step,\n formatCallback,\n onChange,\n from,\n to,\n onBack,\n onForward,\n minValue,\n maxValue,\n className,\n period = \"week\",\n withDatePicker = true,\n defaultMonth = moment(),\n enableYearPicker,\n position = \"bottom\",\n popperClassName,\n mode = \"outlined\",\n alwaysShowDate = false,\n disableArrows = false,\n}) => {\n const [fromDate, setFromDate] = useState<Moment>(moment.utc(from));\n const [toDate, setToDate] = useState<Moment>(moment.utc(to));\n\n const getDatesByPeriod = useCallback(\n (interval: number): Moment[] => {\n const date = fromDate ? fromDate : moment();\n if (step === \"daily\") {\n date.add(interval, \"days\");\n return [date, date.clone()];\n } else if (step === \"weekly\") {\n date.add(interval, \"weeks\");\n return [date.clone().startOf(period), date.clone().endOf(period)];\n } else if (step === \"monthly\") {\n date.add(interval, \"months\");\n return [date.clone().startOf(\"month\"), date.clone().endOf(\"month\")];\n } else if (step === \"quarterly\") {\n date.add(interval, \"quarters\");\n return [date.clone().startOf(\"quarter\"), date.clone().endOf(\"quarter\")];\n } else if (step === \"yearly\") {\n date.add(interval, \"years\");\n return [date.clone().startOf(\"year\"), date.clone().endOf(\"year\")];\n } else if (step === \"range\") {\n // For range step, calculate N days based on current selection\n const daysDiff = toDate.diff(fromDate, \"days\");\n // If same day selected (daysDiff = 0), move by 1 day\n const daysToMove = daysDiff === 0 ? 1 : daysDiff + 1;\n const newFromDate = fromDate.clone().add(interval * daysToMove, \"days\");\n const newToDate =\n daysDiff === 0\n ? newFromDate.clone()\n : toDate.clone().add(interval * daysToMove, \"days\");\n return [newFromDate, newToDate];\n }\n return [date, date];\n },\n [fromDate, toDate, period, step]\n );\n\n const getDateFormatted = useMemo(() => {\n if (formatCallback) {\n return formatCallback(fromDate, toDate);\n }\n\n const actualYear = moment().year();\n\n const showWeekOrCustomDateFormat = (start, end): string => {\n if (start.year() === actualYear && end.year() === actualYear) {\n return (\n start.utc().format(\"MMM DD\") + \" - \" + end.utc().format(\"MMM DD\")\n );\n } else {\n return (\n start.utc().format(\"MMM DD YYYY\") +\n \" - \" +\n end.utc().format(\"MMM DD YYYY\")\n );\n }\n };\n\n if (step === \"daily\") {\n if (fromDate.year() === actualYear) {\n return fromDate.utc().format(\"MMM DD\");\n }\n return fromDate.utc().format(\"MMM DD YYYY\");\n } else if (step === \"weekly\") {\n const startDate = fromDate.clone().utc().startOf(period);\n const endDate = startDate.clone().utc().endOf(period);\n return showWeekOrCustomDateFormat(startDate, endDate);\n } else if (step === \"monthly\") {\n return fromDate.utc().format(\"MMM YYYY\");\n } else if (step === \"quarterly\") {\n return `Q${fromDate.utc().quarter()}/${fromDate.utc().format(\"YYYY\")}`;\n } else if (step === \"yearly\") {\n return fromDate.utc().format(\"YYYY\");\n } else if (step === \"range\") {\n // For range step, if toDate is invalid or at epoch (1970), only show fromDate\n if (!toDate.isValid() || toDate.year() === 1970) {\n if (fromDate.year() === actualYear) {\n return fromDate.utc().format(\"MMM DD\");\n }\n return fromDate.utc().format(\"MMM DD YYYY\");\n }\n // If from and to are the same date, show only once\n if (fromDate.format(\"YYYY-MM-DD\") === toDate.format(\"YYYY-MM-DD\")) {\n if (fromDate.year() === actualYear) {\n return fromDate.utc().format(\"MMM DD\");\n }\n return fromDate.utc().format(\"MMM DD YYYY\");\n }\n return showWeekOrCustomDateFormat(fromDate, toDate);\n }\n\n return \"\";\n }, [fromDate, toDate, step, formatCallback, period]);\n\n const datePickerMode = useMemo(() => {\n if (step === \"range\") return \"custom\";\n if (step === \"yearly\") return \"custom\";\n return step;\n }, [step]);\n\n const onDatePickerChange = useCallback(\n (dates?: TimestampDateRange) => {\n const fromDateTemp: Moment = moment.utc(Number(dates?.from) * 1000);\n const toDateTemp: Moment = moment.utc(Number(dates?.to) * 1000);\n\n setFromDate(fromDateTemp);\n setToDate(toDateTemp);\n\n if (\n onChange &&\n moment.isMoment(fromDateTemp) &&\n moment.isMoment(toDateTemp)\n ) {\n onChange(fromDateTemp.toDate(), toDateTemp.toDate());\n }\n },\n [onChange, setFromDate, setToDate]\n );\n\n const isAfterMaxDate = useMemo(() => {\n return (\n moment.isMoment(maxValue) &&\n moment(moment.utc(maxValue).format(\"YYYY-MM-DD\")).isSameOrBefore(\n toDate.utc().format(\"YYYY-MM-DD\")\n )\n );\n }, [maxValue, toDate]);\n\n const isBeforeMinDate = useMemo(() => {\n return (\n moment.isMoment(minValue) &&\n moment\n .utc(moment.utc(minValue).format(\"YYYY-MM-DD\"))\n .isSameOrAfter(toDate.utc().format(\"YYYY-MM-DD\"))\n );\n }, [minValue, toDate]);\n\n useEffect(() => {\n if (isBeforeMinDate) {\n if (step === \"daily\") {\n setFromDate(moment.utc(minValue));\n setToDate(moment.utc(minValue));\n }\n }\n if (isAfterMaxDate) {\n if (step === \"daily\") {\n setFromDate(moment.utc(maxValue));\n setToDate(moment.utc(maxValue));\n }\n }\n }, [step, minValue, maxValue, isBeforeMinDate, isAfterMaxDate]);\n\n const onRightClickHandler = useCallback(() => {\n if (isAfterMaxDate) {\n return;\n }\n\n const [newFrom, newTo] = getDatesByPeriod(1);\n setFromDate(moment.utc(newFrom));\n setToDate(moment.utc(newTo));\n\n if (onChange) {\n onChange(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n\n if (onForward) {\n onForward(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n }, [isAfterMaxDate, getDatesByPeriod, onChange, onForward]);\n\n const onLeftClickHandler = useCallback(() => {\n if (isBeforeMinDate) {\n return;\n }\n\n const [newFrom, newTo] = getDatesByPeriod(-1);\n setFromDate(moment.utc(newFrom));\n setToDate(moment.utc(newTo));\n\n if (onChange) {\n onChange(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n if (onBack) {\n onBack(moment.utc(newFrom).toDate(), moment.utc(newTo).toDate());\n }\n }, [isBeforeMinDate, getDatesByPeriod, onChange, onBack]);\n\n useEffect(() => {\n setFromDate(moment.utc(from));\n setToDate(moment.utc(to));\n }, [from, to]);\n\n const dateStepperWidth = (\n fromDay: Moment,\n toDay: Moment,\n range: string\n ): { minWidth: string } => {\n if (\n fromDay.utc().year() !== moment.utc().year() ||\n toDay.utc().year() !== moment.utc().year()\n ) {\n switch (range) {\n case \"daily\":\n case \"monthly\":\n return { minWidth: \"122px\" };\n case \"weekly\":\n case \"custom\":\n return { minWidth: \"232px\" };\n }\n }\n switch (range) {\n case \"monthly\":\n return { minWidth: \"122px\" };\n case \"weekly\":\n case \"custom\":\n return { minWidth: \"182px\" };\n }\n\n return { minWidth: \"102px\" };\n };\n const isDisabled = useCallback(\n (day: Moment): boolean => {\n const dayFormat = moment.utc(day).format(\"YYYY-MM-DD\");\n\n const isBefore =\n moment.isMoment(maxValue) &&\n moment(moment.utc(maxValue).format(\"YYYY-MM-DD\")).isBefore(dayFormat);\n const isAfter =\n moment.isMoment(minValue) &&\n moment(moment.utc(minValue).format(\"YYYY-MM-DD\")).isAfter(dayFormat);\n\n return isBefore || isAfter;\n },\n [maxValue, minValue]\n );\n\n const modifiers = useMemo(\n () => ({\n disabled: (day: Moment) => ({ matched: isDisabled(day), title: null }),\n nonWorkingDay: (day: Moment) => ({\n matched: isDisabled(day),\n title: null,\n }),\n }),\n [isDisabled]\n );\n\n return (\n <StyledButtonGroup className={classNames(\"c-date-stepper\", className)}>\n {!disableArrows ? (\n <StyledControl\n type=\"button\"\n variant={mode === \"flat\" ? \"text gray\" : \"secondary\"}\n onClick={onLeftClickHandler}\n disabled={isBeforeMinDate}\n >\n <ArrowLeftIcon />\n </StyledControl>\n ) : null}\n <StyledDiv\n $isTargetable={step === \"yearly\" || !withDatePicker}\n $isRounded={disableArrows}\n $mode={mode}\n $alwaysShowDate={alwaysShowDate}\n style={dateStepperWidth(fromDate, toDate, step)}\n >\n {withDatePicker && step !== \"yearly\" ? (\n <DatePicker\n month={defaultMonth}\n target={\n <StyledButton type=\"button\">{getDateFormatted}</StyledButton>\n }\n mode={datePickerMode}\n selected={{\n from: moment.utc(fromDate).unix(),\n to: moment.utc(toDate).unix(),\n }}\n onChange={onDatePickerChange}\n firstDayOfWeek={period === \"week\" ? 0 : 1}\n modifiers={modifiers}\n disabledDaysAfter={maxValue}\n disabledDaysBefore={minValue}\n disableYearPicker={!enableYearPicker}\n popperClassName={popperClassName}\n position={position}\n key={datePickerMode}\n instant\n required\n />\n ) : (\n <StyledSpan>{getDateFormatted}</StyledSpan>\n )}\n </StyledDiv>\n {!disableArrows ? (\n <StyledControl\n type=\"button\"\n variant={mode === \"flat\" ? \"text gray\" : \"secondary\"}\n onClick={onRightClickHandler}\n disabled={isAfterMaxDate}\n >\n <ArrowRightIcon />\n </StyledControl>\n ) : null}\n </StyledButtonGroup>\n );\n};\n\nDateStepper.displayName = \"DateStepper\";\n"],"mappings":"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","ignoreList":[]}
|
package/dist/index.js
CHANGED
|
@@ -14253,7 +14253,9 @@
|
|
|
14253
14253
|
_ref$mode = _ref.mode,
|
|
14254
14254
|
mode = _ref$mode === void 0 ? "outlined" : _ref$mode,
|
|
14255
14255
|
_ref$alwaysShowDate = _ref.alwaysShowDate,
|
|
14256
|
-
alwaysShowDate = _ref$alwaysShowDate === void 0 ? false : _ref$alwaysShowDate
|
|
14256
|
+
alwaysShowDate = _ref$alwaysShowDate === void 0 ? false : _ref$alwaysShowDate,
|
|
14257
|
+
_ref$disableArrows = _ref.disableArrows,
|
|
14258
|
+
disableArrows = _ref$disableArrows === void 0 ? false : _ref$disableArrows;
|
|
14257
14259
|
var _useState = React.useState(moment__default["default"].utc(from)),
|
|
14258
14260
|
_useState2 = _slicedToArray(_useState, 2),
|
|
14259
14261
|
fromDate = _useState2[0],
|
|
@@ -14279,9 +14281,17 @@
|
|
|
14279
14281
|
} else if (step === "yearly") {
|
|
14280
14282
|
date.add(interval, "years");
|
|
14281
14283
|
return [date.clone().startOf("year"), date.clone().endOf("year")];
|
|
14284
|
+
} else if (step === "range") {
|
|
14285
|
+
// For range step, calculate N days based on current selection
|
|
14286
|
+
var daysDiff = toDate.diff(fromDate, "days");
|
|
14287
|
+
// If same day selected (daysDiff = 0), move by 1 day
|
|
14288
|
+
var daysToMove = daysDiff === 0 ? 1 : daysDiff + 1;
|
|
14289
|
+
var newFromDate = fromDate.clone().add(interval * daysToMove, "days");
|
|
14290
|
+
var newToDate = daysDiff === 0 ? newFromDate.clone() : toDate.clone().add(interval * daysToMove, "days");
|
|
14291
|
+
return [newFromDate, newToDate];
|
|
14282
14292
|
}
|
|
14283
14293
|
return [date, date];
|
|
14284
|
-
}, [fromDate, period, step]);
|
|
14294
|
+
}, [fromDate, toDate, period, step]);
|
|
14285
14295
|
var getDateFormatted = React.useMemo(function () {
|
|
14286
14296
|
if (formatCallback) {
|
|
14287
14297
|
return formatCallback(fromDate, toDate);
|
|
@@ -14310,6 +14320,20 @@
|
|
|
14310
14320
|
} else if (step === "yearly") {
|
|
14311
14321
|
return fromDate.utc().format("YYYY");
|
|
14312
14322
|
} else if (step === "range") {
|
|
14323
|
+
// For range step, if toDate is invalid or at epoch (1970), only show fromDate
|
|
14324
|
+
if (!toDate.isValid() || toDate.year() === 1970) {
|
|
14325
|
+
if (fromDate.year() === actualYear) {
|
|
14326
|
+
return fromDate.utc().format("MMM DD");
|
|
14327
|
+
}
|
|
14328
|
+
return fromDate.utc().format("MMM DD YYYY");
|
|
14329
|
+
}
|
|
14330
|
+
// If from and to are the same date, show only once
|
|
14331
|
+
if (fromDate.format("YYYY-MM-DD") === toDate.format("YYYY-MM-DD")) {
|
|
14332
|
+
if (fromDate.year() === actualYear) {
|
|
14333
|
+
return fromDate.utc().format("MMM DD");
|
|
14334
|
+
}
|
|
14335
|
+
return fromDate.utc().format("MMM DD YYYY");
|
|
14336
|
+
}
|
|
14313
14337
|
return showWeekOrCustomDateFormat(fromDate, toDate);
|
|
14314
14338
|
}
|
|
14315
14339
|
return "";
|
|
@@ -14359,7 +14383,7 @@
|
|
|
14359
14383
|
setFromDate(moment__default["default"].utc(newFrom));
|
|
14360
14384
|
setToDate(moment__default["default"].utc(newTo));
|
|
14361
14385
|
if (onChange) {
|
|
14362
|
-
onChange(moment__default["default"].utc(newFrom), moment__default["default"].utc(newTo));
|
|
14386
|
+
onChange(moment__default["default"].utc(newFrom).toDate(), moment__default["default"].utc(newTo).toDate());
|
|
14363
14387
|
}
|
|
14364
14388
|
if (onForward) {
|
|
14365
14389
|
onForward(moment__default["default"].utc(newFrom).toDate(), moment__default["default"].utc(newTo).toDate());
|
|
@@ -14376,15 +14400,12 @@
|
|
|
14376
14400
|
setFromDate(moment__default["default"].utc(newFrom));
|
|
14377
14401
|
setToDate(moment__default["default"].utc(newTo));
|
|
14378
14402
|
if (onChange) {
|
|
14379
|
-
onChange(moment__default["default"].utc(newFrom), moment__default["default"].utc(newTo));
|
|
14403
|
+
onChange(moment__default["default"].utc(newFrom).toDate(), moment__default["default"].utc(newTo).toDate());
|
|
14380
14404
|
}
|
|
14381
14405
|
if (onBack) {
|
|
14382
14406
|
onBack(moment__default["default"].utc(newFrom).toDate(), moment__default["default"].utc(newTo).toDate());
|
|
14383
14407
|
}
|
|
14384
14408
|
}, [isBeforeMinDate, getDatesByPeriod, onChange, onBack]);
|
|
14385
|
-
var renderLeftRightButtons = React.useMemo(function () {
|
|
14386
|
-
return step !== "range";
|
|
14387
|
-
}, [step]);
|
|
14388
14409
|
React.useEffect(function () {
|
|
14389
14410
|
setFromDate(moment__default["default"].utc(from));
|
|
14390
14411
|
setToDate(moment__default["default"].utc(to));
|
|
@@ -14443,14 +14464,14 @@
|
|
|
14443
14464
|
}, [isDisabled]);
|
|
14444
14465
|
return /*#__PURE__*/React__default["default"].createElement(StyledButtonGroup, {
|
|
14445
14466
|
className: classNames__default["default"]("c-date-stepper", className)
|
|
14446
|
-
},
|
|
14467
|
+
}, !disableArrows ? /*#__PURE__*/React__default["default"].createElement(StyledControl, {
|
|
14447
14468
|
type: "button",
|
|
14448
14469
|
variant: mode === "flat" ? "text gray" : "secondary",
|
|
14449
14470
|
onClick: onLeftClickHandler,
|
|
14450
14471
|
disabled: isBeforeMinDate
|
|
14451
14472
|
}, /*#__PURE__*/React__default["default"].createElement(ArrowLeftIcon$1, null)) : null, /*#__PURE__*/React__default["default"].createElement(StyledDiv$1, {
|
|
14452
14473
|
$isTargetable: step === "yearly" || !withDatePicker,
|
|
14453
|
-
$isRounded:
|
|
14474
|
+
$isRounded: disableArrows,
|
|
14454
14475
|
$mode: mode,
|
|
14455
14476
|
$alwaysShowDate: alwaysShowDate,
|
|
14456
14477
|
style: dateStepperWidth(fromDate, toDate, step)
|
|
@@ -14475,7 +14496,7 @@
|
|
|
14475
14496
|
key: datePickerMode,
|
|
14476
14497
|
instant: true,
|
|
14477
14498
|
required: true
|
|
14478
|
-
}) : /*#__PURE__*/React__default["default"].createElement(StyledSpan$1, null, getDateFormatted)),
|
|
14499
|
+
}) : /*#__PURE__*/React__default["default"].createElement(StyledSpan$1, null, getDateFormatted)), !disableArrows ? /*#__PURE__*/React__default["default"].createElement(StyledControl, {
|
|
14479
14500
|
type: "button",
|
|
14480
14501
|
variant: mode === "flat" ? "text gray" : "secondary",
|
|
14481
14502
|
onClick: onRightClickHandler,
|