UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

88 lines (87 loc) 12.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _react = /*#__PURE__*/ _interop_require_default(require("react")); const _reacti18next = require("react-i18next"); const _ = /*#__PURE__*/ _interop_require_default(require("../..")); const _types = require("../../../../../../../fields/config/types"); const _getTranslation = require("../../../../../../../utilities/getTranslation"); const _getUniqueListBy = /*#__PURE__*/ _interop_require_default(require("../../../../../../../utilities/getUniqueListBy")); const _Label = /*#__PURE__*/ _interop_require_default(require("../../Label")); require("./index.scss"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const baseClass = 'iterable-diff'; const Iterable = ({ comparison, field, fieldComponents, locale, locales, permissions, version })=>{ const versionRowCount = Array.isArray(version) ? version.length : 0; const comparisonRowCount = Array.isArray(comparison) ? comparison.length : 0; const maxRows = Math.max(versionRowCount, comparisonRowCount); const { i18n, t } = (0, _reacti18next.useTranslation)('version'); return /*#__PURE__*/ _react.default.createElement("div", { className: baseClass }, field.label && /*#__PURE__*/ _react.default.createElement(_Label.default, null, locale && /*#__PURE__*/ _react.default.createElement("span", { className: `${baseClass}__locale-label` }, locale), (0, _getTranslation.getTranslation)(field.label, i18n)), maxRows > 0 && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, Array.from(Array(maxRows).keys()).map((row, i)=>{ const versionRow = version?.[i] || {}; const comparisonRow = comparison?.[i] || {}; let subFields = []; if (field.type === 'array') subFields = field.fields; if (field.type === 'blocks') { subFields = [ { name: 'blockType', label: t('fields:blockType'), type: 'text' } ]; if (versionRow?.blockType === comparisonRow?.blockType) { const matchedBlock = field.blocks.find((block)=>block.slug === versionRow?.blockType) || { fields: [] }; subFields = [ ...subFields, ...matchedBlock.fields ]; } else { const matchedVersionBlock = field.blocks.find((block)=>block.slug === versionRow?.blockType) || { fields: [] }; const matchedComparisonBlock = field.blocks.find((block)=>block.slug === comparisonRow?.blockType) || { fields: [] }; subFields = (0, _getUniqueListBy.default)([ ...subFields, ...matchedVersionBlock.fields, ...matchedComparisonBlock.fields ], 'name'); } } return /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__wrap`, key: i }, /*#__PURE__*/ _react.default.createElement(_.default, { comparison: comparisonRow, fieldComponents: fieldComponents, fieldPermissions: permissions, fields: subFields.filter((subField)=>!((0, _types.fieldAffectsData)(subField) && subField.name === 'id')), locales: locales, version: versionRow })); })), maxRows === 0 && /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__no-rows` }, t('noRowsFound', { label: field.labels?.plural ? (0, _getTranslation.getTranslation)(field.labels?.plural, i18n) : t('general:rows') }))); }; const _default = Iterable; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../../../src/admin/components/views/Version/RenderFieldsToDiff/fields/Iterable/index.tsx"],"sourcesContent":["import React from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { ArrayField, BlockField, Field } from '../../../../../../../fields/config/types'\nimport type { Props } from '../types'\n\nimport RenderFieldsToDiff from '../..'\nimport { fieldAffectsData } from '../../../../../../../fields/config/types'\nimport { getTranslation } from '../../../../../../../utilities/getTranslation'\nimport getUniqueListBy from '../../../../../../../utilities/getUniqueListBy'\nimport Label from '../../Label'\nimport './index.scss'\n\nconst baseClass = 'iterable-diff'\n\nconst Iterable: React.FC<Props & { field: ArrayField | BlockField }> = ({\n  comparison,\n  field,\n  fieldComponents,\n  locale,\n  locales,\n  permissions,\n  version,\n}) => {\n  const versionRowCount = Array.isArray(version) ? version.length : 0\n  const comparisonRowCount = Array.isArray(comparison) ? comparison.length : 0\n  const maxRows = Math.max(versionRowCount, comparisonRowCount)\n  const { i18n, t } = useTranslation('version')\n\n  return (\n    <div className={baseClass}>\n      {field.label && (\n        <Label>\n          {locale && <span className={`${baseClass}__locale-label`}>{locale}</span>}\n          {getTranslation(field.label, i18n)}\n        </Label>\n      )}\n      {maxRows > 0 && (\n        <React.Fragment>\n          {Array.from(Array(maxRows).keys()).map((row, i) => {\n            const versionRow = version?.[i] || {}\n            const comparisonRow = comparison?.[i] || {}\n\n            let subFields: Field[] = []\n\n            if (field.type === 'array') subFields = field.fields\n\n            if (field.type === 'blocks') {\n              subFields = [\n                {\n                  name: 'blockType',\n                  label: t('fields:blockType'),\n                  type: 'text',\n                },\n              ]\n\n              if (versionRow?.blockType === comparisonRow?.blockType) {\n                const matchedBlock = field.blocks.find(\n                  (block) => block.slug === versionRow?.blockType,\n                ) || { fields: [] }\n                subFields = [...subFields, ...matchedBlock.fields]\n              } else {\n                const matchedVersionBlock = field.blocks.find(\n                  (block) => block.slug === versionRow?.blockType,\n                ) || { fields: [] }\n                const matchedComparisonBlock = field.blocks.find(\n                  (block) => block.slug === comparisonRow?.blockType,\n                ) || { fields: [] }\n\n                subFields = getUniqueListBy<Field>(\n                  [...subFields, ...matchedVersionBlock.fields, ...matchedComparisonBlock.fields],\n                  'name',\n                )\n              }\n            }\n\n            return (\n              <div className={`${baseClass}__wrap`} key={i}>\n                <RenderFieldsToDiff\n                  comparison={comparisonRow}\n                  fieldComponents={fieldComponents}\n                  fieldPermissions={permissions}\n                  fields={subFields.filter(\n                    (subField) => !(fieldAffectsData(subField) && subField.name === 'id'),\n                  )}\n                  locales={locales}\n                  version={versionRow}\n                />\n              </div>\n            )\n          })}\n        </React.Fragment>\n      )}\n      {maxRows === 0 && (\n        <div className={`${baseClass}__no-rows`}>\n          {t('noRowsFound', {\n            label: field.labels?.plural\n              ? getTranslation(field.labels?.plural, i18n)\n              : t('general:rows'),\n          })}\n        </div>\n      )}\n    </div>\n  )\n}\n\nexport default Iterable\n"],"names":["baseClass","Iterable","comparison","field","fieldComponents","locale","locales","permissions","version","versionRowCount","Array","isArray","length","comparisonRowCount","maxRows","Math","max","i18n","t","useTranslation","div","className","label","Label","span","getTranslation","React","Fragment","from","keys","map","row","i","versionRow","comparisonRow","subFields","type","fields","name","blockType","matchedBlock","blocks","find","block","slug","matchedVersionBlock","matchedComparisonBlock","getUniqueListBy","key","RenderFieldsToDiff","fieldPermissions","filter","subField","fieldAffectsData","labels","plural"],"mappings":";;;;+BA0GA;;;eAAA;;;8DA1GkB;8BACa;yDAKA;uBACE;gCACF;wEACH;8DACV;QACX;;;;;;AAEP,MAAMA,YAAY;AAElB,MAAMC,WAAiE,CAAC,EACtEC,UAAU,EACVC,KAAK,EACLC,eAAe,EACfC,MAAM,EACNC,OAAO,EACPC,WAAW,EACXC,OAAO,EACR;IACC,MAAMC,kBAAkBC,MAAMC,OAAO,CAACH,WAAWA,QAAQI,MAAM,GAAG;IAClE,MAAMC,qBAAqBH,MAAMC,OAAO,CAACT,cAAcA,WAAWU,MAAM,GAAG;IAC3E,MAAME,UAAUC,KAAKC,GAAG,CAACP,iBAAiBI;IAC1C,MAAM,EAAEI,IAAI,EAAEC,CAAC,EAAE,GAAGC,IAAAA,4BAAc,EAAC;IAEnC,qBACE,6BAACC;QAAIC,WAAWrB;OACbG,MAAMmB,KAAK,kBACV,6BAACC,cAAK,QACHlB,wBAAU,6BAACmB;QAAKH,WAAW,CAAC,EAAErB,UAAU,cAAc,CAAC;OAAGK,SAC1DoB,IAAAA,8BAAc,EAACtB,MAAMmB,KAAK,EAAEL,QAGhCH,UAAU,mBACT,6BAACY,cAAK,CAACC,QAAQ,QACZjB,MAAMkB,IAAI,CAAClB,MAAMI,SAASe,IAAI,IAAIC,GAAG,CAAC,CAACC,KAAKC;QAC3C,MAAMC,aAAazB,SAAS,CAACwB,EAAE,IAAI,CAAC;QACpC,MAAME,gBAAgBhC,YAAY,CAAC8B,EAAE,IAAI,CAAC;QAE1C,IAAIG,YAAqB,EAAE;QAE3B,IAAIhC,MAAMiC,IAAI,KAAK,SAASD,YAAYhC,MAAMkC,MAAM;QAEpD,IAAIlC,MAAMiC,IAAI,KAAK,UAAU;YAC3BD,YAAY;gBACV;oBACEG,MAAM;oBACNhB,OAAOJ,EAAE;oBACTkB,MAAM;gBACR;aACD;YAED,IAAIH,YAAYM,cAAcL,eAAeK,WAAW;gBACtD,MAAMC,eAAerC,MAAMsC,MAAM,CAACC,IAAI,CACpC,CAACC,QAAUA,MAAMC,IAAI,KAAKX,YAAYM,cACnC;oBAAEF,QAAQ,EAAE;gBAAC;gBAClBF,YAAY;uBAAIA;uBAAcK,aAAaH,MAAM;iBAAC;YACpD,OAAO;gBACL,MAAMQ,sBAAsB1C,MAAMsC,MAAM,CAACC,IAAI,CAC3C,CAACC,QAAUA,MAAMC,IAAI,KAAKX,YAAYM,cACnC;oBAAEF,QAAQ,EAAE;gBAAC;gBAClB,MAAMS,yBAAyB3C,MAAMsC,MAAM,CAACC,IAAI,CAC9C,CAACC,QAAUA,MAAMC,IAAI,KAAKV,eAAeK,cACtC;oBAAEF,QAAQ,EAAE;gBAAC;gBAElBF,YAAYY,IAAAA,wBAAe,EACzB;uBAAIZ;uBAAcU,oBAAoBR,MAAM;uBAAKS,uBAAuBT,MAAM;iBAAC,EAC/E;YAEJ;QACF;QAEA,qBACE,6BAACjB;YAAIC,WAAW,CAAC,EAAErB,UAAU,MAAM,CAAC;YAAEgD,KAAKhB;yBACzC,6BAACiB,SAAkB;YACjB/C,YAAYgC;YACZ9B,iBAAiBA;YACjB8C,kBAAkB3C;YAClB8B,QAAQF,UAAUgB,MAAM,CACtB,CAACC,WAAa,CAAEC,CAAAA,IAAAA,uBAAgB,EAACD,aAAaA,SAASd,IAAI,KAAK,IAAG;YAErEhC,SAASA;YACTE,SAASyB;;IAIjB,KAGHnB,YAAY,mBACX,6BAACM;QAAIC,WAAW,CAAC,EAAErB,UAAU,SAAS,CAAC;OACpCkB,EAAE,eAAe;QAChBI,OAAOnB,MAAMmD,MAAM,EAAEC,SACjB9B,IAAAA,8BAAc,EAACtB,MAAMmD,MAAM,EAAEC,QAAQtC,QACrCC,EAAE;IACR;AAKV;MAEA,WAAejB"}