UNPKG

grommet

Version:

focus on the essential experience

143 lines (141 loc) 5.72 kB
"use strict"; exports.__esModule = true; exports["default"] = exports.UnSolicitedFeedback = void 0; var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _grommet = require("grommet"); var _defaultProps = require("../../../default-props"); function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; } function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); } // create a floating button for story example // temp fix until this theme issue is resolved: // https://github.com/grommet/grommet-theme-hpe/issues/283 var PositionedFeedbackButton = (0, _styledComponents["default"])(_grommet.Button).attrs(_defaultProps.withTheme).withConfig({ displayName: "UnsolicitedFeedbackstories__PositionedFeedbackButton", componentId: "sc-1b6e3v6-0" })(["position:fixed;bottom:0px;border-radius:6px;right:0px;z-index:10;color:", ";"], function (props) { return props.theme.global.colors['text-strong'].dark; }); // This example shows a way to perform validation across multiple fields. var UnSolicitedFeedback = exports.UnSolicitedFeedback = function UnSolicitedFeedback() { var size = (0, _react.useContext)(_grommet.ResponsiveContext); var _useState = (0, _react.useState)(false), isSuccessful = _useState[0], setIsSuccessful = _useState[1]; var _useState2 = (0, _react.useState)(false), open = _useState2[0], setOpen = _useState2[1]; var onOpen = function onOpen() { return setOpen(true); }; var onClose = function onClose() { return setOpen(undefined); }; var closeFeedbackModal = function closeFeedbackModal() { setTimeout(function () { setOpen(false); setIsSuccessful(false); }, 2000); }; return ( /*#__PURE__*/ // Uncomment <Grommet> lines when using outside of storybook // <Grommet theme={...}> _react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(PositionedFeedbackButton, { onClick: onOpen, margin: { vertical: 'medium', horizontal: 'medium' }, elevation: "large", color: "brand", label: "Submit Feedback", a11yTitle: "This button launches a modal to give feedback.", primary: true, alignSelf: "start" }), open && /*#__PURE__*/_react["default"].createElement(_grommet.Layer, { onClickOutside: onClose, onEsc: onClose }, /*#__PURE__*/_react["default"].createElement(_grommet.Box, { fill: "vertical", overflow: "auto", width: !['xsmall', 'small'].includes(size) ? 'medium' : undefined, pad: "medium", gap: "medium" }, /*#__PURE__*/_react["default"].createElement(_grommet.Header, { direction: "column", align: "start", gap: "xxsmall", pad: { horizontal: 'xxsmall' } }, /*#__PURE__*/_react["default"].createElement(_grommet.Heading, { level: 4, size: "small", margin: "none" }, "Let us know how your expirence was!")), /*#__PURE__*/_react["default"].createElement(_grommet.Box // Padding used to prevent focus from being cutoff , { pad: { horizontal: 'xxsmall' } }, /*#__PURE__*/_react["default"].createElement(_grommet.Form, { method: "post", validate: "submit", kind: "survey", onSubmit: function onSubmit(value) { console.log('submit', value); setIsSuccessful(true); closeFeedbackModal(); } }, /*#__PURE__*/_react["default"].createElement(_grommet.FormField, { htmlFor: "thumbs-rating", name: "rating", label: "Was this content helpful?" }, /*#__PURE__*/_react["default"].createElement(_grommet.ThumbsRating, { id: "thumbs-rating", name: "rating" })), /*#__PURE__*/_react["default"].createElement(_grommet.FormField, { label: "Comments", htmlFor: "comments", name: "comments" }, /*#__PURE__*/_react["default"].createElement(_grommet.TextArea, { id: "comments", name: "comments" })), !isSuccessful ? /*#__PURE__*/_react["default"].createElement(_grommet.Footer, { margin: { top: 'medium', bottom: 'small' }, direction: "row", justify: "end", gap: "small" }, /*#__PURE__*/_react["default"].createElement(_grommet.Button, { onClick: onClose, label: "Cancel" }), /*#__PURE__*/_react["default"].createElement(_grommet.Button, { label: "Submit Feedback", primary: true, type: "submit" })) : /*#__PURE__*/_react["default"].createElement(_grommet.Footer, { margin: { top: 'medium', bottom: 'small' }, align: "end" }, /*#__PURE__*/_react["default"].createElement(_grommet.Text, { weight: "bold", size: "large" }, "Thank you for your response!"))))))) // </Grommet> ); }; UnSolicitedFeedback.storyName = 'UnSolicited feedback'; UnSolicitedFeedback.parameters = { chromatic: { disable: true } }; var _default = exports["default"] = { title: 'Input/Form/UnSolicited feedback' };