UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

203 lines (202 loc) • 19.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _useDebounce = /*#__PURE__*/ _interop_require_default(require("../../../../hooks/useDebounce")); const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../../utilities/RenderCustomComponent")); const _Button = /*#__PURE__*/ _interop_require_default(require("../../Button")); const _ReactSelect = /*#__PURE__*/ _interop_require_default(require("../../ReactSelect")); const _Date = /*#__PURE__*/ _interop_require_default(require("./Date")); const _Number = /*#__PURE__*/ _interop_require_default(require("./Number")); const _Relationship = /*#__PURE__*/ _interop_require_default(require("./Relationship")); const _Select = require("./Select"); const _Text = /*#__PURE__*/ _interop_require_default(require("./Text")); require("./index.scss"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interop_require_wildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = { __proto__: null }; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for(var key in obj){ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } const valueFields = { Date: _Date.default, Number: _Number.default, Relationship: _Relationship.default, Select: _Select.Select, Text: _Text.default }; const baseClass = 'condition'; const Condition = (props)=>{ const { andIndex, dispatch, fields, orIndex, value } = props; const fieldName = Object.keys(value)[0]; const [activeField, setActiveField] = (0, _react.useState)(()=>fields.find((field)=>fieldName === field.value)); const operatorAndValue = value?.[fieldName] ? Object.entries(value[fieldName])[0] : undefined; const queryValue = operatorAndValue?.[1]; const operatorValue = operatorAndValue?.[0]; const [internalValue, setInternalValue] = (0, _react.useState)(queryValue); const [internalOperatorField, setInternalOperatorField] = (0, _react.useState)(operatorValue); const debouncedValue = (0, _useDebounce.default)(internalValue, 300); (0, _react.useEffect)(()=>{ const newActiveField = fields.find(({ value: name })=>name === fieldName); if (newActiveField && newActiveField !== activeField) { setActiveField(newActiveField); setInternalOperatorField(null); setInternalValue(''); } }, [ fieldName, fields, activeField ]); (0, _react.useEffect)(()=>{ dispatch({ andIndex, orIndex, type: 'update', value: debouncedValue || '' }); }, [ debouncedValue, dispatch, orIndex, andIndex ]); const booleanSelect = [ 'exists' ].includes(operatorValue) || activeField.props.type === 'checkbox'; const ValueComponent = booleanSelect ? _Select.Select : valueFields[activeField?.component] || valueFields.Text; let valueOptions; if (booleanSelect) { valueOptions = [ 'true', 'false' ]; } else if (activeField?.props && 'options' in activeField.props) { valueOptions = activeField.props.options; } return /*#__PURE__*/ _react.default.createElement("div", { className: baseClass }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__wrap` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__inputs` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__field` }, /*#__PURE__*/ _react.default.createElement(_ReactSelect.default, { isClearable: false, onChange: (field)=>{ dispatch({ andIndex: andIndex, field: field?.value, orIndex: orIndex, type: 'update' }); }, options: fields, value: fields.find((field)=>fieldName === field.value) })), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__operator` }, /*#__PURE__*/ _react.default.createElement(_ReactSelect.default, { disabled: !fieldName, isClearable: false, onChange: (operator)=>{ dispatch({ andIndex, operator: operator.value, orIndex, type: 'update' }); setInternalOperatorField(operator.value); }, options: activeField.operators, value: activeField.operators.find((operator)=>internalOperatorField === operator.value) || null })), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__value` }, /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, { CustomComponent: activeField?.props?.admin?.components?.Filter, DefaultComponent: ValueComponent, componentProps: { ...activeField?.props, disabled: !operatorValue, onChange: setInternalValue, operator: operatorValue, options: valueOptions, value: internalValue } }))), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__actions` }, /*#__PURE__*/ _react.default.createElement(_Button.default, { buttonStyle: "icon-label", className: `${baseClass}__actions-remove`, icon: "x", iconStyle: "with-border", onClick: ()=>dispatch({ andIndex, orIndex, type: 'remove' }), round: true }), /*#__PURE__*/ _react.default.createElement(_Button.default, { buttonStyle: "icon-label", className: `${baseClass}__actions-add`, icon: "plus", iconStyle: "with-border", onClick: ()=>dispatch({ andIndex: andIndex + 1, field: fields[0].value, orIndex, relation: 'and', type: 'add' }), round: true })))); }; const _default = Condition; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/admin/components/elements/WhereBuilder/Condition/index.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react'\n\nimport type { FieldCondition } from '../types'\nimport type { Props } from './types'\n\nimport useDebounce from '../../../../hooks/useDebounce'\nimport RenderCustomComponent from '../../../utilities/RenderCustomComponent'\nimport Button from '../../Button'\nimport ReactSelect from '../../ReactSelect'\nimport Date from './Date'\nimport Number from './Number'\nimport Relationship from './Relationship'\nimport { Select } from './Select'\nimport Text from './Text'\nimport './index.scss'\n\nconst valueFields = {\n  Date,\n  Number,\n  Relationship,\n  Select,\n  Text,\n}\n\nconst baseClass = 'condition'\n\nconst Condition: React.FC<Props> = (props) => {\n  const { andIndex, dispatch, fields, orIndex, value } = props\n  const fieldName = Object.keys(value)[0]\n  const [activeField, setActiveField] = useState<FieldCondition>(() =>\n    fields.find((field) => fieldName === field.value),\n  )\n\n  const operatorAndValue = value?.[fieldName] ? Object.entries(value[fieldName])[0] : undefined\n  const queryValue = operatorAndValue?.[1]\n  const operatorValue = operatorAndValue?.[0]\n\n  const [internalValue, setInternalValue] = useState(queryValue)\n  const [internalOperatorField, setInternalOperatorField] = useState(operatorValue)\n\n  const debouncedValue = useDebounce(internalValue, 300)\n\n  useEffect(() => {\n    const newActiveField = fields.find(({ value: name }) => name === fieldName)\n\n    if (newActiveField && newActiveField !== activeField) {\n      setActiveField(newActiveField)\n      setInternalOperatorField(null)\n      setInternalValue('')\n    }\n  }, [fieldName, fields, activeField])\n\n  useEffect(() => {\n    dispatch({\n      andIndex,\n      orIndex,\n      type: 'update',\n      value: debouncedValue || '',\n    })\n  }, [debouncedValue, dispatch, orIndex, andIndex])\n\n  const booleanSelect = ['exists'].includes(operatorValue) || activeField.props.type === 'checkbox'\n  const ValueComponent = booleanSelect\n    ? Select\n    : valueFields[activeField?.component] || valueFields.Text\n\n  let valueOptions\n  if (booleanSelect) {\n    valueOptions = ['true', 'false']\n  } else if (activeField?.props && 'options' in activeField.props) {\n    valueOptions = activeField.props.options\n  }\n\n  return (\n    <div className={baseClass}>\n      <div className={`${baseClass}__wrap`}>\n        <div className={`${baseClass}__inputs`}>\n          <div className={`${baseClass}__field`}>\n            <ReactSelect\n              isClearable={false}\n              onChange={(field) => {\n                dispatch({\n                  andIndex: andIndex,\n                  field: field?.value,\n                  orIndex: orIndex,\n                  type: 'update',\n                })\n              }}\n              options={fields}\n              value={fields.find((field) => fieldName === field.value)}\n            />\n          </div>\n          <div className={`${baseClass}__operator`}>\n            <ReactSelect\n              disabled={!fieldName}\n              isClearable={false}\n              onChange={(operator) => {\n                dispatch({\n                  andIndex,\n                  operator: operator.value,\n                  orIndex,\n                  type: 'update',\n                })\n                setInternalOperatorField(operator.value)\n              }}\n              options={activeField.operators}\n              value={\n                activeField.operators.find(\n                  (operator) => internalOperatorField === operator.value,\n                ) || null\n              }\n            />\n          </div>\n          <div className={`${baseClass}__value`}>\n            <RenderCustomComponent\n              CustomComponent={activeField?.props?.admin?.components?.Filter}\n              DefaultComponent={ValueComponent}\n              componentProps={{\n                ...activeField?.props,\n                disabled: !operatorValue,\n                onChange: setInternalValue,\n                operator: operatorValue,\n                options: valueOptions,\n                value: internalValue,\n              }}\n            />\n          </div>\n        </div>\n        <div className={`${baseClass}__actions`}>\n          <Button\n            buttonStyle=\"icon-label\"\n            className={`${baseClass}__actions-remove`}\n            icon=\"x\"\n            iconStyle=\"with-border\"\n            onClick={() =>\n              dispatch({\n                andIndex,\n                orIndex,\n                type: 'remove',\n              })\n            }\n            round\n          />\n          <Button\n            buttonStyle=\"icon-label\"\n            className={`${baseClass}__actions-add`}\n            icon=\"plus\"\n            iconStyle=\"with-border\"\n            onClick={() =>\n              dispatch({\n                andIndex: andIndex + 1,\n                field: fields[0].value,\n                orIndex,\n                relation: 'and',\n                type: 'add',\n              })\n            }\n            round\n          />\n        </div>\n      </div>\n    </div>\n  )\n}\n\nexport default Condition\n"],"names":["valueFields","Date","Number","Relationship","Select","Text","baseClass","Condition","props","andIndex","dispatch","fields","orIndex","value","fieldName","Object","keys","activeField","setActiveField","useState","find","field","operatorAndValue","entries","undefined","queryValue","operatorValue","internalValue","setInternalValue","internalOperatorField","setInternalOperatorField","debouncedValue","useDebounce","useEffect","newActiveField","name","type","booleanSelect","includes","ValueComponent","component","valueOptions","options","div","className","ReactSelect","isClearable","onChange","disabled","operator","operators","RenderCustomComponent","CustomComponent","admin","components","Filter","DefaultComponent","componentProps","Button","buttonStyle","icon","iconStyle","onClick","round","relation"],"mappings":";;;;+BAqKA;;;eAAA;;;+DArK2C;oEAKnB;8EACU;+DACf;oEACK;6DACP;+DACE;qEACM;wBACF;6DACN;QACV;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEP,MAAMA,cAAc;IAClBC,MAAAA,aAAI;IACJC,QAAAA,eAAM;IACNC,cAAAA,qBAAY;IACZC,QAAAA,cAAM;IACNC,MAAAA,aAAI;AACN;AAEA,MAAMC,YAAY;AAElB,MAAMC,YAA6B,CAACC;IAClC,MAAM,EAAEC,QAAQ,EAAEC,QAAQ,EAAEC,MAAM,EAAEC,OAAO,EAAEC,KAAK,EAAE,GAAGL;IACvD,MAAMM,YAAYC,OAAOC,IAAI,CAACH,MAAM,CAAC,EAAE;IACvC,MAAM,CAACI,aAAaC,eAAe,GAAGC,IAAAA,eAAQ,EAAiB,IAC7DR,OAAOS,IAAI,CAAC,CAACC,QAAUP,cAAcO,MAAMR,KAAK;IAGlD,MAAMS,mBAAmBT,OAAO,CAACC,UAAU,GAAGC,OAAOQ,OAAO,CAACV,KAAK,CAACC,UAAU,CAAC,CAAC,EAAE,GAAGU;IACpF,MAAMC,aAAaH,kBAAkB,CAAC,EAAE;IACxC,MAAMI,gBAAgBJ,kBAAkB,CAAC,EAAE;IAE3C,MAAM,CAACK,eAAeC,iBAAiB,GAAGT,IAAAA,eAAQ,EAACM;IACnD,MAAM,CAACI,uBAAuBC,yBAAyB,GAAGX,IAAAA,eAAQ,EAACO;IAEnE,MAAMK,iBAAiBC,IAAAA,oBAAW,EAACL,eAAe;IAElDM,IAAAA,gBAAS,EAAC;QACR,MAAMC,iBAAiBvB,OAAOS,IAAI,CAAC,CAAC,EAAEP,OAAOsB,IAAI,EAAE,GAAKA,SAASrB;QAEjE,IAAIoB,kBAAkBA,mBAAmBjB,aAAa;YACpDC,eAAegB;YACfJ,yBAAyB;YACzBF,iBAAiB;QACnB;IACF,GAAG;QAACd;QAAWH;QAAQM;KAAY;IAEnCgB,IAAAA,gBAAS,EAAC;QACRvB,SAAS;YACPD;YACAG;YACAwB,MAAM;YACNvB,OAAOkB,kBAAkB;QAC3B;IACF,GAAG;QAACA;QAAgBrB;QAAUE;QAASH;KAAS;IAEhD,MAAM4B,gBAAgB;QAAC;KAAS,CAACC,QAAQ,CAACZ,kBAAkBT,YAAYT,KAAK,CAAC4B,IAAI,KAAK;IACvF,MAAMG,iBAAiBF,gBACnBjC,cAAM,GACNJ,WAAW,CAACiB,aAAauB,UAAU,IAAIxC,YAAYK,IAAI;IAE3D,IAAIoC;IACJ,IAAIJ,eAAe;QACjBI,eAAe;YAAC;YAAQ;SAAQ;IAClC,OAAO,IAAIxB,aAAaT,SAAS,aAAaS,YAAYT,KAAK,EAAE;QAC/DiC,eAAexB,YAAYT,KAAK,CAACkC,OAAO;IAC1C;IAEA,qBACE,6BAACC;QAAIC,WAAWtC;qBACd,6BAACqC;QAAIC,WAAW,CAAC,EAAEtC,UAAU,MAAM,CAAC;qBAClC,6BAACqC;QAAIC,WAAW,CAAC,EAAEtC,UAAU,QAAQ,CAAC;qBACpC,6BAACqC;QAAIC,WAAW,CAAC,EAAEtC,UAAU,OAAO,CAAC;qBACnC,6BAACuC,oBAAW;QACVC,aAAa;QACbC,UAAU,CAAC1B;YACTX,SAAS;gBACPD,UAAUA;gBACVY,OAAOA,OAAOR;gBACdD,SAASA;gBACTwB,MAAM;YACR;QACF;QACAM,SAAS/B;QACTE,OAAOF,OAAOS,IAAI,CAAC,CAACC,QAAUP,cAAcO,MAAMR,KAAK;uBAG3D,6BAAC8B;QAAIC,WAAW,CAAC,EAAEtC,UAAU,UAAU,CAAC;qBACtC,6BAACuC,oBAAW;QACVG,UAAU,CAAClC;QACXgC,aAAa;QACbC,UAAU,CAACE;YACTvC,SAAS;gBACPD;gBACAwC,UAAUA,SAASpC,KAAK;gBACxBD;gBACAwB,MAAM;YACR;YACAN,yBAAyBmB,SAASpC,KAAK;QACzC;QACA6B,SAASzB,YAAYiC,SAAS;QAC9BrC,OACEI,YAAYiC,SAAS,CAAC9B,IAAI,CACxB,CAAC6B,WAAapB,0BAA0BoB,SAASpC,KAAK,KACnD;uBAIX,6BAAC8B;QAAIC,WAAW,CAAC,EAAEtC,UAAU,OAAO,CAAC;qBACnC,6BAAC6C,8BAAqB;QACpBC,iBAAiBnC,aAAaT,OAAO6C,OAAOC,YAAYC;QACxDC,kBAAkBjB;QAClBkB,gBAAgB;YACd,GAAGxC,aAAaT,KAAK;YACrBwC,UAAU,CAACtB;YACXqB,UAAUnB;YACVqB,UAAUvB;YACVgB,SAASD;YACT5B,OAAOc;QACT;wBAIN,6BAACgB;QAAIC,WAAW,CAAC,EAAEtC,UAAU,SAAS,CAAC;qBACrC,6BAACoD,eAAM;QACLC,aAAY;QACZf,WAAW,CAAC,EAAEtC,UAAU,gBAAgB,CAAC;QACzCsD,MAAK;QACLC,WAAU;QACVC,SAAS,IACPpD,SAAS;gBACPD;gBACAG;gBACAwB,MAAM;YACR;QAEF2B,OAAAA;sBAEF,6BAACL,eAAM;QACLC,aAAY;QACZf,WAAW,CAAC,EAAEtC,UAAU,aAAa,CAAC;QACtCsD,MAAK;QACLC,WAAU;QACVC,SAAS,IACPpD,SAAS;gBACPD,UAAUA,WAAW;gBACrBY,OAAOV,MAAM,CAAC,EAAE,CAACE,KAAK;gBACtBD;gBACAoD,UAAU;gBACV5B,MAAM;YACR;QAEF2B,OAAAA;;AAMZ;MAEA,WAAexD"}