@reltio/remotes 1.4.1621 → 1.4.1623

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.
Files changed (107) hide show
  1. package/1039.js +1 -1
  2. package/1146.js +1 -1
  3. package/1148.js +1 -1
  4. package/1334.js +1 -1
  5. package/1425.js +1 -1
  6. package/1572.js +1 -1
  7. package/1572.js.map +1 -1
  8. package/1664.js +1 -1
  9. package/1707.js +1 -1
  10. package/1790.js +1 -1
  11. package/1840.js +1 -1
  12. package/1925.js +1 -1
  13. package/1925.js.map +1 -1
  14. package/2049.js +1 -1
  15. package/2066.js +1 -1
  16. package/2066.js.map +1 -1
  17. package/2201.js +1 -1
  18. package/2400.js +1 -1
  19. package/2400.js.map +1 -1
  20. package/2404.js +1 -1
  21. package/2404.js.map +1 -1
  22. package/2463.js +1 -1
  23. package/2641.js +1 -1
  24. package/2641.js.map +1 -1
  25. package/3096.js +1 -1
  26. package/3348.js +1 -1
  27. package/3358.js +1 -1
  28. package/3358.js.map +1 -1
  29. package/3373.js +1 -1
  30. package/3381.js +1 -1
  31. package/3383.js +1 -1
  32. package/3463.js +1 -1
  33. package/3469.js +1 -1
  34. package/3538.js +1 -1
  35. package/3538.js.map +1 -1
  36. package/356.js +1 -1
  37. package/3875.js +1 -1
  38. package/3902.js +1 -1
  39. package/3902.js.map +1 -1
  40. package/3926.js +1 -1
  41. package/3926.js.map +1 -1
  42. package/415.js +1 -1
  43. package/4212.js +1 -1
  44. package/4390.js +1 -1
  45. package/4481.js +1 -1
  46. package/4703.js +1 -1
  47. package/4780.js +1 -1
  48. package/4806.js +1 -1
  49. package/4838.js +1 -1
  50. package/50.js +1 -1
  51. package/5034.js +1 -1
  52. package/5039.js +1 -1
  53. package/5053.js +1 -1
  54. package/5108.js +1 -1
  55. package/5163.js +1 -1
  56. package/5163.js.map +1 -1
  57. package/5617.js +1 -1
  58. package/6020.js +1 -1
  59. package/6173.js +1 -1
  60. package/6228.js +1 -1
  61. package/6280.js +1 -1
  62. package/6287.js +1 -1
  63. package/6531.js +1 -1
  64. package/6606.js +1 -1
  65. package/6606.js.map +1 -1
  66. package/6799.js +1 -1
  67. package/6844.js +1 -1
  68. package/6853.js +1 -1
  69. package/6860.js +1 -1
  70. package/6903.js +1 -1
  71. package/7340.js +1 -1
  72. package/735.js +1 -1
  73. package/7422.js +1 -1
  74. package/7626.js +1 -1
  75. package/764.js +1 -1
  76. package/7896.js +1 -1
  77. package/8168.js +1 -1
  78. package/820.js +1 -1
  79. package/8207.js +1 -1
  80. package/8322.js +1 -1
  81. package/8481.js +2 -0
  82. package/8481.js.map +1 -0
  83. package/8565.js +1 -1
  84. package/8741.js +1 -1
  85. package/9016.js +1 -1
  86. package/9028.js +1 -1
  87. package/9028.js.map +1 -1
  88. package/9283.js +1 -1
  89. package/9309.js +1 -1
  90. package/9328.js +1 -1
  91. package/9387.js +1 -1
  92. package/9719.js +1 -1
  93. package/9736.js +1 -1
  94. package/9861.js +1 -1
  95. package/987.js +1 -1
  96. package/99.js +1 -1
  97. package/9945.js +2 -0
  98. package/9945.js.map +1 -0
  99. package/9960.js +1 -1
  100. package/main.js +1 -1
  101. package/package.json +1 -1
  102. package/remoteEntry.js +1 -1
  103. package/remoteEntry.js.map +1 -1
  104. package/3727.js +0 -2
  105. package/3727.js.map +0 -1
  106. package/673.js +0 -2
  107. package/673.js.map +0 -1
