payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
107 lines (106 loc) • 13.9 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_default(require("react"));
const _types = require("../../../../../fields/config/types");
const _Nested = /*#__PURE__*/ _interop_require_default(require("./fields/Nested"));
const _diffMethods = require("./fields/diffMethods");
require("./index.scss");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
const baseClass = 'render-field-diffs';
const RenderFieldsToDiff = ({ comparison, fieldComponents, fieldPermissions, fields, locales, version })=>/*#__PURE__*/ _react.default.createElement("div", {
className: baseClass
}, fields.map((field, i)=>{
const Component = fieldComponents[field.type];
const isRichText = field.type === 'richText';
const diffMethod = _diffMethods.diffMethods[field.type] || 'CHARS';
if (Component) {
if ((0, _types.fieldAffectsData)(field)) {
const valueIsObject = field.type === 'code' || field.type === 'json';
const versionValue = valueIsObject ? JSON.stringify(version?.[field.name]) : version?.[field.name];
const comparisonValue = valueIsObject ? JSON.stringify(comparison?.[field.name]) : comparison?.[field.name];
const hasPermission = fieldPermissions?.[field.name]?.read?.permission;
const subFieldPermissions = fieldPermissions?.[field.name]?.fields;
if (hasPermission === false) return null;
if (field.localized) {
return /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__field`,
key: i
}, locales.map((locale, index)=>{
const versionLocaleValue = versionValue?.[locale];
const comparisonLocaleValue = comparisonValue?.[locale];
return /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__locale`,
key: [
locale,
index
].join('-')
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__locale-value`
}, /*#__PURE__*/ _react.default.createElement(Component, {
comparison: comparisonLocaleValue,
diffMethod: diffMethod,
field: field,
fieldComponents: fieldComponents,
isRichText: isRichText,
locale: locale,
locales: locales,
permissions: subFieldPermissions,
version: versionLocaleValue
})));
}));
}
return /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__field`,
key: i
}, /*#__PURE__*/ _react.default.createElement(Component, {
comparison: comparisonValue,
diffMethod: diffMethod,
field: field,
fieldComponents: fieldComponents,
isRichText: isRichText,
locales: locales,
permissions: subFieldPermissions,
version: versionValue
}));
}
if (field.type === 'tabs') {
const Tabs = fieldComponents.tabs;
return /*#__PURE__*/ _react.default.createElement(Tabs, {
comparison: comparison,
field: field,
fieldComponents: fieldComponents,
key: i,
locales: locales,
version: version
});
}
// At this point, we are dealing with a `row` or similar
if ((0, _types.fieldHasSubFields)(field)) {
return /*#__PURE__*/ _react.default.createElement(_Nested.default, {
comparison: comparison,
disableGutter: true,
field: field,
fieldComponents: fieldComponents,
key: i,
locales: locales,
permissions: fieldPermissions,
version: version
});
}
}
return null;
}));
const _default = RenderFieldsToDiff;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/admin/components/views/Version/RenderFieldsToDiff/index.tsx"],"sourcesContent":["import type { DiffMethod } from 'react-diff-viewer-continued'\n\nimport React from 'react'\n\nimport type { Props } from './types'\n\nimport { fieldAffectsData, fieldHasSubFields } from '../../../../../fields/config/types'\nimport Nested from './fields/Nested'\nimport { diffMethods } from './fields/diffMethods'\nimport './index.scss'\n\nconst baseClass = 'render-field-diffs'\n\nconst RenderFieldsToDiff: React.FC<Props> = ({\n  comparison,\n  fieldComponents,\n  fieldPermissions,\n  fields,\n  locales,\n  version,\n}) => (\n  <div className={baseClass}>\n    {fields.map((field, i) => {\n      const Component = fieldComponents[field.type]\n\n      const isRichText = field.type === 'richText'\n      const diffMethod: DiffMethod = diffMethods[field.type] || 'CHARS'\n\n      if (Component) {\n        if (fieldAffectsData(field)) {\n          const valueIsObject = field.type === 'code' || field.type === 'json'\n          const versionValue = valueIsObject\n            ? JSON.stringify(version?.[field.name])\n            : version?.[field.name]\n          const comparisonValue = valueIsObject\n            ? JSON.stringify(comparison?.[field.name])\n            : comparison?.[field.name]\n          const hasPermission = fieldPermissions?.[field.name]?.read?.permission\n          const subFieldPermissions = fieldPermissions?.[field.name]?.fields\n\n          if (hasPermission === false) return null\n\n          if (field.localized) {\n            return (\n              <div className={`${baseClass}__field`} key={i}>\n                {locales.map((locale, index) => {\n                  const versionLocaleValue = versionValue?.[locale]\n                  const comparisonLocaleValue = comparisonValue?.[locale]\n                  return (\n                    <div className={`${baseClass}__locale`} key={[locale, index].join('-')}>\n                      <div className={`${baseClass}__locale-value`}>\n                        <Component\n                          comparison={comparisonLocaleValue}\n                          diffMethod={diffMethod}\n                          field={field}\n                          fieldComponents={fieldComponents}\n                          isRichText={isRichText}\n                          locale={locale}\n                          locales={locales}\n                          permissions={subFieldPermissions}\n                          version={versionLocaleValue}\n                        />\n                      </div>\n                    </div>\n                  )\n                })}\n              </div>\n            )\n          }\n\n          return (\n            <div className={`${baseClass}__field`} key={i}>\n              <Component\n                comparison={comparisonValue}\n                diffMethod={diffMethod}\n                field={field}\n                fieldComponents={fieldComponents}\n                isRichText={isRichText}\n                locales={locales}\n                permissions={subFieldPermissions}\n                version={versionValue}\n              />\n            </div>\n          )\n        }\n\n        if (field.type === 'tabs') {\n          const Tabs = fieldComponents.tabs\n\n          return (\n            <Tabs\n              comparison={comparison}\n              field={field}\n              fieldComponents={fieldComponents}\n              key={i}\n              locales={locales}\n              version={version}\n            />\n          )\n        }\n\n        // At this point, we are dealing with a `row` or similar\n        if (fieldHasSubFields(field)) {\n          return (\n            <Nested\n              comparison={comparison}\n              disableGutter\n              field={field}\n              fieldComponents={fieldComponents}\n              key={i}\n              locales={locales}\n              permissions={fieldPermissions}\n              version={version}\n            />\n          )\n        }\n      }\n\n      return null\n    })}\n  </div>\n)\n\nexport default RenderFieldsToDiff\n"],"names":["baseClass","RenderFieldsToDiff","comparison","fieldComponents","fieldPermissions","fields","locales","version","div","className","map","field","i","Component","type","isRichText","diffMethod","diffMethods","fieldAffectsData","valueIsObject","versionValue","JSON","stringify","name","comparisonValue","hasPermission","read","permission","subFieldPermissions","localized","key","locale","index","versionLocaleValue","comparisonLocaleValue","join","permissions","Tabs","tabs","fieldHasSubFields","Nested","disableGutter"],"mappings":";;;;+BA2HA;;;eAAA;;;8DAzHkB;uBAIkC;+DACjC;6BACS;QACrB;;;;;;AAEP,MAAMA,YAAY;AAElB,MAAMC,qBAAsC,CAAC,EAC3CC,UAAU,EACVC,eAAe,EACfC,gBAAgB,EAChBC,MAAM,EACNC,OAAO,EACPC,OAAO,EACR,iBACC,6BAACC;QAAIC,WAAWT;OACbK,OAAOK,GAAG,CAAC,CAACC,OAAOC;QAClB,MAAMC,YAAYV,eAAe,CAACQ,MAAMG,IAAI,CAAC;QAE7C,MAAMC,aAAaJ,MAAMG,IAAI,KAAK;QAClC,MAAME,aAAyBC,wBAAW,CAACN,MAAMG,IAAI,CAAC,IAAI;QAE1D,IAAID,WAAW;YACb,IAAIK,IAAAA,uBAAgB,EAACP,QAAQ;gBAC3B,MAAMQ,gBAAgBR,MAAMG,IAAI,KAAK,UAAUH,MAAMG,IAAI,KAAK;gBAC9D,MAAMM,eAAeD,gBACjBE,KAAKC,SAAS,CAACf,SAAS,CAACI,MAAMY,IAAI,CAAC,IACpChB,SAAS,CAACI,MAAMY,IAAI,CAAC;gBACzB,MAAMC,kBAAkBL,gBACpBE,KAAKC,SAAS,CAACpB,YAAY,CAACS,MAAMY,IAAI,CAAC,IACvCrB,YAAY,CAACS,MAAMY,IAAI,CAAC;gBAC5B,MAAME,gBAAgBrB,kBAAkB,CAACO,MAAMY,IAAI,CAAC,EAAEG,MAAMC;gBAC5D,MAAMC,sBAAsBxB,kBAAkB,CAACO,MAAMY,IAAI,CAAC,EAAElB;gBAE5D,IAAIoB,kBAAkB,OAAO,OAAO;gBAEpC,IAAId,MAAMkB,SAAS,EAAE;oBACnB,qBACE,6BAACrB;wBAAIC,WAAW,CAAC,EAAET,UAAU,OAAO,CAAC;wBAAE8B,KAAKlB;uBACzCN,QAAQI,GAAG,CAAC,CAACqB,QAAQC;wBACpB,MAAMC,qBAAqBb,cAAc,CAACW,OAAO;wBACjD,MAAMG,wBAAwBV,iBAAiB,CAACO,OAAO;wBACvD,qBACE,6BAACvB;4BAAIC,WAAW,CAAC,EAAET,UAAU,QAAQ,CAAC;4BAAE8B,KAAK;gCAACC;gCAAQC;6BAAM,CAACG,IAAI,CAAC;yCAChE,6BAAC3B;4BAAIC,WAAW,CAAC,EAAET,UAAU,cAAc,CAAC;yCAC1C,6BAACa;4BACCX,YAAYgC;4BACZlB,YAAYA;4BACZL,OAAOA;4BACPR,iBAAiBA;4BACjBY,YAAYA;4BACZgB,QAAQA;4BACRzB,SAASA;4BACT8B,aAAaR;4BACbrB,SAAS0B;;oBAKnB;gBAGN;gBAEA,qBACE,6BAACzB;oBAAIC,WAAW,CAAC,EAAET,UAAU,OAAO,CAAC;oBAAE8B,KAAKlB;iCAC1C,6BAACC;oBACCX,YAAYsB;oBACZR,YAAYA;oBACZL,OAAOA;oBACPR,iBAAiBA;oBACjBY,YAAYA;oBACZT,SAASA;oBACT8B,aAAaR;oBACbrB,SAASa;;YAIjB;YAEA,IAAIT,MAAMG,IAAI,KAAK,QAAQ;gBACzB,MAAMuB,OAAOlC,gBAAgBmC,IAAI;gBAEjC,qBACE,6BAACD;oBACCnC,YAAYA;oBACZS,OAAOA;oBACPR,iBAAiBA;oBACjB2B,KAAKlB;oBACLN,SAASA;oBACTC,SAASA;;YAGf;YAEA,wDAAwD;YACxD,IAAIgC,IAAAA,wBAAiB,EAAC5B,QAAQ;gBAC5B,qBACE,6BAAC6B,eAAM;oBACLtC,YAAYA;oBACZuC,eAAAA;oBACA9B,OAAOA;oBACPR,iBAAiBA;oBACjB2B,KAAKlB;oBACLN,SAASA;oBACT8B,aAAahC;oBACbG,SAASA;;YAGf;QACF;QAEA,OAAO;IACT;MAIJ,WAAeN"}