payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
203 lines (202 loc) • 19.7 kB
JavaScript
"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"}