UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

107 lines (106 loc) 13.9 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 _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"}