Skip to content

Commit

Permalink
Browser Focus Out 버그 Fix, (Trigger 버튼 추가)
Browse files Browse the repository at this point in the history
  • Loading branch information
flamecommit committed May 2, 2024
1 parent 1fdc1fa commit ea6934a
Show file tree
Hide file tree
Showing 6 changed files with 62 additions and 11 deletions.
4 changes: 4 additions & 0 deletions package/src/assets/calendar.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
13 changes: 13 additions & 0 deletions package/src/assets/global.css
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,19 @@
font-size: 0;
cursor: pointer;
}
.react-datepicker__trigger {
margin-left: 0.4rem;
width: 18px;
height: 18px;
background-image: url('');
background-repeat: no-repeat;
background-position: center;
background-size: 100%;
border: none;
background-color: transparent;
font-size: 0;
cursor: pointer;
}

/* portal */
.react-datepicker__portal {
Expand Down
13 changes: 13 additions & 0 deletions package/src/components/Datepicker.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -140,6 +140,19 @@ function Datepicker({
setViewDate(formatDate(value || NEW_DATE, 'YYYY-MM-DD'));
}, [value]);

// browser에서 focus가 사라졌을 때 picker close
const windowBlurHandler = () => {
setIsVisible(false);
};

useEffect(() => {
window.addEventListener('blur', windowBlurHandler);
// return window.removeEventListener('blur', windowBlurHandler);
return () => {
window.removeEventListener('blur', windowBlurHandler);
};
}, []);

return (
<div className={`${NAME_SPACE}__wrapper ${className}`}>
<DatepickerInput
Expand Down
13 changes: 12 additions & 1 deletion package/src/components/input/DatepickerInput.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,11 @@ export default function DatepickerInput({
}: IProps) {
const formatArray = useMemo(() => splitString(valueFormat), [valueFormat]);

const triggerHandler = () => {
if (disabled) return;
setIsVisible(true);
};

return (
<div
className={`${NAME_SPACE}__input-container`}
Expand All @@ -49,14 +54,20 @@ export default function DatepickerInput({
setDateValue={setDateValue}
timeValue={timeValue}
setTimeValue={setTimeValue}
setIsVisible={setIsVisible}
type={type}
viewDate={viewDate}
setViewDate={setViewDate}
disabled={disabled}
/>
);
})}
<button
type="button"
className={`${NAME_SPACE}__trigger`}
onClick={triggerHandler}
>
Trigger
</button>
{useClearButton && (
<button
type="button"
Expand Down
7 changes: 1 addition & 6 deletions package/src/components/input/InputUnit.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,18 +9,16 @@ import {
useState,
} from 'react';
import { NAME_SPACE, VALUE_TYPES } from '../../constants/core';
import { IDateValue, ITimeValue, TIsVisible } from '../../types/props';
import { IDateValue, ITimeValue } from '../../types/props';
import { getDateValueUnit, getTimeValueUnit } from '../../utils/datetime';
import { addLeadingZero, isNumeric } from '../../utils/string';

interface IProps {
visibleType?: TIsVisible;
type: string;
dateValue: IDateValue;
setDateValue: (value: IDateValue) => void;
timeValue: ITimeValue;
setTimeValue: (value: ITimeValue) => void;
setIsVisible: (value: TIsVisible) => void;
viewDate: string;
setViewDate: (value: string) => void;
disabled: boolean;
Expand Down Expand Up @@ -57,13 +55,11 @@ function getNextSiblingsWithDataValueTrue(
}

function InputUnit({
visibleType = true,
type,
dateValue,
setDateValue,
timeValue,
setTimeValue,
setIsVisible,
viewDate,
setViewDate,
disabled,
Expand Down Expand Up @@ -237,7 +233,6 @@ function InputUnit({

const focusHandler = (e: React.FocusEvent<HTMLDivElement>) => {
if (disabled) return;
setIsVisible(visibleType);
setTimeout(() => {
selectText(e.target);
}, 10);
Expand Down
23 changes: 19 additions & 4 deletions package/src/components/input/RangepickerInput.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,11 @@ export default function RangepickerInput({
}: IProps) {
const formatArray = useMemo(() => splitString(valueFormat), [valueFormat]);

const triggerHandler = (type: 'start' | 'end') => {
if (disabled) return;
setIsVisible(type);
};

return (
<div
className={`${NAME_SPACE}__input-container`}
Expand All @@ -63,12 +68,10 @@ export default function RangepickerInput({
return (
<InputUnit
key={i}
visibleType="start"
dateValue={dateStartValue}
setDateValue={setDateStartValue}
timeValue={timeStartValue}
setTimeValue={setTimeStartValue}
setIsVisible={setIsVisible}
type={type}
viewDate={viewStartDate}
setViewDate={setViewStartDate}
Expand All @@ -77,6 +80,13 @@ export default function RangepickerInput({
);
})}
</div>
<button
type="button"
className={`${NAME_SPACE}__trigger`}
onClick={() => triggerHandler('start')}
>
Trigger
</button>
<div className={`${NAME_SPACE}__input-range-separator`}> ~ </div>
<div
className={`${NAME_SPACE}__input-range-container`}
Expand All @@ -86,12 +96,10 @@ export default function RangepickerInput({
return (
<InputUnit
key={i}
visibleType="end"
dateValue={dateEndValue}
setDateValue={setDateEndValue}
timeValue={timeEndValue}
setTimeValue={setTimeEndValue}
setIsVisible={setIsVisible}
type={type}
viewDate={viewEndDate}
setViewDate={setViewEndDate}
Expand All @@ -100,6 +108,13 @@ export default function RangepickerInput({
);
})}
</div>
<button
type="button"
className={`${NAME_SPACE}__trigger`}
onClick={() => triggerHandler('end')}
>
Trigger
</button>
{useClearButton && (
<button
type="button"
Expand Down

0 comments on commit ea6934a

Please sign in to comment.