@reltio/remotes 1.4.1546 → 1.4.1548
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.
- package/122.js +2 -0
- package/122.js.map +1 -0
- package/1268.js +1 -1
- package/1852.js +2 -0
- package/1852.js.map +1 -0
- package/2125.js +1 -1
- package/2125.js.map +1 -1
- package/3346.js +2 -0
- package/3346.js.map +1 -0
- package/3468.js +2 -0
- package/3468.js.map +1 -0
- package/{574.css → 3515.css} +1 -1
- package/3515.css.map +1 -0
- package/{574.js → 3515.js} +2 -2
- package/3515.js.map +1 -0
- package/3540.js +1 -1
- package/3540.js.map +1 -1
- package/3726.js +2 -0
- package/3726.js.map +1 -0
- package/4120.js +1 -1
- package/4120.js.map +1 -1
- package/4183.js +1 -1
- package/4183.js.map +1 -1
- package/4469.js +1 -1
- package/4469.js.map +1 -1
- package/4571.js +1 -1
- package/4701.js +2 -0
- package/4701.js.map +1 -0
- package/705.js +2 -0
- package/705.js.map +1 -0
- package/7594.js +2 -0
- package/7594.js.map +1 -0
- package/769.js +1 -1
- package/769.js.map +1 -1
- package/8061.js +2 -0
- package/8061.js.map +1 -0
- package/8340.js +1 -1
- package/8340.js.map +1 -1
- package/8684.js +1 -1
- package/package.json +1 -1
- package/remoteEntry.js +1 -1
- package/remoteEntry.js.map +1 -1
- package/1308.js +0 -2
- package/1308.js.map +0 -1
- package/2663.js +0 -2
- package/2663.js.map +0 -1
- package/316.js +0 -2
- package/316.js.map +0 -1
- package/385.js +0 -2
- package/385.js.map +0 -1
- package/566.js +0 -2
- package/566.js.map +0 -1
- package/574.css.map +0 -1
- package/574.js.map +0 -1
- package/6233.js +0 -2
- package/6233.js.map +0 -1
- package/6578.js +0 -2
- package/6578.js.map +0 -1
- package/7198.js +0 -2
- package/7198.js.map +0 -1
- package/8051.js +0 -2
- package/8051.js.map +0 -1
- package/8594.js +0 -2
- package/8594.js.map +0 -1
package/3468.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"3468.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 '@material-ui/core/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 as Typography} from '@material-ui/core';\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)}>\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 />\n </div>\n );\n};\n\nexport default AttributeSelector;\n","import {makeStyles} from '@material-ui/core/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 capitalize from '@material-ui/core/utils/capitalize';\nimport {TextField as TextField} from '@material-ui/core';\nimport SimpleDropDownSelector from '../SimpleDropDownSelector/SimpleDropDownSelector';\nimport {getValue} from '../../core/utils';\n\nimport {useStyles} from './styles';\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 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 as MenuItem} from '@material-ui/core';\nimport {Checkbox as Checkbox} from '@material-ui/core';\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 '@material-ui/core/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 @material-ui/core/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 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 '@material-ui/core/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 as Typography} from '@material-ui/core';\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 '@material-ui/core/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 as Typography} from '@material-ui/core';\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)}>\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 />\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 '@material-ui/core/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';\n\nimport {TextField as TextField} from '@material-ui/core';\nimport {Menu as Menu} from '@material-ui/core';\nimport DropdownIndicatorWithIconButton from '../../commonReactSelectComponents/DropdownIndicatorWithIconButton';\nimport DateRangePicker from '../../DateRangePicker/DateRangePicker';\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 <Menu\n variant=\"menu\"\n open={open}\n autoFocus={false}\n classes={{paper: styles.paper}}\n anchorEl={inputRef.current}\n onClose={onCancel}\n anchorOrigin={{\n vertical: 'bottom',\n horizontal: 'left'\n }}\n transformOrigin={{\n vertical: 'top',\n horizontal: 'left'\n }}\n elevation={2}\n getContentAnchorEl={null}\n MenuListProps={{\n autoFocusItem: open,\n style: {width: '100%'}\n }}\n >\n <DateRangePicker\n values={values}\n onCancel={onCancel}\n onApply={onApply}\n type={DataTypes.TYPE_ACTIVENESS_DATE}\n />\n </Menu>\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 '@material-ui/core/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 as Typography} from '@material-ui/core';\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)}>\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 '@material-ui/core/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 as Typography} from '@material-ui/core';\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};\n\nconst HistoryActivitySelector = ({selectedHistoryActivityTypes, onChange, className}: 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)}>\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={{classes: {root: styles.dropDownInput}}}\n components={{\n DropdownIndicator: DropdownIndicatorWithIconButton\n }}\n styles={customStyles}\n classes={styles}\n menuPlacement=\"bottom\"\n menuPortalTarget={document.body}\n />\n </div>\n );\n};\n\nexport default HistoryActivitySelector;\n","import {makeStyles} from '@material-ui/core/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 padding: 20,\n height: 410,\n display: 'flex',\n flexDirection: 'column'\n },\n filterContainerScrollable: {\n overflowY: 'auto'\n },\n filterItem: {\n marginTop: 15\n },\n filterControls: {\n display: 'flex',\n padding: '10px 12px',\n borderTop: 'solid 1px rgba(0, 0, 0, 0.12)'\n },\n clearButton: {\n marginRight: 'auto'\n },\n input: {\n height: '100%',\n paddingLeft: '12px',\n paddingRight: '8px'\n }\n});\n","import React, {useCallback, useEffect, useRef, useState} from 'react';\nimport i18n from 'ui-i18n';\nimport {curry, dissoc} from 'ramda';\nimport FilterListIcon from '@material-ui/icons/FilterList';\nimport {Button as Button} from '@material-ui/core';\nimport {Popover as Popover} from '@material-ui/core';\nimport {Typography as Typography} from '@material-ui/core';\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';\n\nimport {DEFAULT_HISTORY_FILTER, isDefaultFilter} from '../hooks/useHistory';\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 <div className={styles.filterContainer}>\n <Typography variant=\"h6\">{i18n.text('Filter')}</Typography>\n <div className={styles.filterContainerScrollable}>\n <DateRangeSelector\n value={dateRange}\n onChange={handlePropChange('dateRange')}\n className={styles.filterItem}\n />\n <UserSelector\n selectedUsers={users}\n onChange={handlePropChange('users')}\n className={styles.filterItem}\n />\n <HistoryActivitySelector\n selectedHistoryActivityTypes={activities}\n onChange={handlePropChange('activities')}\n className={styles.filterItem}\n />\n <AttributeSelector\n selectedAttributes={attributes}\n entityType={entityType}\n onChange={handlePropChange('attributes')}\n className={styles.filterItem}\n title={i18n.text('Attribute updated')}\n />\n </div>\n </div>\n <div className={styles.filterControls}>\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 </div>\n </Popover>\n </>\n );\n};\n\nexport default HistoryFilterButton;\n","import {makeStyles} from '@material-ui/core/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 as MenuItem} from '@material-ui/core';\nimport {Typography as Typography} from '@material-ui/core';\nimport CheckIcon from '@material-ui/icons/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 '@material-ui/icons/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 '@material-ui/core/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 backgroundColor: '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 as Divider} from '@material-ui/core';\nimport {Typography as Typography} from '@material-ui/core';\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 '@material-ui/core/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 as Typography} from '@material-ui/core';\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 '@material-ui/core/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 as Button} from '@material-ui/core';\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 '@material-ui/core/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 '@material-ui/core/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(() => (historyPage + 1) * MAX_HISTORY_ROWS < historyWithTotal?.total, [\n historyWithTotal,\n 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 {Portal as Portal} from '@material-ui/core';\nimport {Button as Button} from '@material-ui/core';\nimport Snackbar, {SnackbarOrigin} from '@material-ui/core/Snackbar';\n\ntype SnackbarOptions = {\n anchorOrigin?: SnackbarOrigin;\n showDismiss?: boolean;\n};\nconst FIVE_MINUTES = 5 * 60 * 1000;\nexport const useSnackbar = (options: SnackbarOptions = {}) => {\n const {anchorOrigin, showDismiss} = options;\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 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={FIVE_MINUTES}\n onClose={closeSnackbar}\n message={snackbarMessage}\n action={\n showDismiss ? (\n <Button color=\"primary\" onClick={closeSnackbar}>\n {i18n.text('Dismiss')}\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","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","onCancel","fullWidth","DataTypes","endAdornment","menuIsOpen","readOnly","autoFocus","anchorEl","onClose","anchorOrigin","vertical","horizontal","transformOrigin","elevation","getContentAnchorEl","MenuListProps","autoFocusItem","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","filterContainerScrollable","filterItem","filterControls","clearButton","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","Popover","UserSelector","AttributeSelector","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","divider","count","filterButton","total","Divider","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","borderColor","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","isOpenSnackbar","setIsOpenSnackbar","snackbarMessage","setSnackbarMessage","closeSnackbar","showSnackbarMessage","message","SnackbarRenderer","Portal","autoHideDuration"],"sourceRoot":""}
|
package/{574.css → 3515.css}
RENAMED
package/3515.css.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"3515.css","mappings":"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","sources":["webpack://@reltio/remotes/../../node_modules/@react-sigma/core/lib/react-sigma.min.css","webpack://@reltio/remotes/../hierarchy-tree/src/HierarchyView/Tree/theme/node-content.css","webpack://@reltio/remotes/../hierarchy-tree/src/HierarchyView/Tree/theme/tree-node.css"],"sourcesContent":[":root{--sigma-background-color:#fff;--sigma-controls-background-color:#fff;--sigma-controls-background-color-hover:rgba(0,0,0,0.2);--sigma-controls-border-color:rgba(0,0,0,0.2);--sigma-controls-color:#000;--sigma-controls-zindex:100;--sigma-controls-margin:5px;--sigma-controls-size:30px;}div.react-sigma{height:100%;width:100%;position:relative;background:var(--sigma-background-color);}div.sigma-container{height:100%;width:100%;}.react-sigma-controls{position:absolute;z-index:var(--sigma-controls-zindex);border:2px solid var(--sigma-controls-border-color);border-radius:4px;color:var(--sigma-controls-color);background-color:var(--sigma-controls-background-color);}.react-sigma-controls.bottom-right{bottom:var(--sigma-controls-margin);right:var(--sigma-controls-margin);}.react-sigma-controls.bottom-left{bottom:var(--sigma-controls-margin);left:var(--sigma-controls-margin);}.react-sigma-controls.top-right{top:var(--sigma-controls-margin);right:var(--sigma-controls-margin);}.react-sigma-controls.top-left{top:var(--sigma-controls-margin);left:var(--sigma-controls-margin);}.react-sigma-controls:first-child{border-top-left-radius:2px;border-top-right-radius:2px;}.react-sigma-controls:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px;}.react-sigma-control{width:var(--sigma-controls-size);height:var(--sigma-controls-size);line-height:var(--sigma-controls-size);background-color:var(--sigma-controls-background-color);border-bottom:1px solid var(--sigma-controls-border-color);}.react-sigma-control:last-child{border-bottom:none;}.react-sigma-control > *{box-sizing:border-box;}.react-sigma-control > button{display:block;border:none;margin:0;padding:0;width:var(--sigma-controls-size);height:var(--sigma-controls-size);line-height:var(--sigma-controls-size);background-position:center;background-size:50%;background-repeat:no-repeat;background-color:var(--sigma-controls-background-color);clip:rect(0,0,0,0);}.react-sigma-control > button:hover{background-color:var(--sigma-controls-background-color-hover);}.react-sigma-search{background-color:var(--sigma-controls-background-color);}.react-sigma-search label{visibility:hidden;}.react-sigma-search input{color:var(--sigma-controls-color);background-color:var(--sigma-controls-background-color);font-size:1em;width:100%;margin:0;border:none;padding:var(--sigma-controls-margin);box-sizing:border-box;}",".rst__rowWrapper {\n height: 100%;\n box-sizing: border-box;\n}\n\n.rst__rtl.rst__rowWrapper {\n}\n\n.rst__row {\n height: 100%;\n display: flex;\n}\n.rst__row > * {\n box-sizing: border-box;\n}\n\n/**\n * The outline of where the element will go if dropped, displayed while dragging\n */\n.rst__rowLandingPad,\n.rst__rowCancelPad {\n border: none !important;\n box-shadow: none !important;\n outline: none !important;\n}\n.rst__rowLandingPad > *,\n.rst__rowCancelPad > * {\n opacity: 0 !important;\n}\n.rst__rowLandingPad::before,\n.rst__rowCancelPad::before {\n background-color: rgba(0,114,207,0.12);\n border: 1px dashed #2184D4;\n content: '';\n position: absolute;\n top: 0;\n right: 23px;\n bottom: 0;\n left: 18px;\n z-index: 1;\n}\n\n/**\n * Alternate appearance of the landing pad when the dragged location is invalid\n */\n.rst__rowCancelPad::before {\n background-color: rgba(255,102,115,0.12);\n border: 1px dashed #FF6673;\n}\n\n/**\n * Nodes matching the search conditions are highlighted\n */\n.rst__rowSearchMatch {\n outline: solid 3px #0080ff;\n}\n\n/**\n * The node that matches the search conditions and is currently focused\n */\n.rst__rowSearchFocus {\n outline: solid 3px #fc6421;\n}\n\n.rst__rowContents,\n.rst__rowLabel,\n.rst__rowToolbar,\n.rst__moveHandle,\n.rst__toolbarButton {\n display: inline-block;\n vertical-align: middle;\n}\n\n.rst__rowContents {\n position: relative;\n border-left: none;\n padding-left: 4px;\n flex: 1 1 auto;\n width: 0;\n display: flex;\n}\n\n.rst__rtl.rst__rowContents {\n border-right: none;\n border-left: solid #bbb 1px;\n padding: 0 10px 0 5px;\n}\n\n.rst__rowContentsDragDisabled {\n}\n\n.rst__rtl.rst__rowContentsDragDisabled {\n border-right: solid #bbb 1px;\n border-left: solid #bbb 1px;\n}\n\n.rst__rowLabel {\n flex: 1 1 auto;\n width: 0;\n padding-right: 11px;\n}\n.rst__rtl.rst__rowLabel {\n padding-left: 20px;\n padding-right: inherit;\n}\n\n.rst__rowToolbar {\n flex: 0 1 auto;\n display: flex;\n}\n\n.rst__moveHandle {\n display: flex;\n align-items: start;\n padding-top: 3px;\n cursor: move;\n color: rgba(0,0,0,0.54);\n visibility: hidden;\n width: 17px;\n margin-left: -13px;\n}\n.rst__moveHandle svg {\n margin-left: 0px;\n}\n.rst__moveHandle + .rst__rowContents .rst__buttonWrapper{\n margin-left: -4px;\n}\n\n.rst__node:hover .rst__moveHandle {\n visibility: visible;\n}\n.rst_node_hover_disabled:hover .rst__moveHandle{\n visibility: hidden;\n}\n.rst__loadingHandle {\n height: 100%;\n width: 44px;\n background: #d9d9d9\n url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0MiIgaGVpZ2h0PSI0MiI+PGcgc3Ryb2tlPSIjRkZGIiBzdHJva2Utd2lkdGg9IjIuOSIgPjxwYXRoIGQ9Ik0xNCAxNS43aDE0LjQiLz48cGF0aCBkPSJNMTQgMjEuNGgxNC40Ii8+PHBhdGggZD0iTTE0IDI3LjFoMTQuNCIvPjwvZz4KPC9zdmc+')\n no-repeat center;\n border: solid #aaa 1px;\n box-shadow: 0 2px 2px -2px;\n cursor: move;\n border-radius: 1px;\n z-index: 1;\n}\n\n.rst__loadingHandle {\n cursor: default;\n background: #d9d9d9;\n}\n\n@keyframes pointFade {\n 0%,\n 19.999%,\n 100% {\n opacity: 0;\n }\n 20% {\n opacity: 1;\n }\n}\n\n.rst__loadingCircle {\n width: 80%;\n height: 80%;\n margin: 10%;\n position: relative;\n}\n\n.rst__loadingCirclePoint {\n width: 100%;\n height: 100%;\n position: absolute;\n left: 0;\n top: 0;\n}\n\n.rst__rtl.rst__loadingCirclePoint {\n right: 0;\n left: initial;\n}\n\n.rst__loadingCirclePoint::before {\n content: '';\n display: block;\n margin: 0 auto;\n width: 11%;\n height: 30%;\n background-color: #fff;\n border-radius: 30%;\n animation: pointFade 800ms infinite ease-in-out both;\n}\n.rst__loadingCirclePoint:nth-of-type(1) {\n transform: rotate(0deg);\n}\n.rst__loadingCirclePoint:nth-of-type(7) {\n transform: rotate(180deg);\n}\n.rst__loadingCirclePoint:nth-of-type(1)::before,\n.rst__loadingCirclePoint:nth-of-type(7)::before {\n animation-delay: -800ms;\n}\n.rst__loadingCirclePoint:nth-of-type(2) {\n transform: rotate(30deg);\n}\n.rst__loadingCirclePoint:nth-of-type(8) {\n transform: rotate(210deg);\n}\n.rst__loadingCirclePoint:nth-of-type(2)::before,\n.rst__loadingCirclePoint:nth-of-type(8)::before {\n animation-delay: -666ms;\n}\n.rst__loadingCirclePoint:nth-of-type(3) {\n transform: rotate(60deg);\n}\n.rst__loadingCirclePoint:nth-of-type(9) {\n transform: rotate(240deg);\n}\n.rst__loadingCirclePoint:nth-of-type(3)::before,\n.rst__loadingCirclePoint:nth-of-type(9)::before {\n animation-delay: -533ms;\n}\n.rst__loadingCirclePoint:nth-of-type(4) {\n transform: rotate(90deg);\n}\n.rst__loadingCirclePoint:nth-of-type(10) {\n transform: rotate(270deg);\n}\n.rst__loadingCirclePoint:nth-of-type(4)::before,\n.rst__loadingCirclePoint:nth-of-type(10)::before {\n animation-delay: -400ms;\n}\n.rst__loadingCirclePoint:nth-of-type(5) {\n transform: rotate(120deg);\n}\n.rst__loadingCirclePoint:nth-of-type(11) {\n transform: rotate(300deg);\n}\n.rst__loadingCirclePoint:nth-of-type(5)::before,\n.rst__loadingCirclePoint:nth-of-type(11)::before {\n animation-delay: -266ms;\n}\n.rst__loadingCirclePoint:nth-of-type(6) {\n transform: rotate(150deg);\n}\n.rst__loadingCirclePoint:nth-of-type(12) {\n transform: rotate(330deg);\n}\n.rst__loadingCirclePoint:nth-of-type(6)::before,\n.rst__loadingCirclePoint:nth-of-type(12)::before {\n animation-delay: -133ms;\n}\n.rst__loadingCirclePoint:nth-of-type(7) {\n transform: rotate(180deg);\n}\n.rst__loadingCirclePoint:nth-of-type(13) {\n transform: rotate(360deg);\n}\n.rst__loadingCirclePoint:nth-of-type(7)::before,\n.rst__loadingCirclePoint:nth-of-type(13)::before {\n animation-delay: 0ms;\n}\n\n.rst__rowTitle {\n}\n\n.rst__rowTitleWithSubtitle {\n font-size: 85%;\n display: block;\n height: 0.8rem;\n}\n\n.rst__rowSubtitle {\n font-size: 70%;\n line-height: 1;\n}\n\n.rst__buttonWrapper {\n display: flex;\n padding-top: 13px;\n width: 12px;\n cursor: pointer;\n}\n\n.rst__buttonWrapper.rst__noButton {\n cursor: inherit;\n}\n\n.rst__root .rst__buttonWrapper {\n display: none;\n}\n\n.rst__collapseButton,\n.rst__expandButton {\n transition: transform .15s ease;\n width: 0;\n height: 0;\n border-left: 4px solid transparent;\n border-right: 4px solid transparent;\n border-top: 4px solid rgba(0, 0, 0, 0.54);\n}\n\n.rst__collapseButton {\n transform: rotate(0deg);\n}\n\n.rst__expandButton {\n transform: rotate(-90deg);\n}\n\n","/**\n * Extra class applied to VirtualScroll through className prop\n */\n.rst__virtualScrollOverride {\n overflow: auto !important;\n}\n\n.ReactVirtualized__Grid__innerScrollContainer {\n overflow: visible !important;\n max-width: none !important;\n}\n\n.rst__rtl .ReactVirtualized__Grid__innerScrollContainer {\n direction: rtl;\n}\n\n.ReactVirtualized__Grid {\n outline: none;\n}\n\n.rst__node {\n min-width: 100%;\n position: relative;\n text-align: left;\n padding: 0 24px 0 18px;\n box-sizing: border-box;\n white-space: normal;\n}\n.rst__node:hover {\n background-color: rgba(0,0,0,0.06);\n}\n.rst_node_hover_disabled:hover {\n background-color: transparent;\n}\n.rst__node.rst__root .rst__absoluteLineBlock,\n.rst__node.rst__root .rst__lineBlock {\n display: none;\n}\n.rst__node.rst__root .rst__nodeContent {\n width: 100% !important;\n left: 0 !important;\n}\n\n.rst__node.rst__rtl {\n text-align: right;\n}\n\n.rst__nodeContent {\n position: absolute;\n top: 0;\n bottom: 0;\n padding-left: 19px;\n box-sizing: border-box;\n}\n\n/* ==========================================================================\n Scaffold\n Line-overlaid blocks used for showing the tree structure\n ========================================================================== */\n.rst__lineBlock,\n.rst__absoluteLineBlock {\n height: 100%;\n position: relative;\n display: inline-block;\n}\n\n.rst__absoluteLineBlock {\n position: absolute;\n top: 0;\n margin-left: 18px;\n}\n\n.rst__lineHalfHorizontalRight::before,\n.rst__lineFullVertical::after,\n.rst__lineHalfVerticalTop::after,\n.rst__lineHalfVerticalBottom::after {\n position: absolute;\n content: '';\n background-color: rgba(0,122,193,0.3);\n}\n\n/**\n * +-----+\n * | |\n * | +--+\n * | |\n * +-----+\n */\n.rst__lineHalfHorizontalRight::before {\n height: 1px;\n top: 14px;\n right: 19%; /*0*/\n width: 24%; /*50*/\n}\n\n.rst__rtl.rst__lineHalfHorizontalRight::before {\n left: 0;\n right: initial;\n}\n\n/**\n * +--+--+\n * | | |\n * | | |\n * | | |\n * +--+--+\n */\n.rst__lineFullVertical::after,\n.rst__lineHalfVerticalTop::after,\n.rst__lineHalfVerticalBottom::after {\n width: 1px;\n left: 50%;\n top: 0;\n height: 100%;\n}\n\n/**\n * +--+--+\n * | | |\n * | | |\n * | | |\n * +--+--+\n */\n.rst__rtl.rst__lineFullVertical::after,\n.rst__rtl.rst__lineHalfVerticalTop::after,\n.rst__rtl.rst__lineHalfVerticalBottom::after {\n right: 50%;\n left: initial;\n}\n\n/**\n * +-----+\n * | | |\n * | + |\n * | |\n * +-----+\n */\n.rst__lineHalfVerticalTop::after {\n height: 15px;\n}\n\n/**\n * +-----+\n * | |\n * | + |\n * | | |\n * +-----+\n */\n.rst__lineHalfVerticalBottom::after {\n top: auto;\n bottom: 0;\n height: 50%;\n}\n\n/* Highlight line for pointing to dragged row destination\n ========================================================================== */\n/**\n * +--+--+\n * | | |\n * | | |\n * | | |\n * +--+--+\n */\n.rst__highlightLineVertical {\n z-index: 3;\n}\n.rst__highlightLineVertical::before {\n position: absolute;\n content: '';\n background-color: #36c2f6;\n width: 6px;\n margin-left: -3px;\n left: 50%;\n top: 0;\n height: 100%;\n}\n\n.rst__rtl.rst__highlightLineVertical::before {\n margin-left: initial;\n margin-right: -4px;\n left: initial;\n right: 50%;\n}\n\n@keyframes arrow-pulse {\n 0% {\n transform: translate(0, 0);\n opacity: 0;\n }\n 30% {\n transform: translate(0, 300%);\n opacity: 1;\n }\n 70% {\n transform: translate(0, 700%);\n opacity: 1;\n }\n 100% {\n transform: translate(0, 1000%);\n opacity: 0;\n }\n}\n.rst__highlightLineVertical::after {\n content: '';\n position: absolute;\n height: 0;\n margin-left: -4px;\n left: 50%;\n top: 0;\n border-left: 4px solid transparent;\n border-right: 4px solid transparent;\n border-top: 4px solid white;\n animation: arrow-pulse 1s infinite linear both;\n}\n\n.rst__rtl.rst__highlightLineVertical::after {\n margin-left: initial;\n margin-right: -4px;\n right: 50%;\n left: initial;\n}\n\n/**\n * +-----+\n * | |\n * | +--+\n * | | |\n * +--+--+\n */\n.rst__highlightTopLeftCorner::before {\n z-index: 3;\n content: '';\n position: absolute;\n border-top: solid 6px #36c2f6;\n border-left: solid 6px #36c2f6;\n box-sizing: border-box;\n height: calc(50% + 4px);\n top: 50%;\n margin-top: -4px;\n right: 0;\n width: calc(50% + 3px);\n}\n\n.rst__rtl.rst__highlightTopLeftCorner::before {\n border-right: solid 8px #36c2f6;\n border-left: none;\n left: 0;\n right: initial;\n}\n\n/**\n * +--+--+\n * | | |\n * | | |\n * | +->|\n * +-----+\n */\n.rst__highlightBottomLeftCorner {\n z-index: 3;\n}\n.rst__highlightBottomLeftCorner::before {\n content: '';\n position: absolute;\n border-bottom: solid 6px #36c2f6;\n border-left: solid 6px #36c2f6;\n box-sizing: border-box;\n height: calc(100% + 4px);\n top: 0;\n right: 2px;\n width: calc(50% + 1px);\n}\n\n.rst__rtl.rst__highlightBottomLeftCorner::before {\n border-right: solid 8px #36c2f6;\n border-left: none;\n left: 12px;\n right: initial;\n}\n\n.rst__highlightBottomLeftCorner::after {\n content: '';\n position: absolute;\n height: 0;\n right: -7px;\n top: 100%;\n margin-top: -8px;\n border-top: 9px solid transparent;\n border-bottom: 9px solid transparent;\n border-left: 9px solid #36c2f6;\n}\n\n.rst__rtl.rst__highlightBottomLeftCorner::after {\n left: 0;\n right: initial;\n border-right: 12px solid #36c2f6;\n border-left: none;\n}\n\n/**\n * Line for under a node with children\n */\n.rst__lineChildren {\n height: 100%;\n display: inline-block;\n position: absolute;\n}\n.rst__lineChildren::after {\n content: '';\n position: absolute;\n background-color: rgba(0,122,193,0.3);\n width: 1px;\n left: 50%;\n bottom: 0;\n height: calc(100% - 28px);\n}\n\n.rst__rtl.rst__lineChildren::after {\n right: 50%;\n left: initial;\n}\n"],"names":[],"sourceRoot":""}
|