UNPKG

mindstream-react-gravity-form

Version:

A component for including Gravity Forms on React apps via the Wordpress API

2 lines 16.1 kB
"use strict";function _typeof(a){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a},_typeof(a)}Object.defineProperty(exports,"__esModule",{value:!0}),exports["default"]=void 0;var _react=_interopRequireWildcard(require("react")),_DatePicker=_interopRequireDefault(require("./DatePicker")),_DateSelect=_interopRequireDefault(require("./DateSelect")),_DateInput=_interopRequireDefault(require("./DateInput")),_InputLabel=_interopRequireDefault(require("../../FormElements/InputLabel"));function _interopRequireDefault(a){return a&&a.__esModule?a:{default:a}}function _getRequireWildcardCache(){if("function"!=typeof WeakMap)return null;var a=new WeakMap;return _getRequireWildcardCache=function(){return a},a}function _interopRequireWildcard(a){if(a&&a.__esModule)return a;if(null===a||"object"!==_typeof(a)&&"function"!=typeof a)return{default:a};var b=_getRequireWildcardCache();if(b&&b.has(a))return b.get(a);var c={},d=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var e in a)if(Object.prototype.hasOwnProperty.call(a,e)){var f=d?Object.getOwnPropertyDescriptor(a,e):null;f&&(f.get||f.set)?Object.defineProperty(c,e,f):c[e]=a[e]}return c["default"]=a,b&&b.set(a,c),c}function ownKeys(a,b){var c=Object.keys(a);if(Object.getOwnPropertySymbols){var d=Object.getOwnPropertySymbols(a);b&&(d=d.filter(function(b){return Object.getOwnPropertyDescriptor(a,b).enumerable})),c.push.apply(c,d)}return c}function _objectSpread(a){for(var b,c=1;c<arguments.length;c++)b=null==arguments[c]?{}:arguments[c],c%2?ownKeys(Object(b),!0).forEach(function(c){_defineProperty(a,c,b[c])}):Object.getOwnPropertyDescriptors?Object.defineProperties(a,Object.getOwnPropertyDescriptors(b)):ownKeys(Object(b)).forEach(function(c){Object.defineProperty(a,c,Object.getOwnPropertyDescriptor(b,c))});return a}function _defineProperty(a,b,c){return b in a?Object.defineProperty(a,b,{value:c,enumerable:!0,configurable:!0,writable:!0}):a[b]=c,a}function _slicedToArray(a,b){return _arrayWithHoles(a)||_iterableToArrayLimit(a,b)||_unsupportedIterableToArray(a,b)||_nonIterableRest()}function _nonIterableRest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(a,b){if(a){if("string"==typeof a)return _arrayLikeToArray(a,b);var c=Object.prototype.toString.call(a).slice(8,-1);return"Object"===c&&a.constructor&&(c=a.constructor.name),"Map"===c||"Set"===c?Array.from(a):"Arguments"===c||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(c)?_arrayLikeToArray(a,b):void 0}}function _arrayLikeToArray(a,b){(null==b||b>a.length)&&(b=a.length);for(var c=0,d=Array(b);c<b;c++)d[c]=a[c];return d}function _iterableToArrayLimit(a,b){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(a)){var c=[],d=!0,e=!1,f=void 0;try{for(var g,h=a[Symbol.iterator]();!(d=(g=h.next()).done)&&(c.push(g.value),!(b&&c.length===b));d=!0);}catch(a){e=!0,f=a}finally{try{d||null==h["return"]||h["return"]()}finally{if(e)throw f}}return c}}function _arrayWithHoles(a){if(Array.isArray(a))return a}function _objectWithoutProperties(a,b){if(null==a)return{};var c,d,e=_objectWithoutPropertiesLoose(a,b);if(Object.getOwnPropertySymbols){var f=Object.getOwnPropertySymbols(a);for(d=0;d<f.length;d++)c=f[d],!(0<=b.indexOf(c))&&Object.prototype.propertyIsEnumerable.call(a,c)&&(e[c]=a[c])}return e}function _objectWithoutPropertiesLoose(a,b){if(null==a)return{};var c,d,e={},f=Object.keys(a);for(d=0;d<f.length;d++)c=f[d],0<=b.indexOf(c)||(e[c]=a[c]);return e}var _default=function(a){var b=a.field,c=a.value,d=a.validationMessage,e=a.touched,f=a.setTouched,g=a.hideField,h=a.updateForm,i=a.styledComponents,j=a.error,k=a.unsetError,l=a.setFocusClass,m=a.cssClass,n=_objectWithoutProperties(a,["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","setFocusClass","cssClass"]),o=b.id,p=b.formId,q=b.type,r=b.label,s=b.isRequired,t=b.description,u=b.descriptionPlacement,v=b.labelPlacement,w=b.width,x=b.inputs,y=b.dateType,z=b.dateFormat,A=b.defaultValue,B=(i||!1).Box,C=void 0===B?"div":B,D=!!(z&&"dmy"===z)&&"dd/MM/yyyy",E=!!A&&new Date(A);if(D&&A){var F=-1<A.indexOf("/"),G=F?A.split("/"):A.split("-"),H=F?new Date(+G[2],G[1]-1,+G[0]):G;E=H}var I=(0,_react.useState)(E),J=_slicedToArray(I,2),K=J[0],L=J[1],M=function getFormattedInputs(a){if(y){if("datefield"===y)return"dmy"===z||"dmy_dash"===z||"dmy_dot"===z?[a[1],a[0],a[2]]:"ymd_slash"===z||"ymd_dash"===z||"ymd_dot"===z?[a[2],a[0],a[1]]:a;if("datedropdown"===y)return[a[1],a[0],a[2]]}return a}(x),N=_objectSpread({id:o,field:b,isRequired:s,format:D,formattedInputs:M,updateForm:h,startDate:K,setTouched:f,setDate:L,setFocusClass:l,error:j,unsetError:k,validationMessage:d,styledComponents:i,touched:e},n);return _react["default"].createElement(C,{width:w,className:d&&e||j?"form-field error ".concat(m):"form-field ".concat(m),style:{display:g?"none":void 0}},_react["default"].createElement(_InputLabel["default"],{formId:p,id:o,label:r,labelPlacement:v,isRequired:s,styledComponent:i}),_react["default"].createElement("div",{className:q},"above"===u&&t&&_react["default"].createElement("div",{className:"description"},t),y&&function renderDateField(a){return"datepicker"===a?_react["default"].createElement(_DatePicker["default"],{defaultProps:N}):"datedropdown"===a?_react["default"].createElement(_DateSelect["default"],{defaultProps:N}):_react["default"].createElement(_DateInput["default"],{defaultProps:N})}(y),"above"!==u&&t&&_react["default"].createElement("div",{className:"description"},t)))};exports["default"]=_default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Fields/Date/Date.jsx"],"names":["field","value","validationMessage","touched","setTouched","hideField","updateForm","styledComponents","error","unsetError","setFocusClass","cssClass","props","id","formId","type","label","isRequired","description","descriptionPlacement","labelPlacement","width","inputs","dateType","dateFormat","defaultValue","Box","format","selectedValue","Date","tmpFormat","indexOf","dateParts","split","dateObject","startDate","setDate","formattedInputs","getFormattedInputs","items","defaultProps","display","renderDateField"],"mappings":"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","sourcesContent":["import React, { useState } from 'react';\r\n\r\n// components\r\nimport DatePicker from './DatePicker';\r\nimport DateSelect from './DateSelect';\r\nimport DateInput from './DateInput';\r\nimport InputLabel from '../../FormElements/InputLabel';\r\n\r\nexport default ({\r\n  field,\r\n  value,\r\n  validationMessage,\r\n  touched,\r\n  setTouched,\r\n  hideField,\r\n  updateForm,\r\n  styledComponents,\r\n  error,\r\n  unsetError,\r\n  setFocusClass,\r\n  cssClass,\r\n  ...props\r\n}) => {\r\n  const {\r\n    id,\r\n    formId,\r\n    type,\r\n    label,\r\n    isRequired,\r\n    description,\r\n    descriptionPlacement,\r\n    labelPlacement,\r\n    width,\r\n    inputs,\r\n    dateType,\r\n    dateFormat,\r\n    defaultValue,\r\n  } = field;\r\n\r\n  const {\r\n    Box = 'div',\r\n  } = styledComponents || false;\r\n\r\n  // convert date format\r\n  const format = dateFormat && dateFormat === 'dmy' ? 'dd/MM/yyyy' : false;\r\n  let selectedValue = defaultValue ? new Date(defaultValue) : false;\r\n\r\n  if (format && defaultValue) {\r\n    const tmpFormat = defaultValue.indexOf('/') > -1;\r\n    const dateParts = tmpFormat\r\n      ? defaultValue.split('/')\r\n      : defaultValue.split('-');\r\n\r\n    const dateObject = tmpFormat\r\n      ? new Date(+dateParts[2], dateParts[1] - 1, +dateParts[0])\r\n      : dateParts;\r\n\r\n    selectedValue = dateObject;\r\n  }\r\n\r\n  const [startDate, setDate] = useState(selectedValue);\r\n\r\n  const getFormattedInputs = (items) => {\r\n    if (dateType) {\r\n      if (dateType === 'datefield') {\r\n        switch (dateFormat) {\r\n          case 'dmy':\r\n          case 'dmy_dash':\r\n          case 'dmy_dot':\r\n            return [items[1], items[0], items[2]];\r\n          case 'ymd_slash':\r\n          case 'ymd_dash':\r\n          case 'ymd_dot':\r\n            return [items[2], items[0], items[1]];\r\n          default:\r\n            return items;\r\n        }\r\n      } else if (dateType === 'datedropdown') {\r\n        return [items[1], items[0], items[2]];\r\n      }\r\n    }\r\n    return items;\r\n  };\r\n\r\n  const formattedInputs = getFormattedInputs(inputs);\r\n\r\n  const defaultProps = {\r\n    id,\r\n    field,\r\n    isRequired,\r\n    format,\r\n    formattedInputs,\r\n    updateForm,\r\n    startDate,\r\n    setTouched,\r\n    setDate,\r\n    setFocusClass,\r\n    error,\r\n    unsetError,\r\n    validationMessage,\r\n    styledComponents,\r\n    touched,\r\n    ...props,\r\n  };\r\n\r\n  const renderDateField = (dateType) => {\r\n    switch (dateType) {\r\n      case 'datepicker':\r\n        return <DatePicker defaultProps={defaultProps} />;\r\n      case 'datedropdown':\r\n        return <DateSelect defaultProps={defaultProps} />;\r\n      default:\r\n        return <DateInput defaultProps={defaultProps} />;\r\n    }\r\n  };\r\n\r\n  return (\r\n    <Box\r\n      width={width}\r\n      className={\r\n        (validationMessage && touched) || error\r\n          ? `form-field error ${cssClass}`\r\n          : `form-field ${cssClass}`\r\n      }\r\n      style={{ display: hideField ? 'none' : undefined }}\r\n    >\r\n      <InputLabel\r\n        formId={formId}\r\n        id={id}\r\n        label={label}\r\n        labelPlacement={labelPlacement}\r\n        isRequired={isRequired}\r\n        styledComponent={styledComponents}\r\n      />\r\n      <div className={type}>\r\n        {descriptionPlacement === 'above' && description && (\r\n          <div className=\"description\">{description}</div>\r\n        )}\r\n        {dateType && renderDateField(dateType)}\r\n        {descriptionPlacement !== 'above' && description && (\r\n          <div className=\"description\">{description}</div>\r\n        )}\r\n      </div>\r\n    </Box>\r\n  );\r\n};\r\n"]}