package/3902.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"3902.js","mappings":"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","sources":["webpack://@reltio/remotes/../components/src/components/AttributeSelector/styles.ts","webpack://@reltio/remotes/../components/src/components/AttributeSelector/AttributeSelector.tsx","webpack://@reltio/remotes/../components/src/components/DateIntervalSelector/styles.ts","webpack://@reltio/remotes/../components/src/components/DateIntervalSelector/DateIntervalSelector.tsx","webpack://@reltio/remotes/../components/src/components/ReactSelect/CreatableSelect.js","webpack://@reltio/remotes/../components/src/components/ReactSelect/MultiSelect/components/Option.js","webpack://@reltio/remotes/../components/src/components/ReactSelect/MultiSelect/components/index.js","webpack://@reltio/remotes/../components/src/components/ReactSelect/MultiSelect/MultiSelect.js","webpack://@reltio/remotes/../components/src/components/ReactSelect/MultiSelect/index.js","webpack://@reltio/remotes/../components/src/icons/AttributesList.tsx","webpack://@reltio/remotes/../components/src/components/SidePanelEmptyState/styles.ts","webpack://@reltio/remotes/../components/src/components/SidePanelEmptyState/SidePanelEmptyState.tsx","webpack://@reltio/remotes/../components/src/components/UserSelector/styles.ts","webpack://@reltio/remotes/../components/src/components/UserSelector/UserSelector.tsx","webpack://@reltio/remotes/../components/src/components/activityLog/types/ActivityTypes.ts","webpack://@reltio/remotes/../components/src/components/activityLog/utils/activities.ts","webpack://@reltio/remotes/../components/src/components/editors/CustomDateRangeEditor/styles.ts","webpack://@reltio/remotes/../components/src/components/editors/CustomDateRangeEditor/CustomDateRangeEditor.tsx","webpack://@reltio/remotes/../components/src/components/history/DateRangeSelector/utils.ts","webpack://@reltio/remotes/../components/src/components/history/DateRangeSelector/styles.ts","webpack://@reltio/remotes/../components/src/components/history/DateRangeSelector/DateRangeSelector.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryActivitySelector/utils.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryActivitySelector/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryActivitySelector/HistoryActivitySelector.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryFilterButton/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryFilterButton/HistoryFilterButton.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryMenuButton/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryMenuButton/MenuItemRenderer.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryMenuButton/HistoryMenuButton.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryHeader/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryHeader/HistoryHeader.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryPanelEmptyState/HistoryPanelEmptyState.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryRow/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryRow/HistoryRow.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryGraph/helpers.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryGraph/HistoryLink.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryGraph/HistoryCircle.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryGraph/HistoryGraph.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryTree/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryTree/HistoryTree.tsx","webpack://@reltio/remotes/../components/src/components/history/ContributorsPanel/styles.ts","webpack://@reltio/remotes/../components/src/components/history/ContributorsPanel/ContributorItem.tsx","webpack://@reltio/remotes/../components/src/components/history/ContributorsPanel/ContributorsPanel.tsx","webpack://@reltio/remotes/../components/src/components/history/hooks/useHistoryTree.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryView/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryView/HistoryView.tsx","webpack://@reltio/remotes/../components/src/components/history/utils/filters.ts","webpack://@reltio/remotes/../components/src/components/history/hooks/useHistory.ts","webpack://@reltio/remotes/../components/src/components/history/hooks/useHistoryEnabled.ts","webpack://@reltio/remotes/../components/src/components/history/hooks/useHistorySlice.ts","webpack://@reltio/remotes/../components/src/components/history/types/HistoryChangeTypes.ts","webpack://@reltio/remotes/../components/src/components/history/types/HistoryFilter.ts","webpack://@reltio/remotes/../components/src/hooks/useSnackbar.tsx"],"sourcesContent":["import {makeStyles} from '@mui/styles';\n\nexport const customStyles = {\n input: (currentStyles) => ({...currentStyles, fontSize: '14px'}),\n menuPortal: (currentStyles) => ({...currentStyles, zIndex: 1300})\n};\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n title: {\n paddingBottom: '10px',\n paddingLeft: '5px',\n fontSize: '14px'\n },\n dropDownInput: {\n width: '100%',\n justifyContent: 'center',\n backgroundColor: 'rgba(0, 0, 0, 0.03)',\n borderTop: '4px'\n },\n option: {\n fontSize: '14px',\n height: '32px'\n },\n noOptionsMessage: {\n fontSize: '14px'\n }\n});\n","import React, {useCallback, useMemo} from 'react';\nimport i18n from 'ui-i18n';\nimport classnames from 'classnames';\nimport {pipe, defaultTo} from 'ramda';\nimport {useSelector} from 'react-redux';\nimport {AttributeOption} from '../../types';\nimport mdmModule from '@reltio/mdm-module';\nimport {MultiValueProps, OptionProps} from 'react-select';\nimport {AttributeType, getAttributeTypeSubAttributes, Metadata, TEntityType} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport MultiSelect from '../ReactSelect/MultiSelect';\nimport MultiValue from '../ReactSelect/commonComponents/MultiValue';\nimport DropdownIndicatorWithIconButton from '../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport AttributeListItem from '../AttributeListItem/AttributeListItem';\nimport {customStyles, useStyles} from './styles';\n\ntype Props = {\n entityType: TEntityType;\n selectedAttributes: AttributeOption[];\n className?: string;\n onChange?: (attributes: AttributeOption[]) => void;\n title?: string;\n disableUnderline?: boolean;\n menuPlacement?: string;\n};\n\nconst AttributeSelector = ({\n entityType,\n selectedAttributes,\n className,\n onChange,\n title,\n disableUnderline,\n menuPlacement = 'bottom'\n}: Props) => {\n const metadata: Metadata = useSelector(mdmModule.selectors.getMetadata);\n const styles = useStyles();\n\n const prepareItems = useCallback(\n (data: AttributeType[], level = 0, prevLabel = ''): AttributeOption[] => {\n return data.reduce((acc, item) => {\n if (item.hidden) return acc;\n const chipLabel = `${prevLabel && prevLabel + ' / '}${item.label}`;\n acc.push({\n label: item.label,\n value: item.uri,\n attrType: item,\n chipLabel,\n level\n });\n const subAttributes = getAttributeTypeSubAttributes(metadata, item);\n return acc.concat(subAttributes ? prepareItems(subAttributes, level + 1, chipLabel) : []);\n }, []);\n },\n [metadata]\n );\n\n const options = useMemo(() => prepareItems(entityType?.attributes || []), [entityType, prepareItems]);\n\n const CustomOption = ({isFocused, isSelected, data, label, innerProps}: OptionProps<AttributeOption, true>) => (\n <div {...innerProps}>\n <AttributeListItem\n checked={isSelected}\n level={data.level}\n data={data}\n label={label}\n labelInText={label}\n isFocused={isFocused}\n />\n </div>\n );\n\n const CustomMultiValue = ({data, ...props}: MultiValueProps<AttributeOption>) => (\n <MultiValue {...props}>{data.chipLabel}</MultiValue>\n );\n\n return (\n <div className={classnames(styles.root, className)} data-reltio-id=\"attribute-selector\">\n <Typography className={styles.title} variant={'subtitle1'}>\n {title || i18n.text('Attribute')}\n </Typography>\n <MultiSelect\n value={selectedAttributes}\n options={options}\n TextFieldProps={{\n InputProps: {disableUnderline},\n classes: {root: styles.dropDownInput}\n }}\n components={{\n DropdownIndicator: DropdownIndicatorWithIconButton,\n MultiValue: CustomMultiValue,\n Option: CustomOption\n }}\n onChange={pipe(defaultTo([]), onChange)}\n styles={customStyles}\n classes={styles}\n menuPlacement={menuPlacement}\n menuPortalTarget={document.body}\n menuShouldBlockScroll={true}\n captureMenuScroll={false}\n />\n </div>\n );\n};\n\nexport default AttributeSelector;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n flex: 1\n },\n input: {\n height: '100%',\n paddingLeft: '12px',\n paddingRight: '8px',\n fontSize: '14px'\n },\n inputNumber: {\n minWidth: '60px',\n marginRight: 10,\n height: '100%',\n backgroundColor: 'rgba(0, 0, 0, 0.03)'\n },\n inputUnit: {\n width: '100%'\n }\n});\n","import React from 'react';\nimport {pipe} from 'ramda';\nimport {getIntervalUnitLabel} from '@reltio/mdm-sdk';\nimport TextField from '@mui/material/TextField';\nimport SimpleDropDownSelector from '../SimpleDropDownSelector/SimpleDropDownSelector';\nimport {getValue} from '../../core/utils';\nimport {useStyles} from './styles';\n\nimport {capitalize} from '@mui/material/utils';\n\ntype Props = {\n interval: [number, string];\n onChange: ([number, string]) => void;\n onFocus?: () => void;\n};\n\nconst periods = ['minutes', 'hours', 'days', 'weeks', 'months', 'years'];\n\nconst DateIntervalSelector = ({interval: [value, unit], onChange, onFocus}: Props) => {\n const styles = useStyles();\n const getIntervalFromValue = (newValue: number) => [newValue, unit];\n const getIntervalFromUnit = ({value: newUnit}: {value: string}) => [value, newUnit];\n const onNumberChange = pipe(getValue, parseInt, getIntervalFromValue, onChange);\n const onUnitChange = pipe(getIntervalFromUnit, onChange);\n return (\n <div className={styles.root}>\n <TextField\n variant=\"standard\"\n type=\"number\"\n value={value || ''}\n onChange={onNumberChange}\n inputProps={{min: 1, onFocus: onFocus}}\n InputProps={{classes: {root: styles.input}}}\n className={styles.inputNumber}\n />\n <SimpleDropDownSelector\n label={''}\n placeholder={capitalize(unit)}\n className={styles.inputUnit}\n value={{value: unit, label: capitalize(getIntervalUnitLabel(unit))}}\n options={periods.map((value) => ({\n value,\n label: capitalize(getIntervalUnitLabel(value))\n }))}\n onChange={onUnitChange}\n TextFieldProps={{\n inputProps: {onFocus: onFocus},\n InputProps: {classes: {root: styles.input}}\n }}\n />\n </div>\n );\n};\n\nexport default DateIntervalSelector;\n","import CreatableSelect from 'react-select/creatable';\nimport withMuiSkin from './withMuiSkin';\n\nexport default withMuiSkin(CreatableSelect);\n","import MenuItem from '@mui/material/MenuItem';\nimport Checkbox from '@mui/material/Checkbox';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport classNames from 'classnames';\nimport ExpandedValueTooltip from '../../../ExpandedValueTooltip/ExpandedValueTooltip';\n\nexport default function Option(props) {\n const {\n innerProps,\n innerRef,\n children,\n isFocused,\n isSelected,\n selectProps: {classes},\n label\n } = props;\n\n return (\n <MenuItem\n className={classNames(classes.option, {[classes['option--selected']]: isSelected})}\n ref={innerRef}\n selected={isFocused}\n component=\"div\"\n {...innerProps}\n >\n <Checkbox color=\"primary\" checked={isSelected} />\n <ExpandedValueTooltip value={label}>\n <div className={classes['option--item']}>{children}</div>\n </ExpandedValueTooltip>\n </MenuItem>\n );\n}\n\nOption.propTypes = {\n children: PropTypes.node,\n innerProps: PropTypes.shape({\n id: PropTypes.string.isRequired,\n key: PropTypes.string,\n onClick: PropTypes.func.isRequired,\n onMouseMove: PropTypes.func.isRequired,\n onMouseOver: PropTypes.func.isRequired,\n tabIndex: PropTypes.number.isRequired\n }).isRequired,\n innerRef: PropTypes.oneOfType([\n PropTypes.oneOf([null]),\n PropTypes.func,\n PropTypes.shape({\n current: PropTypes.any.isRequired\n })\n ]),\n isFocused: PropTypes.bool.isRequired,\n isSelected: PropTypes.bool.isRequired,\n label: PropTypes.string,\n selectProps: PropTypes.shape({\n classes: PropTypes.shape({\n option: PropTypes.string\n })\n })\n};\n","import Option from './Option';\n\nconst components = {\n Option\n};\n\nexport default components;\n","import React, {useState} from 'react';\nimport PropTypes from 'prop-types';\nimport {omit} from 'ramda';\nimport CreatableSelect from '../CreatableSelect';\nimport Select from '../Select';\nimport AsyncSelect from '../AsyncSelect';\nimport multiSelectComponents from './components';\nimport {makeStyles} from '@mui/styles';\nimport {mergeClasses} from '../../../core/utils';\n\nconst useStyles = makeStyles((theme) => ({\n label: {\n top: 6,\n left: 16\n },\n placeholder: (props) => ({\n display: !props.placeholder || props.label ? 'none' : undefined\n }),\n 'option--selected': {\n fontWeight: 400\n },\n clearIndicator: {\n padding: theme.spacing(1),\n margin: theme.spacing(0.25, 0.5)\n },\n dropdownIndicator: {\n padding: theme.spacing(1),\n margin: theme.spacing(0.25, 0.5)\n }\n}));\n\nlet id = 0;\nconst getInputId = () => `custom-select-${id++}`;\n\nfunction MultiSelect(props) {\n const {\n label,\n creatable,\n getOptions,\n loadingIndicator,\n components: componentsProp,\n classes: classesProp,\n styles: stylesProp,\n onChange: onChangeProp,\n onInputChange: onInputChangeProp,\n menuPlacement = 'auto',\n ...reactSelectProps\n } = props;\n\n const SelectComponent = creatable ? CreatableSelect : getOptions ? AsyncSelect : Select;\n\n const [inputValue, setInputValue] = useState('');\n const multiSelectClasses = useStyles(omit(['classes'], props));\n const inputId = getInputId();\n\n const components = {\n ...multiSelectComponents,\n ...componentsProp\n };\n\n const classes = mergeClasses(multiSelectClasses, classesProp);\n\n function handleInputChange(value, {action}) {\n onInputChangeProp(value, {action});\n if (action !== 'set-value') {\n setInputValue(value);\n }\n }\n\n function handleChange(value, actionMeta) {\n onChangeProp(value, actionMeta);\n if (actionMeta.action === 'create-option') {\n setInputValue('');\n onInputChangeProp('', {action: 'input-change'});\n }\n }\n\n const styles = {\n indicatorSeparator: (base) => ({\n ...base,\n margin: '10px 0'\n }),\n loadingIndicator: (base) => ({\n ...base,\n display: loadingIndicator ? base.display : 'none'\n }),\n loadingMessage: (base) => ({\n ...base,\n fontFamily: '\"Roboto\", \"Helvetica\", \"Arial\", sans-serif'\n }),\n ...stylesProp\n };\n\n const labelProps = label\n ? {\n inputId,\n TextFieldProps: {\n label,\n InputLabelProps: {\n htmlFor: inputId,\n shrink: props.value && props.value.length ? true : undefined,\n className: classes.label\n },\n ...props.TextFieldProps\n }\n }\n : {};\n\n return (\n <SelectComponent\n isMulti\n inputId={inputId}\n inputValue={inputValue}\n onChange={handleChange}\n onInputChange={handleInputChange}\n closeMenuOnSelect={false}\n hideSelectedOptions={false}\n classes={classes}\n components={components}\n styles={styles}\n menuPlacement={menuPlacement}\n loadOptions={getOptions}\n {...labelProps}\n {...reactSelectProps}\n />\n );\n}\n\nMultiSelect.defaultProps = {\n creatable: false,\n cacheOptions: true,\n components: {},\n classes: {},\n placeholder: '',\n loadingIndicator: false,\n onInputChange: () => {},\n onChange: () => {}\n};\n\nMultiSelect.propTypes = {\n /**\n * Async creatable multi select with optional placeholder, shrink-label, non-closing menu and options with checkboxes.\n * Based on react-select/creatable and react-select/async.\n * See react-select docs: https://react-select.com\n *\n * Below are listed only props used in the MultiSelect component. Check https://react-select.com/props first.\n * */\n\n /** Ability to create values. React-select/async-creatable is used internally */\n creatable: PropTypes.bool,\n /** True for enabling cache. Recommended. */\n cacheOptions: PropTypes.bool,\n defaultOptions: PropTypes.bool,\n /** Array of selected options. */\n value: PropTypes.arrayOf(\n PropTypes.shape({\n label: PropTypes.string.isRequired,\n value: PropTypes.any\n })\n ),\n options: PropTypes.arrayOf(\n PropTypes.shape({\n label: PropTypes.string.isRequired,\n value: PropTypes.any\n })\n ),\n /** Way to receive updated values */\n onChange: PropTypes.func,\n /** Way to receive updated inputValue */\n onInputChange: PropTypes.func,\n /** Input placeholder. Will not be shown if the label prop is specified */\n placeholder: PropTypes.string,\n /** Floating label from @mui/material/TextField component */\n label: PropTypes.string,\n /** Enable to show default react-select's indicator */\n loadingIndicator: PropTypes.bool,\n /** You could redefine any of these components */\n components: PropTypes.shape({\n ClearIndicator: PropTypes.func,\n Control: PropTypes.func,\n DropdownIndicator: PropTypes.func,\n DownChevron: PropTypes.func,\n CrossIcon: PropTypes.func,\n Group: PropTypes.func,\n GroupHeading: PropTypes.func,\n IndicatorsContainer: PropTypes.func,\n IndicatorSeparator: PropTypes.func,\n Input: PropTypes.func,\n LoadingIndicator: PropTypes.func,\n Menu: PropTypes.func,\n MenuList: PropTypes.func,\n MenuPortal: PropTypes.func,\n LoadingMessage: PropTypes.func,\n NoOptionsMessage: PropTypes.func,\n MultiValue: PropTypes.func,\n MultiValueContainer: PropTypes.func,\n MultiValueLabel: PropTypes.func,\n MultiValueRemove: PropTypes.func,\n Option: PropTypes.func,\n Placeholder: PropTypes.func,\n SelectContainer: PropTypes.func,\n SingleValue: PropTypes.func,\n ValueContainer: PropTypes.func\n }),\n /** Classes are passed to mui skin components. Provided classes will be merged with existing ones. */\n classes: PropTypes.shape({\n control: PropTypes.string,\n valueContainer: PropTypes.string,\n multiValue: PropTypes.string,\n noOptionsMessage: PropTypes.string,\n singleValue: PropTypes.string,\n placeholder: PropTypes.string,\n menu: PropTypes.string,\n clearIndicator: PropTypes.string,\n dropdownIndicator: PropTypes.string,\n option: PropTypes.string,\n 'option--selected': PropTypes.string,\n label: PropTypes.string\n }),\n /**\n * React-select's way to customise style. Could be used to style default react-select components.\n * In other cases better to use classes and components props\n * */\n styles: PropTypes.shape({\n clearIndicator: PropTypes.func,\n container: PropTypes.func,\n control: PropTypes.func,\n dropdownIndicator: PropTypes.func,\n group: PropTypes.func,\n groupHeading: PropTypes.func,\n indicatorsContainer: PropTypes.func,\n indicatorSeparator: PropTypes.func,\n input: PropTypes.func,\n loadingIndicator: PropTypes.func,\n loadingMessage: PropTypes.func,\n menu: PropTypes.func,\n menuList: PropTypes.func,\n menuPortal: PropTypes.func,\n multiValue: PropTypes.func,\n multiValueLabel: PropTypes.func,\n multiValueRemove: PropTypes.func,\n noOptionsMessage: PropTypes.func,\n option: PropTypes.func,\n placeholder: PropTypes.func,\n singleValue: PropTypes.func,\n valueContainer: PropTypes.func\n }),\n /** Props from https://material-ui.com/api/text-field/ */\n TextFieldProps: PropTypes.object /* eslint-disable-line react/forbid-prop-types */,\n getOptions: PropTypes.func,\n menuPlacement: PropTypes.string,\n menuPortalTarget: PropTypes.object,\n menuShouldBlockScroll: PropTypes.bool,\n captureMenuScroll: PropTypes.bool,\n getOptionValue: PropTypes.func,\n isSearchable: PropTypes.bool,\n inputRef: PropTypes.shape({current: PropTypes.object})\n};\n\nexport default MultiSelect;\n","import MultiSelect from './MultiSelect';\n\nexport default MultiSelect;\n","import React from 'react';\n\nconst SvgAttributesList: React.FC<React.SVGProps<SVGSVGElement>> = (props) => {\n return (\n <svg width={256} height={256} viewBox=\"0 0 256 256\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" {...props}>\n <circle cx={128} cy={128} r={128} fill=\"#0072CE\" fillOpacity={0.1} />\n <mask\n id=\"AttributesList_svg__a\"\n style={{\n maskType: 'alpha'\n }}\n maskUnits=\"userSpaceOnUse\"\n x={0}\n y={0}\n width={256}\n height={256}\n >\n <circle cx={128} cy={128} r={128} fill=\"#fff\" />\n </mask>\n <g mask=\"url(#AttributesList_svg__a)\">\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M-16 9h256v247H-16V9z\"\n fill=\"url(#AttributesList_svg__b)\"\n />\n <path\n opacity={0.05}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M187.761 56.865l58.639 58.639v148.871H93.383L52 225.083V56.865h135.761z\"\n fill=\"url(#AttributesList_svg__c)\"\n />\n <path\n opacity={0.06}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M47 58h202a7 7 0 017 7v157a7 7 0 01-7 7H47a7 7 0 01-7-7V65a7 7 0 017-7z\"\n fill=\"#000\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M50 56h201a5 5 0 015 5v157a5 5 0 01-5 5H50a5 5 0 01-5-5V61a5 5 0 015-5z\"\n fill=\"#fff\"\n />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105.376 72.635a3 3 0 013-3H150a3 3 0 110 6h-41.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105 84.635a3 3 0 013-3h64.205a3 3 0 110 6H108a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105.376 163a3 3 0 013-3H150a3 3 0 110 6h-41.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105 175a3 3 0 013-3h64.205a3 3 0 110 6H108a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105.376 193a3 3 0 013-3H190a3 3 0 110 6h-81.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105 205a3 3 0 013-3h74.205a3 3 0 110 6H108a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M138.376 103a3 3 0 013-3H223a3 3 0 110 6h-81.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M138 115a3 3 0 013-3h64.205a3 3 0 110 6H141a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <circle cx={67} cy={79} r={9} fill=\"#B6C7DB\" />\n <circle cx={67} cy={79} r={9} fill=\"#B6C7DB\" />\n <circle cx={120} cy={106} r={6} fill=\"#B6C7DB\" />\n <circle cx={120} cy={136} r={6} fill=\"#B6C7DB\" />\n <circle cx={67} cy={169} r={9} fill=\"#B6C7DB\" />\n <circle cx={67} cy={199} r={9} fill=\"#B6C7DB\" />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M138.376 133a3 3 0 013-3H223a3 3 0 110 6h-81.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M138 145a3 3 0 013-3h74.205a3 3 0 110 6H141a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M92.514 108v-8h-2v40.365h11.178v-2h-9.178V110h9.178v-2h-9.178z\"\n fill=\"#2B98F0\"\n />\n <path\n opacity={0.54}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M95.071 77l-3.535 3.535L88 77h7.071z\"\n fill=\"#000\"\n />\n <path\n opacity={0.6}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M50 22h186a6 6 0 016 6v18a6 6 0 01-6 6H50a6 6 0 01-6-6V28a6 6 0 016-6z\"\n fill=\"#fff\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M58 37a6 6 0 016-6h70a6 6 0 110 12H64a6 6 0 01-6-6zm90 0a6 6 0 016-6h10a6 6 0 110 12h-10a6 6 0 01-6-6z\"\n fill=\"#979797\"\n />\n </g>\n <defs>\n <linearGradient\n id=\"AttributesList_svg__b\"\n x1={-16}\n y1={9}\n x2={-16}\n y2={256}\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#FAFAFA\" stopOpacity={0.01} />\n <stop offset={1} stopColor=\"#F4F4F4\" />\n </linearGradient>\n <linearGradient\n id=\"AttributesList_svg__c\"\n x1={266.117}\n y1={181.111}\n x2={154.882}\n y2={77.681}\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopOpacity={0.01} />\n <stop offset={1} />\n </linearGradient>\n </defs>\n </svg>\n );\n};\n\nexport default SvgAttributesList;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n root: {\n display: 'flex',\n flex: '1 1 auto',\n flexWrap: 'nowrap',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n overflow: 'auto',\n height: '100%',\n minHeight: '350px',\n boxSizing: 'border-box',\n padding: '40px'\n },\n logo: {\n width: '190px',\n height: '190px'\n },\n textBox: {\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n maxWidth: 400,\n marginTop: '24px'\n },\n text: {\n color: theme.palette.text.primary,\n fontSize: '20px',\n fontWeight: 500,\n lineHeight: '23px',\n textAlign: 'center'\n },\n secondaryText: {\n color: theme.palette.text.primary,\n fontSize: '14px',\n fontWeight: 'normal',\n lineHeight: '16px',\n letterSpacing: '0.24px',\n textAlign: 'center',\n paddingTop: '8px'\n }\n}));\n","import React from 'react';\nimport Typography from '@mui/material/Typography';\nimport {AttributesList as AttributesListIcon} from '../../icons';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n IconRenderer?: React.ElementType;\n text: string;\n secondaryText?: string;\n};\n\nconst SidePanelEmptyState = ({IconRenderer = AttributesListIcon, text, secondaryText}: Props) => {\n const styles = useStyles();\n return (\n <div className={styles.root}>\n <IconRenderer className={styles.logo} />\n <div className={styles.textBox}>\n <Typography className={styles.text}>{text}</Typography>\n {secondaryText && <Typography className={styles.secondaryText}>{secondaryText}</Typography>}\n </div>\n </div>\n );\n};\n\nexport default SidePanelEmptyState;\n","import {makeStyles} from '@mui/styles';\n\nexport const customStyles = {\n input: (currentStyles) => ({...currentStyles, fontSize: '14px'}),\n loadingMessage: (currentStyles) => ({...currentStyles, fontSize: '14px'}),\n menuPortal: (currentStyles) => ({...currentStyles, zIndex: 1300})\n};\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n title: {\n paddingBottom: '10px',\n paddingLeft: '5px',\n fontSize: '14px'\n },\n dropDownInput: {\n width: '100%',\n justifyContent: 'center',\n backgroundColor: 'rgba(0, 0, 0, 0.03)',\n borderTop: '4px'\n },\n option: {\n fontSize: '14px',\n height: '32px'\n }\n});\n","import React, {useRef} from 'react';\nimport {useSelector} from 'react-redux';\nimport i18n from 'ui-i18n';\nimport {defaultTo, pipe, pluck} from 'ramda';\nimport classnames from 'classnames';\nimport Typography from '@mui/material/Typography';\nimport MultiSelect from '../ReactSelect/MultiSelect';\nimport DropdownIndicatorWithIconButton from '../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport {getAllUsersForTenant, UserInfo, utils} from '@reltio/mdm-sdk';\nimport mdmModule from '@reltio/mdm-module';\nimport {customStyles, useStyles} from './styles';\n\ntype Props = {\n selectedUsers: string[];\n onChange: (activities: string[]) => void;\n className?: string;\n disableUnderline?: boolean;\n};\n\nconst UserSelector = ({selectedUsers, onChange, className, disableUnderline}: Props) => {\n const styles = useStyles();\n\n const valueToOption = (value: string) => ({value, label: value});\n const prepareValues = (values: string[]) => values.map(valueToOption);\n const filterUsers = (inputValue) => (users) =>\n inputValue ? users.filter((username) => utils.strings.search(username, inputValue)) : users;\n\n const tenant = useSelector(mdmModule.selectors.getTenant);\n const servicesPath = useSelector(mdmModule.selectors.getServicesPath);\n\n const cachedRequest = useRef<Promise<UserInfo[]>>();\n const getOptions = (inputValue) => {\n if (!cachedRequest.current) {\n cachedRequest.current = getAllUsersForTenant({tenant, servicesPath});\n }\n return cachedRequest.current.then(pipe(pluck('username'), filterUsers(inputValue), prepareValues));\n };\n\n return (\n <div className={classnames(styles.root, className)} data-reltio-id=\"user-selector\">\n <Typography className={styles.title} variant={'subtitle1'}>\n {i18n.text('User')}\n </Typography>\n <MultiSelect\n value={prepareValues(selectedUsers)}\n onChange={pipe(defaultTo([]), pluck('value'), onChange)}\n defaultOptions={true}\n getOptions={getOptions}\n TextFieldProps={{\n InputProps: {disableUnderline},\n className: styles.dropDownInput\n }}\n components={{\n DropdownIndicator: DropdownIndicatorWithIconButton\n }}\n styles={customStyles}\n classes={styles}\n menuPortalTarget={document.body}\n menuShouldBlockScroll={true}\n captureMenuScroll={false}\n />\n </div>\n );\n};\n\nexport default UserSelector;\n","export enum ActivityTypes {\n MODEL_UPDATED = 'MODEL_UPDATED',\n ENTITY_REMOVED = 'ENTITY_REMOVED',\n ENTITY_CREATED = 'ENTITY_CREATED',\n ENTITY_CHANGED = 'ENTITY_CHANGED',\n ENTITIES_MERGED = 'ENTITIES_MERGED',\n ENTITIES_SPLITTED = 'ENTITIES_SPLITTED',\n ENTITY_LOST_MERGE = 'ENTITY_LOST_MERGE',\n RELATIONSHIP_CREATED = 'RELATIONSHIP_CREATED',\n RELATIONSHIP_REMOVED = 'RELATIONSHIP_REMOVED',\n RELATIONSHIP_CHANGED = 'RELATIONSHIP_CHANGED',\n POTENTIAL_MATCHES_FOUND = 'POTENTIAL_MATCHES_FOUND',\n NOT_MATCHES_SET = 'NOT_MATCHES_SET',\n NOT_MATCHES_RESET = 'NOT_MATCHES_RESET',\n PERIODIC_TASK_SCHEDULED = 'PERIODIC_TASK_SCHEDULED',\n ENTITIES_MERGED_MANUALLY = 'ENTITIES_MERGED_MANUALLY',\n POTENTIAL_MATCHES_REMOVED = 'POTENTIAL_MATCHES_REMOVED',\n ENTITIES_MERGED_ON_THE_FLY = 'ENTITIES_MERGED_ON_THE_FLY',\n USER_LOGIN = 'USER_LOGIN',\n USER_LOGOUT = 'USER_LOGOUT',\n USER_SEARCH = 'USER_SEARCH',\n USER_PROFILE_VIEW = 'USER_PROFILE_VIEW',\n COMMENT_ADDED = 'COMMENT_ADDED',\n COMMENT_UPDATED = 'COMMENT_UPDATED',\n COMMENT_DELETED = 'COMMENT_DELETED',\n ANALYTICS_ATTRIBUTES_CHANGED = 'ANALYTICS_ATTRIBUTES_CHANGED',\n SFDC_CONNECTOR_SYNCHRONIZATION_ISSUE = 'SFDC_CONNECTOR_SYNCHRONIZATION_ISSUE',\n GROUP_CREATED = 'GROUP_CREATED',\n GROUP_REMOVED = 'GROUP_REMOVED',\n GROUP_CHANGED = 'GROUP_CHANGED'\n}\n","import {\n formatDataTypeValue,\n findAttributeTypeByUri,\n Metadata,\n AttributePresentations,\n makeAttrTypeUri,\n getAttrDataTypeDefinition\n} from '@reltio/mdm-sdk';\nimport {filter, groupBy, ifElse, map, path, pipe, propOr, values, isNil, includes, reject} from 'ramda';\nimport i18n from 'ui-i18n';\nimport {ActivityData, ActivityItem, ActivityTypes, DeltaValue} from '../types';\n\nconst getItemDataType = path(['data', 'type']);\n\nexport const getActivityType = (activity: ActivityData) => {\n const {items, label} = activity;\n const [firstItem] = items || [];\n return getItemDataType(firstItem) || label;\n};\n\nexport const isValidActivityType = (type: string): boolean => pipe(values, includes(type))(ActivityTypes);\n\nexport const removeIgnoredItems = (activity: ActivityData): ActivityData => {\n const {items = [], label} = activity;\n const isImplementedItem = (item: ActivityItem): boolean => isValidActivityType(getItemDataType(item) || label);\n const filteredItems = filter(isImplementedItem)(items);\n if (items.length !== filteredItems.length) {\n console.error('Activities not implemented:', reject(isImplementedItem)(items));\n }\n return {\n ...activity,\n items: filteredItems,\n itemsTotal: filteredItems.length\n };\n};\n\nexport const splitActivityByType = (activity: ActivityData) => {\n return pipe(\n propOr([], 'items'),\n groupBy(getItemDataType),\n values,\n ifElse(\n ({length}) => length > 1,\n map((items) => ({\n ...activity,\n items,\n itemsTotal: items.length\n })),\n () => [activity]\n )\n )(activity);\n};\n\nexport const stringifyDeltaValue = (\n deltaValue: DeltaValue['value'],\n attributeTypeUri: string,\n metadata: Metadata,\n attributePresentations: AttributePresentations\n) => {\n const attributeType = findAttributeTypeByUri(metadata, attributeTypeUri);\n const dataTypeDefinition = getAttrDataTypeDefinition(attributeType);\n const formatValue = formatDataTypeValue({attributePresentations, dataTypeDefinition});\n\n if (isNil(deltaValue)) {\n return '';\n }\n\n if (typeof deltaValue === 'string') {\n return attributeType ? formatValue(deltaValue) : deltaValue;\n }\n\n return Object.entries(deltaValue)\n .flatMap(([attributeTypeName, deltaValues]) =>\n deltaValues.map((deltaValue) =>\n stringifyDeltaValue(\n deltaValue.value,\n makeAttrTypeUri(attributeTypeUri, attributeTypeName),\n metadata,\n attributePresentations\n )\n )\n )\n .join(', ');\n};\n\nexport const getActivityLabel = (type: ActivityTypes) => {\n const labels = {\n [ActivityTypes.COMMENT_ADDED]: i18n.text('Comment added'),\n [ActivityTypes.COMMENT_DELETED]: i18n.text('Comment deleted'),\n [ActivityTypes.COMMENT_UPDATED]: i18n.text('Comment updated'),\n [ActivityTypes.ENTITIES_MERGED]: i18n.text('Profile merged'),\n [ActivityTypes.ENTITIES_MERGED_MANUALLY]: i18n.text('Profile merged manually'),\n [ActivityTypes.ENTITIES_MERGED_ON_THE_FLY]: i18n.text('Profile merged on the fly'),\n [ActivityTypes.ENTITIES_SPLITTED]: i18n.text('Profile un-merged'),\n [ActivityTypes.ENTITY_CHANGED]: i18n.text('Profile updated'),\n [ActivityTypes.ENTITY_CREATED]: i18n.text('Profile created'),\n [ActivityTypes.ENTITY_LOST_MERGE]: i18n.text('Profile lost merge'),\n [ActivityTypes.ENTITY_REMOVED]: i18n.text('Profile removed'),\n [ActivityTypes.GROUP_CHANGED]: i18n.text('Group updated'),\n [ActivityTypes.GROUP_CREATED]: i18n.text('Group created'),\n [ActivityTypes.GROUP_REMOVED]: i18n.text('Group removed'),\n [ActivityTypes.MODEL_UPDATED]: i18n.text('Model was updated'),\n [ActivityTypes.NOT_MATCHES_RESET]: i18n.text('Not matches reset'),\n [ActivityTypes.NOT_MATCHES_SET]: i18n.text('Not matches set'),\n [ActivityTypes.PERIODIC_TASK_SCHEDULED]: i18n.text('Periodic task was scheduled'),\n [ActivityTypes.POTENTIAL_MATCHES_FOUND]: i18n.text('Potential matches found'),\n [ActivityTypes.POTENTIAL_MATCHES_REMOVED]: i18n.text('Potential matches removed'),\n [ActivityTypes.RELATIONSHIP_CHANGED]: i18n.text('Relationship updated'),\n [ActivityTypes.RELATIONSHIP_CREATED]: i18n.text('Relationship created'),\n [ActivityTypes.RELATIONSHIP_REMOVED]: i18n.text('Relationship removed'),\n [ActivityTypes.USER_LOGIN]: i18n.text('Logged in'),\n [ActivityTypes.USER_LOGOUT]: i18n.text('Logged out'),\n [ActivityTypes.USER_PROFILE_VIEW]: i18n.text('Profile viewed'),\n [ActivityTypes.USER_SEARCH]: i18n.text('Searched'),\n [ActivityTypes.ANALYTICS_ATTRIBUTES_CHANGED]: i18n.text('Analytics attribute changed'),\n [ActivityTypes.SFDC_CONNECTOR_SYNCHRONIZATION_ISSUE]: i18n.text('SFDC connector synchronization issue')\n };\n return labels[type] || '';\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n dropdownIndicator: {\n transition: 'transform .15s ease'\n },\n inputRoot: {\n fontSize: '14px',\n height: 46\n },\n input: {\n padding: '0 12px 0'\n },\n dateOptionLabel: {\n minWidth: '100px'\n },\n paper: {\n minWidth: '112px'\n }\n});\n","import React, {useCallback, useRef, useState} from 'react';\nimport moment from 'moment';\nimport i18n from 'ui-i18n';\nimport {isNil} from 'ramda';\nimport {DataTypes, formatDataTypeValue} from '@reltio/mdm-sdk';\nimport {noop} from '../../../core';\nimport TextField from '@mui/material/TextField';\nimport Popover from '@mui/material/Popover';\nimport DropdownIndicatorWithIconButton from '../../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport DateRangePicker from '../../DateRangePicker/DateRangePicker';\n\nimport {useStyles} from './styles';\n\ntype DateValues = [Date, Date];\ntype Props = {\n values: DateValues;\n onChange: (values: DateValues) => void;\n onFocus?: () => void;\n};\n\nconst localeFormat = moment.localeData().longDateFormat('L');\n\nconst formatValue = (value: Date, placeholder: string) => {\n return isNil(value)\n ? `${placeholder}`\n : `${formatDataTypeValue({dataTypeDefinition: {type: DataTypes.TYPE_ACTIVENESS_DATE}}, value)}`;\n};\n\nconst CustomDateRangeEditor = ({values, onChange, onFocus = noop}: Props) => {\n const placeholder = localeFormat;\n const inputRef = useRef(null);\n const [open, setOpen] = useState(false);\n const styles = useStyles();\n\n const onApply = (values: DateValues) => {\n onChange(values);\n setOpen(false);\n };\n\n const handleToggle = useCallback(() => {\n setOpen((open) => !open);\n onFocus();\n }, [onFocus]);\n\n const onCancel = () => {\n setOpen(false);\n };\n\n return (\n <div className={styles.root}>\n <TextField\n fullWidth\n value={values.map((value) => formatValue(value, placeholder)).join(' \\u2014 ')}\n onClick={handleToggle}\n variant=\"filled\"\n ref={inputRef}\n InputProps={{\n endAdornment: (\n <DropdownIndicatorWithIconButton\n selectProps={{classes: styles, menuIsOpen: open}}\n innerProps={{}}\n />\n ),\n disableUnderline: isNil(values),\n readOnly: true,\n classes: {\n root: styles.inputRoot,\n input: styles.input\n }\n }}\n InputLabelProps={{\n shrink: false\n }}\n placeholder={i18n.text(`${placeholder} \\u2014 ${placeholder}`)}\n />\n <Popover\n open={open}\n anchorEl={inputRef.current}\n onClose={onCancel}\n anchorOrigin={{\n vertical: 'bottom',\n horizontal: 'right'\n }}\n transformOrigin={{\n vertical: 'top',\n horizontal: 'right'\n }}\n elevation={2}\n >\n <DateRangePicker values={values} onApply={onApply} type={DataTypes.TYPE_ACTIVENESS_DATE} />\n </Popover>\n </div>\n );\n};\n\nexport default CustomDateRangeEditor;\n","import i18n from 'ui-i18n';\nimport {DateRangeTypes} from '@reltio/mdm-sdk';\n\nexport const dateRangeTypeOptions = [DateRangeTypes.WITHIN, DateRangeTypes.AGO, DateRangeTypes.BETWEEN];\n\nexport const getDateRangeTypeLabel = (type: DateRangeTypes) => {\n const labels = {\n [DateRangeTypes.WITHIN]: i18n.text('Within the last'),\n [DateRangeTypes.AGO]: i18n.text('More than'),\n [DateRangeTypes.BETWEEN]: i18n.text('Date range')\n };\n return labels[type] || '';\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n title: {\n paddingBottom: '10px',\n paddingLeft: '5px',\n fontSize: '14px'\n },\n intervalContainer: {\n display: 'flex',\n justifyContent: 'space-between'\n },\n typeInput: {\n width: 160,\n marginRight: 10\n }\n});\n","import React, {useState} from 'react';\nimport i18n from 'ui-i18n';\nimport classnames from 'classnames';\nimport {DateRangeFilter, DateRangeTypes} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport SimpleDropDownSelector from '../../SimpleDropDownSelector/SimpleDropDownSelector';\nimport {dateRangeTypeOptions, getDateRangeTypeLabel} from './utils';\nimport DateIntervalSelector from '../../DateIntervalSelector/DateIntervalSelector';\nimport {useDidUpdateEffect} from '../../../hooks';\nimport CustomDateRangeEditor from '../../editors/CustomDateRangeEditor/CustomDateRangeEditor';\n\nimport {useStyles} from './styles';\n\nconst emptyDates: [Date, Date] = [null, null];\nconst emptyInterval: [number, string] = [null, 'hours'];\n\ntype Props = {\n value: DateRangeFilter;\n onChange: (range: DateRangeFilter) => void;\n className?: string;\n};\n\nconst DateRangeSelector = ({value, onChange, className}: Props) => {\n const styles = useStyles();\n\n const isIntervalType = (type: DateRangeTypes) => type === DateRangeTypes.WITHIN || type === DateRangeTypes.AGO;\n const isBetweenType = (type: DateRangeTypes) => type === DateRangeTypes.BETWEEN;\n\n const initDatesInterval = isBetweenType(value?.type) ? value.period : emptyDates;\n const initInterval = isIntervalType(value?.type) ? value.period : emptyInterval;\n\n const [datesInterval, setDatesInterval] = useState(initDatesInterval as [Date, Date]);\n const [interval, setInterval] = useState(initInterval as [number, string]);\n\n const selectedType = value?.type || DateRangeTypes.WITHIN;\n\n const getCurrentPeriodByType = (type: DateRangeTypes) => {\n if (isIntervalType(type)) {\n return interval;\n } else if (isBetweenType(type)) {\n return datesInterval;\n }\n };\n\n const changeType = ({value: type}: {value: DateRangeTypes}) => {\n if (value?.type !== type) {\n onChange({period: getCurrentPeriodByType(type), type});\n }\n };\n const changePeriod = (period) => {\n onChange({type: selectedType, period});\n };\n\n useDidUpdateEffect(() => {\n if (value) {\n if (isIntervalType(value.type)) {\n setInterval(value.period as [number, string]);\n } else if (isBetweenType(value.type)) {\n setDatesInterval(value.period as [Date, Date]);\n }\n } else {\n setDatesInterval(emptyDates);\n setInterval(emptyInterval);\n }\n }, [value]);\n\n return (\n <div className={classnames(styles.root, className)} data-reltio-id=\"date-range-selector\">\n <Typography className={styles.title} variant={'subtitle1'}>\n {i18n.text('Date')}\n </Typography>\n <div className={styles.intervalContainer}>\n <SimpleDropDownSelector\n label={''}\n className={styles.typeInput}\n value={{\n value: selectedType,\n label: getDateRangeTypeLabel(selectedType)\n }}\n options={dateRangeTypeOptions.map((option) => ({\n value: option,\n label: getDateRangeTypeLabel(option)\n }))}\n onChange={changeType}\n />\n {isIntervalType(selectedType) ? (\n <DateIntervalSelector interval={interval} onChange={changePeriod} />\n ) : (\n <CustomDateRangeEditor values={datesInterval} onChange={changePeriod} />\n )}\n </div>\n </div>\n );\n};\n\nexport default DateRangeSelector;\n","import i18n from 'ui-i18n';\nimport {HistoryActivityType} from '../types/HistoryFilter';\n\nexport const historyActivityOptions = [\n HistoryActivityType.UPDATE,\n HistoryActivityType.MERGE,\n HistoryActivityType.UNMERGE\n];\n\nexport const getHistoryActivityLabel = (type: HistoryActivityType) => {\n const labels = {\n [HistoryActivityType.UPDATE]: i18n.text('Update'),\n [HistoryActivityType.MERGE]: i18n.text('Merge'),\n [HistoryActivityType.UNMERGE]: i18n.text('Unmerge')\n };\n return labels[type] || '';\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const customStyles = {\n input: (currentStyles) => ({...currentStyles, fontSize: '14px'}),\n menuPortal: (currentStyles) => ({...currentStyles, zIndex: 1300})\n};\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n title: {\n paddingBottom: '10px',\n paddingLeft: '5px',\n fontSize: '14px'\n },\n dropDownInput: {\n width: '100%',\n justifyContent: 'center',\n backgroundColor: 'rgba(0, 0, 0, 0.03)',\n borderTop: '4px'\n },\n valueContainer: {\n overflowY: 'auto',\n height: 44\n },\n option: {\n fontSize: '14px',\n height: '32px'\n }\n});\n","import React from 'react';\nimport i18n from 'ui-i18n';\nimport {defaultTo, pipe, pluck} from 'ramda';\nimport classnames from 'classnames';\nimport Typography from '@mui/material/Typography';\nimport MultiSelect from '../../ReactSelect/MultiSelect';\nimport DropdownIndicatorWithIconButton from '../../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport {getHistoryActivityLabel, historyActivityOptions} from './utils';\nimport {HistoryActivityType} from '../types/HistoryFilter';\nimport {customStyles, useStyles} from './styles';\n\ntype Props = {\n selectedHistoryActivityTypes: HistoryActivityType[];\n onChange: (activities: HistoryActivityType[]) => void;\n className?: string;\n disableUnderline?: boolean;\n};\n\nconst HistoryActivitySelector = ({selectedHistoryActivityTypes, onChange, className, disableUnderline}: Props) => {\n const styles = useStyles();\n const valueToOption = (value: HistoryActivityType) => ({value, label: getHistoryActivityLabel(value)});\n const prepareValues = (values: HistoryActivityType[]) => values.map(valueToOption);\n\n const options = prepareValues(historyActivityOptions);\n\n return (\n <div className={classnames(styles.root, className)} data-reltio-id=\"history-activity-selector\">\n <Typography className={styles.title} variant={'subtitle1'}>\n {i18n.text('Activity')}\n </Typography>\n <MultiSelect\n value={prepareValues(selectedHistoryActivityTypes)}\n onChange={pipe(defaultTo([]), pluck('value'), onChange)}\n options={options}\n TextFieldProps={{\n InputProps: {disableUnderline},\n classes: {root: styles.dropDownInput}\n }}\n components={{\n DropdownIndicator: DropdownIndicatorWithIconButton\n }}\n styles={customStyles}\n classes={styles}\n menuPlacement=\"bottom\"\n menuPortalTarget={document.body}\n menuShouldBlockScroll={true}\n captureMenuScroll={false}\n />\n </div>\n );\n};\n\nexport default HistoryActivitySelector;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n popup: {\n width: 500,\n minHeight: 500,\n overflowY: 'hidden',\n display: 'flex',\n flexDirection: 'column'\n },\n filterContainer: {\n maxHeight: '400px',\n borderColor: 'rgba(0,0,0,0.12)'\n },\n filterItem: {\n '&:not(:last-child)': {\n marginBottom: 12\n }\n },\n clearButton: {\n marginRight: 'auto'\n },\n input: {\n height: '100%',\n paddingLeft: '12px',\n paddingRight: '8px'\n },\n divider: {\n marginBottom: 12\n }\n});\n","import React, {useCallback, useEffect, useRef, useState} from 'react';\nimport i18n from 'ui-i18n';\nimport {curry, dissoc} from 'ramda';\nimport FilterListIcon from '@mui/icons-material/FilterList';\nimport Button from '@mui/material/Button';\nimport Popover from '@mui/material/Popover';\nimport DialogActions from '@mui/material/DialogActions';\nimport DialogContent from '@mui/material/DialogContent';\nimport DialogTitle from '@mui/material/DialogTitle';\nimport Divider from '@mui/material/Divider';\nimport {TEntityType, isDateRangeValid} from '@reltio/mdm-sdk';\nimport {SmallIconButton} from '../../SmallIconButton';\nimport {HistoryFilter} from '../types';\nimport UserSelector from '../../UserSelector/UserSelector';\nimport AttributeSelector from '../../AttributeSelector/AttributeSelector';\nimport DateRangeSelector from '../DateRangeSelector/DateRangeSelector';\nimport HistoryActivitySelector from '../HistoryActivitySelector/HistoryActivitySelector';\nimport {DEFAULT_HISTORY_FILTER, isDefaultFilter} from '../hooks/useHistory';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n className?: string;\n filter: HistoryFilter;\n onApplyFilter: (filter: HistoryFilter) => void;\n entityType: TEntityType;\n};\n\nconst HistoryFilterButton = ({className, filter, onApplyFilter, entityType}: Props) => {\n const styles = useStyles();\n const buttonRef = useRef();\n const [isOpen, setIsOpen] = useState(false);\n const [currentValue, setCurrentValue] = useState<HistoryFilter>(filter);\n const {activities = [], attributes = [], dateRange = null, users = []} = currentValue || {};\n\n const buttonColor = isDefaultFilter(filter) ? 'inherit' : 'primary';\n\n useEffect(() => {\n if (isOpen) {\n setCurrentValue(filter);\n }\n }, [filter, isOpen]);\n\n const handlePropChange = curry((propName: string, value: unknown) => {\n setCurrentValue((filterValue) => ({\n ...filterValue,\n [propName]: value\n }));\n });\n\n const togglePopup = useCallback(() => {\n setIsOpen((open) => !open);\n }, []);\n\n const applyButtonHandler = useCallback(() => {\n dateRange && isDateRangeValid(dateRange)\n ? onApplyFilter(currentValue)\n : onApplyFilter(dissoc('dateRange', currentValue));\n togglePopup();\n }, [currentValue, dateRange, onApplyFilter, togglePopup]);\n\n const clearAllButtonHandler = useCallback(() => {\n setCurrentValue({...DEFAULT_HISTORY_FILTER});\n }, []);\n\n return (\n <>\n <SmallIconButton\n ref={buttonRef}\n color={buttonColor}\n icon={FilterListIcon}\n size=\"L\"\n onClick={togglePopup}\n className={className}\n />\n <Popover\n classes={{paper: styles.popup}}\n open={isOpen}\n anchorEl={buttonRef.current}\n onClose={togglePopup}\n anchorOrigin={{\n vertical: 'bottom',\n horizontal: 'right'\n }}\n transformOrigin={{\n vertical: 'top',\n horizontal: 'right'\n }}\n >\n <DialogTitle>{i18n.text('Filter')}</DialogTitle>\n <DialogContent dividers className={styles.filterContainer}>\n <DateRangeSelector\n value={dateRange}\n onChange={handlePropChange('dateRange')}\n className={styles.filterItem}\n />\n <Divider light className={styles.divider} />\n <UserSelector\n selectedUsers={users}\n onChange={handlePropChange('users')}\n className={styles.filterItem}\n disableUnderline\n />\n <Divider light className={styles.divider} />\n <HistoryActivitySelector\n selectedHistoryActivityTypes={activities}\n onChange={handlePropChange('activities')}\n className={styles.filterItem}\n disableUnderline\n />\n <Divider light className={styles.divider} />\n <AttributeSelector\n selectedAttributes={attributes}\n entityType={entityType}\n onChange={handlePropChange('attributes')}\n className={styles.filterItem}\n title={i18n.text('Attribute updated')}\n disableUnderline\n />\n </DialogContent>\n <DialogActions>\n <Button onClick={clearAllButtonHandler} className={styles.clearButton}>\n {i18n.text('Clear all')}\n </Button>\n <Button onClick={togglePopup}>{i18n.text('Cancel')}</Button>\n <Button color=\"primary\" onClick={applyButtonHandler}>\n {i18n.text('Apply')}\n </Button>\n </DialogActions>\n </Popover>\n </>\n );\n};\n\nexport default HistoryFilterButton;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n menuItem: {\n minHeight: '32px'\n },\n menuText: {\n fontSize: '13px',\n lineHeight: '15px',\n letterSpacing: 0,\n marginLeft: '30px'\n },\n checkIcon: {\n position: 'absolute',\n color: 'rgba(0, 0, 0, 0.54)'\n }\n});\n","import React, {forwardRef} from 'react';\nimport MenuItem from '@mui/material/MenuItem';\nimport Typography from '@mui/material/Typography';\nimport CheckIcon from '@mui/icons-material/Check';\nimport {noop} from '../../../core';\nimport {useStyles} from './styles';\n\ntype Item = {\n text: string;\n selected: boolean;\n onClick: (e) => void;\n};\n\ntype Props = {\n item: Item;\n onMenuClose?: () => void;\n};\n\nconst MenuItemRenderer = forwardRef(({item, onMenuClose = noop}: Props, ref: React.Ref<HTMLLIElement>) => {\n const styles = useStyles();\n const {text, selected, onClick} = item;\n const handleClick = (e) => {\n onMenuClose();\n onClick(e);\n };\n\n return (\n <MenuItem classes={{root: styles.menuItem}} onClick={handleClick} ref={ref}>\n {selected && <CheckIcon className={styles.checkIcon} />}\n <Typography classes={{root: styles.menuText}}>{text}</Typography>\n </MenuItem>\n );\n});\nMenuItemRenderer.displayName = 'MenuItemRenderer';\n\nexport default MenuItemRenderer;\n","import React from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport i18n from 'ui-i18n';\nimport MoreVertIcon from '@mui/icons-material/MoreVert';\nimport mdmModule, {HistoryMode, profile} from '@reltio/mdm-module';\nimport {SmallIconButton} from '../../SmallIconButton';\nimport DropDownMenuButton from '../../DropDownMenuButton/DropDownMenuButton';\nimport MenuItemRenderer from './MenuItemRenderer';\n\nconst HistoryMenuButton = () => {\n const mode = useSelector(mdmModule.selectors.getHistoryMode);\n const dispatch = useDispatch();\n const handleModeChange = (selectedMode: HistoryMode) => {\n dispatch(profile.history.actions.setHistoryMode(selectedMode));\n };\n const menuItems = [\n {\n text: i18n.text('Compare to Current view'),\n selected: mode === HistoryMode.Current,\n onClick: () => handleModeChange(HistoryMode.Current)\n },\n {\n text: i18n.text('Compare to Previous view'),\n selected: mode === HistoryMode.Previous,\n onClick: () => handleModeChange(HistoryMode.Previous)\n }\n ];\n\n return (\n <DropDownMenuButton\n MenuItemRenderer={MenuItemRenderer}\n buttonComponent={SmallIconButton}\n buttonProps={{\n icon: MoreVertIcon,\n size: 'L'\n }}\n menuId={'history-menu'}\n menuItems={menuItems}\n />\n );\n};\n\nexport default HistoryMenuButton;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n flex: 1,\n alignItems: 'center'\n },\n icon: {\n margin: 4\n },\n divider: {\n borderColor: 'rgba(0,0,0,0.12)',\n margin: '3px 19px'\n },\n count: {\n fontSize: 14\n },\n filterButton: {\n marginRight: '-4px'\n }\n});\n","import React from 'react';\nimport i18n from 'ui-i18n';\nimport Divider from '@mui/material/Divider';\nimport Typography from '@mui/material/Typography';\nimport {isNil} from 'ramda';\nimport {TEntityType} from '@reltio/mdm-sdk';\nimport Spacer from '../../Spacer/Spacer';\nimport HistoryFilterButton from '../HistoryFilterButton/HistoryFilterButton';\nimport HistoryMenuButton from '../HistoryMenuButton/HistoryMenuButton';\nimport {HistoryFilter} from '../types';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n total?: number;\n entityType: TEntityType;\n filter: HistoryFilter;\n onApplyFilter: (value: HistoryFilter) => void;\n};\n\nconst HistoryHeader = ({total, entityType, filter, onApplyFilter}: Props) => {\n const styles = useStyles();\n return (\n <div className={styles.root}>\n <Typography variant=\"h6\">{i18n.text('History')}</Typography>\n {!isNil(total) && (\n <>\n <Divider orientation=\"vertical\" flexItem className={styles.divider} />\n <Typography variant=\"body1\" color=\"textSecondary\" className={styles.count}>\n {total === 1\n ? i18n.text('${count} contributing profile', {count: total})\n : i18n.text('${count} contributing profiles', {count: total})}\n </Typography>\n </>\n )}\n <Spacer />\n <HistoryFilterButton\n className={styles.filterButton}\n entityType={entityType}\n filter={filter}\n onApplyFilter={onApplyFilter}\n />\n <HistoryMenuButton />\n </div>\n );\n};\n\nexport default HistoryHeader;\n","import React from 'react';\nimport i18n from 'ui-i18n';\nimport SidePanelEmptyState from '../../SidePanelEmptyState/SidePanelEmptyState';\n\nconst HistoryPanelEmptyState = () => (\n <SidePanelEmptyState\n text={i18n.text('History in the making')}\n secondaryText={i18n.text('When you create an event or perform an activity, it will show up here.')}\n />\n);\n\nexport default HistoryPanelEmptyState;\n","import {makeStyles} from '@mui/styles';\n\ntype Type = {\n color?: string;\n};\n\nexport const useStyles = makeStyles(() => ({\n historyRow: {\n position: 'relative',\n padding: '8px 12px 16px',\n cursor: 'pointer'\n },\n selected: {\n background: 'rgba(0,0,0,0.05)',\n '&:before': {\n content: '\"\"',\n background: 'rgba(0,0,0,0.05)',\n width: '100%',\n height: '100%',\n position: 'absolute',\n left: '-100%',\n top: 0\n }\n },\n rowHeader: {\n display: 'flex',\n position: 'relative'\n },\n badge: ({color}: Type) => ({\n position: 'absolute',\n width: '2px',\n height: '100%',\n left: '-9px',\n pointerEvents: 'none',\n background: color,\n '&:before': {\n height: '100%',\n width: '3px',\n content: '\"\"',\n left: '-3px',\n background: color,\n position: 'absolute',\n opacity: 0.06\n }\n }),\n title: {\n color: 'rgba(0,0,0,0.87)',\n fontSize: '13px',\n letterSpacing: 0,\n lineHeight: '16px',\n fontWeight: 400,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n '&.bold': {\n fontWeight: 500\n }\n },\n date: {\n marginLeft: 'auto',\n color: 'rgba(0,0,0,0.54)',\n fontSize: '11px',\n letterSpacing: 0,\n lineHeight: '16px',\n flexShrink: 0\n },\n user: {\n color: 'rgba(0,0,0,0.38)',\n fontSize: '12px',\n letterSpacing: 0,\n lineHeight: '14px'\n }\n}));\n","import React from 'react';\nimport classnames from 'classnames';\nimport i18n from 'ui-i18n';\nimport {getContributorColor, HistoryChange} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport {ActivityTypes} from '../../activityLog/types/ActivityTypes';\nimport {getActivityLabel} from '../../activityLog/utils/activities';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n change: HistoryChange;\n isCurrent?: boolean;\n isSelected: boolean;\n onClick: () => void;\n};\n\nconst HistoryRow = ({change, isCurrent, isSelected, onClick}: Props) => {\n const {uri, type, matchGroups, user, timestamp} = change;\n const color = getContributorColor(uri);\n const styles = useStyles({color});\n return (\n <div className={classnames(styles.historyRow, {[styles.selected]: isSelected})} onClick={onClick}>\n <div className={styles.rowHeader}>\n <div className={styles.badge} />\n <Typography className={classnames(styles.title, {bold: isCurrent})}>\n {isCurrent ? i18n.text('Current view') : getActivityLabel(type as ActivityTypes)}\n </Typography>\n {!isCurrent && <Typography className={styles.date}>{i18n.date(timestamp, 'L LT')}</Typography>}\n </div>\n {matchGroups && (\n <Typography className={styles.title}>\n {i18n.text('Match rule:')} {matchGroups.join(', ')}\n </Typography>\n )}\n <Typography className={styles.user}>{user}</Typography>\n </div>\n );\n};\n\nexport default HistoryRow;\n","import {HistoryChangeTypes} from '../types/HistoryChangeTypes';\n\nexport const getHistoryLinkCurve = (x: number, y: number, toX: number, toY: number) => {\n const isUp = y > toY;\n const isLeft = x < toX;\n const curveStartX = isLeft ? toX - 12 : toX + 12;\n const curveCenterY = isUp ? -6 : 6;\n const curveEndY = isUp ? -12 : 12;\n const curve = isLeft ? `c 6 0 12 ${curveCenterY} 12` : `c -6 0 -12 ${curveCenterY} -12`;\n return `M${x} ${y} L${curveStartX} ${y} ${curve} ${curveEndY} L${toX} ${toY}`;\n};\n\nexport const isFakeHistoryType = (type: string) =>\n type === HistoryChangeTypes.FAKE_FILTERED_INCOMING || type === HistoryChangeTypes.FAKE_FILTERED_OUTGOING;\n","import React from 'react';\nimport {getHistoryLinkCurve} from './helpers';\n\ntype Props = {\n x: number;\n y: number;\n toX: number;\n toY: number;\n color: string;\n isDashed?: boolean;\n};\n\nconst HistoryLink = ({x, y, toX, toY, color, isDashed}: Props) => {\n const lineData = getHistoryLinkCurve(x, y, toX, toY);\n return (\n <path\n d={lineData}\n stroke={color}\n strokeWidth={2}\n fill={'none'}\n strokeDasharray={isDashed ? '3,3' : undefined}\n />\n );\n};\n\nexport default HistoryLink;\n","import React, {forwardRef} from 'react';\n\ntype Props = {\n x: number;\n y: number;\n color: string;\n isDashed?: boolean;\n isCollapsed?: boolean;\n showCollapseIcon?: boolean;\n showLine?: boolean;\n} & React.SVGProps<SVGGElement>;\n\nexport const BUMP_RADIUS = 3;\nexport const LINE_MARGIN = 4;\n\nconst HistoryCircle = ({x, y, color, isDashed, isCollapsed, showCollapseIcon, showLine, ...otherProps}: Props, ref) => {\n const radius = showCollapseIcon ? BUMP_RADIUS * 2 : BUMP_RADIUS;\n return (\n <g {...otherProps} ref={ref}>\n {showLine && (\n <rect\n id=\"line\"\n x={x - radius - LINE_MARGIN}\n y={y - radius - LINE_MARGIN}\n width={radius * 2 + LINE_MARGIN * 2}\n height={2}\n fill={color}\n />\n )}\n <circle\n cx={x}\n cy={y}\n r={radius}\n fill={isDashed ? '#fff' : color}\n stroke={color}\n strokeDasharray={isDashed ? '1,1' : undefined}\n strokeWidth={2}\n />\n {showCollapseIcon && (\n <g id=\"icon\">\n <rect x={x - 4} y={y - 1} width={8} height={2} fill=\"#fff\" />\n {isCollapsed && <rect x={x - 1} y={y - 4} width={2} height={8} fill=\"#fff\" />}\n </g>\n )}\n </g>\n );\n};\n\nexport default forwardRef(HistoryCircle);\n","import React, {memo} from 'react';\nimport {getContributorColor} from '@reltio/mdm-sdk';\nimport HistoryLink from './HistoryLink';\nimport HistoryCircle from './HistoryCircle';\nimport {HistoryData, HistoryChangeTypes} from '../types';\nimport {isFakeHistoryType} from './helpers';\nimport {withTooltip} from '../../../HOCs';\n\nconst COL_WIDTH = 16;\nconst COL_MARGIN = 24;\nconst ROW_MARGIN = 16;\nconst ROW_HEIGHT = 16;\n\nexport const HistoryCircleWithTooltip = withTooltip(HistoryCircle);\n\ntype Props = {\n graphData: HistoryData;\n onHistoryCircleMouseOver?: (uri: string, timestamp: number, index: number) => void;\n};\n\nconst HistoryGraph = ({graphData, onHistoryCircleMouseOver}: Props) => {\n const {historyLanes, rows} = graphData;\n const rowPositions = [ROW_MARGIN];\n\n const {links, rowLines, circles} = rows.reduce(\n (acc, {uri, height, uris, type, fakeType, index, timestamp, label}, i) => {\n const x = historyLanes[uri].index * COL_WIDTH + COL_MARGIN;\n const y = rowPositions[i];\n rowPositions.push(y + height);\n\n const hasFakeType = isFakeHistoryType(fakeType);\n const circleUri = hasFakeType ? uris[0] : uri;\n const isCollapsed = !uris?.some((uri) => historyLanes[uri]);\n acc.circles.push(\n <HistoryCircleWithTooltip\n tooltipTitle={label}\n tooltipPlacement=\"top\"\n onMouseOver={\n onHistoryCircleMouseOver ? () => onHistoryCircleMouseOver(uri, timestamp, index) : undefined\n }\n key={`circle-${circleUri}-${i}`}\n x={x}\n y={y}\n color={getContributorColor(circleUri)}\n isDashed={hasFakeType}\n isCollapsed={isCollapsed}\n showCollapseIcon={!!uris}\n showLine={fakeType === HistoryChangeTypes.FAKE_NAVIGATE_PROFILE}\n />\n );\n\n acc.rowLines.push(\n <rect\n key={`${circleUri}-${index}`}\n x={x}\n y={y - ROW_HEIGHT / 2}\n width={'100%'}\n height={ROW_HEIGHT}\n fill={getContributorColor(circleUri)}\n opacity={0.06}\n />\n );\n\n const isUpRight = type === HistoryChangeTypes.ENTITIES_SPLITTED;\n uris?.forEach((contributorUri) => {\n const contributorLane = historyLanes[contributorUri];\n if (!contributorLane) return;\n const rowHeight = rows[i].height;\n const toX = contributorLane.index * COL_WIDTH + COL_MARGIN;\n const toY = isUpRight ? y - rowHeight : y + rowHeight;\n if (x !== toX)\n acc.links.push(\n <HistoryLink\n key={`link-${contributorUri}-${index}`}\n x={x}\n y={y}\n toX={toX}\n toY={toY}\n isDashed={isFakeHistoryType(fakeType)}\n color={getContributorColor(contributorUri)}\n />\n );\n });\n\n return acc;\n },\n {links: [], circles: [], rowLines: []}\n );\n\n const width = Object.keys(historyLanes).length * COL_WIDTH + COL_MARGIN;\n const height = rowPositions[rowPositions.length - 1] - ROW_MARGIN;\n\n Object.entries(historyLanes).forEach(([contributorUri, contributorLane]) => {\n const x = contributorLane.index * COL_WIDTH + COL_MARGIN;\n contributorLane.lifeTime.forEach(({start, end}, i) => {\n if (rows[end?.index]?.type === HistoryChangeTypes.ENTITIES_SPLITTED) return;\n const startIndex = start?.type === HistoryChangeTypes.ENTITIES_SPLITTED ? start?.index - 1 : start?.index;\n const endIndex =\n end?.type === HistoryChangeTypes.ENTITIES_MERGED_MANUALLY ||\n end?.type === HistoryChangeTypes.ENTITIES_MERGED\n ? end?.index + 1\n : end?.index;\n const startY = rowPositions[startIndex] || rowPositions[rowPositions.length - 2];\n const endY = rowPositions[endIndex] || ROW_MARGIN;\n if (startY <= endY) return;\n const color = getContributorColor(contributorUri);\n if (!end && contributorLane.index > 0) {\n circles.push(\n <HistoryCircle key={`initCircle-${contributorUri}-${i}`} x={x} y={endY} color={color} showLine />\n );\n }\n links.unshift(\n <path\n key={`line-${contributorUri}-${i}`}\n d={`M${x} ${startY} L${x} ${endY}`}\n stroke={color}\n strokeWidth={2}\n />\n );\n });\n });\n\n return (\n <svg className=\"chart\" width={width} height={height}>\n <g id=\"rowLines\">{rowLines}</g>\n <g id=\"links\">{links}</g>\n <g id=\"circles\">{circles}</g>\n </svg>\n );\n};\n\nexport default memo(HistoryGraph);\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n historyTree: {\n display: 'grid',\n gridTemplateColumns: 'auto 1fr',\n overflowY: 'auto'\n },\n graph: {\n overflowX: 'auto',\n overflowY: 'hidden'\n },\n history: {\n minWidth: '260px'\n },\n buttonContainer: {\n gridColumnStart: 1,\n gridColumnEnd: 3,\n padding: '8px 16px'\n },\n shadow: {\n boxShadow: 'inset -8px 0px 5px -5px rgba(0,0,0,0.1)'\n }\n});\n","import React, {useCallback, useEffect, useRef, useState} from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport ReactResizeDetector from 'react-resize-detector';\nimport i18n from 'ui-i18n';\nimport {isNil, uniqBy, prop, identity} from 'ramda';\nimport classnames from 'classnames';\nimport {getEntity, Mode, Metadata, getCrosswalkType} from '@reltio/mdm-sdk';\nimport mdm, {HistoryEvent, profile} from '@reltio/mdm-module';\nimport {HistoryData, HistoryRowData} from '../types';\nimport Button from '@mui/material/Button';\nimport HistoryRow from '../HistoryRow/HistoryRow';\nimport HistoryGraph from '../HistoryGraph/HistoryGraph';\nimport LinearLoadIndicator from '../../LinearLoadIndicator/LinearLoadIndicator';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n historyData: HistoryData;\n canLoadMore: boolean;\n onLoadMore: () => void;\n isLoading: boolean;\n entityUri: string;\n historyEvent: HistoryEvent;\n findPreviousChange: (index: number, uri: string) => HistoryRowData;\n};\n\nconst HistoryTree = ({\n historyData,\n isLoading,\n canLoadMore,\n onLoadMore,\n entityUri,\n historyEvent,\n findPreviousChange\n}: Props) => {\n const styles = useStyles();\n const dispatch = useDispatch();\n const isEditableMode = useSelector(mdm.selectors.getIsEditableMode);\n const metadata: Metadata = useSelector(mdm.selectors.getMetadata);\n\n const [graphData, setGraphData] = useState({historyLanes: {}, rows: []});\n const [isScrollable, setIsScrollable] = useState(false);\n const [selectedIndex, setSelectedIndex] = useState(-1);\n\n useEffect(() => {\n if (isNil(historyEvent)) {\n setSelectedIndex(0);\n return;\n }\n const isCurrentEventChange = (change: HistoryRowData) =>\n change?.uri === (historyEvent?.overrideUri || entityUri) && change?.timestamp === historyEvent?.aStamp;\n const selectedChangeByIndex = selectedIndex !== -1 ? historyData.rows[selectedIndex] : null;\n const currentEventChangeIndex = historyData.rows.findIndex((change) => isCurrentEventChange(change));\n setSelectedIndex(isCurrentEventChange(selectedChangeByIndex) ? selectedIndex : currentEventChangeIndex);\n }, [historyData.rows, historyEvent]);\n\n const graphRef = useRef(null);\n const rowsRef = useCallback(\n (node) => {\n if (!isNil(node)) {\n const rows = historyData.rows?.map((item, i) => ({...item, height: node.childNodes[i]?.clientHeight}));\n setGraphData({historyLanes: historyData.historyLanes, rows});\n }\n },\n [historyData]\n );\n\n const handleGraphScroll = () => {\n const {scrollWidth, clientWidth, scrollLeft} = graphRef?.current || {};\n setIsScrollable(scrollLeft < scrollWidth - clientWidth);\n };\n\n const handleHistoryCircleMouseOver = (uri, timestamp, index) => {\n if (isNil(graphData.rows[index].label)) {\n const options = {time: timestamp, select: 'crosswalks'} as any;\n getEntity(uri, options).then(({crosswalks}) => {\n const label = crosswalks\n ? uniqBy(prop('type'), crosswalks)\n .map((cw) => {\n const crosswalkType = getCrosswalkType(metadata, cw.type);\n return crosswalkType ? crosswalkType.label : null;\n })\n .filter(identity)\n .join(', ')\n : i18n.text('No data');\n\n setGraphData((prevGraphData) => ({\n ...prevGraphData,\n rows: prevGraphData.rows.map((row) => (row.index === index ? {...row, label} : row))\n }));\n });\n }\n };\n\n const handleHistoryRowClick = (index: number, change: HistoryRowData, isSelected: boolean, isCurrent: boolean) => {\n if (isEditableMode) {\n if (\n window.confirm(i18n.text('Are you sure you want to go in history mode? All your changes will be lost.'))\n ) {\n dispatch(profile.mode.actions.modeUpdated(Mode.Viewing));\n } else {\n return;\n }\n }\n\n if ((isCurrent && !isSelected) || (!isCurrent && isSelected)) {\n dispatch(profile.history.actions.clearHistoryEvent());\n setSelectedIndex(0);\n } else if (!isCurrent && !isSelected) {\n const aChange = findPreviousChange(index - 1, change.uri || entityUri);\n const bChange = findPreviousChange(index, change.uri || entityUri);\n const aStamp = aChange?.timestamp;\n const bStamp = bChange?.timestamp;\n const overrideUri = change?.uri === entityUri ? null : change?.uri;\n dispatch(profile.history.actions.setHistoryEvent({aStamp, bStamp, overrideUri}));\n setSelectedIndex(index);\n }\n };\n\n return (\n <div className={styles.historyTree}>\n {isLoading && <LinearLoadIndicator />}\n <div\n className={classnames(styles.graph, {[styles.shadow]: isScrollable})}\n onScroll={handleGraphScroll}\n ref={graphRef}\n >\n <HistoryGraph onHistoryCircleMouseOver={handleHistoryCircleMouseOver} graphData={graphData} />\n <ReactResizeDetector handleWidth onResize={handleGraphScroll} />\n </div>\n <div ref={rowsRef} className={styles.history}>\n {historyData.rows.map((change, i) => {\n const isSelected = i === selectedIndex;\n const isCurrent = i === 0;\n return (\n <HistoryRow\n key={`row-${i}`}\n change={change}\n isCurrent={isCurrent}\n isSelected={isSelected}\n onClick={() => handleHistoryRowClick(i, change, isSelected, isCurrent)}\n />\n );\n })}\n </div>\n {canLoadMore && (\n <div className={styles.buttonContainer}>\n <Button color=\"primary\" onClick={() => onLoadMore()}>\n {i18n.text('Show more')}\n </Button>\n </div>\n )}\n </div>\n );\n};\n\nexport default HistoryTree;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n flexWrap: 'wrap',\n padding: '10px 15px'\n }\n});\n\ntype StylesProps = {\n color: string;\n};\n\nexport const useContributorStyles = makeStyles({\n icon: ({color}: StylesProps) => ({\n boxSizing: 'border-box',\n borderWidth: 2,\n borderStyle: 'solid',\n borderColor: color,\n height: 12,\n width: 12,\n borderRadius: 30,\n transition: 'opacity 0.3s',\n margin: 4\n }),\n active: ({color}: StylesProps) => ({\n backgroundColor: color\n }),\n inactive: {\n backgroundColor: 'white'\n },\n clickable: {\n cursor: 'pointer'\n }\n});\n","import React from 'react';\nimport classnames from 'classnames';\nimport {getContributorColor} from '@reltio/mdm-sdk';\n\nimport {useContributorStyles} from './styles';\n\ntype Props = {\n value: string;\n isSelected?: boolean;\n onClick?: () => void;\n};\n\nconst ContributorItem = ({value, isSelected = true, onClick}: Props) => {\n const color = getContributorColor(value);\n const styles = useContributorStyles({color});\n\n return (\n <div\n className={classnames(styles.icon, {\n [styles.inactive]: !isSelected,\n [styles.active]: isSelected,\n [styles.clickable]: !!onClick\n })}\n onClick={onClick}\n />\n );\n};\n\nexport default ContributorItem;\n","import React from 'react';\nimport classnames from 'classnames';\nimport {without} from 'ramda';\nimport ContributorItem from './ContributorItem';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n values: string[];\n selectedValues: string[];\n onSelectValues: (values: string[]) => void;\n entityUri: string;\n className?: string;\n};\n\nconst ContributorsPanel = ({values, selectedValues, entityUri, onSelectValues, className}: Props) => {\n const styles = useStyles();\n\n const handleClick = (value: string) => {\n if (selectedValues?.includes(value)) {\n onSelectValues(without([value], selectedValues));\n } else {\n onSelectValues([...(selectedValues || []), value]);\n }\n };\n\n return (\n <div className={classnames(styles.root, className)}>\n <ContributorItem value={entityUri} />\n {values?.length > 0 &&\n values.map((value) => (\n <ContributorItem\n key={value}\n value={value}\n isSelected={selectedValues?.includes(value)}\n onClick={() => handleClick(value)}\n />\n ))}\n </div>\n );\n};\n\nexport default ContributorsPanel;\n","import {useMemo} from 'react';\nimport {isNil, pipe, slice, find, curry, drop} from 'ramda';\nimport {HistoryChange} from '@reltio/mdm-sdk';\nimport {HistoryChangeTypes, HistoryLife, HistoryRowData} from './../types';\n\ntype Props = {\n entityUri: string;\n historyChanges: HistoryChange[];\n selectedUris: string[];\n};\n\nexport const useHistoryTree = ({entityUri, historyChanges, selectedUris}: Props) => {\n return useMemo(() => {\n const historyLanes = {[entityUri]: {index: 0, lifeTime: []}};\n const rows = [{user: '', timestamp: 0, uri: entityUri}] as HistoryRowData[];\n\n const checkChange = curry((involvedUris: string | any[], checkInUris: boolean, change: HistoryChange) => {\n const uri = change.uri || entityUri;\n if (involvedUris) {\n if (Array.isArray(involvedUris)) {\n if (change.type !== HistoryChangeTypes.ENTITY_LOST_MERGE) return null;\n if (involvedUris.includes(uri)) {\n return change;\n } else if (checkInUris && change.uris) {\n return involvedUris.some((involvedUri) => change.uris.includes(involvedUri)) ? change : null;\n }\n } else {\n if (uri === involvedUris || (checkInUris && change.uris?.includes(involvedUris))) return change;\n }\n }\n\n return null;\n });\n\n const findNextChange = (index: number, involvedUris: string | any[], checkInUris: boolean) =>\n pipe(drop(index + 1), find(checkChange(involvedUris, checkInUris)))(historyChanges);\n\n const findPreviousChange = (index: number, uri: string) =>\n pipe(slice(index + 1, Infinity), find(checkChange(uri, false)))(rows);\n\n const checkLaneUri = (uri: string) => {\n if (!historyLanes[uri] && (!selectedUris || selectedUris.includes(uri))) {\n historyLanes[uri] = {\n index: Object.keys(historyLanes).length,\n lifeTime: []\n };\n }\n return historyLanes[uri];\n };\n\n const startNewLife = (lifeTime: HistoryLife[], change: HistoryChange) => {\n const currentLife = lifeTime[lifeTime.length - 1];\n if (\n currentLife &&\n (!currentLife.start ||\n (currentLife.start.type === HistoryChangeTypes.ENTITY_CREATED &&\n change.type === HistoryChangeTypes.ENTITIES_SPLITTED))\n ) {\n currentLife.start = change;\n return;\n }\n lifeTime.push({start: change, end: null});\n };\n\n const updateLife = (lifeTime: HistoryLife[], change: HistoryChange) => {\n let shouldAddNewLife = true;\n if (lifeTime.length) {\n const currentLife = lifeTime[lifeTime.length - 1];\n shouldAddNewLife = !(\n (!currentLife.start || currentLife.start.timestamp < change.timestamp) &&\n (!currentLife.end || currentLife.end.timestamp > change.timestamp)\n );\n }\n if (shouldAddNewLife) {\n lifeTime.push({start: null, end: null});\n }\n };\n\n const endLife = (lifeTime: HistoryLife[], change: HistoryChange) => {\n if (lifeTime.length) {\n const currentLife = lifeTime[lifeTime.length - 1];\n if (!currentLife.start) currentLife.start = change;\n }\n lifeTime.push({start: null, end: change});\n };\n\n const checkLifeTime = (lifeTime: HistoryLife[], change: HistoryChange) => {\n switch (change.type) {\n case HistoryChangeTypes.ENTITY_CREATED:\n startNewLife(lifeTime, change);\n break;\n case HistoryChangeTypes.ENTITIES_MERGED_ON_THE_FLY:\n case HistoryChangeTypes.ENTITY_CHANGED:\n updateLife(lifeTime, change);\n break;\n case HistoryChangeTypes.ENTITY_LOST_MERGE:\n case HistoryChangeTypes.ENTITY_REMOVED:\n endLife(lifeTime, change);\n break;\n case HistoryChangeTypes.ENTITIES_SPLITTED:\n updateLife(lifeTime, change);\n change.uris?.forEach((uri) => {\n const relatedLane = historyLanes[uri];\n if (!relatedLane) return;\n const lifeTimeLength = relatedLane.lifeTime.length;\n lifeTimeLength\n ? startNewLife(relatedLane.lifeTime, change)\n : endLife(relatedLane.lifeTime, change);\n\n rows.push({\n uri,\n user: change.user,\n type: change.type,\n fakeType: lifeTimeLength\n ? HistoryChangeTypes.FAKE_UPDATE\n : HistoryChangeTypes.FAKE_NAVIGATE_PROFILE,\n timestamp: change.timestamp\n });\n });\n break;\n case HistoryChangeTypes.ENTITIES_MERGED:\n case HistoryChangeTypes.ENTITIES_MERGED_MANUALLY:\n updateLife(lifeTime, change);\n change.uris?.forEach((uri) => {\n const relatedLane = historyLanes[uri];\n if (relatedLane) endLife(relatedLane.lifeTime, change);\n });\n break;\n }\n };\n\n const postProcessChanges: HistoryChange[] = [];\n historyChanges?.forEach((change, index) => {\n switch (change.type) {\n case HistoryChangeTypes.ENTITIES_SPLITTED:\n if (!findNextChange(index, change.uri || entityUri, false)) {\n return;\n } else {\n const uri = change.uri;\n const involvedUris = change.uris ? [change.uris, uri] : [uri];\n const lostMergeChange = findNextChange(index, involvedUris, true);\n if (lostMergeChange && (!uri || uri === lostMergeChange.uri)) return;\n }\n break;\n case HistoryChangeTypes.ENTITY_LOST_MERGE:\n case HistoryChangeTypes.RELATIONSHIP_CREATED:\n case HistoryChangeTypes.RELATIONSHIP_REMOVED:\n case HistoryChangeTypes.RELATIONSHIP_CHANGED:\n return;\n }\n\n let addPostProcess = false;\n change.uris?.forEach((uri) => {\n if (!checkLaneUri(uri)) addPostProcess = true;\n });\n\n const contributorLane = checkLaneUri(change.uri || entityUri);\n if (!contributorLane) return;\n const rowChange = {...change};\n checkLifeTime(contributorLane.lifeTime, rowChange);\n if (addPostProcess) postProcessChanges.push(rowChange);\n rows.push(rowChange);\n });\n\n postProcessChanges.forEach((postChange) => {\n postChange.uris.forEach((postUri) => {\n if (historyLanes[postUri]) return;\n historyChanges.forEach(({uri, uris, timestamp, user, type}) => {\n if (uri !== postUri) return;\n uris?.forEach((contributorUri) => {\n const contributorLane = historyLanes[contributorUri];\n if (!contributorLane) return;\n let fakeType = null;\n switch (type) {\n case HistoryChangeTypes.ENTITIES_MERGED:\n case HistoryChangeTypes.ENTITIES_MERGED_MANUALLY:\n fakeType = HistoryChangeTypes.FAKE_FILTERED_INCOMING;\n break;\n case HistoryChangeTypes.ENTITIES_SPLITTED:\n fakeType = HistoryChangeTypes.FAKE_FILTERED_OUTGOING;\n break;\n default:\n return;\n }\n\n const fakeChange = {\n fakeType: fakeType,\n uri: postChange.uri,\n uris: [contributorUri],\n type,\n user,\n timestamp\n };\n\n const extendLife = findClosestLife(contributorLane.lifeTime, postChange.timestamp);\n if (fakeType === HistoryChangeTypes.FAKE_FILTERED_INCOMING) {\n if (!isNil(extendLife.endIndex)) {\n contributorLane.lifeTime[extendLife.endIndex].end = fakeChange;\n }\n } else {\n if (!isNil(extendLife.startIndex)) {\n contributorLane.lifeTime[extendLife.startIndex].start = fakeChange;\n }\n }\n rows.splice(rows.indexOf(postChange), 0, fakeChange);\n });\n });\n });\n });\n\n rows.forEach((row, i) => {\n row.index = i;\n row.uri = row.uri || entityUri;\n });\n\n return {\n historyData: {historyLanes, rows},\n findPreviousChange\n };\n }, [entityUri, historyChanges, selectedUris]);\n};\n\nconst findClosestLife = (lifeTime: HistoryLife[], timestamp: number) =>\n lifeTime.reduce(\n (acc, {start, end}, i) => {\n if (start) {\n const d = timestamp - start.timestamp;\n if (isNil(acc.startDistance) || (Math.abs(acc.startDistance) > Math.abs(d) && d > 0)) {\n acc.startIndex = i;\n acc.startDistance = d;\n }\n }\n if (end) {\n const d = timestamp - end.timestamp;\n if (isNil(acc.endDistance) || (Math.abs(acc.endDistance) > Math.abs(d) && d < 0)) {\n acc.endIndex = i;\n acc.endDistance = d;\n }\n }\n return acc;\n },\n {startIndex: null, endIndex: null, startDistance: null, endDistance: null}\n );\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n flexDirection: 'column',\n overflow: 'hidden',\n position: 'relative',\n height: '100%'\n },\n borderBottom: {\n borderBottom: '1px solid rgba(0, 0, 0, 0.12)'\n }\n});\n","import React, {memo, useEffect, useState} from 'react';\nimport {HistoryWithTotal} from '@reltio/mdm-sdk';\nimport HistoryTree from '../HistoryTree/HistoryTree';\nimport ContributorsPanel from '../ContributorsPanel/ContributorsPanel';\nimport {useHistoryTree} from '../hooks/useHistoryTree';\nimport {HistoryEvent} from '@reltio/mdm-module';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n isLoading: boolean;\n historyWithTotal: HistoryWithTotal;\n contributorsUris: string[];\n entityUri: string;\n historyEvent: HistoryEvent;\n canLoadMore: boolean;\n onLoadMore: () => void;\n};\n\nconst HistoryView = ({\n isLoading,\n historyWithTotal,\n contributorsUris,\n entityUri,\n canLoadMore,\n onLoadMore,\n historyEvent\n}: Props) => {\n const styles = useStyles();\n const [selectedUris, setSelectedUris] = useState<string[]>(null);\n\n useEffect(() => {\n setSelectedUris(contributorsUris);\n }, [contributorsUris]);\n\n const {historyData, findPreviousChange} = useHistoryTree({\n entityUri,\n historyChanges: historyWithTotal?.changes,\n selectedUris\n });\n\n return (\n <div className={styles.root}>\n <ContributorsPanel\n values={contributorsUris}\n selectedValues={selectedUris}\n onSelectValues={setSelectedUris}\n entityUri={entityUri}\n className={styles.borderBottom}\n />\n <HistoryTree\n historyData={historyData}\n isLoading={isLoading}\n onLoadMore={onLoadMore}\n canLoadMore={canLoadMore}\n entityUri={entityUri}\n historyEvent={historyEvent}\n findPreviousChange={findPreviousChange}\n />\n </div>\n );\n};\n\nexport default memo(HistoryView);\n","import {\n pipe,\n defaultTo,\n reject,\n map,\n join,\n cond,\n equals,\n append,\n concat,\n chain,\n evolve,\n values,\n over,\n lensProp\n} from 'ramda';\nimport {\n isEmptyValue,\n escapeQueryValue,\n wrapInBrackets,\n multiValueFilter,\n buildUserFilterClause,\n buildDateRangeFilterClause\n} from '@reltio/mdm-sdk';\nimport {HistoryActivityType} from '../types/HistoryFilter';\nimport {ActivityTypes} from '../../activityLog/types/ActivityTypes';\nimport {AttributeOption} from '../../../types';\n\nconst convertHistoryTypes = chain(\n cond([\n [\n equals(HistoryActivityType.MERGE),\n () => [\n ActivityTypes.ENTITIES_MERGED,\n ActivityTypes.ENTITIES_MERGED_MANUALLY,\n ActivityTypes.ENTITIES_MERGED_ON_THE_FLY\n ]\n ],\n [equals(HistoryActivityType.UNMERGE), () => [ActivityTypes.ENTITIES_SPLITTED]],\n [equals(HistoryActivityType.UPDATE), () => [ActivityTypes.ENTITY_CHANGED]]\n ])\n);\n\nconst buildActivityFilterClause = pipe(\n defaultTo([]),\n convertHistoryTypes,\n concat([ActivityTypes.ENTITY_CREATED, ActivityTypes.ENTITY_REMOVED, ActivityTypes.ENTITY_LOST_MERGE]),\n multiValueFilter((value: string) => `equals(type, '${value}')`)\n);\n\nconst buildAttributeFilterClause = (attribute: AttributeOption) => `changes(${escapeQueryValue(attribute.value)})`;\n\nexport const buildHistoryFilterString = pipe(\n defaultTo({}),\n reject(isEmptyValue),\n evolve({\n users: multiValueFilter(buildUserFilterClause),\n attributes: multiValueFilter(buildAttributeFilterClause),\n dateRange: buildDateRangeFilterClause\n }),\n over(lensProp('activities'), buildActivityFilterClause),\n values,\n reject(isEmptyValue),\n append(\"not equals(user, 'collaboration-service')\"),\n map(wrapInBrackets),\n join(' and ')\n);\n","import {useState, useMemo, useCallback, useEffect} from 'react';\nimport {Entity, getHistoricUris, getHistoryWithTotal, HistoryWithTotal, isEmptyValue} from '@reltio/mdm-sdk';\nimport {difference, either, evolve, isEmpty, isNil, pipe, reject} from 'ramda';\nimport {HistoryActivityType, HistoryFilter} from '../types';\nimport {buildHistoryFilterString} from '../utils/filters';\nimport {useSafePromise} from '../../../hooks';\n\ntype Props = {\n entity: Entity;\n enabled: boolean;\n};\n\nconst MAX_HISTORY_ROWS = 32;\n\nexport const DEFAULT_HISTORY_FILTER: HistoryFilter = {\n activities: [HistoryActivityType.MERGE, HistoryActivityType.UNMERGE, HistoryActivityType.UPDATE]\n};\n\nexport const isDefaultFilter = (filter: HistoryFilter): boolean => {\n return pipe(\n evolve({activities: difference(DEFAULT_HISTORY_FILTER.activities)}),\n reject(either(isNil, isEmpty)),\n isEmpty\n )(filter || {});\n};\n\nexport const useHistory = ({entity, enabled}: Props) => {\n const [historyFilter, setHistoryFilter] = useState(DEFAULT_HISTORY_FILTER);\n const [historyPage, setHistoryPage] = useState(0);\n\n const historyFilterString = useMemo(() => buildHistoryFilterString(historyFilter), [historyFilter]);\n\n const [historicUris, setHistoricUris] = useState<string[]>(null);\n const [historyWithTotal, setHistoryWithTotal] = useState<HistoryWithTotal>(null);\n const [isLoading, setIsLoading] = useState(false);\n const safePromise = useSafePromise();\n const entityUri = entity?.uri;\n const options = {max: MAX_HISTORY_ROWS, order: 'desc'};\n const showAll = isEmptyValue(historyFilter?.attributes) || undefined;\n\n const loadHistoryWithTotal = () => {\n setIsLoading(true);\n return safePromise(\n getHistoryWithTotal({\n entityUri,\n historicUris,\n filter: historyFilterString,\n showAll,\n ...options\n })\n )\n .then(setHistoryWithTotal)\n .catch((e) => {\n console.warn('Failed to load history data', e);\n setHistoryWithTotal(null);\n })\n .finally(() => {\n setIsLoading(false);\n });\n };\n\n useEffect(() => {\n if (entityUri && enabled) {\n loadHistoryWithTotal();\n }\n }, [historyFilterString, showAll, historicUris]);\n\n const loadHistoricUris = () => {\n setIsLoading(true);\n return safePromise(getHistoricUris({entityUri}))\n .then((historicUris) => {\n setHistoricUris(historicUris);\n })\n .catch((e) => {\n console.warn('Failed to load history data', e);\n setHistoricUris(null);\n })\n .finally(() => {\n setIsLoading(false);\n });\n };\n\n useEffect(() => {\n if (entityUri && enabled) {\n loadHistoricUris();\n setHistoryPage(0);\n }\n }, [entityUri, entity?.updatedTime, enabled]);\n\n const loadMore = useCallback(\n (offset: number) => {\n if (entityUri && historicUris && enabled) {\n setIsLoading(true);\n safePromise(\n getHistoryWithTotal({\n entityUri,\n historicUris,\n filter: historyFilterString,\n showAll,\n offset,\n ...options\n })\n )\n .then((results) => {\n setHistoryWithTotal((prev) => ({...prev, changes: [...prev?.changes, ...results.changes]}));\n })\n .catch((e) => {\n console.warn('Failed to load history data', e);\n })\n .finally(() => {\n setIsLoading(false);\n });\n }\n },\n [historicUris, historyFilterString, enabled]\n );\n\n const canLoadMore = useMemo(\n () => (historyPage + 1) * MAX_HISTORY_ROWS < historyWithTotal?.total,\n [historyWithTotal, historyPage]\n );\n\n const onApplyFilter = useCallback((filter: HistoryFilter) => {\n setHistoryPage(0);\n setHistoryFilter(filter);\n }, []);\n\n const onClearFilter = useCallback(() => {\n onApplyFilter({...DEFAULT_HISTORY_FILTER});\n }, []);\n\n const onLoadMore = useCallback(() => {\n if (!canLoadMore) return;\n loadMore((historyPage + 1) * MAX_HISTORY_ROWS);\n setHistoryPage(historyPage + 1);\n }, [loadMore, historyPage, canLoadMore]);\n\n return {\n isLoading,\n canLoadMore,\n onLoadMore,\n onApplyFilter,\n onClearFilter,\n historicUris,\n historyWithTotal,\n historyFilter\n };\n};\n","import {useEffect, useState} from 'react';\nimport {isTempUri, isDataTenantEntity, Entity} from '@reltio/mdm-sdk';\nimport {usePerspectivesSettings} from '../../../contexts';\n\ntype Props = {\n entity: Entity;\n perspectiveId: string;\n historyButtonId: number;\n};\n\nexport const useHistoryEnabled = ({perspectiveId, entity, historyButtonId}: Props) => {\n const {perspectiveSettings} = usePerspectivesSettings(perspectiveId);\n const {active} = perspectiveSettings || {};\n\n const isHistoryTabActive = active === historyButtonId;\n const [wasHistoryTabActive, setWasHistoryTabActive] = useState(false);\n const entityUri = entity?.uri;\n useEffect(() => {\n if (!isHistoryTabActive) {\n setWasHistoryTabActive(false);\n }\n }, [entityUri]);\n\n useEffect(() => {\n if (isHistoryTabActive) {\n setWasHistoryTabActive(true);\n }\n }, [isHistoryTabActive]);\n\n const isProfilePersisted = entityUri && !isTempUri(entityUri) && !isDataTenantEntity(entity);\n const isHistoryEnabled = wasHistoryTabActive && isProfilePersisted;\n\n return {isHistoryEnabled, isProfilePersisted};\n};\n","import {useState, useEffect} from 'react';\nimport {useSelector, useDispatch} from 'react-redux';\nimport mdmModule, {HistoryEvent, profile} from '@reltio/mdm-module';\nimport {Entity, getEntityTimeSlice} from '@reltio/mdm-sdk';\nimport {useSafePromise} from '../../../hooks';\n\ntype Props = {\n entity: Entity;\n historyEvent: HistoryEvent;\n};\n\nexport const useHistorySlice = ({entity, historyEvent}: Props) => {\n const [isLoading, setIsLoading] = useState(false);\n const historySlice = useSelector(mdmModule.selectors.getHistorySlice);\n const dispatch = useDispatch();\n const safePromise = useSafePromise();\n\n const {aStamp, bStamp, overrideUri} = historyEvent || {};\n const entityUri = overrideUri || entity?.uri;\n\n useEffect(() => {\n if (historyEvent && entityUri) {\n setIsLoading(true);\n safePromise(\n Promise.all([\n getEntityTimeSlice(entityUri, aStamp),\n bStamp && bStamp !== 1 ? getEntityTimeSlice(entityUri, bStamp) : Promise.resolve(null)\n ])\n )\n .then(([aEntity, bEntity]) => {\n dispatch(profile.history.actions.setHistorySlice({aEntity, bEntity}));\n })\n .catch((e) => {\n console.warn('Failed to load entity slice', e);\n })\n .finally(() => {\n setIsLoading(false);\n });\n }\n }, [aStamp, bStamp, entityUri]);\n\n return {isLoading, historySlice};\n};\n","import {ActivityTypes} from '../../activityLog/types/ActivityTypes';\n\nenum FakeTypes {\n FAKE_NAVIGATE_PROFILE = 'FAKE_NAVIGATE_PROFILE',\n FAKE_FILTERED_INCOMING = 'FAKE_FILTERED_INCOMING',\n FAKE_FILTERED_OUTGOING = 'FAKE_FILTERED_OUTGOING',\n FAKE_UPDATE = 'FAKE_UPDATE'\n}\n\nexport const HistoryChangeTypes = {...ActivityTypes, ...FakeTypes};\nexport type HistoryChangeTypes = typeof HistoryChangeTypes;\n","import {DateRangeFilter} from '@reltio/mdm-sdk';\nimport {AttributeOption} from '../../../types';\n\nexport enum HistoryActivityType {\n UPDATE = 'UPDATE',\n MERGE = 'MERGE',\n UNMERGE = 'UNMERGE'\n}\n\nexport type HistoryFilter = {\n dateRange?: DateRangeFilter;\n users?: string[];\n activities?: HistoryActivityType[];\n attributes?: AttributeOption[];\n};\n","import React, {useCallback, useState} from 'react';\nimport i18n from 'ui-i18n';\nimport {pipe} from 'ramda';\nimport Portal from '@mui/material/Portal';\nimport Button from '@mui/material/Button';\nimport Snackbar, {SnackbarOrigin} from '@mui/material/Snackbar';\nimport {noop} from '../core';\n\ntype SnackbarOptions = {\n anchorOrigin?: SnackbarOrigin;\n showDismiss?: boolean;\n dismissTitle?: string;\n autoHideDuration?: number;\n onDismissClick?: () => void;\n};\n\nconst FIVE_MINUTES = 5 * 60 * 1000;\nexport const useSnackbar = ({\n anchorOrigin = {vertical: 'bottom', horizontal: 'center'},\n showDismiss,\n dismissTitle = i18n.text('Dismiss'),\n autoHideDuration = FIVE_MINUTES,\n onDismissClick = noop\n}: SnackbarOptions = {}) => {\n const [isOpenSnackbar, setIsOpenSnackbar] = useState(false);\n const [snackbarMessage, setSnackbarMessage] = useState('');\n\n const closeSnackbar = useCallback(() => {\n setIsOpenSnackbar(false);\n setSnackbarMessage('');\n }, []);\n\n const handleSnackbarClose = useCallback(\n (_, reason?: string) => {\n if (reason === 'clickaway') {\n return;\n }\n closeSnackbar();\n },\n [closeSnackbar]\n );\n\n const showSnackbarMessage = useCallback((message) => {\n setIsOpenSnackbar(true);\n setSnackbarMessage(message);\n }, []);\n\n const SnackbarRenderer = useCallback(() => {\n return (\n <Portal container={document.body}>\n <Snackbar\n open={isOpenSnackbar}\n anchorOrigin={anchorOrigin}\n autoHideDuration={autoHideDuration}\n onClose={handleSnackbarClose}\n message={snackbarMessage}\n style={{maxWidth: 500}}\n action={\n showDismiss ? (\n <Button color=\"primary\" onClick={pipe(closeSnackbar, onDismissClick)}>\n {dismissTitle}\n </Button>\n ) : undefined\n }\n />\n </Portal>\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isOpenSnackbar, closeSnackbar, snackbarMessage]);\n\n return {SnackbarRenderer, showSnackbarMessage};\n};\n"],"names":["customStyles","input","currentStyles","fontSize","menuPortal","zIndex","useStyles","makeStyles","root","flex","title","paddingBottom","paddingLeft","dropDownInput","width","justifyContent","backgroundColor","borderTop","option","height","noOptionsMessage","entityType","selectedAttributes","className","onChange","disableUnderline","menuPlacement","metadata","useSelector","mdmModule","styles","prepareItems","useCallback","data","level","prevLabel","reduce","acc","item","hidden","chipLabel","label","push","value","uri","attrType","subAttributes","getAttributeTypeSubAttributes","concat","options","useMemo","attributes","classnames","Typography","variant","i18n","MultiSelect","TextFieldProps","InputProps","classes","components","DropdownIndicator","DropdownIndicatorWithIconButton","MultiValue","props","Option","isFocused","isSelected","innerProps","AttributeListItem","checked","labelInText","pipe","defaultTo","menuPortalTarget","document","body","menuShouldBlockScroll","captureMenuScroll","display","paddingRight","inputNumber","minWidth","marginRight","inputUnit","periods","interval","unit","onFocus","onNumberChange","getValue","parseInt","newValue","onUnitChange","newUnit","TextField","type","inputProps","min","SimpleDropDownSelector","placeholder","capitalize","getIntervalUnitLabel","map","withMuiSkin","CreatableSelect","innerRef","children","selectProps","MenuItem","classNames","ref","selected","component","Checkbox","color","ExpandedValueTooltip","propTypes","PropTypes","id","key","onClick","onMouseMove","onMouseOver","tabIndex","isRequired","current","theme","top","left","undefined","fontWeight","clearIndicator","padding","spacing","margin","dropdownIndicator","creatable","getOptions","loadingIndicator","componentsProp","classesProp","stylesProp","onChangeProp","onInputChange","onInputChangeProp","reactSelectProps","SelectComponent","AsyncSelect","Select","inputValue","setInputValue","useState","multiSelectClasses","omit","inputId","multiSelectComponents","mergeClasses","indicatorSeparator","base","loadingMessage","fontFamily","labelProps","InputLabelProps","htmlFor","shrink","length","isMulti","actionMeta","action","closeMenuOnSelect","hideSelectedOptions","loadOptions","defaultProps","cacheOptions","defaultOptions","ClearIndicator","Control","DownChevron","CrossIcon","Group","GroupHeading","IndicatorsContainer","IndicatorSeparator","Input","LoadingIndicator","Menu","MenuList","MenuPortal","LoadingMessage","NoOptionsMessage","MultiValueContainer","MultiValueLabel","MultiValueRemove","Placeholder","SelectContainer","SingleValue","ValueContainer","control","valueContainer","multiValue","singleValue","menu","container","group","groupHeading","indicatorsContainer","menuList","multiValueLabel","multiValueRemove","getOptionValue","isSearchable","inputRef","viewBox","fill","xmlns","cx","cy","r","fillOpacity","style","maskType","maskUnits","x","y","mask","fillRule","clipRule","d","opacity","x1","y1","x2","y2","gradientUnits","stopColor","stopOpacity","offset","flexWrap","flexDirection","alignItems","overflow","minHeight","boxSizing","logo","textBox","maxWidth","marginTop","text","palette","primary","lineHeight","textAlign","secondaryText","letterSpacing","paddingTop","IconRenderer","AttributesListIcon","selectedUsers","valueToOption","prepareValues","values","tenant","servicesPath","cachedRequest","useRef","pluck","getAllUsersForTenant","then","users","filter","username","utils","filterUsers","ActivityTypes","getItemDataType","path","getActivityType","activity","items","firstItem","removeIgnoredItems","isImplementedItem","isValidActivityType","includes","filteredItems","console","error","reject","itemsTotal","splitActivityByType","propOr","groupBy","ifElse","stringifyDeltaValue","deltaValue","attributeTypeUri","attributePresentations","attributeType","findAttributeTypeByUri","dataTypeDefinition","getAttrDataTypeDefinition","formatValue","formatDataTypeValue","isNil","Object","entries","flatMap","attributeTypeName","deltaValues","makeAttrTypeUri","join","getActivityLabel","transition","inputRoot","dateOptionLabel","paper","localeFormat","moment","longDateFormat","noop","open","setOpen","handleToggle","fullWidth","DataTypes","endAdornment","menuIsOpen","readOnly","Popover","anchorEl","onClose","anchorOrigin","vertical","horizontal","transformOrigin","elevation","DateRangePicker","onApply","dateRangeTypeOptions","DateRangeTypes","getDateRangeTypeLabel","intervalContainer","typeInput","emptyDates","emptyInterval","isIntervalType","isBetweenType","initDatesInterval","period","initInterval","datesInterval","setDatesInterval","setInterval","selectedType","getCurrentPeriodByType","changePeriod","useDidUpdateEffect","DateIntervalSelector","CustomDateRangeEditor","historyActivityOptions","HistoryActivityType","overflowY","selectedHistoryActivityTypes","popup","filterContainer","maxHeight","borderColor","filterItem","marginBottom","clearButton","divider","onApplyFilter","buttonRef","isOpen","setIsOpen","currentValue","setCurrentValue","activities","dateRange","buttonColor","isDefaultFilter","useEffect","handlePropChange","curry","propName","filterValue","togglePopup","applyButtonHandler","isDateRangeValid","dissoc","clearAllButtonHandler","DEFAULT_HISTORY_FILTER","SmallIconButton","icon","FilterListIcon","size","DialogTitle","DialogContent","dividers","Divider","light","UserSelector","AttributeSelector","DialogActions","Button","menuItem","menuText","marginLeft","checkIcon","position","MenuItemRenderer","forwardRef","onMenuClose","e","Check","displayName","mode","dispatch","useDispatch","handleModeChange","selectedMode","profile","menuItems","HistoryMode","DropDownMenuButton","buttonComponent","buttonProps","MoreVertIcon","menuId","count","filterButton","total","orientation","flexItem","Spacer","historyRow","cursor","background","content","rowHeader","badge","pointerEvents","textOverflow","whiteSpace","date","flexShrink","user","change","isCurrent","matchGroups","timestamp","getContributorColor","bold","isFakeHistoryType","HistoryChangeTypes","toX","toY","isDashed","lineData","isUp","isLeft","curveCenterY","getHistoryLinkCurve","stroke","strokeWidth","strokeDasharray","isCollapsed","showCollapseIcon","showLine","otherProps","radius","BUMP_RADIUS","LINE_MARGIN","HistoryCircleWithTooltip","withTooltip","HistoryCircle","memo","graphData","onHistoryCircleMouseOver","historyLanes","rows","rowPositions","links","rowLines","circles","i","uris","fakeType","index","hasFakeType","circleUri","some","tooltipTitle","tooltipPlacement","ROW_HEIGHT","isUpRight","forEach","contributorUri","contributorLane","rowHeight","keys","lifeTime","start","end","startIndex","endIndex","startY","endY","unshift","historyTree","gridTemplateColumns","graph","overflowX","history","buttonContainer","gridColumnStart","gridColumnEnd","shadow","boxShadow","historyData","isLoading","canLoadMore","onLoadMore","entityUri","historyEvent","findPreviousChange","isEditableMode","mdm","setGraphData","isScrollable","setIsScrollable","selectedIndex","setSelectedIndex","isCurrentEventChange","overrideUri","aStamp","selectedChangeByIndex","currentEventChangeIndex","findIndex","graphRef","rowsRef","node","childNodes","clientHeight","handleGraphScroll","scrollWidth","clientWidth","scrollLeft","LinearLoadIndicator","onScroll","time","select","getEntity","crosswalks","uniqBy","prop","cw","crosswalkType","getCrosswalkType","identity","prevGraphData","row","handleWidth","onResize","window","confirm","Mode","aChange","bChange","bStamp","handleHistoryRowClick","useContributorStyles","borderWidth","borderStyle","borderRadius","active","inactive","clickable","selectedValues","onSelectValues","without","handleClick","findClosestLife","startDistance","Math","abs","endDistance","borderBottom","historyWithTotal","contributorsUris","selectedUris","setSelectedUris","historyChanges","checkChange","involvedUris","checkInUris","Array","isArray","involvedUri","findNextChange","drop","find","checkLaneUri","startNewLife","currentLife","updateLife","shouldAddNewLife","endLife","postProcessChanges","lostMergeChange","addPostProcess","rowChange","relatedLane","lifeTimeLength","checkLifeTime","postChange","postUri","fakeChange","extendLife","splice","indexOf","slice","Infinity","useHistoryTree","changes","convertHistoryTypes","chain","cond","equals","buildActivityFilterClause","multiValueFilter","buildHistoryFilterString","isEmptyValue","evolve","buildUserFilterClause","attribute","escapeQueryValue","buildDateRangeFilterClause","over","lensProp","append","wrapInBrackets","difference","either","isEmpty","useHistory","entity","enabled","historyFilter","setHistoryFilter","historyPage","setHistoryPage","historyFilterString","historicUris","setHistoricUris","setHistoryWithTotal","setIsLoading","safePromise","useSafePromise","max","order","showAll","getHistoryWithTotal","catch","warn","finally","getHistoricUris","updatedTime","loadMore","results","prev","onClearFilter","useHistoryEnabled","perspectiveId","historyButtonId","perspectiveSettings","usePerspectivesSettings","isHistoryTabActive","wasHistoryTabActive","setWasHistoryTabActive","isProfilePersisted","isTempUri","isDataTenantEntity","isHistoryEnabled","useHistorySlice","historySlice","Promise","all","getEntityTimeSlice","resolve","aEntity","bEntity","FakeTypes","FIVE_MINUTES","useSnackbar","showDismiss","dismissTitle","autoHideDuration","onDismissClick","isOpenSnackbar","setIsOpenSnackbar","snackbarMessage","setSnackbarMessage","closeSnackbar","handleSnackbarClose","_","reason","showSnackbarMessage","message","SnackbarRenderer"],"sourceRoot":""}
1
+ {"version":3,"file":"3902.js","mappings":"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","sources":["webpack://@reltio/remotes/../components/src/components/AttributeSelector/styles.ts","webpack://@reltio/remotes/../components/src/components/AttributeSelector/AttributeSelector.tsx","webpack://@reltio/remotes/../components/src/components/DateIntervalSelector/styles.ts","webpack://@reltio/remotes/../components/src/components/DateIntervalSelector/DateIntervalSelector.tsx","webpack://@reltio/remotes/../components/src/components/ReactSelect/CreatableSelect.js","webpack://@reltio/remotes/../components/src/components/ReactSelect/MultiSelect/components/Option.js","webpack://@reltio/remotes/../components/src/components/ReactSelect/MultiSelect/components/index.js","webpack://@reltio/remotes/../components/src/components/ReactSelect/MultiSelect/MultiSelect.js","webpack://@reltio/remotes/../components/src/components/ReactSelect/MultiSelect/index.js","webpack://@reltio/remotes/../components/src/icons/AttributesList.tsx","webpack://@reltio/remotes/../components/src/components/SidePanelEmptyState/styles.ts","webpack://@reltio/remotes/../components/src/components/SidePanelEmptyState/SidePanelEmptyState.tsx","webpack://@reltio/remotes/../components/src/components/UserSelector/styles.ts","webpack://@reltio/remotes/../components/src/components/UserSelector/UserSelector.tsx","webpack://@reltio/remotes/../components/src/components/activityLog/types/ActivityTypes.ts","webpack://@reltio/remotes/../components/src/components/activityLog/utils/activities.ts","webpack://@reltio/remotes/../components/src/components/editors/CustomDateRangeEditor/styles.ts","webpack://@reltio/remotes/../components/src/components/editors/CustomDateRangeEditor/CustomDateRangeEditor.tsx","webpack://@reltio/remotes/../components/src/components/history/DateRangeSelector/utils.ts","webpack://@reltio/remotes/../components/src/components/history/DateRangeSelector/styles.ts","webpack://@reltio/remotes/../components/src/components/history/DateRangeSelector/DateRangeSelector.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryActivitySelector/utils.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryActivitySelector/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryActivitySelector/HistoryActivitySelector.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryFilterButton/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryFilterButton/HistoryFilterButton.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryMenuButton/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryMenuButton/MenuItemRenderer.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryMenuButton/HistoryMenuButton.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryHeader/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryHeader/HistoryHeader.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryPanelEmptyState/HistoryPanelEmptyState.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryRow/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryRow/HistoryRow.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryGraph/helpers.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryGraph/HistoryLink.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryGraph/HistoryCircle.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryGraph/HistoryGraph.tsx","webpack://@reltio/remotes/../components/src/components/history/HistoryTree/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryTree/HistoryTree.tsx","webpack://@reltio/remotes/../components/src/components/history/ContributorsPanel/styles.ts","webpack://@reltio/remotes/../components/src/components/history/ContributorsPanel/ContributorItem.tsx","webpack://@reltio/remotes/../components/src/components/history/ContributorsPanel/ContributorsPanel.tsx","webpack://@reltio/remotes/../components/src/components/history/hooks/useHistoryTree.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryView/styles.ts","webpack://@reltio/remotes/../components/src/components/history/HistoryView/HistoryView.tsx","webpack://@reltio/remotes/../components/src/components/history/utils/filters.ts","webpack://@reltio/remotes/../components/src/components/history/hooks/useHistory.ts","webpack://@reltio/remotes/../components/src/components/history/hooks/useHistoryEnabled.ts","webpack://@reltio/remotes/../components/src/components/history/hooks/useHistorySlice.ts","webpack://@reltio/remotes/../components/src/components/history/types/HistoryChangeTypes.ts","webpack://@reltio/remotes/../components/src/components/history/types/HistoryFilter.ts","webpack://@reltio/remotes/../components/src/hooks/useSnackbar.tsx"],"sourcesContent":["import {makeStyles} from '@mui/styles';\n\nexport const customStyles = {\n input: (currentStyles) => ({...currentStyles, fontSize: '14px'}),\n menuPortal: (currentStyles) => ({...currentStyles, zIndex: 1300})\n};\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n title: {\n paddingBottom: '10px',\n paddingLeft: '5px',\n fontSize: '14px'\n },\n dropDownInput: {\n width: '100%',\n justifyContent: 'center',\n backgroundColor: 'rgba(0, 0, 0, 0.03)',\n borderTop: '4px'\n },\n option: {\n fontSize: '14px',\n height: '32px'\n },\n noOptionsMessage: {\n fontSize: '14px'\n }\n});\n","import React, {useCallback, useMemo} from 'react';\nimport i18n from 'ui-i18n';\nimport classnames from 'classnames';\nimport {pipe, defaultTo} from 'ramda';\nimport {useSelector} from 'react-redux';\nimport {AttributeOption} from '../../types';\nimport mdmModule from '@reltio/mdm-module';\nimport {MultiValueProps, OptionProps} from 'react-select';\nimport {AttributeType, getAttributeTypeSubAttributes, Metadata, TEntityType} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport MultiSelect from '../ReactSelect/MultiSelect';\nimport MultiValue from '../ReactSelect/commonComponents/MultiValue';\nimport DropdownIndicatorWithIconButton from '../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport AttributeListItem from '../AttributeListItem/AttributeListItem';\nimport {customStyles, useStyles} from './styles';\n\ntype Props = {\n entityType: TEntityType;\n selectedAttributes: AttributeOption[];\n className?: string;\n onChange?: (attributes: AttributeOption[]) => void;\n title?: string;\n disableUnderline?: boolean;\n menuPlacement?: string;\n};\n\nconst AttributeSelector = ({\n entityType,\n selectedAttributes,\n className,\n onChange,\n title,\n disableUnderline,\n menuPlacement = 'bottom'\n}: Props) => {\n const metadata: Metadata = useSelector(mdmModule.selectors.getMetadata);\n const styles = useStyles();\n\n const prepareItems = useCallback(\n (data: AttributeType[], level = 0, prevLabel = ''): AttributeOption[] => {\n return data.reduce((acc, item) => {\n if (item.hidden) return acc;\n const chipLabel = `${prevLabel && prevLabel + ' / '}${item.label}`;\n acc.push({\n label: item.label,\n value: item.uri,\n attrType: item,\n chipLabel,\n level\n });\n const subAttributes = getAttributeTypeSubAttributes(metadata, item);\n return acc.concat(subAttributes ? prepareItems(subAttributes, level + 1, chipLabel) : []);\n }, []);\n },\n [metadata]\n );\n\n const options = useMemo(() => prepareItems(entityType?.attributes || []), [entityType, prepareItems]);\n\n const CustomOption = ({isFocused, isSelected, data, label, innerProps}: OptionProps<AttributeOption, true>) => (\n <div {...innerProps}>\n <AttributeListItem\n checked={isSelected}\n level={data.level}\n data={data}\n label={label}\n labelInText={label}\n isFocused={isFocused}\n />\n </div>\n );\n\n const CustomMultiValue = ({data, ...props}: MultiValueProps<AttributeOption>) => (\n <MultiValue {...props}>{data.chipLabel}</MultiValue>\n );\n\n return (\n <div className={classnames(styles.root, className)} data-reltio-id=\"attribute-selector\">\n <Typography className={styles.title} variant={'subtitle1'}>\n {title || i18n.text('Attribute')}\n </Typography>\n <MultiSelect\n value={selectedAttributes}\n options={options}\n TextFieldProps={{\n InputProps: {disableUnderline},\n classes: {root: styles.dropDownInput}\n }}\n components={{\n DropdownIndicator: DropdownIndicatorWithIconButton,\n MultiValue: CustomMultiValue,\n Option: CustomOption\n }}\n onChange={pipe(defaultTo([]), onChange)}\n styles={customStyles}\n classes={styles}\n menuPlacement={menuPlacement}\n menuPortalTarget={document.body}\n menuShouldBlockScroll={true}\n captureMenuScroll={false}\n />\n </div>\n );\n};\n\nexport default AttributeSelector;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n flex: 1\n },\n input: {\n height: '100%',\n paddingLeft: '12px',\n paddingRight: '8px',\n fontSize: '14px'\n },\n inputNumber: {\n minWidth: '60px',\n marginRight: 10,\n height: '100%',\n backgroundColor: 'rgba(0, 0, 0, 0.03)'\n },\n inputUnit: {\n width: '100%'\n }\n});\n","import React from 'react';\nimport {pipe} from 'ramda';\nimport {getIntervalUnitLabel} from '@reltio/mdm-sdk';\nimport TextField from '@mui/material/TextField';\nimport SimpleDropDownSelector from '../SimpleDropDownSelector/SimpleDropDownSelector';\nimport {getValue} from '../../core/utils';\nimport {useStyles} from './styles';\n\nimport {capitalize} from '@mui/material/utils';\n\ntype Props = {\n interval: [number, string];\n onChange: ([number, string]) => void;\n onFocus?: () => void;\n};\n\nconst periods = ['minutes', 'hours', 'days', 'weeks', 'months', 'years'];\n\nconst DateIntervalSelector = ({interval: [value, unit], onChange, onFocus}: Props) => {\n const styles = useStyles();\n const getIntervalFromValue = (newValue: number) => [newValue, unit];\n const getIntervalFromUnit = ({value: newUnit}: {value: string}) => [value, newUnit];\n const onNumberChange = pipe(getValue, parseInt, getIntervalFromValue, onChange);\n const onUnitChange = pipe(getIntervalFromUnit, onChange);\n return (\n <div className={styles.root}>\n <TextField\n variant=\"standard\"\n type=\"number\"\n value={value || ''}\n onChange={onNumberChange}\n inputProps={{min: 1, onFocus: onFocus}}\n InputProps={{classes: {root: styles.input}}}\n className={styles.inputNumber}\n />\n <SimpleDropDownSelector\n label={''}\n placeholder={capitalize(unit)}\n className={styles.inputUnit}\n value={{value: unit, label: capitalize(getIntervalUnitLabel(unit))}}\n options={periods.map((value) => ({\n value,\n label: capitalize(getIntervalUnitLabel(value))\n }))}\n onChange={onUnitChange}\n TextFieldProps={{\n inputProps: {onFocus: onFocus},\n InputProps: {classes: {root: styles.input}}\n }}\n />\n </div>\n );\n};\n\nexport default DateIntervalSelector;\n","import CreatableSelect from 'react-select/creatable';\nimport withMuiSkin from './withMuiSkin';\n\nexport default withMuiSkin(CreatableSelect);\n","import MenuItem from '@mui/material/MenuItem';\nimport Checkbox from '@mui/material/Checkbox';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport classNames from 'classnames';\nimport ExpandedValueTooltip from '../../../ExpandedValueTooltip/ExpandedValueTooltip';\n\nexport default function Option(props) {\n const {\n innerProps,\n innerRef,\n children,\n isFocused,\n isSelected,\n selectProps: {classes},\n label\n } = props;\n\n return (\n <MenuItem\n className={classNames(classes.option, {[classes['option--selected']]: isSelected})}\n ref={innerRef}\n selected={isFocused}\n component=\"div\"\n {...innerProps}\n >\n <Checkbox color=\"primary\" checked={isSelected} />\n <ExpandedValueTooltip value={label}>\n <div className={classes['option--item']}>{children}</div>\n </ExpandedValueTooltip>\n </MenuItem>\n );\n}\n\nOption.propTypes = {\n children: PropTypes.node,\n innerProps: PropTypes.shape({\n id: PropTypes.string.isRequired,\n key: PropTypes.string,\n onClick: PropTypes.func.isRequired,\n onMouseMove: PropTypes.func.isRequired,\n onMouseOver: PropTypes.func.isRequired,\n tabIndex: PropTypes.number.isRequired\n }).isRequired,\n innerRef: PropTypes.oneOfType([\n PropTypes.oneOf([null]),\n PropTypes.func,\n PropTypes.shape({\n current: PropTypes.any.isRequired\n })\n ]),\n isFocused: PropTypes.bool.isRequired,\n isSelected: PropTypes.bool.isRequired,\n label: PropTypes.string,\n selectProps: PropTypes.shape({\n classes: PropTypes.shape({\n option: PropTypes.string\n })\n })\n};\n","import Option from './Option';\n\nconst components = {\n Option\n};\n\nexport default components;\n","import React, {useState} from 'react';\nimport PropTypes from 'prop-types';\nimport {omit} from 'ramda';\nimport CreatableSelect from '../CreatableSelect';\nimport Select from '../Select';\nimport AsyncSelect from '../AsyncSelect';\nimport multiSelectComponents from './components';\nimport {makeStyles} from '@mui/styles';\nimport {mergeClasses} from '../../../core/utils';\n\nconst useStyles = makeStyles((theme) => ({\n label: {\n top: 6,\n left: 16\n },\n placeholder: (props) => ({\n display: !props.placeholder || props.label ? 'none' : undefined\n }),\n 'option--selected': {\n fontWeight: 400\n },\n clearIndicator: {\n padding: theme.spacing(1),\n margin: theme.spacing(0.25, 0.5)\n },\n dropdownIndicator: {\n padding: theme.spacing(1),\n margin: theme.spacing(0.25, 0.5)\n }\n}));\n\nlet id = 0;\nconst getInputId = () => `custom-select-${id++}`;\n\nfunction MultiSelect(props) {\n const {\n label,\n creatable,\n getOptions,\n loadingIndicator,\n components: componentsProp,\n classes: classesProp,\n styles: stylesProp,\n onChange: onChangeProp,\n onInputChange: onInputChangeProp,\n menuPlacement = 'auto',\n ...reactSelectProps\n } = props;\n\n const SelectComponent = creatable ? CreatableSelect : getOptions ? AsyncSelect : Select;\n\n const [inputValue, setInputValue] = useState('');\n const multiSelectClasses = useStyles(omit(['classes'], props));\n const inputId = getInputId();\n\n const components = {\n ...multiSelectComponents,\n ...componentsProp\n };\n\n const classes = mergeClasses(multiSelectClasses, classesProp);\n\n function handleInputChange(value, {action}) {\n onInputChangeProp(value, {action});\n if (action !== 'set-value') {\n setInputValue(value);\n }\n }\n\n function handleChange(value, actionMeta) {\n onChangeProp(value, actionMeta);\n if (actionMeta.action === 'create-option') {\n setInputValue('');\n onInputChangeProp('', {action: 'input-change'});\n }\n }\n\n const styles = {\n indicatorSeparator: (base) => ({\n ...base,\n margin: '10px 0'\n }),\n loadingIndicator: (base) => ({\n ...base,\n display: loadingIndicator ? base.display : 'none'\n }),\n loadingMessage: (base) => ({\n ...base,\n fontFamily: '\"Roboto\", \"Helvetica\", \"Arial\", sans-serif'\n }),\n ...stylesProp\n };\n\n const labelProps = label\n ? {\n inputId,\n TextFieldProps: {\n label,\n InputLabelProps: {\n htmlFor: inputId,\n shrink: props.value && props.value.length ? true : undefined,\n className: classes.label\n },\n ...props.TextFieldProps\n }\n }\n : {};\n\n return (\n <SelectComponent\n isMulti\n inputId={inputId}\n inputValue={inputValue}\n onChange={handleChange}\n onInputChange={handleInputChange}\n closeMenuOnSelect={false}\n hideSelectedOptions={false}\n classes={classes}\n components={components}\n styles={styles}\n menuPlacement={menuPlacement}\n loadOptions={getOptions}\n {...labelProps}\n {...reactSelectProps}\n />\n );\n}\n\nMultiSelect.defaultProps = {\n creatable: false,\n cacheOptions: true,\n components: {},\n classes: {},\n placeholder: '',\n loadingIndicator: false,\n onInputChange: () => {},\n onChange: () => {}\n};\n\nMultiSelect.propTypes = {\n /**\n * Async creatable multi select with optional placeholder, shrink-label, non-closing menu and options with checkboxes.\n * Based on react-select/creatable and react-select/async.\n * See react-select docs: https://react-select.com\n *\n * Below are listed only props used in the MultiSelect component. Check https://react-select.com/props first.\n * */\n\n /** Ability to create values. React-select/async-creatable is used internally */\n creatable: PropTypes.bool,\n /** True for enabling cache. Recommended. */\n cacheOptions: PropTypes.bool,\n defaultOptions: PropTypes.bool,\n /** Array of selected options. */\n value: PropTypes.arrayOf(\n PropTypes.shape({\n label: PropTypes.string.isRequired,\n value: PropTypes.any\n })\n ),\n options: PropTypes.arrayOf(\n PropTypes.shape({\n label: PropTypes.string.isRequired,\n value: PropTypes.any\n })\n ),\n /** Way to receive updated values */\n onChange: PropTypes.func,\n /** Way to receive updated inputValue */\n onInputChange: PropTypes.func,\n /** Input placeholder. Will not be shown if the label prop is specified */\n placeholder: PropTypes.string,\n /** Floating label from @mui/material/TextField component */\n label: PropTypes.string,\n /** Enable to show default react-select's indicator */\n loadingIndicator: PropTypes.bool,\n /** You could redefine any of these components */\n components: PropTypes.shape({\n ClearIndicator: PropTypes.func,\n Control: PropTypes.func,\n DropdownIndicator: PropTypes.func,\n DownChevron: PropTypes.func,\n CrossIcon: PropTypes.func,\n Group: PropTypes.func,\n GroupHeading: PropTypes.func,\n IndicatorsContainer: PropTypes.func,\n IndicatorSeparator: PropTypes.func,\n Input: PropTypes.func,\n LoadingIndicator: PropTypes.func,\n Menu: PropTypes.func,\n MenuList: PropTypes.func,\n MenuPortal: PropTypes.func,\n LoadingMessage: PropTypes.func,\n NoOptionsMessage: PropTypes.func,\n MultiValue: PropTypes.func,\n MultiValueContainer: PropTypes.func,\n MultiValueLabel: PropTypes.func,\n MultiValueRemove: PropTypes.func,\n Option: PropTypes.func,\n Placeholder: PropTypes.func,\n SelectContainer: PropTypes.func,\n SingleValue: PropTypes.func,\n ValueContainer: PropTypes.func\n }),\n /** Classes are passed to mui skin components. Provided classes will be merged with existing ones. */\n classes: PropTypes.shape({\n control: PropTypes.string,\n valueContainer: PropTypes.string,\n multiValue: PropTypes.string,\n noOptionsMessage: PropTypes.string,\n singleValue: PropTypes.string,\n placeholder: PropTypes.string,\n menu: PropTypes.string,\n clearIndicator: PropTypes.string,\n dropdownIndicator: PropTypes.string,\n option: PropTypes.string,\n 'option--selected': PropTypes.string,\n label: PropTypes.string\n }),\n /**\n * React-select's way to customise style. Could be used to style default react-select components.\n * In other cases better to use classes and components props\n * */\n styles: PropTypes.shape({\n clearIndicator: PropTypes.func,\n container: PropTypes.func,\n control: PropTypes.func,\n dropdownIndicator: PropTypes.func,\n group: PropTypes.func,\n groupHeading: PropTypes.func,\n indicatorsContainer: PropTypes.func,\n indicatorSeparator: PropTypes.func,\n input: PropTypes.func,\n loadingIndicator: PropTypes.func,\n loadingMessage: PropTypes.func,\n menu: PropTypes.func,\n menuList: PropTypes.func,\n menuPortal: PropTypes.func,\n multiValue: PropTypes.func,\n multiValueLabel: PropTypes.func,\n multiValueRemove: PropTypes.func,\n noOptionsMessage: PropTypes.func,\n option: PropTypes.func,\n placeholder: PropTypes.func,\n singleValue: PropTypes.func,\n valueContainer: PropTypes.func\n }),\n /** Props from https://material-ui.com/api/text-field/ */\n TextFieldProps: PropTypes.object /* eslint-disable-line react/forbid-prop-types */,\n getOptions: PropTypes.func,\n menuPlacement: PropTypes.string,\n menuPortalTarget: PropTypes.object,\n menuShouldBlockScroll: PropTypes.bool,\n captureMenuScroll: PropTypes.bool,\n getOptionValue: PropTypes.func,\n isSearchable: PropTypes.bool,\n inputRef: PropTypes.shape({current: PropTypes.object})\n};\n\nexport default MultiSelect;\n","import MultiSelect from './MultiSelect';\n\nexport default MultiSelect;\n","import React from 'react';\n\nconst SvgAttributesList: React.FC<React.SVGProps<SVGSVGElement>> = (props) => {\n return (\n <svg width={256} height={256} viewBox=\"0 0 256 256\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" {...props}>\n <circle cx={128} cy={128} r={128} fill=\"#0072CE\" fillOpacity={0.1} />\n <mask\n id=\"AttributesList_svg__a\"\n style={{\n maskType: 'alpha'\n }}\n maskUnits=\"userSpaceOnUse\"\n x={0}\n y={0}\n width={256}\n height={256}\n >\n <circle cx={128} cy={128} r={128} fill=\"#fff\" />\n </mask>\n <g mask=\"url(#AttributesList_svg__a)\">\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M-16 9h256v247H-16V9z\"\n fill=\"url(#AttributesList_svg__b)\"\n />\n <path\n opacity={0.05}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M187.761 56.865l58.639 58.639v148.871H93.383L52 225.083V56.865h135.761z\"\n fill=\"url(#AttributesList_svg__c)\"\n />\n <path\n opacity={0.06}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M47 58h202a7 7 0 017 7v157a7 7 0 01-7 7H47a7 7 0 01-7-7V65a7 7 0 017-7z\"\n fill=\"#000\"\n />\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M50 56h201a5 5 0 015 5v157a5 5 0 01-5 5H50a5 5 0 01-5-5V61a5 5 0 015-5z\"\n fill=\"#fff\"\n />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105.376 72.635a3 3 0 013-3H150a3 3 0 110 6h-41.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105 84.635a3 3 0 013-3h64.205a3 3 0 110 6H108a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105.376 163a3 3 0 013-3H150a3 3 0 110 6h-41.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105 175a3 3 0 013-3h64.205a3 3 0 110 6H108a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105.376 193a3 3 0 013-3H190a3 3 0 110 6h-81.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M105 205a3 3 0 013-3h74.205a3 3 0 110 6H108a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M138.376 103a3 3 0 013-3H223a3 3 0 110 6h-81.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M138 115a3 3 0 013-3h64.205a3 3 0 110 6H141a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <circle cx={67} cy={79} r={9} fill=\"#B6C7DB\" />\n <circle cx={67} cy={79} r={9} fill=\"#B6C7DB\" />\n <circle cx={120} cy={106} r={6} fill=\"#B6C7DB\" />\n <circle cx={120} cy={136} r={6} fill=\"#B6C7DB\" />\n <circle cx={67} cy={169} r={9} fill=\"#B6C7DB\" />\n <circle cx={67} cy={199} r={9} fill=\"#B6C7DB\" />\n <path\n opacity={0.8}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M138.376 133a3 3 0 013-3H223a3 3 0 110 6h-81.624a3 3 0 01-3-3z\"\n fill=\"#B6C7DB\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M138 145a3 3 0 013-3h74.205a3 3 0 110 6H141a3 3 0 01-3-3z\"\n fill=\"#979797\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M92.514 108v-8h-2v40.365h11.178v-2h-9.178V110h9.178v-2h-9.178z\"\n fill=\"#2B98F0\"\n />\n <path\n opacity={0.54}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M95.071 77l-3.535 3.535L88 77h7.071z\"\n fill=\"#000\"\n />\n <path\n opacity={0.6}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M50 22h186a6 6 0 016 6v18a6 6 0 01-6 6H50a6 6 0 01-6-6V28a6 6 0 016-6z\"\n fill=\"#fff\"\n />\n <path\n opacity={0.2}\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M58 37a6 6 0 016-6h70a6 6 0 110 12H64a6 6 0 01-6-6zm90 0a6 6 0 016-6h10a6 6 0 110 12h-10a6 6 0 01-6-6z\"\n fill=\"#979797\"\n />\n </g>\n <defs>\n <linearGradient\n id=\"AttributesList_svg__b\"\n x1={-16}\n y1={9}\n x2={-16}\n y2={256}\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopColor=\"#FAFAFA\" stopOpacity={0.01} />\n <stop offset={1} stopColor=\"#F4F4F4\" />\n </linearGradient>\n <linearGradient\n id=\"AttributesList_svg__c\"\n x1={266.117}\n y1={181.111}\n x2={154.882}\n y2={77.681}\n gradientUnits=\"userSpaceOnUse\"\n >\n <stop stopOpacity={0.01} />\n <stop offset={1} />\n </linearGradient>\n </defs>\n </svg>\n );\n};\n\nexport default SvgAttributesList;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n root: {\n display: 'flex',\n flex: '1 1 auto',\n flexWrap: 'nowrap',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n overflow: 'auto',\n height: '100%',\n minHeight: '350px',\n boxSizing: 'border-box',\n padding: '40px'\n },\n logo: {\n width: '190px',\n height: '190px'\n },\n textBox: {\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n maxWidth: 400,\n marginTop: '24px'\n },\n text: {\n color: theme.palette.text.primary,\n fontSize: '20px',\n fontWeight: 500,\n lineHeight: '23px',\n textAlign: 'center'\n },\n secondaryText: {\n color: theme.palette.text.primary,\n fontSize: '14px',\n fontWeight: 'normal',\n lineHeight: '16px',\n letterSpacing: '0.24px',\n textAlign: 'center',\n paddingTop: '8px'\n }\n}));\n","import React from 'react';\nimport Typography from '@mui/material/Typography';\nimport {AttributesList as AttributesListIcon} from '../../icons';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n IconRenderer?: React.ElementType;\n text: string;\n secondaryText?: string;\n};\n\nconst SidePanelEmptyState = ({IconRenderer = AttributesListIcon, text, secondaryText}: Props) => {\n const styles = useStyles();\n return (\n <div className={styles.root}>\n <IconRenderer className={styles.logo} />\n <div className={styles.textBox}>\n <Typography className={styles.text}>{text}</Typography>\n {secondaryText && <Typography className={styles.secondaryText}>{secondaryText}</Typography>}\n </div>\n </div>\n );\n};\n\nexport default SidePanelEmptyState;\n","import {makeStyles} from '@mui/styles';\n\nexport const customStyles = {\n input: (currentStyles) => ({...currentStyles, fontSize: '14px'}),\n loadingMessage: (currentStyles) => ({...currentStyles, fontSize: '14px'}),\n menuPortal: (currentStyles) => ({...currentStyles, zIndex: 1300})\n};\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n title: {\n paddingBottom: '10px',\n paddingLeft: '5px',\n fontSize: '14px'\n },\n dropDownInput: {\n width: '100%',\n justifyContent: 'center',\n backgroundColor: 'rgba(0, 0, 0, 0.03)',\n borderTop: '4px'\n },\n option: {\n fontSize: '14px',\n height: '32px'\n }\n});\n","import React, {useRef} from 'react';\nimport {useSelector} from 'react-redux';\nimport i18n from 'ui-i18n';\nimport {defaultTo, pipe, pluck} from 'ramda';\nimport classnames from 'classnames';\nimport Typography from '@mui/material/Typography';\nimport MultiSelect from '../ReactSelect/MultiSelect';\nimport DropdownIndicatorWithIconButton from '../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport {getAllUsersForTenant, UserInfo, utils} from '@reltio/mdm-sdk';\nimport mdmModule from '@reltio/mdm-module';\nimport {customStyles, useStyles} from './styles';\n\ntype Props = {\n selectedUsers: string[];\n onChange: (activities: string[]) => void;\n className?: string;\n disableUnderline?: boolean;\n};\n\nconst UserSelector = ({selectedUsers, onChange, className, disableUnderline}: Props) => {\n const styles = useStyles();\n\n const valueToOption = (value: string) => ({value, label: value});\n const prepareValues = (values: string[]) => values.map(valueToOption);\n const filterUsers = (inputValue) => (users) =>\n inputValue ? users.filter((username) => utils.strings.search(username, inputValue)) : users;\n\n const tenant = useSelector(mdmModule.selectors.getTenant);\n const servicesPath = useSelector(mdmModule.selectors.getServicesPath);\n\n const cachedRequest = useRef<Promise<UserInfo[]>>();\n const getOptions = (inputValue) => {\n if (!cachedRequest.current) {\n cachedRequest.current = getAllUsersForTenant({tenant, servicesPath});\n }\n return cachedRequest.current.then(pipe(pluck('username'), filterUsers(inputValue), prepareValues));\n };\n\n return (\n <div className={classnames(styles.root, className)} data-reltio-id=\"user-selector\">\n <Typography className={styles.title} variant={'subtitle1'}>\n {i18n.text('User')}\n </Typography>\n <MultiSelect\n value={prepareValues(selectedUsers)}\n onChange={pipe(defaultTo([]), pluck('value'), onChange)}\n defaultOptions={true}\n getOptions={getOptions}\n TextFieldProps={{\n InputProps: {disableUnderline},\n className: styles.dropDownInput\n }}\n components={{\n DropdownIndicator: DropdownIndicatorWithIconButton\n }}\n styles={customStyles}\n classes={styles}\n menuPortalTarget={document.body}\n menuShouldBlockScroll={true}\n captureMenuScroll={false}\n />\n </div>\n );\n};\n\nexport default UserSelector;\n","export enum ActivityTypes {\n MODEL_UPDATED = 'MODEL_UPDATED',\n ENTITY_REMOVED = 'ENTITY_REMOVED',\n ENTITY_CREATED = 'ENTITY_CREATED',\n ENTITY_CHANGED = 'ENTITY_CHANGED',\n ENTITIES_MERGED = 'ENTITIES_MERGED',\n ENTITIES_SPLITTED = 'ENTITIES_SPLITTED',\n ENTITY_LOST_MERGE = 'ENTITY_LOST_MERGE',\n RELATIONSHIP_CREATED = 'RELATIONSHIP_CREATED',\n RELATIONSHIP_REMOVED = 'RELATIONSHIP_REMOVED',\n RELATIONSHIP_CHANGED = 'RELATIONSHIP_CHANGED',\n POTENTIAL_MATCHES_FOUND = 'POTENTIAL_MATCHES_FOUND',\n NOT_MATCHES_SET = 'NOT_MATCHES_SET',\n NOT_MATCHES_RESET = 'NOT_MATCHES_RESET',\n PERIODIC_TASK_SCHEDULED = 'PERIODIC_TASK_SCHEDULED',\n ENTITIES_MERGED_MANUALLY = 'ENTITIES_MERGED_MANUALLY',\n POTENTIAL_MATCHES_REMOVED = 'POTENTIAL_MATCHES_REMOVED',\n ENTITIES_MERGED_ON_THE_FLY = 'ENTITIES_MERGED_ON_THE_FLY',\n USER_LOGIN = 'USER_LOGIN',\n USER_LOGOUT = 'USER_LOGOUT',\n USER_SEARCH = 'USER_SEARCH',\n USER_PROFILE_VIEW = 'USER_PROFILE_VIEW',\n COMMENT_ADDED = 'COMMENT_ADDED',\n COMMENT_UPDATED = 'COMMENT_UPDATED',\n COMMENT_DELETED = 'COMMENT_DELETED',\n ANALYTICS_ATTRIBUTES_CHANGED = 'ANALYTICS_ATTRIBUTES_CHANGED',\n SFDC_CONNECTOR_SYNCHRONIZATION_ISSUE = 'SFDC_CONNECTOR_SYNCHRONIZATION_ISSUE',\n GROUP_CREATED = 'GROUP_CREATED',\n GROUP_REMOVED = 'GROUP_REMOVED',\n GROUP_CHANGED = 'GROUP_CHANGED'\n}\n","import {\n formatDataTypeValue,\n findAttributeTypeByUri,\n Metadata,\n AttributePresentations,\n makeAttrTypeUri,\n getAttrDataTypeDefinition\n} from '@reltio/mdm-sdk';\nimport {filter, groupBy, ifElse, map, path, pipe, propOr, values, isNil, includes, reject} from 'ramda';\nimport i18n from 'ui-i18n';\nimport {ActivityData, ActivityItem, ActivityTypes, DeltaValue} from '../types';\n\nconst getItemDataType = path(['data', 'type']);\n\nexport const getActivityType = (activity: ActivityData) => {\n const {items, label} = activity;\n const [firstItem] = items || [];\n return getItemDataType(firstItem) || label;\n};\n\nexport const isValidActivityType = (type: string): boolean => pipe(values, includes(type))(ActivityTypes);\n\nexport const removeIgnoredItems = (activity: ActivityData): ActivityData => {\n const {items = [], label} = activity;\n const isImplementedItem = (item: ActivityItem): boolean => isValidActivityType(getItemDataType(item) || label);\n const filteredItems = filter(isImplementedItem)(items);\n if (items.length !== filteredItems.length) {\n console.error('Activities not implemented:', reject(isImplementedItem)(items));\n }\n return {\n ...activity,\n items: filteredItems,\n itemsTotal: filteredItems.length\n };\n};\n\nexport const splitActivityByType = (activity: ActivityData) => {\n return pipe(\n propOr([], 'items'),\n groupBy(getItemDataType),\n values,\n ifElse(\n ({length}) => length > 1,\n map((items) => ({\n ...activity,\n items,\n itemsTotal: items.length\n })),\n () => [activity]\n )\n )(activity);\n};\n\nexport const stringifyDeltaValue = (\n deltaValue: DeltaValue['value'],\n attributeTypeUri: string,\n metadata: Metadata,\n attributePresentations: AttributePresentations\n) => {\n const attributeType = findAttributeTypeByUri(metadata, attributeTypeUri);\n const dataTypeDefinition = getAttrDataTypeDefinition(attributeType);\n const formatValue = formatDataTypeValue({attributePresentations, dataTypeDefinition});\n\n if (isNil(deltaValue)) {\n return '';\n }\n\n if (typeof deltaValue === 'string') {\n return attributeType ? formatValue(deltaValue) : deltaValue;\n }\n\n return Object.entries(deltaValue)\n .flatMap(([attributeTypeName, deltaValues]) =>\n deltaValues.map((deltaValue) =>\n stringifyDeltaValue(\n deltaValue.value,\n makeAttrTypeUri(attributeTypeUri, attributeTypeName),\n metadata,\n attributePresentations\n )\n )\n )\n .join(', ');\n};\n\nexport const getActivityLabel = (type: ActivityTypes) => {\n const labels = {\n [ActivityTypes.COMMENT_ADDED]: i18n.text('Comment added'),\n [ActivityTypes.COMMENT_DELETED]: i18n.text('Comment deleted'),\n [ActivityTypes.COMMENT_UPDATED]: i18n.text('Comment updated'),\n [ActivityTypes.ENTITIES_MERGED]: i18n.text('Profile merged'),\n [ActivityTypes.ENTITIES_MERGED_MANUALLY]: i18n.text('Profile merged manually'),\n [ActivityTypes.ENTITIES_MERGED_ON_THE_FLY]: i18n.text('Profile merged on the fly'),\n [ActivityTypes.ENTITIES_SPLITTED]: i18n.text('Profile un-merged'),\n [ActivityTypes.ENTITY_CHANGED]: i18n.text('Profile updated'),\n [ActivityTypes.ENTITY_CREATED]: i18n.text('Profile created'),\n [ActivityTypes.ENTITY_LOST_MERGE]: i18n.text('Profile lost merge'),\n [ActivityTypes.ENTITY_REMOVED]: i18n.text('Profile removed'),\n [ActivityTypes.GROUP_CHANGED]: i18n.text('Group updated'),\n [ActivityTypes.GROUP_CREATED]: i18n.text('Group created'),\n [ActivityTypes.GROUP_REMOVED]: i18n.text('Group removed'),\n [ActivityTypes.MODEL_UPDATED]: i18n.text('Model was updated'),\n [ActivityTypes.NOT_MATCHES_RESET]: i18n.text('Not matches reset'),\n [ActivityTypes.NOT_MATCHES_SET]: i18n.text('Not matches set'),\n [ActivityTypes.PERIODIC_TASK_SCHEDULED]: i18n.text('Periodic task was scheduled'),\n [ActivityTypes.POTENTIAL_MATCHES_FOUND]: i18n.text('Potential matches found'),\n [ActivityTypes.POTENTIAL_MATCHES_REMOVED]: i18n.text('Potential matches removed'),\n [ActivityTypes.RELATIONSHIP_CHANGED]: i18n.text('Relationship updated'),\n [ActivityTypes.RELATIONSHIP_CREATED]: i18n.text('Relationship created'),\n [ActivityTypes.RELATIONSHIP_REMOVED]: i18n.text('Relationship removed'),\n [ActivityTypes.USER_LOGIN]: i18n.text('Logged in'),\n [ActivityTypes.USER_LOGOUT]: i18n.text('Logged out'),\n [ActivityTypes.USER_PROFILE_VIEW]: i18n.text('Profile viewed'),\n [ActivityTypes.USER_SEARCH]: i18n.text('Searched'),\n [ActivityTypes.ANALYTICS_ATTRIBUTES_CHANGED]: i18n.text('Analytics attribute changed'),\n [ActivityTypes.SFDC_CONNECTOR_SYNCHRONIZATION_ISSUE]: i18n.text('SFDC connector synchronization issue')\n };\n return labels[type] || '';\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n dropdownIndicator: {\n transition: 'transform .15s ease'\n },\n inputRoot: {\n fontSize: '14px',\n height: 46\n },\n input: {\n padding: '0 12px 0'\n },\n dateOptionLabel: {\n minWidth: '100px'\n },\n paper: {\n minWidth: '112px'\n }\n});\n","import React, {useCallback, useRef, useState} from 'react';\nimport moment from 'moment';\nimport i18n from 'ui-i18n';\nimport {isNil} from 'ramda';\nimport {DataTypes, formatDataTypeValue} from '@reltio/mdm-sdk';\nimport {noop} from '../../../core';\nimport TextField from '@mui/material/TextField';\nimport Popover from '@mui/material/Popover';\nimport DropdownIndicatorWithIconButton from '../../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport DateRangePicker from '../../DateRangePicker/DateRangePicker';\n\nimport {useStyles} from './styles';\n\ntype DateValues = [Date, Date];\ntype Props = {\n values: DateValues;\n onChange: (values: DateValues) => void;\n onFocus?: () => void;\n};\n\nconst localeFormat = moment.localeData().longDateFormat('L');\n\nconst formatValue = (value: Date, placeholder: string) => {\n return isNil(value)\n ? `${placeholder}`\n : `${formatDataTypeValue({dataTypeDefinition: {type: DataTypes.TYPE_ACTIVENESS_DATE}}, value)}`;\n};\n\nconst CustomDateRangeEditor = ({values, onChange, onFocus = noop}: Props) => {\n const placeholder = localeFormat;\n const inputRef = useRef(null);\n const [open, setOpen] = useState(false);\n const styles = useStyles();\n\n const onApply = (values: DateValues) => {\n onChange(values);\n setOpen(false);\n };\n\n const handleToggle = useCallback(() => {\n setOpen((open) => !open);\n onFocus();\n }, [onFocus]);\n\n const onCancel = () => {\n setOpen(false);\n };\n\n return (\n <div className={styles.root}>\n <TextField\n fullWidth\n value={values.map((value) => formatValue(value, placeholder)).join(' \\u2014 ')}\n onClick={handleToggle}\n variant=\"filled\"\n ref={inputRef}\n InputProps={{\n endAdornment: (\n <DropdownIndicatorWithIconButton\n selectProps={{classes: styles, menuIsOpen: open}}\n innerProps={{}}\n />\n ),\n disableUnderline: isNil(values),\n readOnly: true,\n classes: {\n root: styles.inputRoot,\n input: styles.input\n }\n }}\n InputLabelProps={{\n shrink: false\n }}\n placeholder={i18n.text(`${placeholder} \\u2014 ${placeholder}`)}\n />\n <Popover\n open={open}\n anchorEl={inputRef.current}\n onClose={onCancel}\n anchorOrigin={{\n vertical: 'bottom',\n horizontal: 'right'\n }}\n transformOrigin={{\n vertical: 'top',\n horizontal: 'right'\n }}\n elevation={2}\n >\n <DateRangePicker values={values} onApply={onApply} type={DataTypes.TYPE_ACTIVENESS_DATE} />\n </Popover>\n </div>\n );\n};\n\nexport default CustomDateRangeEditor;\n","import i18n from 'ui-i18n';\nimport {DateRangeTypes} from '@reltio/mdm-sdk';\n\nexport const dateRangeTypeOptions = [DateRangeTypes.WITHIN, DateRangeTypes.AGO, DateRangeTypes.BETWEEN];\n\nexport const getDateRangeTypeLabel = (type: DateRangeTypes) => {\n const labels = {\n [DateRangeTypes.WITHIN]: i18n.text('Within the last'),\n [DateRangeTypes.AGO]: i18n.text('More than'),\n [DateRangeTypes.BETWEEN]: i18n.text('Date range')\n };\n return labels[type] || '';\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n title: {\n paddingBottom: '10px',\n paddingLeft: '5px',\n fontSize: '14px'\n },\n intervalContainer: {\n display: 'flex',\n justifyContent: 'space-between'\n },\n typeInput: {\n width: 160,\n marginRight: 10\n }\n});\n","import React, {useState} from 'react';\nimport i18n from 'ui-i18n';\nimport classnames from 'classnames';\nimport {DateRangeFilter, DateRangeTypes} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport SimpleDropDownSelector from '../../SimpleDropDownSelector/SimpleDropDownSelector';\nimport {dateRangeTypeOptions, getDateRangeTypeLabel} from './utils';\nimport DateIntervalSelector from '../../DateIntervalSelector/DateIntervalSelector';\nimport {useDidUpdateEffect} from '../../../hooks';\nimport CustomDateRangeEditor from '../../editors/CustomDateRangeEditor/CustomDateRangeEditor';\n\nimport {useStyles} from './styles';\n\nconst emptyDates: [Date, Date] = [null, null];\nconst emptyInterval: [number, string] = [null, 'hours'];\n\ntype Props = {\n value: DateRangeFilter;\n onChange: (range: DateRangeFilter) => void;\n className?: string;\n};\n\nconst DateRangeSelector = ({value, onChange, className}: Props) => {\n const styles = useStyles();\n\n const isIntervalType = (type: DateRangeTypes) => type === DateRangeTypes.WITHIN || type === DateRangeTypes.AGO;\n const isBetweenType = (type: DateRangeTypes) => type === DateRangeTypes.BETWEEN;\n\n const initDatesInterval = isBetweenType(value?.type) ? value.period : emptyDates;\n const initInterval = isIntervalType(value?.type) ? value.period : emptyInterval;\n\n const [datesInterval, setDatesInterval] = useState(initDatesInterval as [Date, Date]);\n const [interval, setInterval] = useState(initInterval as [number, string]);\n\n const selectedType = value?.type || DateRangeTypes.WITHIN;\n\n const getCurrentPeriodByType = (type: DateRangeTypes) => {\n if (isIntervalType(type)) {\n return interval;\n } else if (isBetweenType(type)) {\n return datesInterval;\n }\n };\n\n const changeType = ({value: type}: {value: DateRangeTypes}) => {\n if (value?.type !== type) {\n onChange({period: getCurrentPeriodByType(type), type});\n }\n };\n const changePeriod = (period) => {\n onChange({type: selectedType, period});\n };\n\n useDidUpdateEffect(() => {\n if (value) {\n if (isIntervalType(value.type)) {\n setInterval(value.period as [number, string]);\n } else if (isBetweenType(value.type)) {\n setDatesInterval(value.period as [Date, Date]);\n }\n } else {\n setDatesInterval(emptyDates);\n setInterval(emptyInterval);\n }\n }, [value]);\n\n return (\n <div className={classnames(styles.root, className)} data-reltio-id=\"date-range-selector\">\n <Typography className={styles.title} variant={'subtitle1'}>\n {i18n.text('Date')}\n </Typography>\n <div className={styles.intervalContainer}>\n <SimpleDropDownSelector\n label={''}\n className={styles.typeInput}\n value={{\n value: selectedType,\n label: getDateRangeTypeLabel(selectedType)\n }}\n options={dateRangeTypeOptions.map((option) => ({\n value: option,\n label: getDateRangeTypeLabel(option)\n }))}\n onChange={changeType}\n />\n {isIntervalType(selectedType) ? (\n <DateIntervalSelector interval={interval} onChange={changePeriod} />\n ) : (\n <CustomDateRangeEditor values={datesInterval} onChange={changePeriod} />\n )}\n </div>\n </div>\n );\n};\n\nexport default DateRangeSelector;\n","import i18n from 'ui-i18n';\nimport {HistoryActivityType} from '../types/HistoryFilter';\n\nexport const historyActivityOptions = [\n HistoryActivityType.UPDATE,\n HistoryActivityType.MERGE,\n HistoryActivityType.UNMERGE\n];\n\nexport const getHistoryActivityLabel = (type: HistoryActivityType) => {\n const labels = {\n [HistoryActivityType.UPDATE]: i18n.text('Update'),\n [HistoryActivityType.MERGE]: i18n.text('Merge'),\n [HistoryActivityType.UNMERGE]: i18n.text('Unmerge')\n };\n return labels[type] || '';\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const customStyles = {\n input: (currentStyles) => ({...currentStyles, fontSize: '14px'}),\n menuPortal: (currentStyles) => ({...currentStyles, zIndex: 1300})\n};\n\nexport const useStyles = makeStyles({\n root: {\n flex: 1\n },\n title: {\n paddingBottom: '10px',\n paddingLeft: '5px',\n fontSize: '14px'\n },\n dropDownInput: {\n width: '100%',\n justifyContent: 'center',\n backgroundColor: 'rgba(0, 0, 0, 0.03)',\n borderTop: '4px'\n },\n valueContainer: {\n overflowY: 'auto',\n height: 44\n },\n option: {\n fontSize: '14px',\n height: '32px'\n }\n});\n","import React from 'react';\nimport i18n from 'ui-i18n';\nimport {defaultTo, pipe, pluck} from 'ramda';\nimport classnames from 'classnames';\nimport Typography from '@mui/material/Typography';\nimport MultiSelect from '../../ReactSelect/MultiSelect';\nimport DropdownIndicatorWithIconButton from '../../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport {getHistoryActivityLabel, historyActivityOptions} from './utils';\nimport {HistoryActivityType} from '../types/HistoryFilter';\nimport {customStyles, useStyles} from './styles';\n\ntype Props = {\n selectedHistoryActivityTypes: HistoryActivityType[];\n onChange: (activities: HistoryActivityType[]) => void;\n className?: string;\n disableUnderline?: boolean;\n};\n\nconst HistoryActivitySelector = ({selectedHistoryActivityTypes, onChange, className, disableUnderline}: Props) => {\n const styles = useStyles();\n const valueToOption = (value: HistoryActivityType) => ({value, label: getHistoryActivityLabel(value)});\n const prepareValues = (values: HistoryActivityType[]) => values.map(valueToOption);\n\n const options = prepareValues(historyActivityOptions);\n\n return (\n <div className={classnames(styles.root, className)} data-reltio-id=\"history-activity-selector\">\n <Typography className={styles.title} variant={'subtitle1'}>\n {i18n.text('Activity')}\n </Typography>\n <MultiSelect\n value={prepareValues(selectedHistoryActivityTypes)}\n onChange={pipe(defaultTo([]), pluck('value'), onChange)}\n options={options}\n TextFieldProps={{\n InputProps: {disableUnderline},\n classes: {root: styles.dropDownInput}\n }}\n components={{\n DropdownIndicator: DropdownIndicatorWithIconButton\n }}\n styles={customStyles}\n classes={styles}\n menuPlacement=\"bottom\"\n menuPortalTarget={document.body}\n menuShouldBlockScroll={true}\n captureMenuScroll={false}\n />\n </div>\n );\n};\n\nexport default HistoryActivitySelector;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n popup: {\n width: 500,\n minHeight: 500,\n overflowY: 'hidden',\n display: 'flex',\n flexDirection: 'column'\n },\n filterContainer: {\n maxHeight: '400px',\n borderColor: 'rgba(0,0,0,0.12)'\n },\n filterItem: {\n '&:not(:last-child)': {\n marginBottom: 12\n }\n },\n clearButton: {\n marginRight: 'auto'\n },\n input: {\n height: '100%',\n paddingLeft: '12px',\n paddingRight: '8px'\n },\n divider: {\n marginBottom: 12\n }\n});\n","import React, {useCallback, useEffect, useRef, useState} from 'react';\nimport i18n from 'ui-i18n';\nimport {curry, dissoc} from 'ramda';\nimport FilterListIcon from '@mui/icons-material/FilterList';\nimport Button from '@mui/material/Button';\nimport Popover from '@mui/material/Popover';\nimport DialogActions from '@mui/material/DialogActions';\nimport DialogContent from '@mui/material/DialogContent';\nimport DialogTitle from '@mui/material/DialogTitle';\nimport Divider from '@mui/material/Divider';\nimport {TEntityType, isDateRangeValid} from '@reltio/mdm-sdk';\nimport {SmallIconButton} from '../../SmallIconButton';\nimport {HistoryFilter} from '../types';\nimport UserSelector from '../../UserSelector/UserSelector';\nimport AttributeSelector from '../../AttributeSelector/AttributeSelector';\nimport DateRangeSelector from '../DateRangeSelector/DateRangeSelector';\nimport HistoryActivitySelector from '../HistoryActivitySelector/HistoryActivitySelector';\nimport {DEFAULT_HISTORY_FILTER, isDefaultFilter} from '../hooks/useHistory';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n className?: string;\n filter: HistoryFilter;\n onApplyFilter: (filter: HistoryFilter) => void;\n entityType: TEntityType;\n};\n\nconst HistoryFilterButton = ({className, filter, onApplyFilter, entityType}: Props) => {\n const styles = useStyles();\n const buttonRef = useRef();\n const [isOpen, setIsOpen] = useState(false);\n const [currentValue, setCurrentValue] = useState<HistoryFilter>(filter);\n const {activities = [], attributes = [], dateRange = null, users = []} = currentValue || {};\n\n const buttonColor = isDefaultFilter(filter) ? 'inherit' : 'primary';\n\n useEffect(() => {\n if (isOpen) {\n setCurrentValue(filter);\n }\n }, [filter, isOpen]);\n\n const handlePropChange = curry((propName: string, value: unknown) => {\n setCurrentValue((filterValue) => ({\n ...filterValue,\n [propName]: value\n }));\n });\n\n const togglePopup = useCallback(() => {\n setIsOpen((open) => !open);\n }, []);\n\n const applyButtonHandler = useCallback(() => {\n dateRange && isDateRangeValid(dateRange)\n ? onApplyFilter(currentValue)\n : onApplyFilter(dissoc('dateRange', currentValue));\n togglePopup();\n }, [currentValue, dateRange, onApplyFilter, togglePopup]);\n\n const clearAllButtonHandler = useCallback(() => {\n setCurrentValue({...DEFAULT_HISTORY_FILTER});\n }, []);\n\n return (\n <>\n <SmallIconButton\n ref={buttonRef}\n color={buttonColor}\n icon={FilterListIcon}\n size=\"L\"\n onClick={togglePopup}\n className={className}\n />\n <Popover\n classes={{paper: styles.popup}}\n open={isOpen}\n anchorEl={buttonRef.current}\n onClose={togglePopup}\n anchorOrigin={{\n vertical: 'bottom',\n horizontal: 'right'\n }}\n transformOrigin={{\n vertical: 'top',\n horizontal: 'right'\n }}\n >\n <DialogTitle>{i18n.text('Filter')}</DialogTitle>\n <DialogContent dividers className={styles.filterContainer}>\n <DateRangeSelector\n value={dateRange}\n onChange={handlePropChange('dateRange')}\n className={styles.filterItem}\n />\n <Divider light className={styles.divider} />\n <UserSelector\n selectedUsers={users}\n onChange={handlePropChange('users')}\n className={styles.filterItem}\n disableUnderline\n />\n <Divider light className={styles.divider} />\n <HistoryActivitySelector\n selectedHistoryActivityTypes={activities}\n onChange={handlePropChange('activities')}\n className={styles.filterItem}\n disableUnderline\n />\n <Divider light className={styles.divider} />\n <AttributeSelector\n selectedAttributes={attributes}\n entityType={entityType}\n onChange={handlePropChange('attributes')}\n className={styles.filterItem}\n title={i18n.text('Attribute updated')}\n disableUnderline\n />\n </DialogContent>\n <DialogActions>\n <Button onClick={clearAllButtonHandler} className={styles.clearButton}>\n {i18n.text('Clear all')}\n </Button>\n <Button onClick={togglePopup}>{i18n.text('Cancel')}</Button>\n <Button color=\"primary\" onClick={applyButtonHandler}>\n {i18n.text('Apply')}\n </Button>\n </DialogActions>\n </Popover>\n </>\n );\n};\n\nexport default HistoryFilterButton;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n menuItem: {\n minHeight: '32px'\n },\n menuText: {\n fontSize: '13px',\n lineHeight: '15px',\n letterSpacing: 0,\n marginLeft: '30px'\n },\n checkIcon: {\n position: 'absolute',\n color: 'rgba(0, 0, 0, 0.54)'\n }\n});\n","import React, {forwardRef} from 'react';\nimport MenuItem from '@mui/material/MenuItem';\nimport Typography from '@mui/material/Typography';\nimport CheckIcon from '@mui/icons-material/Check';\nimport {noop} from '../../../core';\nimport {useStyles} from './styles';\n\ntype Item = {\n text: string;\n selected: boolean;\n onClick: (e) => void;\n};\n\ntype Props = {\n item: Item;\n onMenuClose?: () => void;\n};\n\nconst MenuItemRenderer = forwardRef(({item, onMenuClose = noop}: Props, ref: React.Ref<HTMLLIElement>) => {\n const styles = useStyles();\n const {text, selected, onClick} = item;\n const handleClick = (e) => {\n onMenuClose();\n onClick(e);\n };\n\n return (\n <MenuItem classes={{root: styles.menuItem}} onClick={handleClick} ref={ref}>\n {selected && <CheckIcon className={styles.checkIcon} />}\n <Typography classes={{root: styles.menuText}}>{text}</Typography>\n </MenuItem>\n );\n});\nMenuItemRenderer.displayName = 'MenuItemRenderer';\n\nexport default MenuItemRenderer;\n","import React from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport i18n from 'ui-i18n';\nimport MoreVertIcon from '@mui/icons-material/MoreVert';\nimport mdmModule, {profile} from '@reltio/mdm-module';\nimport {HistoryMode} from '@reltio/mdm-sdk';\nimport {SmallIconButton} from '../../SmallIconButton';\nimport DropDownMenuButton from '../../DropDownMenuButton/DropDownMenuButton';\nimport MenuItemRenderer from './MenuItemRenderer';\n\nconst HistoryMenuButton = () => {\n const mode = useSelector(mdmModule.selectors.getHistoryMode);\n const dispatch = useDispatch();\n const handleModeChange = (selectedMode: HistoryMode) => {\n dispatch(profile.history.actions.setHistoryMode(selectedMode));\n };\n const menuItems = [\n {\n text: i18n.text('Compare to Current view'),\n selected: mode === HistoryMode.Current,\n onClick: () => handleModeChange(HistoryMode.Current)\n },\n {\n text: i18n.text('Compare to Previous view'),\n selected: mode === HistoryMode.Previous,\n onClick: () => handleModeChange(HistoryMode.Previous)\n }\n ];\n\n return (\n <DropDownMenuButton\n MenuItemRenderer={MenuItemRenderer}\n buttonComponent={SmallIconButton}\n buttonProps={{\n icon: MoreVertIcon,\n size: 'L'\n }}\n menuId={'history-menu'}\n menuItems={menuItems}\n />\n );\n};\n\nexport default HistoryMenuButton;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n flex: 1,\n alignItems: 'center'\n },\n icon: {\n margin: 4\n },\n divider: {\n borderColor: 'rgba(0,0,0,0.12)',\n margin: '3px 19px'\n },\n count: {\n fontSize: 14\n },\n filterButton: {\n marginRight: '-4px'\n }\n});\n","import React from 'react';\nimport i18n from 'ui-i18n';\nimport Divider from '@mui/material/Divider';\nimport Typography from '@mui/material/Typography';\nimport {isNil} from 'ramda';\nimport {TEntityType} from '@reltio/mdm-sdk';\nimport Spacer from '../../Spacer/Spacer';\nimport HistoryFilterButton from '../HistoryFilterButton/HistoryFilterButton';\nimport HistoryMenuButton from '../HistoryMenuButton/HistoryMenuButton';\nimport {HistoryFilter} from '../types';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n total?: number;\n entityType: TEntityType;\n filter: HistoryFilter;\n onApplyFilter: (value: HistoryFilter) => void;\n};\n\nconst HistoryHeader = ({total, entityType, filter, onApplyFilter}: Props) => {\n const styles = useStyles();\n return (\n <div className={styles.root}>\n <Typography variant=\"h6\">{i18n.text('History')}</Typography>\n {!isNil(total) && (\n <>\n <Divider orientation=\"vertical\" flexItem className={styles.divider} />\n <Typography variant=\"body1\" color=\"textSecondary\" className={styles.count}>\n {total === 1\n ? i18n.text('${count} contributing profile', {count: total})\n : i18n.text('${count} contributing profiles', {count: total})}\n </Typography>\n </>\n )}\n <Spacer />\n <HistoryFilterButton\n className={styles.filterButton}\n entityType={entityType}\n filter={filter}\n onApplyFilter={onApplyFilter}\n />\n <HistoryMenuButton />\n </div>\n );\n};\n\nexport default HistoryHeader;\n","import React from 'react';\nimport i18n from 'ui-i18n';\nimport SidePanelEmptyState from '../../SidePanelEmptyState/SidePanelEmptyState';\n\nconst HistoryPanelEmptyState = () => (\n <SidePanelEmptyState\n text={i18n.text('History in the making')}\n secondaryText={i18n.text('When you create an event or perform an activity, it will show up here.')}\n />\n);\n\nexport default HistoryPanelEmptyState;\n","import {makeStyles} from '@mui/styles';\n\ntype Type = {\n color?: string;\n};\n\nexport const useStyles = makeStyles(() => ({\n historyRow: {\n position: 'relative',\n padding: '8px 12px 16px',\n cursor: 'pointer'\n },\n selected: {\n background: 'rgba(0,0,0,0.05)',\n '&:before': {\n content: '\"\"',\n background: 'rgba(0,0,0,0.05)',\n width: '100%',\n height: '100%',\n position: 'absolute',\n left: '-100%',\n top: 0\n }\n },\n rowHeader: {\n display: 'flex',\n position: 'relative'\n },\n badge: ({color}: Type) => ({\n position: 'absolute',\n width: '2px',\n height: '100%',\n left: '-9px',\n pointerEvents: 'none',\n background: color,\n '&:before': {\n height: '100%',\n width: '3px',\n content: '\"\"',\n left: '-3px',\n background: color,\n position: 'absolute',\n opacity: 0.06\n }\n }),\n title: {\n color: 'rgba(0,0,0,0.87)',\n fontSize: '13px',\n letterSpacing: 0,\n lineHeight: '16px',\n fontWeight: 400,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n '&.bold': {\n fontWeight: 500\n }\n },\n date: {\n marginLeft: 'auto',\n color: 'rgba(0,0,0,0.54)',\n fontSize: '11px',\n letterSpacing: 0,\n lineHeight: '16px',\n flexShrink: 0\n },\n user: {\n color: 'rgba(0,0,0,0.38)',\n fontSize: '12px',\n letterSpacing: 0,\n lineHeight: '14px'\n }\n}));\n","import React from 'react';\nimport classnames from 'classnames';\nimport i18n from 'ui-i18n';\nimport {getContributorColor, HistoryChange} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport {ActivityTypes} from '../../activityLog/types/ActivityTypes';\nimport {getActivityLabel} from '../../activityLog/utils/activities';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n change: HistoryChange;\n isCurrent?: boolean;\n isSelected: boolean;\n onClick: () => void;\n};\n\nconst HistoryRow = ({change, isCurrent, isSelected, onClick}: Props) => {\n const {uri, type, matchGroups, user, timestamp} = change;\n const color = getContributorColor(uri);\n const styles = useStyles({color});\n return (\n <div className={classnames(styles.historyRow, {[styles.selected]: isSelected})} onClick={onClick}>\n <div className={styles.rowHeader}>\n <div className={styles.badge} />\n <Typography className={classnames(styles.title, {bold: isCurrent})}>\n {isCurrent ? i18n.text('Current view') : getActivityLabel(type as ActivityTypes)}\n </Typography>\n {!isCurrent && <Typography className={styles.date}>{i18n.date(timestamp, 'L LT')}</Typography>}\n </div>\n {matchGroups && (\n <Typography className={styles.title}>\n {i18n.text('Match rule:')} {matchGroups.join(', ')}\n </Typography>\n )}\n <Typography className={styles.user}>{user}</Typography>\n </div>\n );\n};\n\nexport default HistoryRow;\n","import {HistoryChangeTypes} from '../types/HistoryChangeTypes';\n\nexport const getHistoryLinkCurve = (x: number, y: number, toX: number, toY: number) => {\n const isUp = y > toY;\n const isLeft = x < toX;\n const curveStartX = isLeft ? toX - 12 : toX + 12;\n const curveCenterY = isUp ? -6 : 6;\n const curveEndY = isUp ? -12 : 12;\n const curve = isLeft ? `c 6 0 12 ${curveCenterY} 12` : `c -6 0 -12 ${curveCenterY} -12`;\n return `M${x} ${y} L${curveStartX} ${y} ${curve} ${curveEndY} L${toX} ${toY}`;\n};\n\nexport const isFakeHistoryType = (type: string) =>\n type === HistoryChangeTypes.FAKE_FILTERED_INCOMING || type === HistoryChangeTypes.FAKE_FILTERED_OUTGOING;\n","import React from 'react';\nimport {getHistoryLinkCurve} from './helpers';\n\ntype Props = {\n x: number;\n y: number;\n toX: number;\n toY: number;\n color: string;\n isDashed?: boolean;\n};\n\nconst HistoryLink = ({x, y, toX, toY, color, isDashed}: Props) => {\n const lineData = getHistoryLinkCurve(x, y, toX, toY);\n return (\n <path\n d={lineData}\n stroke={color}\n strokeWidth={2}\n fill={'none'}\n strokeDasharray={isDashed ? '3,3' : undefined}\n />\n );\n};\n\nexport default HistoryLink;\n","import React, {forwardRef} from 'react';\n\ntype Props = {\n x: number;\n y: number;\n color: string;\n isDashed?: boolean;\n isCollapsed?: boolean;\n showCollapseIcon?: boolean;\n showLine?: boolean;\n} & React.SVGProps<SVGGElement>;\n\nexport const BUMP_RADIUS = 3;\nexport const LINE_MARGIN = 4;\n\nconst HistoryCircle = ({x, y, color, isDashed, isCollapsed, showCollapseIcon, showLine, ...otherProps}: Props, ref) => {\n const radius = showCollapseIcon ? BUMP_RADIUS * 2 : BUMP_RADIUS;\n return (\n <g {...otherProps} ref={ref}>\n {showLine && (\n <rect\n id=\"line\"\n x={x - radius - LINE_MARGIN}\n y={y - radius - LINE_MARGIN}\n width={radius * 2 + LINE_MARGIN * 2}\n height={2}\n fill={color}\n />\n )}\n <circle\n cx={x}\n cy={y}\n r={radius}\n fill={isDashed ? '#fff' : color}\n stroke={color}\n strokeDasharray={isDashed ? '1,1' : undefined}\n strokeWidth={2}\n />\n {showCollapseIcon && (\n <g id=\"icon\">\n <rect x={x - 4} y={y - 1} width={8} height={2} fill=\"#fff\" />\n {isCollapsed && <rect x={x - 1} y={y - 4} width={2} height={8} fill=\"#fff\" />}\n </g>\n )}\n </g>\n );\n};\n\nexport default forwardRef(HistoryCircle);\n","import React, {memo} from 'react';\nimport {getContributorColor} from '@reltio/mdm-sdk';\nimport HistoryLink from './HistoryLink';\nimport HistoryCircle from './HistoryCircle';\nimport {HistoryData, HistoryChangeTypes} from '../types';\nimport {isFakeHistoryType} from './helpers';\nimport {withTooltip} from '../../../HOCs';\n\nconst COL_WIDTH = 16;\nconst COL_MARGIN = 24;\nconst ROW_MARGIN = 16;\nconst ROW_HEIGHT = 16;\n\nexport const HistoryCircleWithTooltip = withTooltip(HistoryCircle);\n\ntype Props = {\n graphData: HistoryData;\n onHistoryCircleMouseOver?: (uri: string, timestamp: number, index: number) => void;\n};\n\nconst HistoryGraph = ({graphData, onHistoryCircleMouseOver}: Props) => {\n const {historyLanes, rows} = graphData;\n const rowPositions = [ROW_MARGIN];\n\n const {links, rowLines, circles} = rows.reduce(\n (acc, {uri, height, uris, type, fakeType, index, timestamp, label}, i) => {\n const x = historyLanes[uri].index * COL_WIDTH + COL_MARGIN;\n const y = rowPositions[i];\n rowPositions.push(y + height);\n\n const hasFakeType = isFakeHistoryType(fakeType);\n const circleUri = hasFakeType ? uris[0] : uri;\n const isCollapsed = !uris?.some((uri) => historyLanes[uri]);\n acc.circles.push(\n <HistoryCircleWithTooltip\n tooltipTitle={label}\n tooltipPlacement=\"top\"\n onMouseOver={\n onHistoryCircleMouseOver ? () => onHistoryCircleMouseOver(uri, timestamp, index) : undefined\n }\n key={`circle-${circleUri}-${i}`}\n x={x}\n y={y}\n color={getContributorColor(circleUri)}\n isDashed={hasFakeType}\n isCollapsed={isCollapsed}\n showCollapseIcon={!!uris}\n showLine={fakeType === HistoryChangeTypes.FAKE_NAVIGATE_PROFILE}\n />\n );\n\n acc.rowLines.push(\n <rect\n key={`${circleUri}-${index}`}\n x={x}\n y={y - ROW_HEIGHT / 2}\n width={'100%'}\n height={ROW_HEIGHT}\n fill={getContributorColor(circleUri)}\n opacity={0.06}\n />\n );\n\n const isUpRight = type === HistoryChangeTypes.ENTITIES_SPLITTED;\n uris?.forEach((contributorUri) => {\n const contributorLane = historyLanes[contributorUri];\n if (!contributorLane) return;\n const rowHeight = rows[i].height;\n const toX = contributorLane.index * COL_WIDTH + COL_MARGIN;\n const toY = isUpRight ? y - rowHeight : y + rowHeight;\n if (x !== toX)\n acc.links.push(\n <HistoryLink\n key={`link-${contributorUri}-${index}`}\n x={x}\n y={y}\n toX={toX}\n toY={toY}\n isDashed={isFakeHistoryType(fakeType)}\n color={getContributorColor(contributorUri)}\n />\n );\n });\n\n return acc;\n },\n {links: [], circles: [], rowLines: []}\n );\n\n const width = Object.keys(historyLanes).length * COL_WIDTH + COL_MARGIN;\n const height = rowPositions[rowPositions.length - 1] - ROW_MARGIN;\n\n Object.entries(historyLanes).forEach(([contributorUri, contributorLane]) => {\n const x = contributorLane.index * COL_WIDTH + COL_MARGIN;\n contributorLane.lifeTime.forEach(({start, end}, i) => {\n if (rows[end?.index]?.type === HistoryChangeTypes.ENTITIES_SPLITTED) return;\n const startIndex = start?.type === HistoryChangeTypes.ENTITIES_SPLITTED ? start?.index - 1 : start?.index;\n const endIndex =\n end?.type === HistoryChangeTypes.ENTITIES_MERGED_MANUALLY ||\n end?.type === HistoryChangeTypes.ENTITIES_MERGED\n ? end?.index + 1\n : end?.index;\n const startY = rowPositions[startIndex] || rowPositions[rowPositions.length - 2];\n const endY = rowPositions[endIndex] || ROW_MARGIN;\n if (startY <= endY) return;\n const color = getContributorColor(contributorUri);\n if (!end && contributorLane.index > 0) {\n circles.push(\n <HistoryCircle key={`initCircle-${contributorUri}-${i}`} x={x} y={endY} color={color} showLine />\n );\n }\n links.unshift(\n <path\n key={`line-${contributorUri}-${i}`}\n d={`M${x} ${startY} L${x} ${endY}`}\n stroke={color}\n strokeWidth={2}\n />\n );\n });\n });\n\n return (\n <svg className=\"chart\" width={width} height={height}>\n <g id=\"rowLines\">{rowLines}</g>\n <g id=\"links\">{links}</g>\n <g id=\"circles\">{circles}</g>\n </svg>\n );\n};\n\nexport default memo(HistoryGraph);\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n historyTree: {\n display: 'grid',\n gridTemplateColumns: 'auto 1fr',\n overflowY: 'auto'\n },\n graph: {\n overflowX: 'auto',\n overflowY: 'hidden'\n },\n history: {\n minWidth: '260px'\n },\n buttonContainer: {\n gridColumnStart: 1,\n gridColumnEnd: 3,\n padding: '8px 16px'\n },\n shadow: {\n boxShadow: 'inset -8px 0px 5px -5px rgba(0,0,0,0.1)'\n }\n});\n","import React, {useCallback, useEffect, useRef, useState} from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport ReactResizeDetector from 'react-resize-detector';\nimport i18n from 'ui-i18n';\nimport {isNil, uniqBy, prop, identity} from 'ramda';\nimport classnames from 'classnames';\nimport {getEntity, Mode, Metadata, getCrosswalkType, HistoryEvent} from '@reltio/mdm-sdk';\nimport mdm, {profile} from '@reltio/mdm-module';\nimport {HistoryData, HistoryRowData} from '../types';\nimport Button from '@mui/material/Button';\nimport HistoryRow from '../HistoryRow/HistoryRow';\nimport HistoryGraph from '../HistoryGraph/HistoryGraph';\nimport LinearLoadIndicator from '../../LinearLoadIndicator/LinearLoadIndicator';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n historyData: HistoryData;\n canLoadMore: boolean;\n onLoadMore: () => void;\n isLoading: boolean;\n entityUri: string;\n historyEvent: HistoryEvent;\n findPreviousChange: (index: number, uri: string) => HistoryRowData;\n};\n\nconst HistoryTree = ({\n historyData,\n isLoading,\n canLoadMore,\n onLoadMore,\n entityUri,\n historyEvent,\n findPreviousChange\n}: Props) => {\n const styles = useStyles();\n const dispatch = useDispatch();\n const isEditableMode = useSelector(mdm.selectors.getIsEditableMode);\n const metadata: Metadata = useSelector(mdm.selectors.getMetadata);\n\n const [graphData, setGraphData] = useState({historyLanes: {}, rows: []});\n const [isScrollable, setIsScrollable] = useState(false);\n const [selectedIndex, setSelectedIndex] = useState(-1);\n\n useEffect(() => {\n if (isNil(historyEvent)) {\n setSelectedIndex(0);\n return;\n }\n const isCurrentEventChange = (change: HistoryRowData) =>\n change?.uri === (historyEvent?.overrideUri || entityUri) && change?.timestamp === historyEvent?.aStamp;\n const selectedChangeByIndex = selectedIndex !== -1 ? historyData.rows[selectedIndex] : null;\n const currentEventChangeIndex = historyData.rows.findIndex((change) => isCurrentEventChange(change));\n setSelectedIndex(isCurrentEventChange(selectedChangeByIndex) ? selectedIndex : currentEventChangeIndex);\n }, [historyData.rows, historyEvent]);\n\n const graphRef = useRef(null);\n const rowsRef = useCallback(\n (node) => {\n if (!isNil(node)) {\n const rows = historyData.rows?.map((item, i) => ({...item, height: node.childNodes[i]?.clientHeight}));\n setGraphData({historyLanes: historyData.historyLanes, rows});\n }\n },\n [historyData]\n );\n\n const handleGraphScroll = () => {\n const {scrollWidth, clientWidth, scrollLeft} = graphRef?.current || {};\n setIsScrollable(scrollLeft < scrollWidth - clientWidth);\n };\n\n const handleHistoryCircleMouseOver = (uri, timestamp, index) => {\n if (isNil(graphData.rows[index].label)) {\n const options = {time: timestamp, select: 'crosswalks'} as any;\n getEntity(uri, options).then(({crosswalks}) => {\n const label = crosswalks\n ? uniqBy(prop('type'), crosswalks)\n .map((cw) => {\n const crosswalkType = getCrosswalkType(metadata, cw.type);\n return crosswalkType ? crosswalkType.label : null;\n })\n .filter(identity)\n .join(', ')\n : i18n.text('No data');\n\n setGraphData((prevGraphData) => ({\n ...prevGraphData,\n rows: prevGraphData.rows.map((row) => (row.index === index ? {...row, label} : row))\n }));\n });\n }\n };\n\n const handleHistoryRowClick = (index: number, change: HistoryRowData, isSelected: boolean, isCurrent: boolean) => {\n if (isEditableMode) {\n if (\n window.confirm(i18n.text('Are you sure you want to go in history mode? All your changes will be lost.'))\n ) {\n dispatch(profile.mode.actions.modeUpdated(Mode.Viewing));\n } else {\n return;\n }\n }\n\n if ((isCurrent && !isSelected) || (!isCurrent && isSelected)) {\n dispatch(profile.history.actions.clearHistoryEvent());\n setSelectedIndex(0);\n } else if (!isCurrent && !isSelected) {\n const aChange = findPreviousChange(index - 1, change.uri || entityUri);\n const bChange = findPreviousChange(index, change.uri || entityUri);\n const aStamp = aChange?.timestamp;\n const bStamp = bChange?.timestamp;\n const overrideUri = change?.uri === entityUri ? null : change?.uri;\n dispatch(profile.history.actions.setHistoryEvent({aStamp, bStamp, overrideUri}));\n setSelectedIndex(index);\n }\n };\n\n return (\n <div className={styles.historyTree}>\n {isLoading && <LinearLoadIndicator />}\n <div\n className={classnames(styles.graph, {[styles.shadow]: isScrollable})}\n onScroll={handleGraphScroll}\n ref={graphRef}\n >\n <HistoryGraph onHistoryCircleMouseOver={handleHistoryCircleMouseOver} graphData={graphData} />\n <ReactResizeDetector handleWidth onResize={handleGraphScroll} />\n </div>\n <div ref={rowsRef} className={styles.history}>\n {historyData.rows.map((change, i) => {\n const isSelected = i === selectedIndex;\n const isCurrent = i === 0;\n return (\n <HistoryRow\n key={`row-${i}`}\n change={change}\n isCurrent={isCurrent}\n isSelected={isSelected}\n onClick={() => handleHistoryRowClick(i, change, isSelected, isCurrent)}\n />\n );\n })}\n </div>\n {canLoadMore && (\n <div className={styles.buttonContainer}>\n <Button color=\"primary\" onClick={() => onLoadMore()}>\n {i18n.text('Show more')}\n </Button>\n </div>\n )}\n </div>\n );\n};\n\nexport default HistoryTree;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n flexWrap: 'wrap',\n padding: '10px 15px'\n }\n});\n\ntype StylesProps = {\n color: string;\n};\n\nexport const useContributorStyles = makeStyles({\n icon: ({color}: StylesProps) => ({\n boxSizing: 'border-box',\n borderWidth: 2,\n borderStyle: 'solid',\n borderColor: color,\n height: 12,\n width: 12,\n borderRadius: 30,\n transition: 'opacity 0.3s',\n margin: 4\n }),\n active: ({color}: StylesProps) => ({\n backgroundColor: color\n }),\n inactive: {\n backgroundColor: 'white'\n },\n clickable: {\n cursor: 'pointer'\n }\n});\n","import React from 'react';\nimport classnames from 'classnames';\nimport {getContributorColor} from '@reltio/mdm-sdk';\n\nimport {useContributorStyles} from './styles';\n\ntype Props = {\n value: string;\n isSelected?: boolean;\n onClick?: () => void;\n};\n\nconst ContributorItem = ({value, isSelected = true, onClick}: Props) => {\n const color = getContributorColor(value);\n const styles = useContributorStyles({color});\n\n return (\n <div\n className={classnames(styles.icon, {\n [styles.inactive]: !isSelected,\n [styles.active]: isSelected,\n [styles.clickable]: !!onClick\n })}\n onClick={onClick}\n />\n );\n};\n\nexport default ContributorItem;\n","import React from 'react';\nimport classnames from 'classnames';\nimport {without} from 'ramda';\nimport ContributorItem from './ContributorItem';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n values: string[];\n selectedValues: string[];\n onSelectValues: (values: string[]) => void;\n entityUri: string;\n className?: string;\n};\n\nconst ContributorsPanel = ({values, selectedValues, entityUri, onSelectValues, className}: Props) => {\n const styles = useStyles();\n\n const handleClick = (value: string) => {\n if (selectedValues?.includes(value)) {\n onSelectValues(without([value], selectedValues));\n } else {\n onSelectValues([...(selectedValues || []), value]);\n }\n };\n\n return (\n <div className={classnames(styles.root, className)}>\n <ContributorItem value={entityUri} />\n {values?.length > 0 &&\n values.map((value) => (\n <ContributorItem\n key={value}\n value={value}\n isSelected={selectedValues?.includes(value)}\n onClick={() => handleClick(value)}\n />\n ))}\n </div>\n );\n};\n\nexport default ContributorsPanel;\n","import {useMemo} from 'react';\nimport {isNil, pipe, slice, find, curry, drop} from 'ramda';\nimport {HistoryChange} from '@reltio/mdm-sdk';\nimport {HistoryChangeTypes, HistoryLife, HistoryRowData} from './../types';\n\ntype Props = {\n entityUri: string;\n historyChanges: HistoryChange[];\n selectedUris: string[];\n};\n\nexport const useHistoryTree = ({entityUri, historyChanges, selectedUris}: Props) => {\n return useMemo(() => {\n const historyLanes = {[entityUri]: {index: 0, lifeTime: []}};\n const rows = [{user: '', timestamp: 0, uri: entityUri}] as HistoryRowData[];\n\n const checkChange = curry((involvedUris: string | any[], checkInUris: boolean, change: HistoryChange) => {\n const uri = change.uri || entityUri;\n if (involvedUris) {\n if (Array.isArray(involvedUris)) {\n if (change.type !== HistoryChangeTypes.ENTITY_LOST_MERGE) return null;\n if (involvedUris.includes(uri)) {\n return change;\n } else if (checkInUris && change.uris) {\n return involvedUris.some((involvedUri) => change.uris.includes(involvedUri)) ? change : null;\n }\n } else {\n if (uri === involvedUris || (checkInUris && change.uris?.includes(involvedUris))) return change;\n }\n }\n\n return null;\n });\n\n const findNextChange = (index: number, involvedUris: string | any[], checkInUris: boolean) =>\n pipe(drop(index + 1), find(checkChange(involvedUris, checkInUris)))(historyChanges);\n\n const findPreviousChange = (index: number, uri: string) =>\n pipe(slice(index + 1, Infinity), find(checkChange(uri, false)))(rows);\n\n const checkLaneUri = (uri: string) => {\n if (!historyLanes[uri] && (!selectedUris || selectedUris.includes(uri))) {\n historyLanes[uri] = {\n index: Object.keys(historyLanes).length,\n lifeTime: []\n };\n }\n return historyLanes[uri];\n };\n\n const startNewLife = (lifeTime: HistoryLife[], change: HistoryChange) => {\n const currentLife = lifeTime[lifeTime.length - 1];\n if (\n currentLife &&\n (!currentLife.start ||\n (currentLife.start.type === HistoryChangeTypes.ENTITY_CREATED &&\n change.type === HistoryChangeTypes.ENTITIES_SPLITTED))\n ) {\n currentLife.start = change;\n return;\n }\n lifeTime.push({start: change, end: null});\n };\n\n const updateLife = (lifeTime: HistoryLife[], change: HistoryChange) => {\n let shouldAddNewLife = true;\n if (lifeTime.length) {\n const currentLife = lifeTime[lifeTime.length - 1];\n shouldAddNewLife = !(\n (!currentLife.start || currentLife.start.timestamp < change.timestamp) &&\n (!currentLife.end || currentLife.end.timestamp > change.timestamp)\n );\n }\n if (shouldAddNewLife) {\n lifeTime.push({start: null, end: null});\n }\n };\n\n const endLife = (lifeTime: HistoryLife[], change: HistoryChange) => {\n if (lifeTime.length) {\n const currentLife = lifeTime[lifeTime.length - 1];\n if (!currentLife.start) currentLife.start = change;\n }\n lifeTime.push({start: null, end: change});\n };\n\n const checkLifeTime = (lifeTime: HistoryLife[], change: HistoryChange) => {\n switch (change.type) {\n case HistoryChangeTypes.ENTITY_CREATED:\n startNewLife(lifeTime, change);\n break;\n case HistoryChangeTypes.ENTITIES_MERGED_ON_THE_FLY:\n case HistoryChangeTypes.ENTITY_CHANGED:\n updateLife(lifeTime, change);\n break;\n case HistoryChangeTypes.ENTITY_LOST_MERGE:\n case HistoryChangeTypes.ENTITY_REMOVED:\n endLife(lifeTime, change);\n break;\n case HistoryChangeTypes.ENTITIES_SPLITTED:\n updateLife(lifeTime, change);\n change.uris?.forEach((uri) => {\n const relatedLane = historyLanes[uri];\n if (!relatedLane) return;\n const lifeTimeLength = relatedLane.lifeTime.length;\n lifeTimeLength\n ? startNewLife(relatedLane.lifeTime, change)\n : endLife(relatedLane.lifeTime, change);\n\n rows.push({\n uri,\n user: change.user,\n type: change.type,\n fakeType: lifeTimeLength\n ? HistoryChangeTypes.FAKE_UPDATE\n : HistoryChangeTypes.FAKE_NAVIGATE_PROFILE,\n timestamp: change.timestamp\n });\n });\n break;\n case HistoryChangeTypes.ENTITIES_MERGED:\n case HistoryChangeTypes.ENTITIES_MERGED_MANUALLY:\n updateLife(lifeTime, change);\n change.uris?.forEach((uri) => {\n const relatedLane = historyLanes[uri];\n if (relatedLane) endLife(relatedLane.lifeTime, change);\n });\n break;\n }\n };\n\n const postProcessChanges: HistoryChange[] = [];\n historyChanges?.forEach((change, index) => {\n switch (change.type) {\n case HistoryChangeTypes.ENTITIES_SPLITTED:\n if (!findNextChange(index, change.uri || entityUri, false)) {\n return;\n } else {\n const uri = change.uri;\n const involvedUris = change.uris ? [change.uris, uri] : [uri];\n const lostMergeChange = findNextChange(index, involvedUris, true);\n if (lostMergeChange && (!uri || uri === lostMergeChange.uri)) return;\n }\n break;\n case HistoryChangeTypes.ENTITY_LOST_MERGE:\n case HistoryChangeTypes.RELATIONSHIP_CREATED:\n case HistoryChangeTypes.RELATIONSHIP_REMOVED:\n case HistoryChangeTypes.RELATIONSHIP_CHANGED:\n return;\n }\n\n let addPostProcess = false;\n change.uris?.forEach((uri) => {\n if (!checkLaneUri(uri)) addPostProcess = true;\n });\n\n const contributorLane = checkLaneUri(change.uri || entityUri);\n if (!contributorLane) return;\n const rowChange = {...change};\n checkLifeTime(contributorLane.lifeTime, rowChange);\n if (addPostProcess) postProcessChanges.push(rowChange);\n rows.push(rowChange);\n });\n\n postProcessChanges.forEach((postChange) => {\n postChange.uris.forEach((postUri) => {\n if (historyLanes[postUri]) return;\n historyChanges.forEach(({uri, uris, timestamp, user, type}) => {\n if (uri !== postUri) return;\n uris?.forEach((contributorUri) => {\n const contributorLane = historyLanes[contributorUri];\n if (!contributorLane) return;\n let fakeType = null;\n switch (type) {\n case HistoryChangeTypes.ENTITIES_MERGED:\n case HistoryChangeTypes.ENTITIES_MERGED_MANUALLY:\n fakeType = HistoryChangeTypes.FAKE_FILTERED_INCOMING;\n break;\n case HistoryChangeTypes.ENTITIES_SPLITTED:\n fakeType = HistoryChangeTypes.FAKE_FILTERED_OUTGOING;\n break;\n default:\n return;\n }\n\n const fakeChange = {\n fakeType: fakeType,\n uri: postChange.uri,\n uris: [contributorUri],\n type,\n user,\n timestamp\n };\n\n const extendLife = findClosestLife(contributorLane.lifeTime, postChange.timestamp);\n if (fakeType === HistoryChangeTypes.FAKE_FILTERED_INCOMING) {\n if (!isNil(extendLife.endIndex)) {\n contributorLane.lifeTime[extendLife.endIndex].end = fakeChange;\n }\n } else {\n if (!isNil(extendLife.startIndex)) {\n contributorLane.lifeTime[extendLife.startIndex].start = fakeChange;\n }\n }\n rows.splice(rows.indexOf(postChange), 0, fakeChange);\n });\n });\n });\n });\n\n rows.forEach((row, i) => {\n row.index = i;\n row.uri = row.uri || entityUri;\n });\n\n return {\n historyData: {historyLanes, rows},\n findPreviousChange\n };\n }, [entityUri, historyChanges, selectedUris]);\n};\n\nconst findClosestLife = (lifeTime: HistoryLife[], timestamp: number) =>\n lifeTime.reduce(\n (acc, {start, end}, i) => {\n if (start) {\n const d = timestamp - start.timestamp;\n if (isNil(acc.startDistance) || (Math.abs(acc.startDistance) > Math.abs(d) && d > 0)) {\n acc.startIndex = i;\n acc.startDistance = d;\n }\n }\n if (end) {\n const d = timestamp - end.timestamp;\n if (isNil(acc.endDistance) || (Math.abs(acc.endDistance) > Math.abs(d) && d < 0)) {\n acc.endIndex = i;\n acc.endDistance = d;\n }\n }\n return acc;\n },\n {startIndex: null, endIndex: null, startDistance: null, endDistance: null}\n );\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n flexDirection: 'column',\n overflow: 'hidden',\n position: 'relative',\n height: '100%'\n },\n borderBottom: {\n borderBottom: '1px solid rgba(0, 0, 0, 0.12)'\n }\n});\n","import React, {memo, useEffect, useState} from 'react';\nimport {HistoryWithTotal, HistoryEvent} from '@reltio/mdm-sdk';\nimport HistoryTree from '../HistoryTree/HistoryTree';\nimport ContributorsPanel from '../ContributorsPanel/ContributorsPanel';\nimport {useHistoryTree} from '../hooks/useHistoryTree';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n isLoading: boolean;\n historyWithTotal: HistoryWithTotal;\n contributorsUris: string[];\n entityUri: string;\n historyEvent: HistoryEvent;\n canLoadMore: boolean;\n onLoadMore: () => void;\n};\n\nconst HistoryView = ({\n isLoading,\n historyWithTotal,\n contributorsUris,\n entityUri,\n canLoadMore,\n onLoadMore,\n historyEvent\n}: Props) => {\n const styles = useStyles();\n const [selectedUris, setSelectedUris] = useState<string[]>(null);\n\n useEffect(() => {\n setSelectedUris(contributorsUris);\n }, [contributorsUris]);\n\n const {historyData, findPreviousChange} = useHistoryTree({\n entityUri,\n historyChanges: historyWithTotal?.changes,\n selectedUris\n });\n\n return (\n <div className={styles.root}>\n <ContributorsPanel\n values={contributorsUris}\n selectedValues={selectedUris}\n onSelectValues={setSelectedUris}\n entityUri={entityUri}\n className={styles.borderBottom}\n />\n <HistoryTree\n historyData={historyData}\n isLoading={isLoading}\n onLoadMore={onLoadMore}\n canLoadMore={canLoadMore}\n entityUri={entityUri}\n historyEvent={historyEvent}\n findPreviousChange={findPreviousChange}\n />\n </div>\n );\n};\n\nexport default memo(HistoryView);\n","import {\n pipe,\n defaultTo,\n reject,\n map,\n join,\n cond,\n equals,\n append,\n concat,\n chain,\n evolve,\n values,\n over,\n lensProp\n} from 'ramda';\nimport {\n isEmptyValue,\n escapeQueryValue,\n wrapInBrackets,\n multiValueFilter,\n buildUserFilterClause,\n buildDateRangeFilterClause\n} from '@reltio/mdm-sdk';\nimport {HistoryActivityType} from '../types/HistoryFilter';\nimport {ActivityTypes} from '../../activityLog/types/ActivityTypes';\nimport {AttributeOption} from '../../../types';\n\nconst convertHistoryTypes = chain(\n cond([\n [\n equals(HistoryActivityType.MERGE),\n () => [\n ActivityTypes.ENTITIES_MERGED,\n ActivityTypes.ENTITIES_MERGED_MANUALLY,\n ActivityTypes.ENTITIES_MERGED_ON_THE_FLY\n ]\n ],\n [equals(HistoryActivityType.UNMERGE), () => [ActivityTypes.ENTITIES_SPLITTED]],\n [equals(HistoryActivityType.UPDATE), () => [ActivityTypes.ENTITY_CHANGED]]\n ])\n);\n\nconst buildActivityFilterClause = pipe(\n defaultTo([]),\n convertHistoryTypes,\n concat([ActivityTypes.ENTITY_CREATED, ActivityTypes.ENTITY_REMOVED, ActivityTypes.ENTITY_LOST_MERGE]),\n multiValueFilter((value: string) => `equals(type, '${value}')`)\n);\n\nconst buildAttributeFilterClause = (attribute: AttributeOption) => `changes(${escapeQueryValue(attribute.value)})`;\n\nexport const buildHistoryFilterString = pipe(\n defaultTo({}),\n reject(isEmptyValue),\n evolve({\n users: multiValueFilter(buildUserFilterClause),\n attributes: multiValueFilter(buildAttributeFilterClause),\n dateRange: buildDateRangeFilterClause\n }),\n over(lensProp('activities'), buildActivityFilterClause),\n values,\n reject(isEmptyValue),\n append(\"not equals(user, 'collaboration-service')\"),\n map(wrapInBrackets),\n join(' and ')\n);\n","import {useState, useMemo, useCallback, useEffect} from 'react';\nimport {Entity, getHistoricUris, getHistoryWithTotal, HistoryWithTotal, isEmptyValue} from '@reltio/mdm-sdk';\nimport {difference, either, evolve, isEmpty, isNil, pipe, reject} from 'ramda';\nimport {HistoryActivityType, HistoryFilter} from '../types';\nimport {buildHistoryFilterString} from '../utils/filters';\nimport {useSafePromise} from '../../../hooks';\n\ntype Props = {\n entity: Entity;\n enabled: boolean;\n};\n\nconst MAX_HISTORY_ROWS = 32;\n\nexport const DEFAULT_HISTORY_FILTER: HistoryFilter = {\n activities: [HistoryActivityType.MERGE, HistoryActivityType.UNMERGE, HistoryActivityType.UPDATE]\n};\n\nexport const isDefaultFilter = (filter: HistoryFilter): boolean => {\n return pipe(\n evolve({activities: difference(DEFAULT_HISTORY_FILTER.activities)}),\n reject(either(isNil, isEmpty)),\n isEmpty\n )(filter || {});\n};\n\nexport const useHistory = ({entity, enabled}: Props) => {\n const [historyFilter, setHistoryFilter] = useState(DEFAULT_HISTORY_FILTER);\n const [historyPage, setHistoryPage] = useState(0);\n\n const historyFilterString = useMemo(() => buildHistoryFilterString(historyFilter), [historyFilter]);\n\n const [historicUris, setHistoricUris] = useState<string[]>(null);\n const [historyWithTotal, setHistoryWithTotal] = useState<HistoryWithTotal>(null);\n const [isLoading, setIsLoading] = useState(false);\n const safePromise = useSafePromise();\n const entityUri = entity?.uri;\n const options = {max: MAX_HISTORY_ROWS, order: 'desc'};\n const showAll = isEmptyValue(historyFilter?.attributes) || undefined;\n\n const loadHistoryWithTotal = () => {\n setIsLoading(true);\n return safePromise(\n getHistoryWithTotal({\n entityUri,\n historicUris,\n filter: historyFilterString,\n showAll,\n ...options\n })\n )\n .then(setHistoryWithTotal)\n .catch((e) => {\n console.warn('Failed to load history data', e);\n setHistoryWithTotal(null);\n })\n .finally(() => {\n setIsLoading(false);\n });\n };\n\n useEffect(() => {\n if (entityUri && enabled) {\n loadHistoryWithTotal();\n }\n }, [historyFilterString, showAll, historicUris]);\n\n const loadHistoricUris = () => {\n setIsLoading(true);\n return safePromise(getHistoricUris({entityUri}))\n .then((historicUris) => {\n setHistoricUris(historicUris);\n })\n .catch((e) => {\n console.warn('Failed to load history data', e);\n setHistoricUris(null);\n })\n .finally(() => {\n setIsLoading(false);\n });\n };\n\n useEffect(() => {\n if (entityUri && enabled) {\n loadHistoricUris();\n setHistoryPage(0);\n }\n }, [entityUri, entity?.updatedTime, enabled]);\n\n const loadMore = useCallback(\n (offset: number) => {\n if (entityUri && historicUris && enabled) {\n setIsLoading(true);\n safePromise(\n getHistoryWithTotal({\n entityUri,\n historicUris,\n filter: historyFilterString,\n showAll,\n offset,\n ...options\n })\n )\n .then((results) => {\n setHistoryWithTotal((prev) => ({...prev, changes: [...prev?.changes, ...results.changes]}));\n })\n .catch((e) => {\n console.warn('Failed to load history data', e);\n })\n .finally(() => {\n setIsLoading(false);\n });\n }\n },\n [historicUris, historyFilterString, enabled]\n );\n\n const canLoadMore = useMemo(\n () => (historyPage + 1) * MAX_HISTORY_ROWS < historyWithTotal?.total,\n [historyWithTotal, historyPage]\n );\n\n const onApplyFilter = useCallback((filter: HistoryFilter) => {\n setHistoryPage(0);\n setHistoryFilter(filter);\n }, []);\n\n const onClearFilter = useCallback(() => {\n onApplyFilter({...DEFAULT_HISTORY_FILTER});\n }, []);\n\n const onLoadMore = useCallback(() => {\n if (!canLoadMore) return;\n loadMore((historyPage + 1) * MAX_HISTORY_ROWS);\n setHistoryPage(historyPage + 1);\n }, [loadMore, historyPage, canLoadMore]);\n\n return {\n isLoading,\n canLoadMore,\n onLoadMore,\n onApplyFilter,\n onClearFilter,\n historicUris,\n historyWithTotal,\n historyFilter\n };\n};\n","import {useEffect, useState} from 'react';\nimport {isTempUri, isDataTenantEntity, Entity} from '@reltio/mdm-sdk';\nimport {usePerspectivesSettings} from '../../../contexts';\n\ntype Props = {\n entity: Entity;\n perspectiveId: string;\n historyButtonId: number;\n};\n\nexport const useHistoryEnabled = ({perspectiveId, entity, historyButtonId}: Props) => {\n const {perspectiveSettings} = usePerspectivesSettings(perspectiveId);\n const {active} = perspectiveSettings || {};\n\n const isHistoryTabActive = active === historyButtonId;\n const [wasHistoryTabActive, setWasHistoryTabActive] = useState(false);\n const entityUri = entity?.uri;\n useEffect(() => {\n if (!isHistoryTabActive) {\n setWasHistoryTabActive(false);\n }\n }, [entityUri]);\n\n useEffect(() => {\n if (isHistoryTabActive) {\n setWasHistoryTabActive(true);\n }\n }, [isHistoryTabActive]);\n\n const isProfilePersisted = entityUri && !isTempUri(entityUri) && !isDataTenantEntity(entity);\n const isHistoryEnabled = wasHistoryTabActive && isProfilePersisted;\n\n return {isHistoryEnabled, isProfilePersisted};\n};\n","import {useState, useEffect} from 'react';\nimport {useSelector, useDispatch} from 'react-redux';\nimport mdmModule, {profile} from '@reltio/mdm-module';\nimport {Entity, getEntityTimeSlice, HistoryEvent} from '@reltio/mdm-sdk';\nimport {useSafePromise} from '../../../hooks';\n\ntype Props = {\n entity: Entity;\n historyEvent: HistoryEvent;\n};\n\nexport const useHistorySlice = ({entity, historyEvent}: Props) => {\n const [isLoading, setIsLoading] = useState(false);\n const historySlice = useSelector(mdmModule.selectors.getHistorySlice);\n const dispatch = useDispatch();\n const safePromise = useSafePromise();\n\n const {aStamp, bStamp, overrideUri} = historyEvent || {};\n const entityUri = overrideUri || entity?.uri;\n\n useEffect(() => {\n if (historyEvent && entityUri) {\n setIsLoading(true);\n safePromise(\n Promise.all([\n getEntityTimeSlice(entityUri, aStamp),\n bStamp && bStamp !== 1 ? getEntityTimeSlice(entityUri, bStamp) : Promise.resolve(null)\n ])\n )\n .then(([aEntity, bEntity]) => {\n dispatch(profile.history.actions.setHistorySlice({aEntity, bEntity}));\n })\n .catch((e) => {\n console.warn('Failed to load entity slice', e);\n })\n .finally(() => {\n setIsLoading(false);\n });\n }\n }, [aStamp, bStamp, entityUri]);\n\n return {isLoading, historySlice};\n};\n","import {ActivityTypes} from '../../activityLog/types/ActivityTypes';\n\nenum FakeTypes {\n FAKE_NAVIGATE_PROFILE = 'FAKE_NAVIGATE_PROFILE',\n FAKE_FILTERED_INCOMING = 'FAKE_FILTERED_INCOMING',\n FAKE_FILTERED_OUTGOING = 'FAKE_FILTERED_OUTGOING',\n FAKE_UPDATE = 'FAKE_UPDATE'\n}\n\nexport const HistoryChangeTypes = {...ActivityTypes, ...FakeTypes};\nexport type HistoryChangeTypes = typeof HistoryChangeTypes;\n","import {DateRangeFilter} from '@reltio/mdm-sdk';\nimport {AttributeOption} from '../../../types';\n\nexport enum HistoryActivityType {\n UPDATE = 'UPDATE',\n MERGE = 'MERGE',\n UNMERGE = 'UNMERGE'\n}\n\nexport type HistoryFilter = {\n dateRange?: DateRangeFilter;\n users?: string[];\n activities?: HistoryActivityType[];\n attributes?: AttributeOption[];\n};\n","import React, {useCallback, useState} from 'react';\nimport i18n from 'ui-i18n';\nimport {pipe} from 'ramda';\nimport Portal from '@mui/material/Portal';\nimport Button from '@mui/material/Button';\nimport Snackbar, {SnackbarOrigin} from '@mui/material/Snackbar';\nimport {noop} from '../core';\n\ntype SnackbarOptions = {\n anchorOrigin?: SnackbarOrigin;\n showDismiss?: boolean;\n dismissTitle?: string;\n autoHideDuration?: number;\n onDismissClick?: () => void;\n};\n\nconst FIVE_MINUTES = 5 * 60 * 1000;\nexport const useSnackbar = ({\n anchorOrigin = {vertical: 'bottom', horizontal: 'center'},\n showDismiss,\n dismissTitle = i18n.text('Dismiss'),\n autoHideDuration = FIVE_MINUTES,\n onDismissClick = noop\n}: SnackbarOptions = {}) => {\n const [isOpenSnackbar, setIsOpenSnackbar] = useState(false);\n const [snackbarMessage, setSnackbarMessage] = useState('');\n\n const closeSnackbar = useCallback(() => {\n setIsOpenSnackbar(false);\n setSnackbarMessage('');\n }, []);\n\n const handleSnackbarClose = useCallback(\n (_, reason?: string) => {\n if (reason === 'clickaway') {\n return;\n }\n closeSnackbar();\n },\n [closeSnackbar]\n );\n\n const showSnackbarMessage = useCallback((message) => {\n setIsOpenSnackbar(true);\n setSnackbarMessage(message);\n }, []);\n\n const SnackbarRenderer = useCallback(() => {\n return (\n <Portal container={document.body}>\n <Snackbar\n open={isOpenSnackbar}\n anchorOrigin={anchorOrigin}\n autoHideDuration={autoHideDuration}\n onClose={handleSnackbarClose}\n message={snackbarMessage}\n style={{maxWidth: 500}}\n action={\n showDismiss ? (\n <Button color=\"primary\" onClick={pipe(closeSnackbar, onDismissClick)}>\n {dismissTitle}\n </Button>\n ) : undefined\n }\n />\n </Portal>\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isOpenSnackbar, closeSnackbar, snackbarMessage]);\n\n return {SnackbarRenderer, showSnackbarMessage};\n};\n"],"names":["customStyles","input","currentStyles","fontSize","menuPortal","zIndex","useStyles","makeStyles","root","flex","title","paddingBottom","paddingLeft","dropDownInput","width","justifyContent","backgroundColor","borderTop","option","height","noOptionsMessage","entityType","selectedAttributes","className","onChange","disableUnderline","menuPlacement","metadata","useSelector","mdmModule","styles","prepareItems","useCallback","data","level","prevLabel","reduce","acc","item","hidden","chipLabel","label","push","value","uri","attrType","subAttributes","getAttributeTypeSubAttributes","concat","options","useMemo","attributes","classnames","Typography","variant","i18n","MultiSelect","TextFieldProps","InputProps","classes","components","DropdownIndicator","DropdownIndicatorWithIconButton","MultiValue","props","Option","isFocused","isSelected","innerProps","AttributeListItem","checked","labelInText","pipe","defaultTo","menuPortalTarget","document","body","menuShouldBlockScroll","captureMenuScroll","display","paddingRight","inputNumber","minWidth","marginRight","inputUnit","periods","interval","unit","onFocus","onNumberChange","getValue","parseInt","newValue","onUnitChange","newUnit","TextField","type","inputProps","min","SimpleDropDownSelector","placeholder","capitalize","getIntervalUnitLabel","map","withMuiSkin","CreatableSelect","innerRef","children","selectProps","MenuItem","classNames","ref","selected","component","Checkbox","color","ExpandedValueTooltip","propTypes","PropTypes","id","key","onClick","onMouseMove","onMouseOver","tabIndex","isRequired","current","theme","top","left","undefined","fontWeight","clearIndicator","padding","spacing","margin","dropdownIndicator","creatable","getOptions","loadingIndicator","componentsProp","classesProp","stylesProp","onChangeProp","onInputChange","onInputChangeProp","reactSelectProps","SelectComponent","AsyncSelect","Select","inputValue","setInputValue","useState","multiSelectClasses","omit","inputId","multiSelectComponents","mergeClasses","indicatorSeparator","base","loadingMessage","fontFamily","labelProps","InputLabelProps","htmlFor","shrink","length","isMulti","actionMeta","action","closeMenuOnSelect","hideSelectedOptions","loadOptions","defaultProps","cacheOptions","defaultOptions","ClearIndicator","Control","DownChevron","CrossIcon","Group","GroupHeading","IndicatorsContainer","IndicatorSeparator","Input","LoadingIndicator","Menu","MenuList","MenuPortal","LoadingMessage","NoOptionsMessage","MultiValueContainer","MultiValueLabel","MultiValueRemove","Placeholder","SelectContainer","SingleValue","ValueContainer","control","valueContainer","multiValue","singleValue","menu","container","group","groupHeading","indicatorsContainer","menuList","multiValueLabel","multiValueRemove","getOptionValue","isSearchable","inputRef","viewBox","fill","xmlns","cx","cy","r","fillOpacity","style","maskType","maskUnits","x","y","mask","fillRule","clipRule","d","opacity","x1","y1","x2","y2","gradientUnits","stopColor","stopOpacity","offset","flexWrap","flexDirection","alignItems","overflow","minHeight","boxSizing","logo","textBox","maxWidth","marginTop","text","palette","primary","lineHeight","textAlign","secondaryText","letterSpacing","paddingTop","IconRenderer","AttributesListIcon","selectedUsers","valueToOption","prepareValues","values","tenant","servicesPath","cachedRequest","useRef","pluck","getAllUsersForTenant","then","users","filter","username","utils","filterUsers","ActivityTypes","getItemDataType","path","getActivityType","activity","items","firstItem","removeIgnoredItems","isImplementedItem","isValidActivityType","includes","filteredItems","console","error","reject","itemsTotal","splitActivityByType","propOr","groupBy","ifElse","stringifyDeltaValue","deltaValue","attributeTypeUri","attributePresentations","attributeType","findAttributeTypeByUri","dataTypeDefinition","getAttrDataTypeDefinition","formatValue","formatDataTypeValue","isNil","Object","entries","flatMap","attributeTypeName","deltaValues","makeAttrTypeUri","join","getActivityLabel","transition","inputRoot","dateOptionLabel","paper","localeFormat","moment","longDateFormat","noop","open","setOpen","handleToggle","fullWidth","DataTypes","endAdornment","menuIsOpen","readOnly","Popover","anchorEl","onClose","anchorOrigin","vertical","horizontal","transformOrigin","elevation","DateRangePicker","onApply","dateRangeTypeOptions","DateRangeTypes","getDateRangeTypeLabel","intervalContainer","typeInput","emptyDates","emptyInterval","isIntervalType","isBetweenType","initDatesInterval","period","initInterval","datesInterval","setDatesInterval","setInterval","selectedType","getCurrentPeriodByType","changePeriod","useDidUpdateEffect","DateIntervalSelector","CustomDateRangeEditor","historyActivityOptions","HistoryActivityType","overflowY","selectedHistoryActivityTypes","popup","filterContainer","maxHeight","borderColor","filterItem","marginBottom","clearButton","divider","onApplyFilter","buttonRef","isOpen","setIsOpen","currentValue","setCurrentValue","activities","dateRange","buttonColor","isDefaultFilter","useEffect","handlePropChange","curry","propName","filterValue","togglePopup","applyButtonHandler","isDateRangeValid","dissoc","clearAllButtonHandler","DEFAULT_HISTORY_FILTER","SmallIconButton","icon","FilterListIcon","size","DialogTitle","DialogContent","dividers","Divider","light","UserSelector","AttributeSelector","DialogActions","Button","menuItem","menuText","marginLeft","checkIcon","position","MenuItemRenderer","forwardRef","onMenuClose","e","Check","displayName","mode","dispatch","useDispatch","handleModeChange","selectedMode","profile","menuItems","HistoryMode","DropDownMenuButton","buttonComponent","buttonProps","MoreVertIcon","menuId","count","filterButton","total","orientation","flexItem","Spacer","historyRow","cursor","background","content","rowHeader","badge","pointerEvents","textOverflow","whiteSpace","date","flexShrink","user","change","isCurrent","matchGroups","timestamp","getContributorColor","bold","isFakeHistoryType","HistoryChangeTypes","toX","toY","isDashed","lineData","isUp","isLeft","curveCenterY","getHistoryLinkCurve","stroke","strokeWidth","strokeDasharray","isCollapsed","showCollapseIcon","showLine","otherProps","radius","BUMP_RADIUS","LINE_MARGIN","HistoryCircleWithTooltip","withTooltip","HistoryCircle","memo","graphData","onHistoryCircleMouseOver","historyLanes","rows","rowPositions","links","rowLines","circles","i","uris","fakeType","index","hasFakeType","circleUri","some","tooltipTitle","tooltipPlacement","ROW_HEIGHT","isUpRight","forEach","contributorUri","contributorLane","rowHeight","keys","lifeTime","start","end","startIndex","endIndex","startY","endY","unshift","historyTree","gridTemplateColumns","graph","overflowX","history","buttonContainer","gridColumnStart","gridColumnEnd","shadow","boxShadow","historyData","isLoading","canLoadMore","onLoadMore","entityUri","historyEvent","findPreviousChange","isEditableMode","mdm","setGraphData","isScrollable","setIsScrollable","selectedIndex","setSelectedIndex","isCurrentEventChange","overrideUri","aStamp","selectedChangeByIndex","currentEventChangeIndex","findIndex","graphRef","rowsRef","node","childNodes","clientHeight","handleGraphScroll","scrollWidth","clientWidth","scrollLeft","LinearLoadIndicator","onScroll","time","select","getEntity","crosswalks","uniqBy","prop","cw","crosswalkType","getCrosswalkType","identity","prevGraphData","row","handleWidth","onResize","window","confirm","Mode","aChange","bChange","bStamp","handleHistoryRowClick","useContributorStyles","borderWidth","borderStyle","borderRadius","active","inactive","clickable","selectedValues","onSelectValues","without","handleClick","findClosestLife","startDistance","Math","abs","endDistance","borderBottom","historyWithTotal","contributorsUris","selectedUris","setSelectedUris","historyChanges","checkChange","involvedUris","checkInUris","Array","isArray","involvedUri","findNextChange","drop","find","checkLaneUri","startNewLife","currentLife","updateLife","shouldAddNewLife","endLife","postProcessChanges","lostMergeChange","addPostProcess","rowChange","relatedLane","lifeTimeLength","checkLifeTime","postChange","postUri","fakeChange","extendLife","splice","indexOf","slice","Infinity","useHistoryTree","changes","convertHistoryTypes","chain","cond","equals","buildActivityFilterClause","multiValueFilter","buildHistoryFilterString","isEmptyValue","evolve","buildUserFilterClause","attribute","escapeQueryValue","buildDateRangeFilterClause","over","lensProp","append","wrapInBrackets","difference","either","isEmpty","useHistory","entity","enabled","historyFilter","setHistoryFilter","historyPage","setHistoryPage","historyFilterString","historicUris","setHistoricUris","setHistoryWithTotal","setIsLoading","safePromise","useSafePromise","max","order","showAll","getHistoryWithTotal","catch","warn","finally","getHistoricUris","updatedTime","loadMore","results","prev","onClearFilter","useHistoryEnabled","perspectiveId","historyButtonId","perspectiveSettings","usePerspectivesSettings","isHistoryTabActive","wasHistoryTabActive","setWasHistoryTabActive","isProfilePersisted","isTempUri","isDataTenantEntity","isHistoryEnabled","useHistorySlice","historySlice","Promise","all","getEntityTimeSlice","resolve","aEntity","bEntity","FakeTypes","FIVE_MINUTES","useSnackbar","showDismiss","dismissTitle","autoHideDuration","onDismissClick","isOpenSnackbar","setIsOpenSnackbar","snackbarMessage","setSnackbarMessage","closeSnackbar","handleSnackbarClose","_","reason","showSnackbarMessage","message","SnackbarRenderer"],"sourceRoot":""}