@ceed/ads 1.5.4-next.2 → 1.5.4-next.4
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/components/Calendar/utils/index.d.ts +3 -1
- package/dist/components/MonthPicker/MonthPicker.d.ts +1 -0
- package/dist/index.cjs +23 -13
- package/dist/index.js +23 -13
- package/framer/index.js +27 -27
- package/package.json +1 -1
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
export declare const getCalendarDates: (date: Date) => (number | undefined)[][];
|
|
2
2
|
export declare const getYearName: (date: Date, locale: string) => string;
|
|
3
|
-
export declare const getMonthName: (date: Date, locale: string
|
|
3
|
+
export declare const getMonthName: (date: Date, locale: string, options?: {
|
|
4
|
+
hideYear?: boolean;
|
|
5
|
+
}) => string;
|
|
4
6
|
export declare const getMonthNameFromIndex: (index: number, locale: string) => string;
|
|
5
7
|
/**
|
|
6
8
|
* 일~토 / Sun ~ Sat 같은 요일 이름을 가져옵니다.
|
|
@@ -21,6 +21,7 @@ interface BaseMonthPickerProps {
|
|
|
21
21
|
disablePast?: boolean;
|
|
22
22
|
format?: string;
|
|
23
23
|
displayFormat?: string;
|
|
24
|
+
locale?: string;
|
|
24
25
|
}
|
|
25
26
|
export type MonthPickerProps = BaseMonthPickerProps & Omit<React.ComponentProps<typeof Input>, "onChange" | "value" | "defaultValue">;
|
|
26
27
|
declare const MonthPicker: React.ForwardRefExoticComponent<Omit<MonthPickerProps, "ref"> & React.RefAttributes<HTMLInputElement>>;
|
package/dist/index.cjs
CHANGED
|
@@ -865,8 +865,11 @@ var getCalendarDates = (date) => {
|
|
|
865
865
|
var getYearName = (date, locale) => {
|
|
866
866
|
return date.toLocaleString(locale, { year: "numeric" });
|
|
867
867
|
};
|
|
868
|
-
var getMonthName = (date, locale) => {
|
|
869
|
-
return date.toLocaleString(locale, {
|
|
868
|
+
var getMonthName = (date, locale, options) => {
|
|
869
|
+
return date.toLocaleString(locale, {
|
|
870
|
+
month: "long",
|
|
871
|
+
...options?.hideYear ? {} : { year: "numeric" }
|
|
872
|
+
});
|
|
870
873
|
};
|
|
871
874
|
var getMonthNameFromIndex = (index, locale) => {
|
|
872
875
|
return new Date(0, index).toLocaleString(locale, { month: "short" });
|
|
@@ -5001,13 +5004,10 @@ var MonthPickerRoot = (0, import_joy46.styled)("div", {
|
|
|
5001
5004
|
})({
|
|
5002
5005
|
width: "100%"
|
|
5003
5006
|
});
|
|
5004
|
-
|
|
5005
|
-
return new Intl.DateTimeFormat("en-US", { month: "long" }).format(date);
|
|
5006
|
-
}
|
|
5007
|
-
var formatValueString3 = (date, format) => {
|
|
5007
|
+
var formatValueString3 = (date, format, locale = "default") => {
|
|
5008
5008
|
const year = date.getFullYear().toString();
|
|
5009
5009
|
const month = (date.getMonth() + 1).toString().padStart(2, "0");
|
|
5010
|
-
const monthName =
|
|
5010
|
+
const monthName = getMonthName(date, locale, { hideYear: true });
|
|
5011
5011
|
const day = "01";
|
|
5012
5012
|
return format.replace(/MMMM/g, monthName).replace(/MM/g, month).replace(/DD/g, day).replace(/YYYY/g, year);
|
|
5013
5013
|
};
|
|
@@ -5050,9 +5050,16 @@ var MonthPicker = (0, import_react33.forwardRef)(
|
|
|
5050
5050
|
// NOTE: 스타일 관련된 props는 최상위 엘리먼트에 적용한다.
|
|
5051
5051
|
sx,
|
|
5052
5052
|
className,
|
|
5053
|
+
/**
|
|
5054
|
+
* NOTE: 현재 CalendarDate는 YYYY-MM-DD로 개발하고 있어 date를 포함하여 value를 관리한다.
|
|
5055
|
+
* @see https://ecubelabs.atlassian.net/wiki/spaces/SW/pages/1938784349/Date#CalendarDate
|
|
5056
|
+
* @see https://github.com/Ecube-Labs/hds/pull/145
|
|
5057
|
+
*
|
|
5058
|
+
*/
|
|
5053
5059
|
format = "YYYY/MM/DD",
|
|
5054
5060
|
displayFormat = "YYYY/MM",
|
|
5055
5061
|
size,
|
|
5062
|
+
locale,
|
|
5056
5063
|
...innerProps
|
|
5057
5064
|
} = props;
|
|
5058
5065
|
const innerRef = (0, import_react33.useRef)(null);
|
|
@@ -5067,7 +5074,7 @@ var MonthPicker = (0, import_react33.forwardRef)(
|
|
|
5067
5074
|
{ disableStrict: true }
|
|
5068
5075
|
);
|
|
5069
5076
|
const [displayValue, setDisplayValue] = (0, import_react33.useState)(
|
|
5070
|
-
() => value ? formatValueString3(parseDate3(value, format), displayFormat) : ""
|
|
5077
|
+
() => value ? formatValueString3(parseDate3(value, format), displayFormat, locale) : ""
|
|
5071
5078
|
);
|
|
5072
5079
|
const [anchorEl, setAnchorEl] = (0, import_react33.useState)(null);
|
|
5073
5080
|
const open = Boolean(anchorEl);
|
|
@@ -5086,7 +5093,8 @@ var MonthPicker = (0, import_react33.forwardRef)(
|
|
|
5086
5093
|
}
|
|
5087
5094
|
const formattedValue = formatValueString3(
|
|
5088
5095
|
parseDate3(value, format),
|
|
5089
|
-
displayFormat
|
|
5096
|
+
displayFormat,
|
|
5097
|
+
locale
|
|
5090
5098
|
);
|
|
5091
5099
|
setDisplayValue(formattedValue);
|
|
5092
5100
|
}, [displayFormat, format, value]);
|
|
@@ -5094,11 +5102,11 @@ var MonthPicker = (0, import_react33.forwardRef)(
|
|
|
5094
5102
|
(event) => {
|
|
5095
5103
|
const value2 = event.target.value;
|
|
5096
5104
|
setDisplayValue(
|
|
5097
|
-
value2 ? formatValueString3(parseDate3(value2, format), displayFormat) : value2
|
|
5105
|
+
value2 ? formatValueString3(parseDate3(value2, format), displayFormat, locale) : value2
|
|
5098
5106
|
);
|
|
5099
5107
|
setValue(value2);
|
|
5100
5108
|
},
|
|
5101
|
-
[displayFormat, format, setValue]
|
|
5109
|
+
[displayFormat, format, setValue, locale]
|
|
5102
5110
|
);
|
|
5103
5111
|
const handleCalendarToggle = (0, import_react33.useCallback)(
|
|
5104
5112
|
(event) => {
|
|
@@ -5147,6 +5155,7 @@ var MonthPicker = (0, import_react33.forwardRef)(
|
|
|
5147
5155
|
endDecorator: /* @__PURE__ */ import_react33.default.createElement(
|
|
5148
5156
|
IconButton_default,
|
|
5149
5157
|
{
|
|
5158
|
+
ref: buttonRef,
|
|
5150
5159
|
variant: "plain",
|
|
5151
5160
|
onClick: handleCalendarToggle,
|
|
5152
5161
|
"aria-label": "Toggle Calendar",
|
|
@@ -5189,7 +5198,7 @@ var MonthPicker = (0, import_react33.forwardRef)(
|
|
|
5189
5198
|
handleChange({
|
|
5190
5199
|
target: {
|
|
5191
5200
|
name: props.name,
|
|
5192
|
-
value: formatValueString3(date, format)
|
|
5201
|
+
value: formatValueString3(date, format, locale)
|
|
5193
5202
|
}
|
|
5194
5203
|
});
|
|
5195
5204
|
setAnchorEl(null);
|
|
@@ -5197,7 +5206,8 @@ var MonthPicker = (0, import_react33.forwardRef)(
|
|
|
5197
5206
|
minDate: minDate ? new Date(minDate) : void 0,
|
|
5198
5207
|
maxDate: maxDate ? new Date(maxDate) : void 0,
|
|
5199
5208
|
disableFuture,
|
|
5200
|
-
disablePast
|
|
5209
|
+
disablePast,
|
|
5210
|
+
locale
|
|
5201
5211
|
}
|
|
5202
5212
|
), /* @__PURE__ */ import_react33.default.createElement(
|
|
5203
5213
|
DialogActions_default,
|
package/dist/index.js
CHANGED
|
@@ -785,8 +785,11 @@ var getCalendarDates = (date) => {
|
|
|
785
785
|
var getYearName = (date, locale) => {
|
|
786
786
|
return date.toLocaleString(locale, { year: "numeric" });
|
|
787
787
|
};
|
|
788
|
-
var getMonthName = (date, locale) => {
|
|
789
|
-
return date.toLocaleString(locale, {
|
|
788
|
+
var getMonthName = (date, locale, options) => {
|
|
789
|
+
return date.toLocaleString(locale, {
|
|
790
|
+
month: "long",
|
|
791
|
+
...options?.hideYear ? {} : { year: "numeric" }
|
|
792
|
+
});
|
|
790
793
|
};
|
|
791
794
|
var getMonthNameFromIndex = (index, locale) => {
|
|
792
795
|
return new Date(0, index).toLocaleString(locale, { month: "short" });
|
|
@@ -4988,13 +4991,10 @@ var MonthPickerRoot = styled20("div", {
|
|
|
4988
4991
|
})({
|
|
4989
4992
|
width: "100%"
|
|
4990
4993
|
});
|
|
4991
|
-
|
|
4992
|
-
return new Intl.DateTimeFormat("en-US", { month: "long" }).format(date);
|
|
4993
|
-
}
|
|
4994
|
-
var formatValueString3 = (date, format) => {
|
|
4994
|
+
var formatValueString3 = (date, format, locale = "default") => {
|
|
4995
4995
|
const year = date.getFullYear().toString();
|
|
4996
4996
|
const month = (date.getMonth() + 1).toString().padStart(2, "0");
|
|
4997
|
-
const monthName =
|
|
4997
|
+
const monthName = getMonthName(date, locale, { hideYear: true });
|
|
4998
4998
|
const day = "01";
|
|
4999
4999
|
return format.replace(/MMMM/g, monthName).replace(/MM/g, month).replace(/DD/g, day).replace(/YYYY/g, year);
|
|
5000
5000
|
};
|
|
@@ -5037,9 +5037,16 @@ var MonthPicker = forwardRef9(
|
|
|
5037
5037
|
// NOTE: 스타일 관련된 props는 최상위 엘리먼트에 적용한다.
|
|
5038
5038
|
sx,
|
|
5039
5039
|
className,
|
|
5040
|
+
/**
|
|
5041
|
+
* NOTE: 현재 CalendarDate는 YYYY-MM-DD로 개발하고 있어 date를 포함하여 value를 관리한다.
|
|
5042
|
+
* @see https://ecubelabs.atlassian.net/wiki/spaces/SW/pages/1938784349/Date#CalendarDate
|
|
5043
|
+
* @see https://github.com/Ecube-Labs/hds/pull/145
|
|
5044
|
+
*
|
|
5045
|
+
*/
|
|
5040
5046
|
format = "YYYY/MM/DD",
|
|
5041
5047
|
displayFormat = "YYYY/MM",
|
|
5042
5048
|
size,
|
|
5049
|
+
locale,
|
|
5043
5050
|
...innerProps
|
|
5044
5051
|
} = props;
|
|
5045
5052
|
const innerRef = useRef7(null);
|
|
@@ -5054,7 +5061,7 @@ var MonthPicker = forwardRef9(
|
|
|
5054
5061
|
{ disableStrict: true }
|
|
5055
5062
|
);
|
|
5056
5063
|
const [displayValue, setDisplayValue] = useState10(
|
|
5057
|
-
() => value ? formatValueString3(parseDate3(value, format), displayFormat) : ""
|
|
5064
|
+
() => value ? formatValueString3(parseDate3(value, format), displayFormat, locale) : ""
|
|
5058
5065
|
);
|
|
5059
5066
|
const [anchorEl, setAnchorEl] = useState10(null);
|
|
5060
5067
|
const open = Boolean(anchorEl);
|
|
@@ -5073,7 +5080,8 @@ var MonthPicker = forwardRef9(
|
|
|
5073
5080
|
}
|
|
5074
5081
|
const formattedValue = formatValueString3(
|
|
5075
5082
|
parseDate3(value, format),
|
|
5076
|
-
displayFormat
|
|
5083
|
+
displayFormat,
|
|
5084
|
+
locale
|
|
5077
5085
|
);
|
|
5078
5086
|
setDisplayValue(formattedValue);
|
|
5079
5087
|
}, [displayFormat, format, value]);
|
|
@@ -5081,11 +5089,11 @@ var MonthPicker = forwardRef9(
|
|
|
5081
5089
|
(event) => {
|
|
5082
5090
|
const value2 = event.target.value;
|
|
5083
5091
|
setDisplayValue(
|
|
5084
|
-
value2 ? formatValueString3(parseDate3(value2, format), displayFormat) : value2
|
|
5092
|
+
value2 ? formatValueString3(parseDate3(value2, format), displayFormat, locale) : value2
|
|
5085
5093
|
);
|
|
5086
5094
|
setValue(value2);
|
|
5087
5095
|
},
|
|
5088
|
-
[displayFormat, format, setValue]
|
|
5096
|
+
[displayFormat, format, setValue, locale]
|
|
5089
5097
|
);
|
|
5090
5098
|
const handleCalendarToggle = useCallback12(
|
|
5091
5099
|
(event) => {
|
|
@@ -5134,6 +5142,7 @@ var MonthPicker = forwardRef9(
|
|
|
5134
5142
|
endDecorator: /* @__PURE__ */ React31.createElement(
|
|
5135
5143
|
IconButton_default,
|
|
5136
5144
|
{
|
|
5145
|
+
ref: buttonRef,
|
|
5137
5146
|
variant: "plain",
|
|
5138
5147
|
onClick: handleCalendarToggle,
|
|
5139
5148
|
"aria-label": "Toggle Calendar",
|
|
@@ -5176,7 +5185,7 @@ var MonthPicker = forwardRef9(
|
|
|
5176
5185
|
handleChange({
|
|
5177
5186
|
target: {
|
|
5178
5187
|
name: props.name,
|
|
5179
|
-
value: formatValueString3(date, format)
|
|
5188
|
+
value: formatValueString3(date, format, locale)
|
|
5180
5189
|
}
|
|
5181
5190
|
});
|
|
5182
5191
|
setAnchorEl(null);
|
|
@@ -5184,7 +5193,8 @@ var MonthPicker = forwardRef9(
|
|
|
5184
5193
|
minDate: minDate ? new Date(minDate) : void 0,
|
|
5185
5194
|
maxDate: maxDate ? new Date(maxDate) : void 0,
|
|
5186
5195
|
disableFuture,
|
|
5187
|
-
disablePast
|
|
5196
|
+
disablePast,
|
|
5197
|
+
locale
|
|
5188
5198
|
}
|
|
5189
5199
|
), /* @__PURE__ */ React31.createElement(
|
|
5190
5200
|
DialogActions_default,
|