@dotconnor/grommet
Version:
focus on the essential experience
87 lines (80 loc) • 2.27 kB
JavaScript
import React, { useEffect, useRef, useState } from 'react';
import { Box, Calendar, Drop, Heading, Grommet, TextInput } from 'grommet';
import { grommet } from 'grommet/themes';
var OverflowDrop = function OverflowDrop() {
var targetRef = useRef();
var inputRef = useRef();
var _useState = useState(undefined),
date = _useState[0],
setDate = _useState[1];
var _useState2 = useState(false),
showCalendar = _useState2[0],
setShowCalendar = _useState2[1];
var onSelect = function onSelect(nextDate) {
setDate(nextDate !== date ? nextDate : undefined);
setShowCalendar(false);
};
var _useState3 = useState(false),
setShowDrop = _useState3[1];
useEffect(function () {
return setShowDrop(true);
}, []);
return /*#__PURE__*/React.createElement(Grommet, {
theme: grommet,
full: true
}, /*#__PURE__*/React.createElement(Box, {
fill: true,
align: "center",
justify: "center"
}, /*#__PURE__*/React.createElement(Box, {
background: "dark-3",
pad: "medium",
align: "center",
justify: "start",
ref: targetRef
}, "Target"), targetRef.current && /*#__PURE__*/React.createElement(Drop, {
overflow: "unset",
align: {
top: 'bottom',
left: 'left'
},
target: targetRef.current,
onClose: function onClose() {
return setShowCalendar(false);
}
}, /*#__PURE__*/React.createElement(Box, {
height: "small"
}, /*#__PURE__*/React.createElement(Heading, {
level: 4
}, "Select Start Date"), /*#__PURE__*/React.createElement("div", {
style: {
position: 'relative'
}
}, /*#__PURE__*/React.createElement(TextInput, {
ref: inputRef,
value: date || '',
placeholder: "Focus on me",
onFocus: function onFocus() {
return setShowCalendar(true);
}
}), showCalendar && /*#__PURE__*/React.createElement("div", {
style: {
position: 'absolute',
background: '#eee'
}
}, /*#__PURE__*/React.createElement(Calendar, {
date: date,
onSelect: onSelect,
size: "small"
})))))));
};
export var Overflow = function Overflow() {
return /*#__PURE__*/React.createElement(OverflowDrop, null);
};
Overflow.story = {
parameters: {
chromatic: {
disable: true
}
}
};