@commercetools-frontend-extensions/change-history 8.30.0 → 8.30.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -153,7 +153,7 @@ var omitBy__default = /*#__PURE__*/_interopDefault(omitBy);
153
153
  var LeadingIcon__default = /*#__PURE__*/_interopDefault(LeadingIcon);
154
154
 
155
155
  // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
156
- var version = "8.30.0";
156
+ var version = "8.30.1";
157
157
 
158
158
  // EXAMPLE
159
159
  // export const FEATURE_FLAG_NAME = 'featureFlagName';
@@ -13912,11 +13912,15 @@ var messages$q = reactIntl.defineMessages({
13912
13912
 
13913
13913
  const _excluded = ["resources"];
13914
13914
  function ownKeys$G(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
13915
- function _objectSpread$G(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys$G(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys$G(Object(t))).call(_context4, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
13915
+ function _objectSpread$G(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys$G(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys$G(Object(t))).call(_context3, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
13916
13916
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
13917
13917
  const isResourceChangeFilterValue = input => {
13918
- var _context, _context2;
13919
- return input && typeof input === 'object' && 'resource' in input && 'change' in input && (input.resource === null || typeof input.resource === 'string' && _includesInstanceProperty__default["default"](_context = _Object$values__default["default"](RESOURCE_TYPE)).call(_context, input.resource)) && (input.change === null || typeof input.change === 'string' && _includesInstanceProperty__default["default"](_context2 = _Object$values__default["default"](CHANGE_TYPE_NAME)).call(_context2, input.change));
13918
+ var _context;
13919
+ return input && typeof input === 'object' && 'resource' in input && 'change' in input && (input.resource === null || typeof input.resource === 'string' && _includesInstanceProperty__default["default"](_context = _Object$values__default["default"](RESOURCE_TYPE)).call(_context, input.resource)) && (input.change === null || typeof input.change === 'string')
13920
+ // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until
13921
+ // it is a complete list.
13922
+ // Object.values(CHANGE_TYPE_NAME).includes(input.change)
13923
+ ;
13920
13924
  };
13921
13925
  const getChangesByResourceType = (resourceType, intl) => {
13922
13926
  const getChanges = getChangesOptions(resourceType);
@@ -13953,13 +13957,13 @@ const ResourceChangeFilter = _ref => {
13953
13957
  return jsxRuntime.jsx(RequiredFilter, {
13954
13958
  error: props.error,
13955
13959
  children: jsxRuntime.jsx("div", {
13956
- css: /*#__PURE__*/react$1.css("min-width:", designSystem.designTokens.constraint16, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAuFgB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport {\n  CHANGE_TYPE_NAME,\n  RESOURCE_TYPE,\n  TChangeTypeName,\n  TResourceType,\n} from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null ||\n      (typeof input.change === 'string' && Object.values(CHANGE_TYPE_NAME).includes(input.change)))\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13960
+ css: /*#__PURE__*/react$1.css("min-width:", designSystem.designTokens.constraint16, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAoFgB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport { RESOURCE_TYPE, TChangeTypeName, TResourceType } from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null || typeof input.change === 'string')\n    // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until\n    // it is a complete list.\n    // Object.values(CHANGE_TYPE_NAME).includes(input.change)\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13957
13961
  children: jsxRuntime.jsxs(uiKit.Spacings.Inline, {
13958
13962
  alignItems: "center",
13959
13963
  children: [jsxRuntime.jsx("div", {
13960
13964
  children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$G({}, messages$q.whenLabel))
13961
13965
  }), jsxRuntime.jsx("div", {
13962
- css: /*#__PURE__*/react$1.css("min-width:", designSystem.designTokens.constraint7, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAgGoB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport {\n  CHANGE_TYPE_NAME,\n  RESOURCE_TYPE,\n  TChangeTypeName,\n  TResourceType,\n} from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null ||\n      (typeof input.change === 'string' && Object.values(CHANGE_TYPE_NAME).includes(input.change)))\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13966
+ css: /*#__PURE__*/react$1.css("min-width:", designSystem.designTokens.constraint7, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AA6FoB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport { RESOURCE_TYPE, TChangeTypeName, TResourceType } from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null || typeof input.change === 'string')\n    // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until\n    // it is a complete list.\n    // Object.values(CHANGE_TYPE_NAME).includes(input.change)\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13963
13967
  children: jsxRuntime.jsx(uiKit.SelectInput, {
13964
13968
  name: "change-selector",
13965
13969
  value: resource,
@@ -13986,7 +13990,7 @@ const ResourceChangeFilter = _ref => {
13986
13990
  "data-testid": "prueba",
13987
13991
  children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$G({}, messages$q.hasLabel))
13988
13992
  }), jsxRuntime.jsx("div", {
13989
- css: /*#__PURE__*/react$1.css("min-width:", designSystem.designTokens.constraint7, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAsIwB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport {\n  CHANGE_TYPE_NAME,\n  RESOURCE_TYPE,\n  TChangeTypeName,\n  TResourceType,\n} from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null ||\n      (typeof input.change === 'string' && Object.values(CHANGE_TYPE_NAME).includes(input.change)))\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13993
+ css: /*#__PURE__*/react$1.css("min-width:", designSystem.designTokens.constraint7, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAmIwB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport { RESOURCE_TYPE, TChangeTypeName, TResourceType } from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null || typeof input.change === 'string')\n    // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until\n    // it is a complete list.\n    // Object.values(CHANGE_TYPE_NAME).includes(input.change)\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13990
13994
  children: jsxRuntime.jsx(uiKit.SelectInput, {
13991
13995
  name: "change-selector",
13992
13996
  "data-testid": `change-selector-${resource}`,
@@ -153,7 +153,7 @@ var omitBy__default = /*#__PURE__*/_interopDefault(omitBy);
153
153
  var LeadingIcon__default = /*#__PURE__*/_interopDefault(LeadingIcon);
154
154
 
155
155
  // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
156
- var version = "8.30.0";
156
+ var version = "8.30.1";
157
157
 
158
158
  // EXAMPLE
159
159
  // export const FEATURE_FLAG_NAME = 'featureFlagName';
@@ -13409,11 +13409,15 @@ var messages$q = reactIntl.defineMessages({
13409
13409
 
13410
13410
  const _excluded = ["resources"];
13411
13411
  function ownKeys$G(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
13412
- function _objectSpread$G(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys$G(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys$G(Object(t))).call(_context4, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
13412
+ function _objectSpread$G(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys$G(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys$G(Object(t))).call(_context3, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
13413
13413
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
13414
13414
  const isResourceChangeFilterValue = input => {
13415
- var _context, _context2;
13416
- return input && typeof input === 'object' && 'resource' in input && 'change' in input && (input.resource === null || typeof input.resource === 'string' && _includesInstanceProperty__default["default"](_context = _Object$values__default["default"](RESOURCE_TYPE)).call(_context, input.resource)) && (input.change === null || typeof input.change === 'string' && _includesInstanceProperty__default["default"](_context2 = _Object$values__default["default"](CHANGE_TYPE_NAME)).call(_context2, input.change));
13415
+ var _context;
13416
+ return input && typeof input === 'object' && 'resource' in input && 'change' in input && (input.resource === null || typeof input.resource === 'string' && _includesInstanceProperty__default["default"](_context = _Object$values__default["default"](RESOURCE_TYPE)).call(_context, input.resource)) && (input.change === null || typeof input.change === 'string')
13417
+ // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until
13418
+ // it is a complete list.
13419
+ // Object.values(CHANGE_TYPE_NAME).includes(input.change)
13420
+ ;
13417
13421
  };
13418
13422
  const getChangesByResourceType = (resourceType, intl) => {
13419
13423
  const getChanges = getChangesOptions(resourceType);
@@ -93,7 +93,7 @@ import LeadingIcon from '@commercetools-uikit/icons/leading-icon';
93
93
  import { parseChunkImport, mapLocaleToIntlLocale } from '@commercetools-frontend/i18n';
94
94
 
95
95
  // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
96
- var version = "8.30.0";
96
+ var version = "8.30.1";
97
97
 
98
98
  // EXAMPLE
99
99
  // export const FEATURE_FLAG_NAME = 'featureFlagName';
@@ -13852,11 +13852,15 @@ var messages$q = defineMessages({
13852
13852
 
13853
13853
  const _excluded = ["resources"];
13854
13854
  function ownKeys$G(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
13855
- function _objectSpread$G(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context3 = ownKeys$G(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context4 = ownKeys$G(Object(t))).call(_context4, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
13855
+ function _objectSpread$G(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context2 = ownKeys$G(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context3 = ownKeys$G(Object(t))).call(_context3, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
13856
13856
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
13857
13857
  const isResourceChangeFilterValue = input => {
13858
- var _context, _context2;
13859
- return input && typeof input === 'object' && 'resource' in input && 'change' in input && (input.resource === null || typeof input.resource === 'string' && _includesInstanceProperty(_context = _Object$values(RESOURCE_TYPE)).call(_context, input.resource)) && (input.change === null || typeof input.change === 'string' && _includesInstanceProperty(_context2 = _Object$values(CHANGE_TYPE_NAME)).call(_context2, input.change));
13858
+ var _context;
13859
+ return input && typeof input === 'object' && 'resource' in input && 'change' in input && (input.resource === null || typeof input.resource === 'string' && _includesInstanceProperty(_context = _Object$values(RESOURCE_TYPE)).call(_context, input.resource)) && (input.change === null || typeof input.change === 'string')
13860
+ // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until
13861
+ // it is a complete list.
13862
+ // Object.values(CHANGE_TYPE_NAME).includes(input.change)
13863
+ ;
13860
13864
  };
13861
13865
  const getChangesByResourceType = (resourceType, intl) => {
13862
13866
  const getChanges = getChangesOptions(resourceType);
@@ -13893,13 +13897,13 @@ const ResourceChangeFilter = _ref => {
13893
13897
  return jsx(RequiredFilter, {
13894
13898
  error: props.error,
13895
13899
  children: jsx("div", {
13896
- css: /*#__PURE__*/css("min-width:", designTokens$1.constraint16, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAuFgB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport {\n  CHANGE_TYPE_NAME,\n  RESOURCE_TYPE,\n  TChangeTypeName,\n  TResourceType,\n} from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null ||\n      (typeof input.change === 'string' && Object.values(CHANGE_TYPE_NAME).includes(input.change)))\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13900
+ css: /*#__PURE__*/css("min-width:", designTokens$1.constraint16, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAoFgB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport { RESOURCE_TYPE, TChangeTypeName, TResourceType } from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null || typeof input.change === 'string')\n    // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until\n    // it is a complete list.\n    // Object.values(CHANGE_TYPE_NAME).includes(input.change)\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13897
13901
  children: jsxs(Spacings.Inline, {
13898
13902
  alignItems: "center",
13899
13903
  children: [jsx("div", {
13900
13904
  children: jsx(FormattedMessage, _objectSpread$G({}, messages$q.whenLabel))
13901
13905
  }), jsx("div", {
13902
- css: /*#__PURE__*/css("min-width:", designTokens$1.constraint7, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAgGoB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport {\n  CHANGE_TYPE_NAME,\n  RESOURCE_TYPE,\n  TChangeTypeName,\n  TResourceType,\n} from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null ||\n      (typeof input.change === 'string' && Object.values(CHANGE_TYPE_NAME).includes(input.change)))\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13906
+ css: /*#__PURE__*/css("min-width:", designTokens$1.constraint7, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AA6FoB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport { RESOURCE_TYPE, TChangeTypeName, TResourceType } from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null || typeof input.change === 'string')\n    // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until\n    // it is a complete list.\n    // Object.values(CHANGE_TYPE_NAME).includes(input.change)\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13903
13907
  children: jsx(SelectInput, {
13904
13908
  name: "change-selector",
13905
13909
  value: resource,
@@ -13926,7 +13930,7 @@ const ResourceChangeFilter = _ref => {
13926
13930
  "data-testid": "prueba",
13927
13931
  children: jsx(FormattedMessage, _objectSpread$G({}, messages$q.hasLabel))
13928
13932
  }), jsx("div", {
13929
- css: /*#__PURE__*/css("min-width:", designTokens$1.constraint7, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAsIwB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport {\n  CHANGE_TYPE_NAME,\n  RESOURCE_TYPE,\n  TChangeTypeName,\n  TResourceType,\n} from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null ||\n      (typeof input.change === 'string' && Object.values(CHANGE_TYPE_NAME).includes(input.change)))\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13933
+ css: /*#__PURE__*/css("min-width:", designTokens$1.constraint7, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:ResourceChangeFilter;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["resource-change-filter.tsx"],"names":[],"mappings":"AAmIwB","file":"resource-change-filter.tsx","sourcesContent":["import { Fragment } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\n\nimport orderBy from 'lodash/orderBy';\n\nimport { SelectInput, Spacings } from '@commercetools-frontend/ui-kit';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { TOption, TOptions } from '@commercetools-uikit/select-input';\n\nimport { css } from '@emotion/react';\n\nimport { TierLevels } from '../../../../../types/src/generated/change-history';\nimport { RESOURCE_TYPE, TChangeTypeName, TResourceType } from '../../../../constants';\nimport { useVersionTier } from '../../../../hooks';\nimport { getChangesOptions } from '../../../../resources';\nimport { TIntl } from '../../../../types/common-types';\nimport { TFieldFilterValue, TFilterFieldComponentProps } from '../../../../types/filters-types';\nimport {\n  optionsGrouping,\n  TOptionsWithDisabledForBasic,\n} from '../../../change-history-list-view/filter-definitions';\nimport { getFilterOption } from '../../filter-utils';\nimport { TCreateStandardFilterMapMeta } from '../../standard-filter-definitions';\nimport RequiredFilter from '../required-filter';\nimport messages from './messages';\n\nexport type TResourceChangeFilterValue = {\n  resource: TResourceType | null;\n  change: TChangeTypeName | null;\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const isResourceChangeFilterValue = (input: any): input is TResourceChangeFilterValue => {\n  return (\n    input &&\n    typeof input === 'object' &&\n    'resource' in input &&\n    'change' in input &&\n    (input.resource === null ||\n      (typeof input.resource === 'string' &&\n        Object.values(RESOURCE_TYPE).includes(input.resource))) &&\n    (input.change === null || typeof input.change === 'string')\n    // TODO: We could be checking against the enum but because it's not complete currently, we need to take this out until\n    // it is a complete list.\n    // Object.values(CHANGE_TYPE_NAME).includes(input.change)\n  );\n};\n\nconst getChangesByResourceType = (resourceType: TResourceType, intl: TIntl): TOptions => {\n  const getChanges = getChangesOptions(resourceType);\n  const changesByResourceType = getChanges ? getChanges(intl) : [];\n\n  return orderBy<TOption>(changesByResourceType, ['label'], ['asc']);\n};\n\nexport type TResourceChangeFilterProps = TFilterFieldComponentProps & {\n  resources: TCreateStandardFilterMapMeta['resources'];\n};\n\nconst getDefaultValue = (resources: TOption[], value: TFieldFilterValue | undefined) => {\n  let resource = '';\n  let change = '';\n  if (isResourceChangeFilterValue(value)) {\n    resource = value.resource ?? '';\n    change = value.change ?? '';\n  }\n  if (resources.length === 1) {\n    resource = resources[0].value;\n  }\n  return {\n    resource,\n    change,\n  };\n};\nconst ResourceChangeFilter = ({ resources = [], ...props }: TResourceChangeFilterProps) => {\n  const intl = useIntl();\n  const { tier } = useVersionTier();\n  const isPremiumFiltersDisabled = tier === TierLevels.Basic;\n  const { resource, change } = getDefaultValue(resources, props.value);\n  const sortedResources = orderBy<TOption>(resources, ['label'], ['asc']);\n\n  return (\n    <RequiredFilter error={props.error}>\n      <div\n        css={css`\n          min-width: ${designTokens.constraint16};\n        `}\n      >\n        <Spacings.Inline alignItems=\"center\">\n          <div>\n            <FormattedMessage {...messages.whenLabel} />\n          </div>\n          <div\n            css={css`\n              min-width: ${designTokens.constraint7};\n            `}\n          >\n            <SelectInput\n              name=\"change-selector\"\n              value={resource}\n              options={optionsGrouping({\n                options: sortedResources,\n                tier,\n              })}\n              isOptionDisabled={\n                isPremiumFiltersDisabled\n                  ? (option: unknown, _selectValue: unknown) => {\n                      const typedOption = option as TOptionsWithDisabledForBasic;\n                      return typedOption.disabledForBasic ? typedOption.disabledForBasic : false;\n                    }\n                  : (_option: unknown, _selectValue: unknown) => false\n              }\n              filterOption={getFilterOption(isPremiumFiltersDisabled)}\n              placeholder={intl.formatMessage(messages.resourceInputPlaceholder)}\n              onChange={nextValue =>\n                props.onUpdateFilter({\n                  resource: nextValue.target.value,\n                  change: null,\n                } as TResourceChangeFilterValue)\n              }\n              isClearable={false}\n              isDisabled={resources.length === 1}\n              horizontalConstraint={16}\n            />\n          </div>\n          {resource && (\n            <Fragment>\n              <div data-testid=\"prueba\">\n                <FormattedMessage {...messages.hasLabel} />\n              </div>\n              <div\n                css={css`\n                  min-width: ${designTokens.constraint7};\n                `}\n              >\n                <SelectInput\n                  name=\"change-selector\"\n                  data-testid={`change-selector-${resource}`}\n                  value={change}\n                  placeholder={intl.formatMessage(messages.changeInputPlaceholder)}\n                  options={getChangesByResourceType(resource as TResourceType, intl)}\n                  onChange={nextValue =>\n                    props.onUpdateFilter({\n                      resource: resource,\n                      change: nextValue.target.value,\n                    } as TResourceChangeFilterValue)\n                  }\n                  isClearable={false}\n                  isDisabled={false}\n                  horizontalConstraint={16}\n                />\n              </div>\n            </Fragment>\n          )}\n        </Spacings.Inline>\n      </div>\n    </RequiredFilter>\n  );\n};\nResourceChangeFilter.displayName = 'ResourceChangeFilter';\n\nexport default ResourceChangeFilter;\n"]} */"),
13930
13934
  children: jsx(SelectInput, {
13931
13935
  name: "change-selector",
13932
13936
  "data-testid": `change-selector-${resource}`,
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-frontend-extensions/change-history",
3
3
  "description": "Change history shared components and utilities",
4
- "version": "8.30.0",
4
+ "version": "8.30.1",
5
5
  "license": "MIT",
6
6
  "publishConfig": {
7
7
  "access": "public"