@reltio/remotes 1.4.1553 → 1.4.1555

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/8061.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"8061.js","mappings":"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","sources":["webpack://@reltio/remotes/../../node_modules/@date-io/moment/build/index.esm.js","webpack://@reltio/remotes/../../node_modules/@material-ui/icons/Edit.js","webpack://@reltio/remotes/../../node_modules/@material-ui/icons/EventBusy.js","webpack://@reltio/remotes/../../node_modules/@material-ui/icons/Info.js","webpack://@reltio/remotes/../../node_modules/@material-ui/icons/KeyboardArrowLeft.js","webpack://@reltio/remotes/../../node_modules/@material-ui/icons/KeyboardArrowRight.js","webpack://@reltio/remotes/../../node_modules/@material-ui/icons/Settings.js","webpack://@reltio/remotes/../../node_modules/@material-ui/icons/Visibility.js","webpack://@reltio/remotes/../components/src/icons/Filter.tsx","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTableHeader/FilterButton/styles.js","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTableHeader/FilterButton/FilterButton.js","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTablePagination/styles.js","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTablePagination/BasicTablePagination.js","webpack://@reltio/remotes/../components/src/components/BasicTableView/viewState/basicTableViewState.js","webpack://@reltio/remotes/../components/src/components/BasicView/styles.js","webpack://@reltio/remotes/../components/src/components/BasicView/BasicView.tsx","webpack://@reltio/remotes/../components/src/components/ConfirmationDialog/styles.ts","webpack://@reltio/remotes/../components/src/components/ConfirmationDialog/ConfirmationDialog.tsx","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenuItemRender/styles.ts","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenuItemRender/SettingsMenuItemRender.tsx","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenu.tsx","webpack://@reltio/remotes/../components/src/components/VerticalDivider/VerticalDivider.js","webpack://@reltio/remotes/../components/src/hooks/useActions.ts","webpack://@reltio/remotes/../components/src/hooks/useRelationsLoader.ts","webpack://@reltio/remotes/../relationships/src/hooks/useSavedState.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/helpers/tableHelpers.ts","webpack://@reltio/remotes/../relationships/src/hooks/useRelationshipsTable.ts","webpack://@reltio/remotes/../relationships/src/components/RelationTypeSelector/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationTypeSelector/RelationTypeSelector.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTableHeader/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTableHeader/RelationshipsTableHeader.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/HeadCellRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/EntityProfileRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/AttributesRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/DefaultCellValueRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/helpers.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/RowCellRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/MenuItemRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/RelationshipMenuButton.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/RelationshipsTable.tsx","webpack://@reltio/remotes/../relationships/src/components/LegendTable/helpers.ts","webpack://@reltio/remotes/../relationships/src/components/LegendTable/styles.ts","webpack://@reltio/remotes/../relationships/src/components/LegendTable/LegendTable.tsx","webpack://@reltio/remotes/../relationships/src/components/LegendPanel/styles.ts","webpack://@reltio/remotes/../relationships/src/components/LegendPanel/LegendPanel.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/EntityInfo/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/EntityInfo/EntityInfo.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDirection/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDirection/RelationDirection.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDate/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDate/RelationDate.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationshipBand.tsx","webpack://@reltio/remotes/../relationships/src/services/errors.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipDetails/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipDetails/RelationshipDetails.tsx","webpack://@reltio/remotes/../relationships/src/hooks/useCrosswalksDisplay.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/RelationshipsView.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/helpers/filtersHelpers.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/index.tsx","webpack://@reltio/remotes/./src/relationships.ts"],"sourcesContent":["import defaultMoment from 'moment';\n\nvar MomentUtils = /** @class */ (function () {\n function MomentUtils(_a) {\n var _b = _a === void 0 ? {} : _a, locale = _b.locale, instance = _b.instance, moment = _b.moment;\n this.yearFormat = \"YYYY\";\n this.yearMonthFormat = \"MMMM YYYY\";\n this.dateTime12hFormat = \"MMMM Do hh:mm a\";\n this.dateTime24hFormat = \"MMMM Do HH:mm\";\n this.time12hFormat = \"hh:mm A\";\n this.time24hFormat = \"HH:mm\";\n this.dateFormat = \"MMMM Do\";\n this.moment = instance || moment || defaultMoment;\n this.locale = locale;\n }\n MomentUtils.prototype.parse = function (value, format) {\n if (value === \"\") {\n return null;\n }\n return this.moment(value, format, true);\n };\n MomentUtils.prototype.date = function (value) {\n if (value === null) {\n return null;\n }\n var moment = this.moment(value);\n moment.locale(this.locale);\n return moment;\n };\n MomentUtils.prototype.isValid = function (value) {\n return this.moment(value).isValid();\n };\n MomentUtils.prototype.isNull = function (date) {\n return date === null;\n };\n MomentUtils.prototype.getDiff = function (date, comparing) {\n return date.diff(comparing);\n };\n MomentUtils.prototype.isAfter = function (date, value) {\n return date.isAfter(value);\n };\n MomentUtils.prototype.isBefore = function (date, value) {\n return date.isBefore(value);\n };\n MomentUtils.prototype.isAfterDay = function (date, value) {\n return date.isAfter(value, \"day\");\n };\n MomentUtils.prototype.isBeforeDay = function (date, value) {\n return date.isBefore(value, \"day\");\n };\n MomentUtils.prototype.isBeforeYear = function (date, value) {\n return date.isBefore(value, \"year\");\n };\n MomentUtils.prototype.isAfterYear = function (date, value) {\n return date.isAfter(value, \"year\");\n };\n MomentUtils.prototype.startOfDay = function (date) {\n return date.clone().startOf(\"day\");\n };\n MomentUtils.prototype.endOfDay = function (date) {\n return date.clone().endOf(\"day\");\n };\n MomentUtils.prototype.format = function (date, formatString) {\n date.locale(this.locale);\n return date.format(formatString);\n };\n MomentUtils.prototype.formatNumber = function (numberToFormat) {\n return numberToFormat;\n };\n MomentUtils.prototype.getHours = function (date) {\n return date.get(\"hours\");\n };\n MomentUtils.prototype.addDays = function (date, count) {\n return count < 0\n ? date.clone().subtract(Math.abs(count), \"days\")\n : date.clone().add(count, \"days\");\n };\n MomentUtils.prototype.setHours = function (date, count) {\n return date.clone().hours(count);\n };\n MomentUtils.prototype.getMinutes = function (date) {\n return date.get(\"minutes\");\n };\n MomentUtils.prototype.setMinutes = function (date, count) {\n return date.clone().minutes(count);\n };\n MomentUtils.prototype.getSeconds = function (date) {\n return date.get(\"seconds\");\n };\n MomentUtils.prototype.setSeconds = function (date, count) {\n return date.clone().seconds(count);\n };\n MomentUtils.prototype.getMonth = function (date) {\n return date.get(\"month\");\n };\n MomentUtils.prototype.isSameDay = function (date, comparing) {\n return date.isSame(comparing, \"day\");\n };\n MomentUtils.prototype.isSameMonth = function (date, comparing) {\n return date.isSame(comparing, \"month\");\n };\n MomentUtils.prototype.isSameYear = function (date, comparing) {\n return date.isSame(comparing, \"year\");\n };\n MomentUtils.prototype.isSameHour = function (date, comparing) {\n return date.isSame(comparing, \"hour\");\n };\n MomentUtils.prototype.setMonth = function (date, count) {\n return date.clone().month(count);\n };\n MomentUtils.prototype.getMeridiemText = function (ampm) {\n return ampm === \"am\" ? \"AM\" : \"PM\";\n };\n MomentUtils.prototype.startOfMonth = function (date) {\n return date.clone().startOf(\"month\");\n };\n MomentUtils.prototype.endOfMonth = function (date) {\n return date.clone().endOf(\"month\");\n };\n MomentUtils.prototype.getNextMonth = function (date) {\n return date.clone().add(1, \"month\");\n };\n MomentUtils.prototype.getPreviousMonth = function (date) {\n return date.clone().subtract(1, \"month\");\n };\n MomentUtils.prototype.getMonthArray = function (date) {\n var firstMonth = date.clone().startOf(\"year\");\n var monthArray = [firstMonth];\n while (monthArray.length < 12) {\n var prevMonth = monthArray[monthArray.length - 1];\n monthArray.push(this.getNextMonth(prevMonth));\n }\n return monthArray;\n };\n MomentUtils.prototype.getYear = function (date) {\n return date.get(\"year\");\n };\n MomentUtils.prototype.setYear = function (date, year) {\n return date.clone().set(\"year\", year);\n };\n MomentUtils.prototype.mergeDateAndTime = function (date, time) {\n return this.setMinutes(this.setHours(date, this.getHours(time)), this.getMinutes(time));\n };\n MomentUtils.prototype.getWeekdays = function () {\n return this.moment.weekdaysShort(true);\n };\n MomentUtils.prototype.isEqual = function (value, comparing) {\n if (value === null && comparing === null) {\n return true;\n }\n return this.moment(value).isSame(comparing);\n };\n MomentUtils.prototype.getWeekArray = function (date) {\n var start = date\n .clone()\n .startOf(\"month\")\n .startOf(\"week\");\n var end = date\n .clone()\n .endOf(\"month\")\n .endOf(\"week\");\n var count = 0;\n var current = start;\n var nestedWeeks = [];\n while (current.isBefore(end)) {\n var weekNumber = Math.floor(count / 7);\n nestedWeeks[weekNumber] = nestedWeeks[weekNumber] || [];\n nestedWeeks[weekNumber].push(current);\n current = current.clone().add(1, \"day\");\n count += 1;\n }\n return nestedWeeks;\n };\n MomentUtils.prototype.getYearRange = function (start, end) {\n var startDate = this.moment(start).startOf(\"year\");\n var endDate = this.moment(end).endOf(\"year\");\n var years = [];\n var current = startDate;\n while (current.isBefore(endDate)) {\n years.push(current);\n current = current.clone().add(1, \"year\");\n }\n return years;\n };\n // displaying methods\n MomentUtils.prototype.getCalendarHeaderText = function (date) {\n return this.format(date, this.yearMonthFormat);\n };\n MomentUtils.prototype.getYearText = function (date) {\n return this.format(date, \"YYYY\");\n };\n MomentUtils.prototype.getDatePickerHeaderText = function (date) {\n return this.format(date, \"ddd, MMM D\");\n };\n MomentUtils.prototype.getDateTimePickerHeaderText = function (date) {\n return this.format(date, \"MMM D\");\n };\n MomentUtils.prototype.getMonthText = function (date) {\n return this.format(date, \"MMMM\");\n };\n MomentUtils.prototype.getDayText = function (date) {\n return this.format(date, \"D\");\n };\n MomentUtils.prototype.getHourText = function (date, ampm) {\n return this.format(date, ampm ? \"hh\" : \"HH\");\n };\n MomentUtils.prototype.getMinuteText = function (date) {\n return this.format(date, \"mm\");\n };\n MomentUtils.prototype.getSecondText = function (date) {\n return this.format(date, \"ss\");\n };\n return MomentUtils;\n}());\n\nexport default MomentUtils;\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34a.9959.9959 0 00-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z\"\n}), 'Edit');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M9.31 17l2.44-2.44L14.19 17l1.06-1.06-2.44-2.44 2.44-2.44L14.19 10l-2.44 2.44L9.31 10l-1.06 1.06 2.44 2.44-2.44 2.44L9.31 17zM19 3h-1V1h-2v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V8h14v11z\"\n}), 'EventBusy');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z\"\n}), 'Info');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M15.41 16.59L10.83 12l4.58-4.59L14 6l-6 6 6 6 1.41-1.41z\"\n}), 'KeyboardArrowLeft');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z\"\n}), 'KeyboardArrowRight');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null, _react.default.createElement(\"path\", {\n transform: \"scale(1.2, 1.2)\",\n fill: \"none\",\n d: \"M0 0h20v20H0V0z\"\n}), _react.default.createElement(\"path\", {\n transform: \"scale(1.2, 1.2)\",\n d: \"M15.95 10.78c.03-.25.05-.51.05-.78s-.02-.53-.06-.78l1.69-1.32c.15-.12.19-.34.1-.51l-1.6-2.77c-.1-.18-.31-.24-.49-.18l-1.99.8c-.42-.32-.86-.58-1.35-.78L12 2.34c-.03-.2-.2-.34-.4-.34H8.4c-.2 0-.36.14-.39.34l-.3 2.12c-.49.2-.94.47-1.35.78l-1.99-.8c-.18-.07-.39 0-.49.18l-1.6 2.77c-.1.18-.06.39.1.51l1.69 1.32c-.04.25-.07.52-.07.78s.02.53.06.78L2.37 12.1c-.15.12-.19.34-.1.51l1.6 2.77c.1.18.31.24.49.18l1.99-.8c.42.32.86.58 1.35.78l.3 2.12c.04.2.2.34.4.34h3.2c.2 0 .37-.14.39-.34l.3-2.12c.49-.2.94-.47 1.35-.78l1.99.8c.18.07.39 0 .49-.18l1.6-2.77c.1-.18.06-.39-.1-.51l-1.67-1.32zM10 13c-1.65 0-3-1.35-3-3s1.35-3 3-3 3 1.35 3 3-1.35 3-3 3z\"\n})), 'Settings');\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"./utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(\"path\", {\n d: \"M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z\"\n}), 'Visibility');\n\nexports.default = _default;","import React from 'react';\n\nconst SvgFilter: React.FC<React.SVGProps<SVGSVGElement>> = (props) => {\n return (\n <svg width={18} height={18} viewBox=\"0 0 18 18\" xmlns=\"http://www.w3.org/2000/svg\" {...props}>\n <path d=\"M18 2V0H0v2l7 8v8l4-2v-6z\" fill=\"currentColor\" fillRule=\"nonzero\" stroke=\"none\" strokeWidth={1} />\n </svg>\n );\n};\n\nexport default SvgFilter;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n 'filterIcon--enabled': {\n color: theme.palette.primary.main\n },\n closeIcon: {\n position: 'absolute',\n right: '3px',\n bottom: '3px',\n transform: 'scale(0.5)'\n },\n button: {\n padding: '11px'\n }\n}));\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport i18n from 'ui-i18n';\nimport {IconButton as IconButton} from '@material-ui/core';\nimport CloseIcon from '@material-ui/icons/Close';\nimport {Tooltip as Tooltip} from '@material-ui/core';\nimport FilterIcon from '../../../../icons/Filter';\nimport {useStyles} from './styles';\n\nconst FilterButton = ({enabled, onClick}) => {\n const styles = useStyles();\n\n return (\n <Tooltip title={enabled ? i18n.text('Clear all filters') : i18n.text('Filter')}>\n <IconButton onClick={onClick} classes={{root: styles.button}}>\n {enabled ? (\n <>\n <FilterIcon className={styles['filterIcon--enabled']} />\n <CloseIcon color=\"primary\" className={styles.closeIcon} />\n </>\n ) : (\n <FilterIcon />\n )}\n </IconButton>\n </Tooltip>\n );\n};\n\nFilterButton.propTypes = {\n enabled: PropTypes.bool,\n onClick: PropTypes.func\n};\n\nexport default FilterButton;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles({\n pagination: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'flex-end',\n height: '56px',\n borderTop: '1px solid rgba(0,0,0,0.12)',\n boxShadow: 'none'\n },\n caption: {\n color: 'rgba(0,0,0,0.6)',\n fontSize: '12px',\n lineHeight: '16px'\n },\n selectRoot: {\n marginLeft: '5px',\n marginRight: '36px'\n },\n select: {\n color: 'rgba(0,0,0,0.6)',\n fontSize: '12px',\n lineHeight: '16px',\n textAlign: 'right'\n },\n actions: {\n marginLeft: '32px'\n }\n});\n","import PropTypes from 'prop-types';\nimport React, {useCallback} from 'react';\nimport classnames from 'classnames';\nimport {TablePagination as TablePagination} from '@material-ui/core';\nimport i18n from 'ui-i18n';\nimport {getValue} from '../../../core/utils';\nimport {nthArg, pipe, pathOr, identity} from 'ramda';\nimport {useStyles} from './styles';\n\nconst BasicTablePagination = ({\n classes = {},\n count,\n rowsPerPageOptions,\n page,\n onChangePage,\n rowsPerPage,\n onChangeRowsPerPage,\n basicTableRef,\n labelRowsPerPage\n}) => {\n const labelDisplayedRows = ({from, to, count}) =>\n i18n.text('${fromRow}-${toRow} of ${countRows}', {\n fromRow: i18n.number(from, '0,0'),\n toRow: i18n.number(to, '0,0'),\n countRows: i18n.number(count, '0,0')\n });\n const styles = useStyles();\n const resetScrollbarPosition = useCallback(() => {\n pathOr(identity, ['current', 'resetScrollbarPosition'], basicTableRef)();\n }, [basicTableRef]);\n const handleChangePage = useCallback(\n (value) => {\n onChangePage(value);\n resetScrollbarPosition();\n },\n [onChangePage, resetScrollbarPosition]\n );\n const handleChangeRowsPerPage = useCallback(\n (value) => {\n onChangePage(0);\n onChangeRowsPerPage(value);\n resetScrollbarPosition();\n },\n [onChangePage, onChangeRowsPerPage, resetScrollbarPosition]\n );\n return (\n <TablePagination\n classes={{\n ...classes,\n root: classnames(styles.pagination, classes.root),\n select: classnames(styles.select, classes.select),\n caption: styles.caption,\n selectRoot: styles.selectRoot,\n actions: styles.actions\n }}\n component=\"div\"\n labelRowsPerPage={labelRowsPerPage || i18n.text('Rows per page:')}\n labelDisplayedRows={labelDisplayedRows}\n count={count}\n rowsPerPageOptions={rowsPerPageOptions}\n page={page}\n onChangePage={pipe(nthArg(1), handleChangePage)}\n rowsPerPage={rowsPerPage}\n onChangeRowsPerPage={pipe(getValue, handleChangeRowsPerPage)}\n />\n );\n};\n\nBasicTablePagination.propTypes = {\n classes: PropTypes.object,\n rowsPerPageOptions: PropTypes.arrayOf(PropTypes.number),\n count: PropTypes.number,\n page: PropTypes.number,\n onChangePage: PropTypes.func,\n rowsPerPage: PropTypes.number,\n onChangeRowsPerPage: PropTypes.func,\n basicTableRef: PropTypes.shape({current: PropTypes.object}),\n labelRowsPerPage: PropTypes.string\n};\n\nexport default React.memo(BasicTablePagination);\n","import {always, assoc, difference, dissoc, evolve, keys, path, when} from 'ramda';\nimport {createStandardAction, toggleSortOrder} from '../../../core';\n\nconst CHANGE_COLUMNS = 'CHANGE_COLUMNS';\nconst TOGGLE_FILTERS = 'TOGGLE_FILTERS';\nconst CHANGE_FILTER = 'CHANGE_FILTER';\nconst TOGGLE_SORT = 'TOGGLE_SORT';\nconst CHANGE_PAGE = 'CHANGE_PAGE';\nconst CHANGE_ROWS_PER_PAGE = 'CHANGE_ROWS_PER_PAGE';\n\nexport const actions = {\n changeColumns: createStandardAction(CHANGE_COLUMNS),\n toggleFilters: createStandardAction(TOGGLE_FILTERS),\n changeFilter: createStandardAction(CHANGE_FILTER),\n toggleSort: createStandardAction(TOGGLE_SORT),\n changePage: createStandardAction(CHANGE_PAGE),\n changeRowsPerPage: createStandardAction(CHANGE_ROWS_PER_PAGE)\n};\n\nexport const changeVisibleColumns = (state, nextVisibleColumns) => {\n const removedColumns = difference(state.visibleColumns, nextVisibleColumns);\n const isRemovedColumn = (columnId) => removedColumns.includes(columnId);\n return evolve(\n {\n visibleColumns: always(nextVisibleColumns),\n sorting: when(\n (sorting = {}) => isRemovedColumn(sorting.field),\n () => {\n const [nextSortField] = nextVisibleColumns;\n return {field: nextSortField, order: 'asc'};\n }\n ),\n filters: (filters) =>\n keys(filters).reduce(\n (acc, columnId) => (isRemovedColumn(columnId) ? dissoc(columnId, acc) : acc),\n filters\n )\n },\n state\n );\n};\n\nexport const reducer = (state, action) => {\n switch (action.type) {\n case CHANGE_COLUMNS: {\n const columnIds = action.payload;\n return changeVisibleColumns(state, columnIds);\n }\n case TOGGLE_FILTERS: {\n const enableFilters = !state.filters;\n return {\n ...state,\n filters: enableFilters ? {} : null,\n page: enableFilters ? state.page : 0\n };\n }\n case CHANGE_FILTER: {\n const {columnId, filter} = action.payload;\n return evolve({filters: filter ? assoc(columnId, filter) : dissoc(columnId), page: always(0)}, state);\n }\n case TOGGLE_SORT: {\n const nextSortField = action.payload;\n const prevSortField = path(['sorting', 'field'], state);\n const prevSortOrder = path(['sorting', 'order'], state);\n return {\n ...state,\n sorting: {\n field: nextSortField,\n order: toggleSortOrder(nextSortField === prevSortField ? prevSortOrder : null)\n },\n page: 0\n };\n }\n case CHANGE_PAGE:\n return {...state, page: action.payload};\n case CHANGE_ROWS_PER_PAGE:\n return {...state, rowsPerPage: action.payload};\n default:\n return state;\n }\n};\n\nexport default {\n reducer,\n actions,\n changeVisibleColumns\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n 'basic-view__paper': {\n display: 'flex',\n flexDirection: 'column',\n ...theme.basicView\n }\n}));\n","import Paper, {PaperProps} from '@material-ui/core/Paper';\nimport PropTypes from 'prop-types';\nimport React, {forwardRef, Ref} from 'react';\nimport {useStyles} from './styles';\n\nconst BasicView = forwardRef<Ref<typeof Paper>, PaperProps>(({children, className, ...otherProps}, ref) => {\n const styles = useStyles();\n return (\n <Paper ref={ref} className={className} classes={{root: styles['basic-view__paper']}} {...otherProps}>\n {children}\n </Paper>\n );\n});\n\nBasicView.displayName = 'BasicView';\n\nBasicView.propTypes = {\n children: PropTypes.node,\n className: PropTypes.string\n};\n\nexport default BasicView;\n","import {makeStyles} from '@material-ui/core/styles';\n\nconst useStyles = makeStyles({\n paper: {\n minHeight: '180px'\n },\n title: {\n padding: '16px 16px 10px 16px',\n fontSize: '20px',\n fontWeight: 500,\n letterSpacing: '0.25px',\n lineHeight: '24px'\n },\n content: {\n padding: '0 16px'\n },\n contentText: {\n marginBottom: 0,\n fontSize: '16px',\n letterSpacing: '0.15px',\n lineHeight: '24px'\n },\n actionButtons: {\n display: 'flex',\n paddingTop: '4px',\n fontSize: '14px',\n fontWeight: 500,\n letterSpacing: 0,\n lineHeight: '16px',\n '& > div': {\n marginLeft: 'auto'\n }\n },\n discardButton: {\n marginRight: '8px'\n }\n});\n\nexport {useStyles};\n","import React from 'react';\nimport i18n from 'ui-i18n';\nimport {Button as Button} from '@material-ui/core';\nimport {Dialog as Dialog} from '@material-ui/core';\nimport {DialogActions as DialogActions} from '@material-ui/core';\nimport {DialogContent as DialogContent} from '@material-ui/core';\nimport {DialogContentText as DialogContentText} from '@material-ui/core';\nimport {DialogTitle as DialogTitle} from '@material-ui/core';\n\nimport {useStyles} from './styles';\n\nexport type Props = {\n open: boolean;\n title: React.ReactNode;\n content: React.ReactNode;\n cancelCaption?: string;\n discardCaption?: string;\n saveCaption?: string;\n disabledSave?: boolean;\n onCancel?: () => void;\n onDiscard?: () => void;\n onSave: () => void;\n};\n\nconst ConfirmationDialog = ({\n open,\n title,\n content,\n onCancel,\n cancelCaption = i18n.text('Cancel'),\n onDiscard,\n discardCaption = '',\n onSave,\n saveCaption = i18n.text('Save'),\n disabledSave = false\n}: Props) => {\n const styles = useStyles();\n\n return (\n <Dialog open={open} onClose={onCancel} classes={{paperScrollPaper: styles.paper}}>\n <DialogTitle classes={{root: styles.title}}>{title}</DialogTitle>\n <DialogContent classes={{root: styles.content}}>\n <DialogContentText classes={{root: styles.contentText}}>{content}</DialogContentText>\n </DialogContent>\n <DialogActions className={styles.actionButtons} disableSpacing>\n {onCancel && <Button onClick={onCancel}>{cancelCaption}</Button>}\n <div>\n {onDiscard && (\n <Button onClick={onDiscard} classes={{root: styles.discardButton}}>\n {discardCaption}\n </Button>\n )}\n <Button onClick={onSave} color=\"primary\" disabled={disabledSave} autoFocus>\n {saveCaption}\n </Button>\n </div>\n </DialogActions>\n </Dialog>\n );\n};\n\nexport default ConfirmationDialog;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n menuItem: {\n height: '32px'\n },\n menuText: {\n color: theme.palette.text.primary,\n fontSize: '13px',\n lineHeight: '15px'\n },\n checkbox: {\n padding: 0,\n marginRight: '15px'\n }\n}));\n","import React, {forwardRef} from 'react';\nimport {identity} from 'ramda';\nimport {Checkbox as Checkbox} from '@material-ui/core';\nimport {MenuItem as MenuItem} from '@material-ui/core';\nimport {Typography as Typography} from '@material-ui/core';\nimport {DropDownMenuItem} from '../../../types';\nimport {useStyles} from './styles';\n\ntype Props = {\n item: DropDownMenuItem;\n onMenuClose?: (e) => void;\n};\n\nconst SettingsMenuItemRenderer = forwardRef(({item, onMenuClose = identity}: Props, ref: React.Ref<HTMLLIElement>) => {\n const styles = useStyles();\n const {text, onClick, id, selected} = item;\n const handleClick = (e) => {\n onMenuClose(e);\n onClick(e);\n };\n\n return (\n <MenuItem\n classes={{root: styles.menuItem}}\n onClick={handleClick}\n ref={ref}\n data-modal\n data-reltio-id={`reltio-settings-menu-item${id}`}\n >\n <Checkbox checked={selected} className={styles.checkbox} color=\"primary\" />\n <Typography classes={{root: styles.menuText}}>{text}</Typography>\n </MenuItem>\n );\n});\n\nSettingsMenuItemRenderer.displayName = 'SettingsMenuItemRenderer';\n\nexport default SettingsMenuItemRenderer;\n","import React from 'react';\nimport SettingsIcon from '@material-ui/icons/Settings';\nimport i18n from 'ui-i18n';\nimport {DropDownMenuItem} from '../../types';\nimport {SmallIconButtonWithTooltip} from '../SmallIconButton';\nimport DropDownMenuButton from '../DropDownMenuButton/DropDownMenuButton';\nimport SettingsMenuItemRenderer from './SettingsMenuItemRender/SettingsMenuItemRender';\n\ntype Props = {\n items: Array<DropDownMenuItem>;\n menuId: string;\n};\n\nconst SettingsMenu = ({items, menuId}: Props) => {\n return (\n <DropDownMenuButton\n buttonComponent={SmallIconButtonWithTooltip}\n buttonProps={{\n icon: SettingsIcon,\n tooltipTitle: i18n.text('Settings'),\n size: 'L'\n }}\n menuId={menuId}\n menuItems={items}\n MenuItemRenderer={SettingsMenuItemRenderer}\n />\n );\n};\n\nexport default SettingsMenu;\n","import PropTypes from 'prop-types';\nimport React from 'react';\n\nconst VerticalDivider = ({height, margin}) => (\n <div\n style={{\n width: '1px',\n height: `${height}px`,\n borderLeft: '1px solid rgba(0,0,0,0.38)',\n margin: `0 ${margin}px`,\n flexShrink: '0'\n }}\n />\n);\n\nVerticalDivider.propTypes = {\n height: PropTypes.number,\n margin: PropTypes.number\n};\n\nexport default VerticalDivider;\n","import {useMemo} from 'react';\nimport {pipe} from 'ramda';\n\ntype UseActions = ({\n actions,\n dispatch\n}: {\n actions: {\n [key: string]: <T>(payload: T) => {type: string; payload: T};\n };\n dispatch: <T>({type, payload}: {type: string; payload: T}) => void;\n}) => {\n [key in keyof typeof actions]: <T>(payload: T) => void;\n};\n\nexport const useActions: UseActions = ({actions, dispatch}) =>\n useMemo(\n () =>\n Object.entries(actions).reduce((acc, [actionName, actionCreator]) => {\n return {...acc, [actionName]: pipe(actionCreator, dispatch)};\n }, {}),\n [dispatch, actions]\n );\n","import {useCallback, useEffect, useMemo, useRef, useState} from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport {cond, pipe, prop, T, evolve, filter as filterFn, when, identity, times, length, ifElse, always} from 'ramda';\nimport mdm, {profile} from '@reltio/mdm-module';\nimport {\n ActivityFilter,\n addGlobalFilterToQuery,\n Connection,\n Entity,\n getRelationsForDataTenantEntity,\n getRelationsForEntity,\n GlobalSearchRequestOptions,\n isAvailableEntityTypeUri,\n isAvailableRelationTypeUri,\n isDataTenantEntity,\n isObject,\n isTempUri,\n Metadata,\n Mode,\n RelationsContent,\n RelationsViewConfig,\n wrapInArrayIfNeeded\n} from '@reltio/mdm-sdk';\nimport {useSafePromise} from './useSafePromise';\nimport {usePrevious} from './usePrevious';\n\ntype Props = {\n sorting?: {\n field: string;\n order: string;\n };\n filter?: string;\n page: number;\n rowsPerPage: number;\n config: Pick<RelationsViewConfig, 'suggested' | 'content' | 'id'>;\n entity: Entity;\n relationActivityFilter?: ActivityFilter;\n mode: Mode;\n searchByOv?: boolean;\n};\n\nconst buildSuggestedIds = when(\n identity,\n pipe(\n wrapInArrayIfNeeded,\n length,\n times((n) => n + 1)\n )\n);\ntype ConnectionResponse = Array<{connections?: Connection[]; total: number}>;\n\nexport const useRelationsLoader = ({\n sorting,\n filter,\n page,\n rowsPerPage,\n config,\n entity,\n relationActivityFilter,\n mode,\n searchByOv = false\n}: Props) => {\n const [isLoading, setIsLoading] = useState(false);\n const dispatch = useDispatch();\n const tenant = useSelector(mdm.selectors.getTenant) as string;\n const metadata = useSelector(mdm.selectors.getMetadata) as Metadata;\n const dtssPath = useSelector(mdm.selectors.getDtssPath) as string;\n const {activityFilter, globalFilter}: GlobalSearchRequestOptions =\n useSelector(mdm.selectors.getGlobalSearchRequestOptions) || {};\n const lastLoadedTime = useSelector(mdm.selectors.getProfileLastLoadedTime);\n const safePromise = useSafePromise();\n\n const processContent = (content: RelationsContent) => {\n const getUri = when(isObject, prop('uri'));\n const filterRelation = pipe(getUri, isAvailableRelationTypeUri(metadata));\n\n return evolve({\n entityTypes: filterFn(isAvailableEntityTypeUri(metadata)),\n inRelations: filterFn(filterRelation),\n outRelations: filterFn(filterRelation),\n nextEntry: processContent\n })(content);\n };\n\n const suggested = config.suggested;\n const options = useMemo(\n () => ({\n searchByOv\n }),\n [searchByOv]\n );\n const loadRelations = useCallback(() => {\n if (entity?.uri) {\n const processedConfig = processContent(config.content);\n const requestConfig = {\n ...processedConfig,\n sortBy: sorting?.field,\n order: sorting?.order,\n returnDates: true,\n returnObjects: true,\n activeness: {\n relation: relationActivityFilter || ActivityFilter.ALL,\n entity: activityFilter\n },\n max: rowsPerPage,\n offset: page * rowsPerPage,\n filter: addGlobalFilterToQuery(globalFilter, filter) || undefined,\n suggested: buildSuggestedIds(suggested)\n };\n const configs = [requestConfig].concat(\n ifElse(\n identity,\n pipe(wrapInArrayIfNeeded, (suggested) =>\n suggested.map((config, i) => ({...config, id: requestConfig.suggested[i]}))\n ),\n always([])\n )(suggested)\n );\n\n const request: (entity: Entity) => Promise<ConnectionResponse> = cond([\n [pipe(prop('uri'), isTempUri), () => Promise.resolve([{total: 0}])],\n [\n isDataTenantEntity,\n (entity) =>\n getRelationsForDataTenantEntity({\n entityUri: entity.uri,\n configs: configs,\n customerTenant: tenant,\n dataTenant: entity.dataTenant,\n dtssPath,\n options\n })\n ],\n [T, (entity) => getRelationsForEntity(entity.uri, configs, options)]\n ]);\n setIsLoading(true);\n safePromise(request(entity))\n .then(([{connections, total}]) => {\n dispatch(profile.relations.actions.relationsLoaded({id: config.id, connections, total}));\n })\n .finally(() => {\n setIsLoading(false);\n });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n activityFilter,\n metadata,\n config,\n dispatch,\n dtssPath,\n entity?.uri,\n entity?.dataTenant,\n filter,\n globalFilter,\n page,\n relationActivityFilter,\n rowsPerPage,\n safePromise,\n sorting,\n tenant,\n options,\n lastLoadedTime\n ]);\n const isRequestSentRef = useRef<boolean>(false);\n isRequestSentRef.current = false;\n useEffect(() => {\n isRequestSentRef.current = true;\n loadRelations();\n }, [loadRelations]);\n\n const prevMode = usePrevious(mode);\n useEffect(() => {\n if (mode === Mode.Viewing && !isRequestSentRef.current && prevMode !== mode) {\n isRequestSentRef.current = true;\n loadRelations();\n }\n }, [loadRelations, mode, prevMode]);\n return {isLoading, reload: loadRelations};\n};\n","import {useEffect, useState} from 'react';\nimport {useDidUpdateEffect} from '@reltio/components';\nimport {\n RelationshipsSavedState,\n RelationsTableSavedState,\n AttributesTableSavedState\n} from './../types/RelationshipsSavedState';\n\nconst DEFAULT_SAVED_STATE = {\n relationsTable: {},\n attributesTable: {}\n};\n\nconst useSavedState = ({getSavedState, saveState, entityTypeUri}) => {\n const [savedState, setSavedState] = useState<RelationshipsSavedState>(DEFAULT_SAVED_STATE);\n const [changedRelationsState, setRelationsChangedState] = useState<Record<string, RelationsTableSavedState>>(null);\n\n const saveChangesLocallyForPrevEntityType = () => {\n if (changedRelationsState) {\n setSavedState({...savedState, relationsTable: changedRelationsState});\n setRelationsChangedState(null);\n }\n };\n useDidUpdateEffect(saveChangesLocallyForPrevEntityType, [entityTypeUri]);\n\n const updateRelationsTableSavedState = (stateToSave: RelationsTableSavedState) => {\n const changedState: Record<string, RelationsTableSavedState> = {\n ...savedState.relationsTable,\n [entityTypeUri]: stateToSave\n };\n setRelationsChangedState(changedState);\n saveState({...savedState, relationsTable: changedState});\n };\n\n const updateAttributesTableSavedState = (stateToSave: AttributesTableSavedState) => {\n saveState({...savedState, attributesTable: stateToSave});\n };\n\n const [isLoading, setIsLoading] = useState(true);\n\n useEffect(() => {\n getSavedState()\n .then((savedState) => {\n setSavedState(savedState || DEFAULT_SAVED_STATE);\n })\n .then((_) => setIsLoading(false))\n .catch((_) => setIsLoading(false));\n }, []); // eslint-disable-line\n return {\n isLoading,\n relationsTableSavedState: savedState.relationsTable?.[entityTypeUri],\n attributesTableSavedState: savedState.attributesTable,\n updateRelationsTableSavedState,\n updateAttributesTableSavedState\n };\n};\n\nexport default useSavedState;\n","import {\n attributeUriToSearchUri,\n DataTypes,\n getAttrDataTypeDefinition,\n getReadableAttributesList,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {adjust, assoc, concat, find, map, pipe, pluck, prop, propEq, reject, uniqBy} from 'ramda';\nimport i18n from 'ui-i18n';\nimport {RelationshipsTableColumnData} from '../../../types';\n\nconst RELATION_TYPE_COLUMN_ID = 'relation.type';\nconst ATTRIBUTES_COLUMN_ID = 'relation.attributes';\n\nexport const DEFAULT_COLUMNS_DATA = [\n {\n id: 'entity.label',\n get label() {\n return i18n.text('Profile');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_STRING\n },\n hideable: false,\n filterable: false,\n initialWidth: 280,\n autoResize: false\n },\n {\n id: RELATION_TYPE_COLUMN_ID,\n get label() {\n return i18n.text('Type');\n }\n },\n {\n id: 'relation.label',\n get label() {\n return i18n.text('Directional Label');\n },\n filterable: false,\n dataTypeDefinition: {\n type: DataTypes.TYPE_STRING\n }\n },\n {\n id: 'relation.activeness.startDate',\n get label() {\n return i18n.text('Start Date');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_ACTIVENESS_DATE\n }\n },\n {\n id: 'relation.activeness.endDate',\n get label() {\n return i18n.text('End Date');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_ACTIVENESS_DATE\n }\n },\n {\n id: ATTRIBUTES_COLUMN_ID,\n get label() {\n return i18n.text('Attributes');\n },\n sortable: false,\n filterable: false,\n maxAttrsToShow: 7\n }\n];\n\nexport const DEFAULT_COLUMNS = pluck('id', DEFAULT_COLUMNS_DATA);\nexport const ALL_TYPES_COLUMNS = [RELATION_TYPE_COLUMN_ID, ATTRIBUTES_COLUMN_ID];\n\nexport const ROWS_PER_PAGE_OPTIONS = [20, 50, 100];\n\nconst getColumnIdFromAttrUri = pipe(attributeUriToSearchUri, concat('relation.'));\n\nconst getColumnsDataFromRelationAttributes = pipe(\n map((attr) => ({\n id: getColumnIdFromAttrUri(attr.uri),\n label: attr.label,\n description: attr?.description,\n dataTypeDefinition: getAttrDataTypeDefinition(attr)\n })),\n uniqBy(prop('id'))\n);\n\nconst getRelationColumnDataType = (relationTypes: TRelationType[]) => ({\n type: DataTypes.TYPE_SELECT,\n options: relationTypes.map(({uri, label}) => ({value: uri, label}))\n});\n\nconst updateColumnData = (columnId: string, updateFn) => (columnsData: RelationshipsTableColumnData[]) =>\n adjust(columnsData.findIndex(propEq('id', columnId)), updateFn, columnsData);\n\nconst updateRelationTypeColumn = (relationTypes: TRelationType[]) =>\n updateColumnData(RELATION_TYPE_COLUMN_ID, assoc('dataTypeDefinition', getRelationColumnDataType(relationTypes)));\n\nexport const getColumnsData = (relationTypes: TRelationType[], currentRelationType: string) =>\n currentRelationType\n ? pipe(\n find((relationType: TRelationType) => relationType.uri === currentRelationType),\n getReadableAttributesList,\n getColumnsDataFromRelationAttributes,\n concat(DEFAULT_COLUMNS_DATA),\n reject(({id}) => ALL_TYPES_COLUMNS.includes(id))\n )(relationTypes)\n : updateRelationTypeColumn(relationTypes)(DEFAULT_COLUMNS_DATA);\n","import {\n assoc,\n pipe,\n evolve,\n either,\n path,\n prop,\n propOr,\n ifElse,\n always,\n without,\n concat,\n intersection,\n pick,\n unless,\n isNil,\n filter\n} from 'ramda';\nimport {useReducer} from 'react';\nimport {basicTableViewState, createStandardAction, Sorting, useActions} from '@reltio/components';\nimport {ALL_TYPES_COLUMNS, DEFAULT_COLUMNS} from '../components/RelationshipsView/helpers/tableHelpers';\nimport {validateFilterValue} from '@reltio/mdm-sdk';\n\ntype Props = {\n defaultColumns: string[];\n defaultSorting: Sorting;\n defaultRowsPerPage: number;\n};\n\nconst CHANGE_RELATION_TYPE = 'CHANGE_RELATION_TYPE';\nconst APPLY_SAVED_STATE = 'APPLY_SAVED_STATE';\nconst SAVE_CURRENT_STATE = 'SAVE_CURRENT_STATE';\n\nconst actions = {\n ...basicTableViewState.actions,\n changeRelationType: createStandardAction(CHANGE_RELATION_TYPE),\n applySavedState: createStandardAction(APPLY_SAVED_STATE),\n saveCurrentState: createStandardAction(SAVE_CURRENT_STATE)\n};\n\nconst resetPageNumber = assoc('page', 0);\n\nconst getDefaultVisibleColumnsForCurrentRelationType = (state) => {\n return pipe(\n prop('visibleColumns'),\n ifElse(always(state.currentRelationType), without(ALL_TYPES_COLUMNS), concat(ALL_TYPES_COLUMNS)),\n intersection(DEFAULT_COLUMNS)\n )(state);\n};\n\nconst getSavedVisibleColumnsForCurrentRelationType = (state) =>\n path(['visibleColumnsForRelationTypes', `${state.currentRelationType}`], state);\n\nconst changeVisibleColumnsForCurrentRelationType = (state) => {\n const nextVisibleColumns = either(\n getSavedVisibleColumnsForCurrentRelationType,\n getDefaultVisibleColumnsForCurrentRelationType\n )(state);\n return basicTableViewState.changeVisibleColumns(state, nextVisibleColumns);\n};\n\nconst getFiltersFromSavedState = pipe(\n propOr(null, 'filters'),\n unless(\n isNil,\n filter(({filter, value}) => validateFilterValue(filter, value))\n )\n);\n\nconst saveVisibleColumnsForCurrentRelationType = (state) => {\n const {currentRelationType, visibleColumns} = state;\n return evolve(\n {\n visibleColumnsForRelationTypes: assoc(`${currentRelationType}`, visibleColumns)\n },\n state\n );\n};\n\nconst getStateToSave = pipe(\n saveVisibleColumnsForCurrentRelationType,\n pick(['currentRelationType', 'visibleColumnsForRelationTypes', 'filters', 'sorting'])\n);\n\nexport const useRelationshipsTable = ({defaultColumns, defaultSorting, defaultRowsPerPage}: Props) => {\n const initState = {\n visibleColumns: defaultColumns,\n filters: null,\n sorting: defaultSorting,\n page: 0,\n rowsPerPage: defaultRowsPerPage,\n currentRelationType: null,\n stateToSave: null,\n visibleColumnsForRelationTypes: {},\n entityTypeOfAppliedSavedState: null\n };\n const [state, dispatch] = useReducer((state, action) => {\n switch (action.type) {\n case CHANGE_RELATION_TYPE: {\n const nextRelationType = action.payload;\n return pipe(\n saveVisibleColumnsForCurrentRelationType,\n assoc('currentRelationType', nextRelationType),\n changeVisibleColumnsForCurrentRelationType,\n resetPageNumber\n )(state);\n }\n case APPLY_SAVED_STATE: {\n const {savedState, entityTypeUri} = action.payload;\n const visibleColumns = savedState\n ? getSavedVisibleColumnsForCurrentRelationType(savedState)\n : state.visibleColumns;\n const filters = savedState ? getFiltersFromSavedState(savedState) : state.filters;\n return {\n ...state,\n ...savedState,\n filters,\n visibleColumns,\n entityTypeOfAppliedSavedState: entityTypeUri\n };\n }\n case SAVE_CURRENT_STATE: {\n return {\n ...state,\n stateToSave: getStateToSave(state)\n };\n }\n default:\n return basicTableViewState.reducer(state, action);\n }\n }, initState);\n const tableActions = useActions({actions, dispatch});\n return [state, tableActions];\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles({\n select: {\n fontSize: '13px',\n color: 'rgba(0,0,0,.6)',\n paddingLeft: '15px',\n '&&': {\n paddingRight: '35px'\n }\n },\n selectMenu: {\n '& li': {\n fontSize: '13px',\n height: '32px'\n }\n },\n textField: {\n maxWidth: '100%'\n }\n});\n","import React, {useMemo} from 'react';\nimport i18n from 'ui-i18n';\nimport {map, concat, pipe} from 'ramda';\nimport {TRelationType} from '@reltio/mdm-sdk';\nimport {DropDownEditor} from '@reltio/components';\nimport {useStyles} from './styles';\n\ntype Props = {\n value: string;\n onChange: (value: string) => void;\n relationTypes: TRelationType[];\n className?: string;\n};\n\nconst RelationTypeSelector = ({value, onChange, relationTypes, className}: Props) => {\n const styles = useStyles();\n const entries = useMemo(\n () =>\n pipe(\n map(({label, uri}) => ({label, value: uri})),\n concat([{value: '', label: i18n.text('All types')}])\n )(relationTypes),\n [relationTypes]\n );\n\n return (\n <div className={className}>\n <DropDownEditor\n displayEmpty\n disableUnderline\n classes={{\n select: styles.select\n }}\n TextFieldProps={{\n classes: {\n root: styles.textField\n }\n }}\n MenuProps={{\n classes: {\n list: styles.selectMenu\n }\n }}\n value={value || ''}\n entries={entries}\n onChange={(value: string) => onChange(value || null)}\n />\n </div>\n );\n};\n\nexport default RelationTypeSelector;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n header: {\n height: '56px',\n boxSizing: 'border-box',\n paddingRight: '10px'\n },\n title: {\n fontSize: '16px'\n },\n total: {\n fontSize: '14px',\n color: theme.palette.text.secondary,\n flexShrink: 0,\n marginRight: '5px'\n },\n relationTypeSelector: {\n margin: '0px 10px 0 30px',\n overflow: 'hidden'\n }\n}));\n","import React, {memo, useMemo} from 'react';\nimport i18n from 'ui-i18n';\nimport {TRelationType} from '@reltio/mdm-sdk';\nimport {Typography as Typography} from '@material-ui/core';\nimport {\n BasicViewHeader,\n ColumnsSettings,\n DropDownMenuItem,\n FilterButton,\n SettingsMenu,\n Spacer,\n VerticalDivider\n} from '@reltio/components';\nimport RelationTypeSelector from '../RelationTypeSelector/RelationTypeSelector';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n total: number;\n filteringEnabled: boolean;\n onToggleFilters: () => void;\n columnsData: Record<string, unknown>[];\n selectedColumns: string[];\n currentRelationType: string;\n onRelationTypeChange: (value: string) => void;\n relationTypes: TRelationType[];\n onChangeColumns: (columns: string[]) => void;\n searchByOv: boolean;\n onToggleSearchByOv: () => void;\n showInactive: boolean;\n onToggleShowInactive: () => void;\n};\n\nconst RelationshipsTableHeader = ({\n total,\n filteringEnabled,\n onToggleFilters,\n columnsData,\n selectedColumns,\n currentRelationType,\n onRelationTypeChange,\n relationTypes,\n onChangeColumns,\n searchByOv,\n onToggleSearchByOv,\n showInactive,\n onToggleShowInactive\n}: Props) => {\n const styles = useStyles();\n\n const settingItems = useMemo<Array<DropDownMenuItem>>(() => {\n return [\n {\n selected: searchByOv,\n text: i18n.text('Search by OV only'),\n onClick: onToggleSearchByOv,\n id: 'showNonOv'\n },\n {\n selected: showInactive,\n text: i18n.text('Show inactive relationships'),\n onClick: onToggleShowInactive,\n id: 'showInactive'\n }\n ];\n }, [onToggleSearchByOv, searchByOv, onToggleShowInactive, showInactive]);\n\n return (\n <BasicViewHeader title={i18n.text('Relationships')} classes={{root: styles.header, title: styles.title}}>\n {relationTypes.length > 0 && (\n <RelationTypeSelector\n className={styles.relationTypeSelector}\n value={currentRelationType}\n onChange={onRelationTypeChange}\n relationTypes={relationTypes}\n />\n )}\n <VerticalDivider height={28} margin={20} />\n <Typography variant=\"caption\" className={styles.total}>\n {total === 1\n ? i18n.text('${count} record', {count: total})\n : i18n.text('${count} records', {count: total})}\n </Typography>\n <Spacer />\n <SettingsMenu items={settingItems} menuId=\"relationships-view-settings\" />\n <FilterButton enabled={filteringEnabled} onClick={onToggleFilters} />\n <VerticalDivider height={28} margin={8} />\n <ColumnsSettings\n columnsData={columnsData}\n selectedColumns={selectedColumns}\n onChangeColumns={onChangeColumns}\n />\n </BasicViewHeader>\n );\n};\n\nexport default memo(RelationshipsTableHeader);\n","import {makeStyles, Theme} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme: Theme) => ({\n headCell: {\n display: 'flex',\n alignItems: 'center',\n height: '100%',\n width: '100%',\n fontSize: '12px',\n color: theme.palette.text.secondary,\n background: 'linear-gradient(0deg, rgba(0, 0, 0, 0.06), rgba(0, 0, 0, 0.06)), #FFFFFF'\n },\n rowCell: {\n fontSize: '13px',\n overflow: 'hidden',\n overflowWrap: 'break-word'\n },\n inactiveRowCell: {\n opacity: 0.6\n },\n defaultWrapper: {\n padding: '15px 25px 0 25px',\n '&:last-child': {\n paddingBottom: '15px'\n }\n },\n entityCell: {\n display: 'flex',\n alignItems: 'flex-start',\n padding: '15px'\n },\n entityAvatar: {\n transform: 'scale(0.5)',\n margin: '-10px 0 -10px -10px'\n },\n inactiveEntityAvatar: {\n overflow: 'initial',\n '&:after': {\n content: '\"\"',\n position: 'absolute',\n backgroundColor: 'rgb(209, 206, 206)',\n border: '1px solid rgba(0, 0, 0, 1)',\n borderRadius: '2px',\n width: '12px',\n right: 0,\n bottom: 0,\n height: '12px'\n },\n '& > img': {\n borderRadius: '50%',\n overflow: 'hidden'\n }\n },\n entityLabel: {\n color: theme.palette.primary.main,\n textDecoration: 'none',\n fontWeight: 500\n },\n attributesWrapper: {\n padding: '15px 25px 10px 25px',\n color: 'rgba(0,0,0,0.87)'\n },\n commentsContainer: {\n marginLeft: 'auto'\n },\n description: {\n marginLeft: '-22px'\n }\n}));\n","import React from 'react';\nimport DefaultHeadCellRenderer from 'react-components/dist/Table/DefaultHeadCellRenderer/DefaultHeadCellRenderer';\nimport {DescriptionIcon, withFilterAtBottom} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\nconst HeadCellRenderer = (props) => {\n const styles = useStyles();\n const {description} = props?.headCellData;\n return (\n <div className={styles.headCell}>\n <DefaultHeadCellRenderer {...props} />\n <DescriptionIcon description={description} className={styles.description} />\n </div>\n );\n};\n\nexport default withFilterAtBottom(HeadCellRenderer);\n","import React from 'react';\nimport classnames from 'classnames';\nimport {useSelector} from 'react-redux';\nimport {CommentsContainer, COMMENTS_CONTAINER_VISIBILITY_AREA, EntityTypeIcon, EntityUriLink} from '@reltio/components';\nimport {\n CollaborationObjectTypes,\n ConnectionEntity,\n ConnectionRelation,\n createRelatedObjectUris,\n getEntityUriForLink,\n getLabel,\n TEntityType\n} from '@reltio/mdm-sdk';\nimport mdmModule from '@reltio/mdm-module';\nimport {useStyles} from './styles';\n\ntype Props = {\n value: {\n entity: ConnectionEntity;\n relation: ConnectionRelation;\n entityType: TEntityType;\n };\n isInactiveRelation?: boolean;\n};\n\nconst EntityProfileRenderer = ({value: {entity, entityType, relation}, isInactiveRelation}: Props) => {\n const styles = useStyles();\n const currentEntityUri = useSelector(mdmModule.selectors.getEntityUri);\n return (\n <div className={classnames(styles.entityCell, COMMENTS_CONTAINER_VISIBILITY_AREA)}>\n <EntityTypeIcon\n className={classnames(styles.entityAvatar, {[styles.inactiveEntityAvatar]: isInactiveRelation})}\n entityType={entityType}\n />\n <EntityUriLink\n value={getEntityUriForLink({uri: entity.entityUri, dataTenant: entity.dataTenant})}\n className={styles.entityLabel}\n >\n {getLabel(entity.entityLabel)}\n </EntityUriLink>\n <div className={styles.commentsContainer} onClick={(e) => e.stopPropagation()}>\n <CommentsContainer\n uri={relation.relationUri}\n relatedObjectUris={createRelatedObjectUris(CollaborationObjectTypes.RELATION, {\n entityUri: currentEntityUri,\n connection: {relation, entity}\n })}\n objectType={CollaborationObjectTypes.RELATION}\n allowOnlyOneComment\n />\n </div>\n </div>\n );\n};\n\nexport default EntityProfileRenderer;\n","import React from 'react';\nimport {ReadOnlyAttributesList} from '@reltio/components';\nimport {AttributeType, RecordAttributesType} from '@reltio/mdm-sdk';\nimport {RelationshipsTableColumnData} from '../../../types';\nimport {useStyles} from './styles';\n\ntype Props = {\n columnData: RelationshipsTableColumnData;\n value: {\n attributeTypes: AttributeType[];\n attributes: RecordAttributesType;\n };\n};\n\nconst AttributesRenderer = ({columnData, value: {attributes, attributeTypes}}: Props) => {\n const styles = useStyles();\n\n return (\n <div className={styles.attributesWrapper} onClick={(e) => e.stopPropagation()}>\n <ReadOnlyAttributesList\n max={columnData.maxAttrsToShow}\n entity={{attributes}}\n attrTypes={attributeTypes}\n drawLines={false}\n />\n </div>\n );\n};\n\nexport default AttributesRenderer;\n","import React from 'react';\nimport {DataTypeValue} from '@reltio/components';\nimport {useStyles} from './styles';\nimport {RelationshipsTableColumnData} from '../../../types';\n\ntype Props = {\n columnData: RelationshipsTableColumnData;\n value: unknown;\n};\n\nconst DefaultCellValueRenderer = ({value, columnData: {dataTypeDefinition}}: Props) => {\n const styles = useStyles();\n return (\n <div className={styles.defaultWrapper}>\n <DataTypeValue value={value} dataTypeDefinition={dataTypeDefinition} />\n </div>\n );\n};\n\nexport default DefaultCellValueRenderer;\n","import {assoc, split, slice, values, length, path, cond, map, pathEq, pipe, reduce, T} from 'ramda';\nimport {defaultGetRowCellHeight} from '@reltio/components';\nimport {Connection, getEntityType, getRelationType, getOvAttributeValuesByPath, Metadata} from '@reltio/mdm-sdk';\nimport HeadCellRenderer from './cell-renderers/HeadCellRenderer';\nimport EntityProfileRenderer from './cell-renderers/EntityProfileRenderer';\nimport AttributesRenderer from './cell-renderers/AttributesRenderer';\nimport DefaultCellValueRenderer from './cell-renderers/DefaultCellValueRenderer';\nimport {RelationshipsTableColumnData} from '../../types';\n\nconst getAttrPathFromColumnId = pipe(split('.'), slice(2, Infinity));\n\nconst getRelationAttributeValues = (attrPath, relation) =>\n pipe(path(['object', 'attributes']), getOvAttributeValuesByPath(attrPath))(relation);\n\nconst getRowValueByColumnId = (metadata: Metadata, {entity, relation}: Connection, columnId: string) => {\n switch (columnId) {\n case 'entity.label':\n return {entity, entityType: getEntityType(metadata, entity.entityType), relation};\n case 'relation.type':\n return relation.relationType;\n case 'relation.label':\n return relation.relationLabel;\n case 'relation.activeness.startDate':\n return relation.startDate;\n case 'relation.activeness.endDate':\n return relation.endDate;\n case 'relation.attributes':\n return {\n attributes: relation.object.attributes,\n attributeTypes: getRelationType(metadata, relation.relationType).attributes\n };\n default: {\n const attrPath = getAttrPathFromColumnId(columnId);\n return getRelationAttributeValues(attrPath, relation);\n }\n }\n};\n\nconst getBasicTableRowsData = (\n metadata: Metadata,\n columnsData: RelationshipsTableColumnData[],\n connections: Connection[]\n) => {\n return (connections || []).map((connection) =>\n pipe(\n reduce((acc, {id}) => assoc(id, getRowValueByColumnId(metadata, connection, id), acc), {}),\n assoc('rawValue', connection)\n )(columnsData)\n );\n};\n\nconst getNestedPathByColumnId = (columnId: string) => {\n if (columnId.startsWith('relation.attributes')) {\n const attrPath = getAttrPathFromColumnId(columnId);\n return attrPath.length > 1 ? attrPath.slice(0, -1) : null;\n } else {\n return null;\n }\n};\n\nconst getCellValueRenderer = (columnId: string) => {\n switch (columnId) {\n case 'entity.label':\n return EntityProfileRenderer;\n case 'relation.attributes':\n return AttributesRenderer;\n default:\n return DefaultCellValueRenderer;\n }\n};\n\nconst getColumnDataByColumnId = (columnData: RelationshipsTableColumnData) => ({\n sortable: true,\n resizable: true,\n ...columnData,\n headCellRenderer: HeadCellRenderer,\n nestedPath: getNestedPathByColumnId(columnData.id),\n rowCellValueRenderer: getCellValueRenderer(columnData.id)\n});\n\nconst getBasicTableColumnsData = map(getColumnDataByColumnId);\n\nconst calculateAttributesCellHeight = ({columnData, cell}) => {\n const attributesCount = pipe(path(['values', 0, 'attributes']), values, length)(cell);\n return attributesCount > columnData.maxAttrsToShow\n ? columnData.maxAttrsToShow * 26 + 49\n : attributesCount * 26 + 25;\n};\n\nconst getStaticRowCellHeight = cond([\n [pathEq(['columnData', 'id'], 'relation.attributes'), calculateAttributesCellHeight],\n [T, defaultGetRowCellHeight]\n]);\n\nexport {getBasicTableRowsData, getBasicTableColumnsData, getStaticRowCellHeight};\n","import React from 'react';\nimport classnames from 'classnames';\nimport {useStyles} from './styles';\n\ntype Props = {\n cell: {\n values: unknown[];\n };\n CellValueRenderer: React.ElementType;\n isInactiveRelation?: boolean;\n};\n\nconst RowCellRenderer = ({cell, CellValueRenderer, ...otherProps}: Props) => {\n const styles = useStyles();\n return (\n <div className={classnames(styles.rowCell, {[styles.inactiveRowCell]: otherProps.isInactiveRelation})}>\n {cell.values.map((value, index) => (\n <CellValueRenderer key={index} value={value} {...otherProps} />\n ))}\n </div>\n );\n};\n\nexport default RowCellRenderer;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n menuItem: {\n minHeight: '32px',\n color: theme.palette.text.secondary\n },\n menuText: {\n color: theme.palette.text.primary,\n fontSize: '13px',\n lineHeight: '15px',\n letterSpacing: 0,\n marginLeft: '16px'\n },\n buttons: {\n display: 'flex',\n alignItems: 'center',\n paddingRight: '5px'\n }\n}));\n","import React, {forwardRef, ReactNode} from 'react';\nimport {MenuItem as MenuItem} from '@material-ui/core';\nimport {Typography as Typography} from '@material-ui/core';\nimport {noop, withTooltip} from '@reltio/components';\nimport {useStyles} from './styles';\n\nconst MenuItemWithTooltip = withTooltip(MenuItem);\n\ntype Item = {\n text?: string;\n disabled?: boolean;\n icon: ReactNode;\n tooltip?: string;\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 {icon, disabled, text, tooltip, onClick} = item;\n const handleClick = (e) => {\n onMenuClose();\n onClick(e);\n };\n\n return (\n <MenuItemWithTooltip\n tooltipTitle={tooltip}\n showForDisabled={true}\n classes={{root: styles.menuItem}}\n onClick={handleClick}\n disabled={disabled}\n ref={ref}\n >\n {icon}\n <Typography classes={{root: styles.menuText}}>{text}</Typography>\n </MenuItemWithTooltip>\n );\n});\nMenuItemRenderer.displayName = 'MenuItemRenderer';\n\nexport default MenuItemRenderer;\n","import React, {useCallback, useState} from 'react';\nimport {useSelector} from 'react-redux';\nimport mdmModule from '@reltio/mdm-module';\nimport i18n from 'ui-i18n';\nimport DeleteIcon from '@material-ui/icons/Delete';\nimport MoreVertIcon from '@material-ui/icons/MoreVert';\nimport {ConfirmationDialog, DropDownMenuButton, noop, SmallIconButton} from '@reltio/components';\nimport MenuItemRenderer from './MenuItemRenderer';\nimport {checkMetadataPermission, Connection, getLabel, getRelationType, MetadataPermissions} from '@reltio/mdm-sdk';\nimport {pipe, prop} from 'ramda';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n disableDelete?: boolean;\n connection: Connection;\n onMenuOpen?: () => void;\n onMenuClose?: () => void;\n onDelete: () => void;\n};\n\nexport const RelationshipMenuButton = ({\n disableDelete,\n connection: {entity, relation},\n onMenuOpen = noop,\n onMenuClose = noop,\n onDelete\n}: Props) => {\n const styles = useStyles();\n\n const metadata = useSelector(mdmModule.selectors.getMetadata);\n\n const hasDeletePermission = pipe(\n prop('relationType'),\n getRelationType(metadata),\n checkMetadataPermission(MetadataPermissions.DELETE)\n )(relation);\n\n const canDelete = !disableDelete && hasDeletePermission;\n\n const [pendingDeletion, setPendingDeletion] = useState(false);\n const showDeleteConfirmation = () => setPendingDeletion(true);\n const hideDeleteConfirmation = () => setPendingDeletion(false);\n\n const actions = [\n {\n disabled: !canDelete,\n text: i18n.text('Delete'),\n icon: <DeleteIcon />,\n tooltip: canDelete ? null : i18n.text(\"You don't have permissions to delete\"),\n onClick: showDeleteConfirmation\n }\n ];\n\n const handleMenuClose = useCallback(() => {\n if (!pendingDeletion) {\n onMenuClose();\n }\n }, [pendingDeletion, onMenuClose]);\n const truncateWithEllipsis = (text: string) => (text.length > 17 ? `${text.substring(0, 17)}...` : text);\n\n return (\n <div className={styles.buttons}>\n <DropDownMenuButton\n MenuItemRenderer={MenuItemRenderer}\n menuId={'relationships-table-actions'}\n buttonComponent={SmallIconButton}\n buttonProps={{\n icon: MoreVertIcon,\n size: 'S'\n }}\n menuItems={actions}\n onMenuOpen={onMenuOpen}\n onMenuClose={handleMenuClose}\n />\n <ConfirmationDialog\n open={pendingDeletion}\n title={i18n.text('Do you want to delete relationship \"${label}\"?', {\n label: truncateWithEllipsis(getLabel(entity.entityLabel))\n })}\n content={i18n.text(\n 'This relationship will be removed and all the values in the relationship will be permanently deleted. \\\nAre you sure you want to delete this relationship?'\n )}\n onSave={pipe(hideDeleteConfirmation, onMenuClose, onDelete)}\n onDiscard={pipe(hideDeleteConfirmation, onMenuClose)}\n saveCaption={i18n.text('Delete')}\n discardCaption={i18n.text('Cancel')}\n />\n </div>\n );\n};\n\nexport default RelationshipMenuButton;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles({\n tableContainer: {\n flex: 1,\n overflow: 'hidden',\n display: 'flex',\n zIndex: 0\n },\n hoveredRowRightContentWrapper: {\n width: '100%',\n pointerEvents: 'none!important' as any\n },\n menuButtonContainer: {\n position: 'absolute',\n top: 'calc(50% - 12px)',\n right: 0,\n pointerEvents: 'all'\n },\n tooltipAnchor: {\n width: '100%',\n height: '1px'\n }\n});\n","import React, {ForwardedRef, memo, useCallback, useMemo, useState} from 'react';\nimport {Connection, isActiveObject, Metadata} from '@reltio/mdm-sdk';\nimport {\n BasicTable,\n ColumnData,\n ColumnFilter,\n RowCellAutoSizer,\n Sorting,\n useDynamicRowCellHeight\n} from '@reltio/components';\nimport {Tooltip as Tooltip} from '@material-ui/core';\nimport i18n from 'ui-i18n';\nimport {getBasicTableColumnsData, getBasicTableRowsData, getStaticRowCellHeight} from './helpers';\nimport RowCellRenderer from './cell-renderers/RowCellRenderer';\nimport {either} from 'ramda';\nimport RelationshipMenuButton from '../RelationshipMenuButton/RelationshipMenuButton';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n metadata: Metadata;\n connections: Connection[];\n columnsData: ColumnData[];\n sorting: Sorting;\n onSort: (field: string) => void;\n filters?: Record<string, ColumnFilter>;\n onFilter: (event: {columnId: string; filter: ColumnFilter}) => void;\n onRowClick: (rowIndex: number) => void;\n onDelete: (relationUri: string) => void;\n tableRef: ForwardedRef<unknown>;\n readOnly?: boolean;\n};\n\nconst RelationshipsTable = ({\n metadata,\n connections,\n columnsData,\n sorting,\n onSort,\n filters,\n onFilter,\n onRowClick,\n tableRef,\n onDelete,\n readOnly\n}: Props) => {\n const styles = useStyles();\n\n const tableRowsData = useMemo(() => getBasicTableRowsData(metadata, columnsData, connections), [\n metadata,\n connections,\n columnsData\n ]);\n const tableColumnsData = useMemo(() => getBasicTableColumnsData(columnsData), [columnsData]);\n\n const {getDynamicRowCellHeight, changeRowCellHeight} = useDynamicRowCellHeight();\n const getRowCellHeight = useCallback(either(getDynamicRowCellHeight, getStaticRowCellHeight), [\n getDynamicRowCellHeight,\n getStaticRowCellHeight\n ]);\n const [hoverRowIndex, setHoverRowIndex] = useState<number>(null);\n\n const renderRowCell = useCallback(\n (props) => {\n const isInactiveRelation = !isActiveObject(props.rowValue.rawValue.relation);\n return (\n <RowCellAutoSizer onChangeHeight={changeRowCellHeight} {...props}>\n <RowCellRenderer {...props} isInactiveRelation={isInactiveRelation} />\n </RowCellAutoSizer>\n );\n },\n [changeRowCellHeight]\n );\n\n const [isActionsMenuOpen, setIsActionsMenuOpen] = useState(false);\n\n const handleActionsMenuOpen = useCallback(() => setIsActionsMenuOpen(true), []);\n const handleActionsMenuClose = useCallback(() => {\n setHoverRowIndex(null);\n setIsActionsMenuOpen(false);\n }, []);\n\n const onRowHover = useCallback(\n (rowIndex) => setHoverRowIndex((prevHoverRowIndex) => (isActionsMenuOpen ? prevHoverRowIndex : rowIndex)),\n [isActionsMenuOpen]\n );\n\n const hoveredRowRightContent = useMemo(() => {\n const connection: Connection = hoverRowIndex != null ? tableRowsData[hoverRowIndex].rawValue : null;\n const isInactiveRelation = !isActiveObject(connection?.relation);\n\n return (\n connection && (\n <>\n <Tooltip\n key={connection.relation.relationUri}\n open={isInactiveRelation}\n title={i18n.text('Inactive')}\n >\n <div className={styles.tooltipAnchor} />\n </Tooltip>\n <div className={styles.menuButtonContainer}>\n <RelationshipMenuButton\n disableDelete={readOnly}\n connection={connection}\n onMenuOpen={handleActionsMenuOpen}\n onMenuClose={handleActionsMenuClose}\n onDelete={() => onDelete(connection.relation.relationUri)}\n />\n </div>\n </>\n )\n );\n }, [onDelete, tableRowsData, hoverRowIndex]);\n\n return (\n <div className={styles.tableContainer}>\n <BasicTable\n fixFirstColumn={true}\n columnsData={tableColumnsData}\n rowsData={tableRowsData}\n sorting={sorting}\n onSort={onSort}\n filters={filters}\n onFilter={onFilter}\n defaultColumnWidth={250}\n defaultColumnMinWidth={200}\n headRowHeight={48}\n getRowCellHeight={getRowCellHeight}\n renderRowCell={renderRowCell}\n onRowClick={onRowClick}\n ref={tableRef}\n hoverStateEnabled={true}\n hoverRowIndex={hoverRowIndex}\n onRowHover={onRowHover}\n hoveredRowRightContent={hoveredRowRightContent}\n classes={{\n hoveredRowRightContentWrapper: styles.hoveredRowRightContentWrapper\n }}\n />\n </div>\n );\n};\n\nexport default memo(RelationshipsTable);\n","import {AttributeType, Relation} from '@reltio/mdm-sdk';\nimport {CrosswalksByTypes, groupCrosswalksByTypesAndSources} from '@reltio/components';\nimport {assoc, map, pipe, propOr} from 'ramda';\n\ntype TableRow = {\n source: string;\n crosswalksByTypes: CrosswalksByTypes;\n};\n\nexport const buildTableRowsData = (relation: Relation, selectedAttributeTypes: AttributeType[] = []): TableRow[] => {\n return pipe(\n propOr([], 'crosswalks'),\n map(assoc('ownerType', 'entity')),\n groupCrosswalksByTypesAndSources(relation.type, selectedAttributeTypes)\n )(relation);\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles(() => ({\n tableRow: {\n '& + &': {\n marginTop: '4px'\n },\n margin: 'auto',\n maxWidth: '448px'\n }\n}));\n","import React, {memo, useCallback, useMemo, useState} from 'react';\nimport {\n AttributeType,\n checkCanDeleteCrosswalk,\n checkCanEditCrosswalk,\n getRelationType,\n Metadata,\n Relation,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {DeleteCrosswalkEvent, EditCrosswalkEvent, SourceCrosswalksRow} from '@reltio/components';\nimport {append, ifElse, includes, without} from 'ramda';\nimport {buildTableRowsData} from './helpers';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n readOnly?: boolean;\n relation: Relation;\n metadata: Metadata;\n selectedAttributeTypes?: AttributeType[];\n onDeleteCrosswalk: (event: DeleteCrosswalkEvent) => void;\n onEditCrosswalk: (event: EditCrosswalkEvent) => void;\n};\n\nconst LegendTable = ({\n readOnly,\n relation,\n metadata,\n selectedAttributeTypes,\n onDeleteCrosswalk,\n onEditCrosswalk\n}: Props) => {\n const styles = useStyles();\n\n const relationType: TRelationType = getRelationType(metadata, relation.type);\n\n const rowsData = useMemo(() => buildTableRowsData(relation, selectedAttributeTypes), [\n relation,\n selectedAttributeTypes\n ]);\n const [expandedSources, setExpandedSources] = useState<string[]>([]);\n\n const handleDelete = useCallback(\n (crosswalkId: string) => {\n onDeleteCrosswalk({entityUri: relation.uri, crosswalkId});\n },\n [onDeleteCrosswalk, relation.uri]\n );\n\n const handleEdit = useCallback(\n (event: Omit<EditCrosswalkEvent, 'entityUri'>) => {\n onEditCrosswalk({entityUri: relation.uri, ...event});\n },\n [onEditCrosswalk, relation.uri]\n );\n\n return (\n <div>\n {rowsData.map(({source, crosswalksByTypes}) => {\n return (\n <div key={source} className={styles.tableRow}>\n <SourceCrosswalksRow\n source={source}\n crosswalksByTypes={crosswalksByTypes}\n expanded={expandedSources.includes(source)}\n disableEditCrosswalk={!checkCanEditCrosswalk(relationType) || readOnly}\n disableDeleteCrosswalk={!checkCanDeleteCrosswalk(relationType) || readOnly}\n onEdit={handleEdit}\n onDelete={handleDelete}\n onToggleExpanded={() => {\n setExpandedSources(ifElse(includes(source), without([source]), append(source)));\n }}\n />\n </div>\n );\n })}\n </div>\n );\n};\n\nexport default memo(LegendTable);\n","import {makeStyles, Theme} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme: Theme) => ({\n header: {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n padding: '20px 12px',\n borderBottom: '1px solid rgba(0, 0, 0, 0.12)'\n },\n title: {\n fontWeight: 500,\n fontSize: '20px',\n lineHeight: '23px',\n letterSpacing: '0.25px',\n color: theme.palette.text.primary,\n marginLeft: '12px'\n },\n hint: {\n color: theme.palette.text.secondary,\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n alignSelf: 'flex-start',\n margin: '4px 14px 10px'\n },\n hintText: {\n marginLeft: '8px',\n fontSize: '12px',\n lineHeight: '16px'\n },\n buttons: {\n display: 'flex',\n padding: '8px 6px 4px'\n },\n buttonLabel: {\n fontSize: '14px',\n fontWeight: 500,\n lineHeight: '16px'\n },\n icon: {\n fontSize: '18px',\n marginRight: '8px'\n },\n editor: {\n paddingLeft: 25,\n margin: 'auto',\n maxWidth: '448px',\n boxSizing: 'border-box',\n marginBottom: '4px'\n },\n tableContainer: {\n overflowY: 'auto',\n overflowX: 'hidden',\n paddingLeft: '16px',\n paddingRight: '6px'\n }\n}));\n","import React, {memo, useState} from 'react';\nimport i18n from 'ui-i18n';\nimport {useSelector} from 'react-redux';\nimport mdmModule from '@reltio/mdm-module';\nimport InfoIcon from '@material-ui/icons/Info';\nimport AddIcon from '@material-ui/icons/Add';\nimport {Button as Button} from '@material-ui/core';\nimport LegendTable from '../LegendTable/LegendTable';\nimport {\n AttributeType,\n checkCanCreateCrosswalk,\n getRelationType,\n Metadata,\n Relation,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {\n AddCrosswalkEvent,\n CrosswalkEditor,\n DeleteCrosswalkEvent,\n EditCrosswalkEvent,\n withTooltip\n} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\nconst ButtonWithTooltip = withTooltip(Button);\n\ntype Props = {\n className?: string;\n readOnly?: boolean;\n relation: Relation;\n selectedAttributeTypes?: AttributeType[];\n onAddCrosswalk: (event: AddCrosswalkEvent) => void;\n onDeleteCrosswalk: (event: DeleteCrosswalkEvent) => void;\n onEditCrosswalk: (event: EditCrosswalkEvent) => void;\n};\n\nconst LegendPanel = ({\n className,\n readOnly,\n relation,\n selectedAttributeTypes,\n onAddCrosswalk,\n onDeleteCrosswalk,\n onEditCrosswalk\n}: Props) => {\n const styles = useStyles();\n\n const metadata: Metadata = useSelector(mdmModule.selectors.getMetadata);\n const relationType: TRelationType = getRelationType(metadata, relation.type);\n\n const [openEditor, setOpenEditor] = useState(false);\n const canAdd = checkCanCreateCrosswalk(relationType) && !readOnly;\n\n return (\n <div className={className}>\n <div className={styles.header}>\n <span className={styles.title}>{i18n.text('Legend')}</span>\n </div>\n <div className={styles.buttons}>\n <ButtonWithTooltip\n color=\"primary\"\n showForDisabled={true}\n disabled={!canAdd}\n tooltipTitle={canAdd ? null : i18n.text(\"You don't have permissions to add crosswalk\")}\n onClick={() => setOpenEditor(true)}\n >\n <AddIcon className={styles.icon} />\n <div className={styles.buttonLabel}>{i18n.text('Crosswalk')}</div>\n </ButtonWithTooltip>\n </div>\n <div className={styles.hint}>\n <InfoIcon className={styles.icon} />\n <span className={styles.hintText}>\n {i18n.text('You can drag a crosswalk to add values to attributes swimlanes')}\n </span>\n </div>\n <div className={styles.tableContainer}>\n {openEditor && (\n <CrosswalkEditor\n className={styles.editor}\n onAdd={(crosswalk) => onAddCrosswalk({entity: relation, crosswalk})}\n onClose={() => setOpenEditor(false)}\n />\n )}\n <LegendTable\n readOnly={readOnly}\n metadata={metadata}\n relation={relation}\n selectedAttributeTypes={selectedAttributeTypes}\n onDeleteCrosswalk={onDeleteCrosswalk}\n onEditCrosswalk={onEditCrosswalk}\n />\n </div>\n </div>\n );\n};\n\nexport default memo(LegendPanel);\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n entityInfo: {\n flex: '0 1 auto',\n overflow: 'hidden',\n minWidth: '100px'\n },\n entityLabelContainer: {\n display: 'flex',\n alignItems: 'center',\n overflow: 'hidden'\n },\n entityLabel: {\n lineHeight: '1.2',\n letterSpacing: '0.25px',\n color: theme.palette.text.primary\n },\n infoIcon: {\n fontSize: '16px',\n color: theme.palette.text.secondary,\n marginLeft: '5px'\n },\n profileBand: {\n margin: '-10px',\n maxWidth: '500px'\n },\n entityTypeBadge: {\n marginTop: '7px'\n }\n}));\n","import React from 'react';\nimport {Entity, getLabel} from '@reltio/mdm-sdk';\nimport {Typography as Typography} from '@material-ui/core';\nimport {ExpandedValueTooltip, LightArrowTooltip, ProfileBand, EntityTypeBadge} from '@reltio/components';\nimport InfoIcon from '@material-ui/icons/Info';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n entity: Entity;\n};\n\nconst EntityInfo = ({entity}: Props) => {\n const styles = useStyles();\n const label = getLabel(entity.label);\n return (\n <div className={styles.entityInfo}>\n <div className={styles.entityLabelContainer}>\n <ExpandedValueTooltip value={label}>\n <Typography variant=\"h6\" className={styles.entityLabel} noWrap>\n {label}\n </Typography>\n </ExpandedValueTooltip>\n <LightArrowTooltip\n title={<ProfileBand className={styles.profileBand} entity={entity} />}\n placement={'right'}\n >\n <InfoIcon className={styles.infoIcon} />\n </LightArrowTooltip>\n </div>\n <EntityTypeBadge className={styles.entityTypeBadge} entity={entity} size={'medium'} />\n </div>\n );\n};\n\nexport default EntityInfo;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n root: {\n flexShrink: 0,\n overflow: 'hidden',\n width: '110px'\n },\n label: {\n color: theme.palette.text.secondary,\n fontSize: '13px'\n }\n}));\n","import React from 'react';\nimport {ConnectionRelation} from '@reltio/mdm-sdk';\nimport {Typography as Typography} from '@material-ui/core';\nimport {ExpandedValueTooltip} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n relation: ConnectionRelation;\n};\n\nconst RelationDirection = ({relation}: Props) => {\n const styles = useStyles();\n const {direction, relationLabel} = relation;\n return (\n <div className={styles.root}>\n <ExpandedValueTooltip value={relationLabel}>\n <Typography variant={'subtitle2'} className={styles.label} align={'center'} noWrap>\n {relationLabel}\n </Typography>\n </ExpandedValueTooltip>\n <svg width=\"110\" height=\"12\" fill=\"black\" fillOpacity=\"0.3\">\n {direction === 'out' && <polygon points=\"94 0, 110 6, 94 12, 94 9, 0 9, 0 3, 94 3\" />}\n {direction === 'bidirectional' && (\n <polygon points=\"94 0, 110 6, 94 12, 94 9, 16 9, 16 12, 0 6, 16 0, 16 3, 94 3\" />\n )}\n {direction === 'in' && <polygon points=\"16 12, 0 6, 16 0, 16 3, 110 3, 110 9, 16 9\" />}\n </svg>\n </div>\n );\n};\n\nexport default RelationDirection;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles(() => ({\n root: {\n '&:hover $editButton': {\n visibility: 'visible'\n }\n },\n editButton: {\n visibility: 'hidden',\n marginLeft: '4px',\n marginBottom: '4px'\n },\n paper: {\n width: '150px',\n border: '3px solid rgba(0, 0, 0, 0.3)',\n borderRadius: '4px',\n boxSizing: 'border-box',\n overflow: 'hidden'\n }\n}));\n","import React, {KeyboardEvent, useRef, useState} from 'react';\nimport {formatDate} from '@reltio/mdm-sdk';\nimport {DateEditor, SmallIconButton} from '@reltio/components';\nimport EditIcon from '@material-ui/icons/Edit';\nimport {Popover as Popover} from '@material-ui/core';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n value: number;\n onChange: (value: number) => void;\n readOnly?: boolean;\n};\n\nconst RelationDate = ({value = null, onChange, readOnly}: Props) => {\n const styles = useStyles();\n const ref = useRef<HTMLSpanElement>();\n\n const [showEditor, setShowEditor] = useState(false);\n const openEditor = () => setShowEditor(true);\n const closeEditor = () => setShowEditor(false);\n\n const [editedValue, setEditedValue] = useState(value);\n\n const applyChangesAndClose = () => {\n if (editedValue !== value) {\n onChange(editedValue);\n }\n closeEditor();\n };\n\n const onKeyUp = (event: KeyboardEvent<HTMLDivElement>) => {\n if (event.key === 'Enter') applyChangesAndClose();\n else if (event.key === 'Escape') closeEditor();\n };\n\n return (\n <span ref={ref} className={styles.root}>\n {value && formatDate(value)}\n <SmallIconButton\n disabled={readOnly}\n icon={EditIcon}\n size={'XXS'}\n className={styles.editButton}\n onClick={openEditor}\n />\n <Popover\n classes={{paper: styles.paper}}\n open={showEditor}\n anchorEl={ref.current}\n anchorOrigin={{vertical: 'top', horizontal: 'left'}}\n transformOrigin={{vertical: 14, horizontal: 20}}\n onKeyUp={onKeyUp}\n onBackdropClick={applyChangesAndClose}\n >\n <DateEditor\n InputProps={{\n autoFocus: true,\n disableUnderline: true,\n fullWidth: true\n }}\n size={'small'}\n hiddenLabel={true}\n label={undefined}\n value={editedValue && new Date(editedValue)}\n onChange={(value) => setEditedValue(value && value.valueOf())}\n />\n </Popover>\n </span>\n );\n};\n\nexport default RelationDate;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n relationBand: {\n flexShrink: 0,\n boxShadow: 'inset 0px -1px 0px rgba(0,0,0,0.06)',\n padding: '16px 19px'\n },\n inactiveRelationBand: {\n opacity: 0.6,\n background: 'rgba(185, 188, 197, 0.18)'\n },\n toolbar: {\n display: 'flex',\n alignItems: 'center',\n gap: '16px',\n marginBottom: '10px'\n },\n mainInfo: {\n display: 'flex',\n gap: '16px',\n marginLeft: '40px'\n },\n detailsInfo: {\n display: 'flex',\n gap: '34px',\n marginLeft: '40px',\n marginTop: '17px',\n color: theme.palette.text.secondary,\n fontSize: '13px'\n },\n detailTitle: {\n color: theme.palette.text.primary,\n flexShrink: 0,\n marginRight: '4px'\n },\n directionalLabel: {\n display: 'flex',\n overflow: 'hidden',\n '& span': {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap'\n }\n },\n relationDate: {\n flexShrink: 0\n },\n commentsContainer: {\n marginRight: '18px'\n }\n}));\n","import React, {memo} from 'react';\nimport {CollaborationObjectTypes, Connection, createRelatedObjectUris, Entity, isActiveObject} from '@reltio/mdm-sdk';\nimport {\n CommentsContainer,\n COMMENTS_CONTAINER_VISIBILITY_AREA,\n ExpandedValueTooltip,\n SmallIconButton,\n Spacer\n} from '@reltio/components';\nimport classnames from 'classnames';\nimport ArrowBackIcon from '@material-ui/icons/ArrowBack';\nimport {Typography as Typography} from '@material-ui/core';\nimport EntityInfo from './EntityInfo/EntityInfo';\nimport RelationDirection from './RelationDirection/RelationDirection';\nimport RelationDate from './RelationDate/RelationDate';\nimport RelationshipMenuButton from '../RelationshipMenuButton/RelationshipMenuButton';\nimport i18n from 'ui-i18n';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n readOnly?: boolean;\n entity: Entity;\n connection: Connection;\n onNavigateBack: () => void;\n onDelete: () => void;\n onChangeActivenessDate: (attributeName: string, value: number) => void;\n};\n\nconst RelationshipBand = ({readOnly, entity, connection, onNavigateBack, onDelete, onChangeActivenessDate}: Props) => {\n const isInactiveRelation = !isActiveObject(connection.relation);\n const styles = useStyles();\n return (\n <div\n className={classnames(styles.relationBand, COMMENTS_CONTAINER_VISIBILITY_AREA, {\n [styles.inactiveRelationBand]: isInactiveRelation\n })}\n >\n <div className={styles.toolbar}>\n <SmallIconButton icon={ArrowBackIcon} size={'S'} onClick={() => onNavigateBack()} />\n <Typography variant={'subtitle2'} display={'inline'}>\n {i18n.text('Back to relationships')}\n </Typography>\n <Spacer />\n <div className={styles.commentsContainer}>\n <CommentsContainer\n uri={connection.relation.relationUri}\n relatedObjectUris={createRelatedObjectUris(CollaborationObjectTypes.RELATION, {\n entityUri: entity?.uri,\n connection\n })}\n objectType={CollaborationObjectTypes.RELATION}\n allowOnlyOneComment\n />\n </div>\n <RelationshipMenuButton connection={connection} onDelete={onDelete} disableDelete={readOnly} />\n </div>\n <div className={styles.mainInfo}>\n <EntityInfo entity={entity} />\n <RelationDirection relation={connection.relation} />\n <EntityInfo entity={{...connection.entity.object, dataTenant: connection.entity.dataTenant}} />\n </div>\n <div className={styles.detailsInfo}>\n <div className={styles.directionalLabel}>\n <span className={styles.detailTitle}>{i18n.text('Directional label:')}</span>\n <ExpandedValueTooltip value={connection.relation.relationLabel}>\n <span>{connection.relation.relationLabel}</span>\n </ExpandedValueTooltip>\n </div>\n <div className={styles.relationDate}>\n <span className={styles.detailTitle}>{i18n.text('Start date:')}</span>\n <RelationDate\n value={connection.relation.startDate}\n onChange={(value) => onChangeActivenessDate('startDate', value)}\n readOnly={readOnly}\n />\n </div>\n <div className={styles.relationDate}>\n <span className={styles.detailTitle}>{i18n.text('End date:')}</span>\n <RelationDate\n value={connection.relation.endDate}\n onChange={(value) => onChangeActivenessDate('endDate', value)}\n readOnly={readOnly}\n />\n </div>\n </div>\n </div>\n );\n};\n\nexport default memo(RelationshipBand);\n","import {ErrorPopup} from '@reltio/components';\nimport i18n from 'ui-i18n';\nimport {getRequestErrorMessage} from '@reltio/mdm-sdk';\n\nexport const showErrorMessage = (error: unknown) => {\n console.error(error); // eslint-disable-line\n ErrorPopup.addError({\n title: i18n.text('Error'),\n message: getRequestErrorMessage(error, i18n.text('Something went wrong'))\n });\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles({\n detailsView: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n overflow: 'hidden'\n },\n locked: {\n pointerEvents: 'none'\n },\n resizablePanesWrapper: {\n flexGrow: 1\n },\n pane: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n display: 'flex',\n flexDirection: 'column',\n overflow: 'hidden'\n }\n});\n","import React, {memo, useCallback, useMemo, useState} from 'react';\nimport classnames from 'classnames';\nimport {\n ApiError,\n ApiErrorCode,\n AttributeType,\n Connection,\n deleteActivenessAttribute,\n Entity,\n getRelation,\n Relation,\n updateActivenessAttribute\n} from '@reltio/mdm-sdk';\nimport {\n AttributesTable,\n BasicView,\n CrosswalkDragLayer,\n CrosswalksDisplayProvider,\n ExpandedAttributesProvider,\n ResizablePanes,\n useCrosswalkActions,\n useModifiedEntity,\n useSafePromise\n} from '@reltio/components';\nimport LegendPanel from '../LegendPanel/LegendPanel';\nimport RelationshipBand from '../RelationshipBand/RelationshipBand';\nimport {assocPath, dissocPath, pipe} from 'ramda';\nimport {showErrorMessage} from '../../services/errors';\nimport {useCrosswalksDisplay} from '../../hooks/useCrosswalksDisplay';\nimport HTML5Backend from 'react-dnd-html5-backend';\nimport {DndProvider} from 'react-dnd';\n\nimport {useStyles} from './styles';\n\nconst MIN_PANE1_SIZE = 600;\nconst MIN_PANE2_SIZE = 480;\nconst MAX_PANE1_SIZE = -MIN_PANE2_SIZE;\n\ntype Props = {\n entity: Entity;\n connection: Connection;\n visibleColumns?: string[];\n onClose: (error?: ApiError) => void;\n onDeleteConnection: () => void;\n onChangeConnection: (connection: Connection) => void;\n onChangeVisibleColumns: (visibleColumns: string[]) => void;\n readOnly?: boolean;\n};\n\nconst RelationshipDetails = ({\n entity,\n connection,\n visibleColumns,\n onClose,\n onDeleteConnection,\n onChangeConnection,\n onChangeVisibleColumns,\n readOnly\n}: Props) => {\n const styles = useStyles();\n const displayProps = useCrosswalksDisplay();\n const [paneSize, setPaneSize] = useState(MAX_PANE1_SIZE);\n const handlePaneSizeChange = useCallback(({percentageSize}) => setPaneSize(percentageSize), []);\n\n const [selectedAttrTypes, setSelectedAttrTypes] = useState<AttributeType[]>();\n const [isLoading, setIsLoading] = useState(false);\n const relationUri = connection.relation.relationUri;\n\n const safePromise = useSafePromise();\n const onLoad = useCallback(() => setIsLoading(true), []);\n const onLoaded = useCallback(() => setIsLoading(false), []);\n const onDeleteRelation = useCallback(pipe(onDeleteConnection, onLoad), []);\n const [onError, reloadRelation] = useMemo(() => {\n const onError = (error: ApiError) => {\n if (error.errorCode === ApiErrorCode.CROSSWALK_NOT_FOUND) {\n showErrorMessage(error);\n reloadRelation();\n } else if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n onClose(error);\n } else {\n showErrorMessage(error);\n onLoaded();\n }\n };\n const reloadRelation = () => {\n safePromise(getRelation(relationUri))\n .then((newRelation: Relation) => {\n onChangeConnection(assocPath(['relation', 'object'], newRelation, connection));\n onLoaded();\n })\n .catch(onError);\n };\n return [onError, reloadRelation];\n }, [connection, onLoaded, onChangeConnection, onClose]);\n\n const {\n modifiedEntity,\n crosswalksMap,\n newlyCreatedAttributes,\n onPinAttribute,\n onIgnoreAttribute,\n onAddAttribute,\n onEditAttribute,\n onDeleteAttribute\n } = useModifiedEntity({\n entity: connection.relation.object,\n onModify: reloadRelation,\n onError,\n onLoad\n });\n\n const {addCrosswalk, deleteCrosswalk, editCrosswalk} = useCrosswalkActions({\n onSuccess: reloadRelation,\n onError,\n onLoad\n });\n\n const onChangeActivenessDate = useCallback(\n (attributeName: string, value: number) => {\n onLoad();\n const request = value\n ? updateActivenessAttribute({entityUri: relationUri, attributeName, value}).then(() =>\n onChangeConnection(assocPath(['relation', attributeName], value, connection))\n )\n : deleteActivenessAttribute({entityUri: relationUri, attributeName}).then(() =>\n onChangeConnection(dissocPath(['relation', attributeName], connection))\n );\n request.then(onLoaded).catch(onError);\n },\n [connection, onLoad, onLoaded, onError]\n );\n\n return (\n <BasicView className={styles.detailsView}>\n <CrosswalksDisplayProvider {...displayProps}>\n <DndProvider backend={HTML5Backend}>\n <CrosswalkDragLayer />\n <ResizablePanes\n className={classnames(styles.resizablePanesWrapper, {[styles.locked]: isLoading})}\n orientation={'vertical'}\n size={paneSize}\n minSize={MIN_PANE1_SIZE}\n maxSize={MAX_PANE1_SIZE}\n allowResize={true}\n onChange={handlePaneSizeChange}\n >\n <div className={styles.pane}>\n <RelationshipBand\n readOnly={readOnly}\n entity={entity}\n connection={connection}\n onNavigateBack={onClose}\n onDelete={onDeleteRelation}\n onChangeActivenessDate={onChangeActivenessDate}\n />\n <ExpandedAttributesProvider attributeUris={newlyCreatedAttributes}>\n <AttributesTable\n readOnly={readOnly}\n entity={modifiedEntity}\n crosswalksMap={crosswalksMap}\n isLoading={isLoading}\n onPin={onPinAttribute}\n onIgnore={onIgnoreAttribute}\n onEdit={onEditAttribute}\n onAdd={onAddAttribute}\n onDelete={onDeleteAttribute}\n selectedAttributeTypes={selectedAttrTypes}\n onSelectAttributeTypes={setSelectedAttrTypes}\n visibleColumns={visibleColumns}\n onChangeVisibleColumns={onChangeVisibleColumns}\n />\n </ExpandedAttributesProvider>\n </div>\n <LegendPanel\n readOnly={readOnly}\n className={styles.pane}\n relation={connection.relation.object}\n selectedAttributeTypes={selectedAttrTypes}\n onAddCrosswalk={addCrosswalk}\n onDeleteCrosswalk={deleteCrosswalk}\n onEditCrosswalk={editCrosswalk}\n />\n </ResizablePanes>\n </DndProvider>\n </CrosswalksDisplayProvider>\n </BasicView>\n );\n};\n\nexport default memo(RelationshipDetails);\n","import {useCallback, useMemo, useState, useRef} from 'react';\nimport {CrosswalkBase, debounce, eqCrosswalks} from '@reltio/mdm-sdk';\nimport {any, concat} from 'ramda';\n\nexport const useCrosswalksDisplay = () => {\n const [highlightedCrosswalks, setHighlightedCrosswalks] = useState<CrosswalkBase[]>([]);\n const highlightedCrosswalksCache = useRef([]);\n const applyHighlightedCrosswalks = useCallback(\n debounce(() => {\n setHighlightedCrosswalks([...highlightedCrosswalksCache.current]);\n }, 50),\n []\n );\n const cacheHighlightedCrosswalks = useCallback(\n (arr) => {\n highlightedCrosswalksCache.current = arr;\n applyHighlightedCrosswalks(arr);\n },\n [applyHighlightedCrosswalks]\n );\n\n const setCrosswalkHighlighted = useCallback(\n (crosswalk: CrosswalkBase, highlighted: boolean) => {\n if (!crosswalk) return;\n if (highlighted) {\n cacheHighlightedCrosswalks([crosswalk]);\n } else {\n cacheHighlightedCrosswalks([]);\n }\n },\n [cacheHighlightedCrosswalks]\n );\n\n const [focusedCrosswalks, setFocusedCrosswalks] = useState<CrosswalkBase[]>([]);\n const calculateFocusedCrosswalks = (prev: CrosswalkBase[], next: CrosswalkBase[]) =>\n concat(\n prev.filter((prevCrosswalk) => !any(eqCrosswalks(prevCrosswalk), next)),\n next.filter((nextCrosswalk) => !any(eqCrosswalks(nextCrosswalk), prev))\n );\n\n const toggleCrosswalkFocus = useCallback((crosswalk: CrosswalkBase) => {\n if (!crosswalk) return;\n setFocusedCrosswalks((prevValue) => calculateFocusedCrosswalks([crosswalk], prevValue));\n }, []);\n\n return {\n highlightedCrosswalks: useMemo(() => [...highlightedCrosswalks, ...focusedCrosswalks], [\n highlightedCrosswalks,\n focusedCrosswalks\n ]),\n focusedCrosswalks,\n toggleCrosswalkFocus,\n setCrosswalkHighlighted\n };\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles({\n relationshipsView: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n overflowX: 'hidden',\n overflowY: 'auto',\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif',\n display: 'flex',\n flexDirection: 'column'\n },\n '@global div[role=tooltip]': {\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif'\n },\n '@global div[role=presentation]': {\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif'\n },\n pane: {\n display: 'flex',\n flexDirection: 'column',\n flex: 1,\n overflow: 'hidden',\n position: 'relative'\n }\n});\n","import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react';\nimport {Dispatch} from 'redux';\nimport {connect} from 'react-redux';\nimport {\n always,\n andThen,\n both,\n either,\n equals,\n filter,\n identity,\n map,\n otherwise,\n pipe,\n prop,\n propEq,\n update,\n when,\n not\n} from 'ramda';\nimport mdmModule, {profile} from '@reltio/mdm-module';\nimport {\n ApiError,\n ApiErrorCode,\n checkMetadataPermission,\n CollaborationObjectTypes,\n Connection,\n Entity,\n getEntitiesMapForConnections,\n getInheritancePath,\n getRelationshipsObjectIdsForCollaboration,\n isDataTenantEntity,\n Metadata,\n MetadataPermissions,\n Mode,\n RelationshipsPerspectiveConfig,\n removeRelation,\n TRelationType,\n ActivityFilter\n} from '@reltio/mdm-sdk';\nimport {\n BasicTablePagination,\n CollaborationContextProvider,\n EntitiesMapContext,\n LinearLoadIndicator,\n ScreenProfileBand,\n useCollaboration,\n useDidUpdateEffect,\n useRelationsLoader\n} from '@reltio/components';\nimport useSavedState from '../../hooks/useSavedState';\nimport {useRelationshipsTable} from '../../hooks/useRelationshipsTable';\nimport {RelationshipsSavedState} from '../../types';\nimport {DEFAULT_COLUMNS, getColumnsData, ROWS_PER_PAGE_OPTIONS} from './helpers/tableHelpers';\nimport {buildRelationshipsFilter} from './helpers/filtersHelpers';\nimport RelationshipsTableHeader from '../RelationshipsTableHeader/RelationshipsTableHeader';\nimport RelationshipsTable from '../RelationshipsTable/RelationshipsTable';\nimport RelationshipDetails from '../RelationshipDetails/RelationshipDetails';\nimport {showErrorMessage} from '../../services/errors';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n config: RelationshipsPerspectiveConfig;\n entity: Entity;\n metadata: Metadata;\n connections: Connection[];\n total: number;\n saveState: (state: RelationshipsSavedState) => void;\n getSavedState: () => Promise<RelationshipsSavedState>;\n dispatch: Dispatch;\n};\n\nconst RelationshipsView = ({\n config,\n entity,\n metadata,\n connections,\n total,\n saveState,\n getSavedState,\n dispatch\n}: Props) => {\n const styles = useStyles();\n const tableRef = useRef();\n\n const isDTEntity = isDataTenantEntity(entity);\n\n const [searchByOv, setSearchByOv] = useState(false);\n const [showInactive, setShowInactive] = useState(false);\n\n const {type: entityTypeUri} = entity || {};\n const [\n {\n visibleColumns,\n filters,\n page,\n rowsPerPage,\n sorting,\n currentRelationType,\n stateToSave,\n entityTypeOfAppliedSavedState\n },\n {\n changeColumns,\n toggleFilters,\n changeFilter,\n changePage,\n changeRowsPerPage,\n toggleSort,\n changeRelationType,\n saveCurrentState,\n applySavedState\n }\n ] = useRelationshipsTable({\n defaultColumns: DEFAULT_COLUMNS,\n defaultRowsPerPage: ROWS_PER_PAGE_OPTIONS[0],\n defaultSorting: {\n field: DEFAULT_COLUMNS[0],\n order: 'asc'\n }\n });\n\n const isSavedStateApplied = entityTypeOfAppliedSavedState === entityTypeUri;\n\n const {\n isLoading: isSavedStateLoading,\n relationsTableSavedState,\n attributesTableSavedState,\n updateRelationsTableSavedState,\n updateAttributesTableSavedState\n } = useSavedState({\n getSavedState,\n saveState,\n entityTypeUri\n });\n\n const [attributesTableVisibleColumns, setAttributesTableVisibleColumns] = useState<string[]>();\n\n useEffect(() => {\n if (!isSavedStateLoading) {\n applySavedState({savedState: relationsTableSavedState, entityTypeUri});\n }\n }, [isSavedStateLoading, entityTypeUri]); // eslint-disable-line\n\n useEffect(() => {\n if (!isSavedStateLoading) {\n setAttributesTableVisibleColumns(attributesTableSavedState?.visibleColumns);\n }\n }, [isSavedStateLoading]); // eslint-disable-line\n\n useDidUpdateEffect(() => {\n if (isSavedStateApplied) {\n updateRelationsTableSavedState(stateToSave);\n }\n }, [stateToSave]);\n\n const resetPage = () => {\n changePage(0);\n };\n useDidUpdateEffect(resetPage, [entity]);\n\n const [detailedConnectionIndex, setDetailedConnectionIndex] = useState<number>();\n const hideConnectionDetails = useCallback(() => {\n setDetailedConnectionIndex(null);\n }, []);\n\n const relationTypes: TRelationType[] = useMemo(() => {\n const inheritancePath = getInheritancePath(metadata, entityTypeUri);\n const isRelatedToEntityType = ({startObject, endObject}) =>\n inheritancePath.some(either(equals(startObject.objectTypeURI), equals(endObject.objectTypeURI)));\n return metadata.relationTypes.filter(\n both(checkMetadataPermission(MetadataPermissions.READ), isRelatedToEntityType)\n );\n }, [metadata, entityTypeUri]);\n\n const columnsData = useMemo(\n () => getColumnsData(relationTypes, currentRelationType),\n [relationTypes, currentRelationType]\n );\n const visibleColumnsData = useMemo(\n () => visibleColumns.map((id) => columnsData.find(propEq('id', id))).filter(identity),\n [visibleColumns, columnsData]\n );\n\n const relationsConfig = useMemo(() => {\n const relations = pipe(\n when(always(currentRelationType), filter(propEq('uri', currentRelationType))),\n map(prop('uri'))\n )(relationTypes);\n return {\n id: config.id,\n content: {\n inRelations: relations,\n outRelations: relations\n }\n };\n }, [config.id, currentRelationType, relationTypes]);\n\n const relationFilter = useMemo(\n () => buildRelationshipsFilter(filters, visibleColumnsData),\n [filters, visibleColumnsData]\n );\n\n const {isLoading: isRelationsLoading, reload: reloadRelations} = useRelationsLoader({\n page,\n rowsPerPage,\n config: relationsConfig,\n entity: isSavedStateApplied ? entity : null,\n filter: relationFilter,\n mode: Mode.Viewing,\n sorting,\n searchByOv,\n relationActivityFilter: showInactive ? ActivityFilter.ALL : ActivityFilter.ACTIVE_ONLY\n });\n\n const isLoading = !isSavedStateApplied || isRelationsLoading;\n\n const onSort = useCallback(pipe(toggleSort, saveCurrentState), [toggleSort, saveCurrentState]);\n const onFilter = useCallback(pipe(changeFilter, saveCurrentState), [changeFilter, saveCurrentState]);\n const onToggleFilters = useCallback(pipe(toggleFilters, saveCurrentState), [toggleFilters, saveCurrentState]);\n const onChangeColumns = useCallback(pipe(changeColumns, saveCurrentState), [changeColumns, saveCurrentState]);\n const onRelationTypeChange = useCallback(pipe(changeRelationType, saveCurrentState), [\n changeRelationType,\n saveCurrentState\n ]);\n const onChangeDetailedColumns = useCallback(\n (visibleColumns: string[]) => {\n setAttributesTableVisibleColumns(visibleColumns);\n updateAttributesTableSavedState({visibleColumns});\n },\n [updateAttributesTableSavedState]\n );\n\n const detailedConnection = connections?.[detailedConnectionIndex];\n const onChangeDetailedConnection = useCallback(\n (newConnection: Connection) => {\n dispatch(\n profile.relations.actions.relationsLoaded({\n id: config.id,\n connections: update(detailedConnectionIndex, newConnection, connections),\n total\n })\n );\n },\n [detailedConnection]\n );\n const [objectIds, objectTypes] = useMemo(() => {\n return [getRelationshipsObjectIdsForCollaboration(connections), [CollaborationObjectTypes.RELATION]];\n }, [connections]);\n\n const collaboration = useCollaboration({objectIds, objectTypes, enabled: !isDTEntity});\n const entitiesMap = useMemo(() => getEntitiesMapForConnections(connections), [connections]);\n\n const handleError = useCallback(\n (error: ApiError) => {\n showErrorMessage(error);\n if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n reloadRelations();\n }\n },\n [reloadRelations]\n );\n\n const deleteRelation = useCallback(\n (relationUri: string) => {\n pipe(removeRelation, andThen(reloadRelations), otherwise(handleError))(relationUri);\n },\n [reloadRelations, handleError]\n );\n\n const deleteRelationAndCloseDetails = useCallback(() => {\n pipe(\n removeRelation,\n andThen(pipe(hideConnectionDetails, reloadRelations)),\n otherwise((error: ApiError) => {\n if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n hideConnectionDetails();\n }\n handleError(error);\n })\n )(detailedConnection.relation.relationUri);\n }, [detailedConnection, reloadRelations, hideConnectionDetails, handleError]);\n\n const onCloseConnectionDetails = useCallback(\n (error?: ApiError) => {\n if (error) handleError(error);\n hideConnectionDetails();\n },\n [handleError, hideConnectionDetails]\n );\n\n const onToggleSearchByOv = useCallback(() => {\n setSearchByOv(not);\n }, []);\n\n const onToggleShowInactive = useCallback(() => {\n setShowInactive(not);\n }, []);\n\n return (\n <CollaborationContextProvider collaboration={collaboration}>\n <EntitiesMapContext.Provider value={entitiesMap}>\n <div className={styles.relationshipsView}>\n <ScreenProfileBand entity={entity} />\n <RelationshipsTableHeader\n total={total}\n filteringEnabled={!!filters}\n onToggleFilters={onToggleFilters}\n columnsData={columnsData}\n selectedColumns={visibleColumns}\n onChangeColumns={onChangeColumns}\n relationTypes={relationTypes}\n currentRelationType={currentRelationType}\n onRelationTypeChange={onRelationTypeChange}\n searchByOv={searchByOv}\n onToggleSearchByOv={onToggleSearchByOv}\n showInactive={showInactive}\n onToggleShowInactive={onToggleShowInactive}\n />\n <div className={styles.pane}>\n {isLoading && <LinearLoadIndicator />}\n <RelationshipsTable\n readOnly={isDTEntity}\n metadata={metadata}\n connections={connections}\n columnsData={visibleColumnsData}\n sorting={sorting}\n onSort={onSort}\n filters={filters}\n onFilter={onFilter}\n onRowClick={setDetailedConnectionIndex}\n tableRef={tableRef}\n onDelete={deleteRelation}\n />\n <BasicTablePagination\n count={total}\n rowsPerPageOptions={ROWS_PER_PAGE_OPTIONS}\n page={page}\n onChangePage={changePage}\n rowsPerPage={rowsPerPage}\n onChangeRowsPerPage={changeRowsPerPage}\n basicTableRef={tableRef}\n />\n </div>\n {detailedConnection && (\n <RelationshipDetails\n readOnly={isDTEntity}\n entity={entity}\n visibleColumns={attributesTableVisibleColumns}\n onChangeVisibleColumns={onChangeDetailedColumns}\n connection={detailedConnection}\n onClose={onCloseConnectionDetails}\n onDeleteConnection={deleteRelationAndCloseDetails}\n onChangeConnection={onChangeDetailedConnection}\n />\n )}\n </div>\n </EntitiesMapContext.Provider>\n </CollaborationContextProvider>\n );\n};\n\nconst mapStateToProps = (state, {config: {id}}) => {\n return {\n entity: mdmModule.selectors.getEntity(state),\n metadata: mdmModule.selectors.getMetadata(state),\n connections: mdmModule.selectors.getConnectionsByViewId(state, id),\n total: mdmModule.selectors.getTotalByViewId(state, id)\n };\n};\n\nexport default connect(mapStateToProps)(RelationshipsView);\n","import {buildColumnsFilter, ColumnFilter} from '@reltio/components';\nimport {FilterBuilder} from '@reltio/mdm-sdk';\nimport {RelationshipsTableColumnData} from '../../../types';\n\nexport const buildRelationshipsFilter = (\n filters: Record<string, ColumnFilter>,\n columnsData: RelationshipsTableColumnData[]\n) => {\n const filtersClause = buildColumnsFilter(columnsData, filters);\n\n return new FilterBuilder().addClause(filtersClause).build();\n};\n","import React, {useCallback, useContext, useMemo} from 'react';\nimport {Provider} from 'react-redux';\nimport {Store} from 'redux';\n\nimport MomentUtils from '@date-io/moment';\nimport {createGenerateClassName, StylesProvider} from '@material-ui/core/styles';\nimport ReactResizeDetector from 'react-resize-detector';\nimport {MuiPickersUtilsProvider} from '@material-ui/pickers';\nimport {ErrorPopup, ViewIdContext, FeaturesContext} from '@reltio/components';\nimport mdmModule from '@reltio/mdm-module';\nimport {RelationshipsSavedState} from '../../types';\nimport RelationshipsView from './RelationshipsView';\nimport {promisifyCallback, RelationshipsPerspectiveConfig} from '@reltio/mdm-sdk';\n\nconst generateClassName = createGenerateClassName({\n productionPrefix: 'relationshipsPerspective',\n disableGlobal: true\n});\n\ntype Props = {\n config: RelationshipsPerspectiveConfig;\n store: Store<unknown>;\n onResize?: (width: number, height: number) => void;\n saveState: (state: RelationshipsSavedState) => void;\n getSavedState: (clb: (state: RelationshipsSavedState) => void) => void;\n};\n\nconst RelationshipsPerspective = ({config, store, onResize, saveState, getSavedState}: Props) => {\n const getSavedStatePromisified: () => Promise<RelationshipsSavedState> = useCallback(\n promisifyCallback(getSavedState),\n [getSavedState]\n );\n const featuresContext = useContext(FeaturesContext);\n const showDescription = mdmModule.selectors.getShowAttributeDescription(store.getState());\n const features = useMemo(() => ({...featuresContext, showDescription}), [featuresContext, showDescription]);\n\n return (\n <Provider store={store}>\n <ViewIdContext.Provider value={config.id}>\n <FeaturesContext.Provider value={features}>\n <StylesProvider generateClassName={generateClassName}>\n <MuiPickersUtilsProvider utils={MomentUtils}>\n <ReactResizeDetector\n handleHeight\n onResize={(width, height) => onResize?.(Math.floor(width), Math.floor(height))}\n />\n {config && (\n <RelationshipsView\n config={config}\n saveState={saveState}\n getSavedState={getSavedStatePromisified}\n />\n )}\n <ErrorPopup />\n </MuiPickersUtilsProvider>\n </StylesProvider>\n </FeaturesContext.Provider>\n </ViewIdContext.Provider>\n </Provider>\n );\n};\n\nexport default RelationshipsPerspective;\n","import {RelationshipsView} from '@reltio/relationships';\n\nexport default RelationshipsView;\n"],"names":["MomentUtils","_a","_b","locale","instance","moment","this","yearFormat","yearMonthFormat","dateTime12hFormat","dateTime24hFormat","time12hFormat","time24hFormat","dateFormat","prototype","parse","value","format","date","isValid","isNull","getDiff","comparing","diff","isAfter","isBefore","isAfterDay","isBeforeDay","isBeforeYear","isAfterYear","startOfDay","clone","startOf","endOfDay","endOf","formatString","formatNumber","numberToFormat","getHours","get","addDays","count","subtract","Math","abs","add","setHours","hours","getMinutes","setMinutes","minutes","getSeconds","setSeconds","seconds","getMonth","isSameDay","isSame","isSameMonth","isSameYear","isSameHour","setMonth","month","getMeridiemText","ampm","startOfMonth","endOfMonth","getNextMonth","getPreviousMonth","getMonthArray","monthArray","length","prevMonth","push","getYear","setYear","year","set","mergeDateAndTime","time","getWeekdays","weekdaysShort","isEqual","getWeekArray","start","end","current","nestedWeeks","weekNumber","floor","getYearRange","startDate","endDate","years","getCalendarHeaderText","getYearText","getDatePickerHeaderText","getDateTimePickerHeaderText","getMonthText","getDayText","getHourText","getMinuteText","getSecondText","_interopRequireDefault","exports","_react","_default","default","createElement","d","Fragment","transform","fill","props","width","height","viewBox","xmlns","fillRule","stroke","strokeWidth","useStyles","makeStyles","theme","color","palette","primary","main","closeIcon","position","right","bottom","button","padding","FilterButton","enabled","onClick","styles","Tooltip","title","i18n","IconButton","classes","root","Filter","className","Close","propTypes","PropTypes","pagination","display","alignItems","justifyContent","borderTop","boxShadow","caption","fontSize","lineHeight","selectRoot","marginLeft","marginRight","select","textAlign","actions","BasicTablePagination","rowsPerPageOptions","page","onChangePage","rowsPerPage","onChangeRowsPerPage","basicTableRef","labelRowsPerPage","resetScrollbarPosition","useCallback","pathOr","identity","handleChangePage","handleChangeRowsPerPage","TablePagination","classnames","component","labelDisplayedRows","from","to","fromRow","toRow","countRows","pipe","nthArg","getValue","React","CHANGE_COLUMNS","TOGGLE_FILTERS","CHANGE_FILTER","TOGGLE_SORT","CHANGE_PAGE","CHANGE_ROWS_PER_PAGE","changeColumns","createStandardAction","toggleFilters","changeFilter","toggleSort","changePage","changeRowsPerPage","changeVisibleColumns","state","nextVisibleColumns","removedColumns","difference","visibleColumns","isRemovedColumn","columnId","includes","evolve","always","sorting","when","field","nextSortField","order","filters","keys","reduce","acc","dissoc","reducer","action","type","columnIds","payload","enableFilters","filter","assoc","prevSortField","path","prevSortOrder","toggleSortOrder","flexDirection","basicView","BasicView","forwardRef","ref","children","otherProps","Paper","displayName","paper","minHeight","fontWeight","letterSpacing","content","contentText","marginBottom","actionButtons","paddingTop","discardButton","open","onCancel","cancelCaption","onDiscard","discardCaption","onSave","saveCaption","disabledSave","Dialog","onClose","paperScrollPaper","DialogTitle","DialogContent","DialogContentText","DialogActions","disableSpacing","Button","disabled","autoFocus","menuItem","menuText","text","checkbox","SettingsMenuItemRenderer","item","onMenuClose","id","selected","MenuItem","e","Checkbox","checked","Typography","items","menuId","DropDownMenuButton","buttonComponent","SmallIconButtonWithTooltip","buttonProps","icon","SettingsIcon","tooltipTitle","size","menuItems","MenuItemRenderer","VerticalDivider","margin","style","borderLeft","flexShrink","useActions","dispatch","useMemo","Object","entries","actionName","actionCreator","buildSuggestedIds","wrapInArrayIfNeeded","times","n","useRelationsLoader","config","entity","relationActivityFilter","mode","searchByOv","isLoading","setIsLoading","useState","useDispatch","tenant","useSelector","mdm","metadata","dtssPath","activityFilter","globalFilter","lastLoadedTime","safePromise","useSafePromise","processContent","getUri","isObject","prop","filterRelation","isAvailableRelationTypeUri","entityTypes","filterFn","isAvailableEntityTypeUri","inRelations","outRelations","nextEntry","suggested","options","loadRelations","uri","requestConfig","sortBy","returnDates","returnObjects","activeness","relation","ActivityFilter","max","offset","addGlobalFilterToQuery","undefined","configs","concat","ifElse","map","i","request","cond","isTempUri","Promise","resolve","total","isDataTenantEntity","getRelationsForDataTenantEntity","entityUri","customerTenant","dataTenant","T","getRelationsForEntity","then","connections","profile","finally","isRequestSentRef","useRef","useEffect","prevMode","usePrevious","Mode","reload","DEFAULT_SAVED_STATE","relationsTable","attributesTable","RELATION_TYPE_COLUMN_ID","ATTRIBUTES_COLUMN_ID","DEFAULT_COLUMNS_DATA","label","dataTypeDefinition","DataTypes","hideable","filterable","initialWidth","autoResize","sortable","maxAttrsToShow","DEFAULT_COLUMNS","pluck","ALL_TYPES_COLUMNS","ROWS_PER_PAGE_OPTIONS","getColumnIdFromAttrUri","attributeUriToSearchUri","getColumnsDataFromRelationAttributes","attr","description","getAttrDataTypeDefinition","uniqBy","CHANGE_RELATION_TYPE","APPLY_SAVED_STATE","SAVE_CURRENT_STATE","basicTableViewState","changeRelationType","applySavedState","saveCurrentState","resetPageNumber","getDefaultVisibleColumnsForCurrentRelationType","currentRelationType","without","intersection","getSavedVisibleColumnsForCurrentRelationType","changeVisibleColumnsForCurrentRelationType","either","getFiltersFromSavedState","propOr","unless","isNil","validateFilterValue","saveVisibleColumnsForCurrentRelationType","visibleColumnsForRelationTypes","getStateToSave","pick","paddingLeft","paddingRight","selectMenu","textField","maxWidth","onChange","relationTypes","DropDownEditor","displayEmpty","disableUnderline","TextFieldProps","MenuProps","list","header","boxSizing","secondary","relationTypeSelector","overflow","memo","filteringEnabled","onToggleFilters","columnsData","selectedColumns","onRelationTypeChange","onChangeColumns","onToggleSearchByOv","showInactive","onToggleShowInactive","settingItems","BasicViewHeader","variant","Spacer","SettingsMenu","ColumnsSettings","headCell","background","rowCell","overflowWrap","inactiveRowCell","opacity","defaultWrapper","paddingBottom","entityCell","entityAvatar","inactiveEntityAvatar","backgroundColor","border","borderRadius","entityLabel","textDecoration","attributesWrapper","commentsContainer","withFilterAtBottom","headCellData","DefaultHeadCellRenderer","DescriptionIcon","entityType","isInactiveRelation","currentEntityUri","mdmModule","COMMENTS_CONTAINER_VISIBILITY_AREA","EntityTypeIcon","EntityUriLink","getEntityUriForLink","getLabel","stopPropagation","CommentsContainer","relationUri","relatedObjectUris","createRelatedObjectUris","CollaborationObjectTypes","connection","objectType","allowOnlyOneComment","columnData","attributes","attributeTypes","attrTypes","drawLines","DataTypeValue","getAttrPathFromColumnId","split","slice","Infinity","getNestedPathByColumnId","startsWith","attrPath","getCellValueRenderer","EntityProfileRenderer","AttributesRenderer","DefaultCellValueRenderer","getBasicTableColumnsData","resizable","headCellRenderer","HeadCellRenderer","nestedPath","rowCellValueRenderer","getStaticRowCellHeight","pathEq","cell","attributesCount","values","defaultGetRowCellHeight","CellValueRenderer","index","key","buttons","MenuItemWithTooltip","withTooltip","noop","tooltip","showForDisabled","disableDelete","onMenuOpen","onDelete","hasDeletePermission","getRelationType","checkMetadataPermission","MetadataPermissions","canDelete","pendingDeletion","setPendingDeletion","hideDeleteConfirmation","Delete","handleMenuClose","SmallIconButton","MoreVertIcon","ConfirmationDialog","substring","tableContainer","flex","zIndex","hoveredRowRightContentWrapper","pointerEvents","menuButtonContainer","top","tooltipAnchor","onSort","onFilter","onRowClick","tableRef","readOnly","tableRowsData","getEntityType","relationType","relationLabel","object","getOvAttributeValuesByPath","getRelationAttributeValues","getRowValueByColumnId","getBasicTableRowsData","tableColumnsData","getDynamicRowCellHeight","changeRowCellHeight","useDynamicRowCellHeight","getRowCellHeight","hoverRowIndex","setHoverRowIndex","renderRowCell","isActiveObject","rowValue","rawValue","RowCellAutoSizer","onChangeHeight","isActionsMenuOpen","setIsActionsMenuOpen","handleActionsMenuOpen","handleActionsMenuClose","onRowHover","rowIndex","prevHoverRowIndex","hoveredRowRightContent","BasicTable","fixFirstColumn","rowsData","defaultColumnWidth","defaultColumnMinWidth","headRowHeight","hoverStateEnabled","tableRow","marginTop","selectedAttributeTypes","onDeleteCrosswalk","onEditCrosswalk","groupCrosswalksByTypesAndSources","buildTableRowsData","expandedSources","setExpandedSources","handleDelete","crosswalkId","handleEdit","event","source","crosswalksByTypes","SourceCrosswalksRow","expanded","disableEditCrosswalk","checkCanEditCrosswalk","disableDeleteCrosswalk","checkCanDeleteCrosswalk","onEdit","onToggleExpanded","append","borderBottom","hint","alignSelf","hintText","buttonLabel","editor","overflowY","overflowX","ButtonWithTooltip","onAddCrosswalk","openEditor","setOpenEditor","canAdd","checkCanCreateCrosswalk","Add","Info","CrosswalkEditor","onAdd","crosswalk","entityInfo","minWidth","entityLabelContainer","infoIcon","profileBand","entityTypeBadge","ExpandedValueTooltip","noWrap","LightArrowTooltip","ProfileBand","placement","EntityTypeBadge","direction","align","fillOpacity","points","visibility","editButton","showEditor","setShowEditor","closeEditor","editedValue","setEditedValue","applyChangesAndClose","formatDate","EditIcon","Popover","anchorEl","anchorOrigin","vertical","horizontal","transformOrigin","onKeyUp","onBackdropClick","DateEditor","InputProps","fullWidth","hiddenLabel","Date","valueOf","relationBand","inactiveRelationBand","toolbar","gap","mainInfo","detailsInfo","detailTitle","directionalLabel","textOverflow","whiteSpace","relationDate","onNavigateBack","onChangeActivenessDate","ArrowBackIcon","showErrorMessage","error","console","ErrorPopup","message","getRequestErrorMessage","detailsView","left","locked","resizablePanesWrapper","flexGrow","pane","onDeleteConnection","onChangeConnection","onChangeVisibleColumns","displayProps","highlightedCrosswalks","setHighlightedCrosswalks","highlightedCrosswalksCache","applyHighlightedCrosswalks","debounce","cacheHighlightedCrosswalks","arr","setCrosswalkHighlighted","highlighted","focusedCrosswalks","setFocusedCrosswalks","toggleCrosswalkFocus","prevValue","calculateFocusedCrosswalks","prev","next","prevCrosswalk","any","eqCrosswalks","nextCrosswalk","useCrosswalksDisplay","paneSize","setPaneSize","handlePaneSizeChange","percentageSize","selectedAttrTypes","setSelectedAttrTypes","onLoad","onLoaded","onDeleteRelation","onError","reloadRelation","errorCode","ApiErrorCode","getRelation","newRelation","assocPath","catch","modifiedEntity","crosswalksMap","newlyCreatedAttributes","onPinAttribute","onIgnoreAttribute","onAddAttribute","onEditAttribute","onDeleteAttribute","useModifiedEntity","onModify","addCrosswalk","deleteCrosswalk","editCrosswalk","useCrosswalkActions","onSuccess","attributeName","updateActivenessAttribute","deleteActivenessAttribute","dissocPath","DndProvider","backend","HTML5Backend","CrosswalkDragLayer","ResizablePanes","orientation","minSize","maxSize","allowResize","attributeUris","AttributesTable","onPin","onIgnore","onSelectAttributeTypes","relationshipsView","fontFamily","connect","saveState","getSavedState","isDTEntity","setSearchByOv","setShowInactive","entityTypeUri","stateToSave","entityTypeOfAppliedSavedState","defaultColumns","defaultSorting","defaultRowsPerPage","initState","useReducer","nextRelationType","savedState","useRelationshipsTable","isSavedStateApplied","isSavedStateLoading","relationsTableSavedState","attributesTableSavedState","updateRelationsTableSavedState","updateAttributesTableSavedState","setSavedState","changedRelationsState","setRelationsChangedState","useDidUpdateEffect","_","changedState","useSavedState","attributesTableVisibleColumns","setAttributesTableVisibleColumns","detailedConnectionIndex","setDetailedConnectionIndex","hideConnectionDetails","inheritancePath","getInheritancePath","both","startObject","endObject","some","equals","objectTypeURI","find","getReadableAttributesList","reject","updateColumnData","updateFn","getRelationColumnDataType","adjust","findIndex","propEq","updateRelationTypeColumn","getColumnsData","visibleColumnsData","relationsConfig","relations","relationFilter","filtersClause","buildColumnsFilter","FilterBuilder","addClause","build","buildRelationshipsFilter","isRelationsLoading","reloadRelations","onChangeDetailedColumns","detailedConnection","onChangeDetailedConnection","newConnection","update","objectIds","objectTypes","getRelationshipsObjectIdsForCollaboration","collaboration","useCollaboration","entitiesMap","getEntitiesMapForConnections","handleError","deleteRelation","removeRelation","andThen","otherwise","deleteRelationAndCloseDetails","onCloseConnectionDetails","not","CollaborationContext","EntitiesMapContext","ScreenProfileBand","LinearLoadIndicator","generateClassName","createGenerateClassName","productionPrefix","disableGlobal","store","onResize","getSavedStatePromisified","promisifyCallback","featuresContext","useContext","FeaturesContext","showDescription","getState","features","Provider","ViewIdContext","StylesProvider","MuiPickersUtilsProvider","utils","handleHeight"],"sourceRoot":""}