@reltio/remotes 1.4.1521 → 1.4.1523
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/1032.js +1 -1
- package/1032.js.map +1 -1
- package/1268.js +1 -1
- package/1396.js +1 -1
- package/1396.js.map +1 -1
- package/1901.js +3 -0
- package/1901.js.map +1 -0
- package/233.js +2 -0
- package/233.js.map +1 -0
- package/316.js +2 -0
- package/316.js.map +1 -0
- package/3164.js +2 -0
- package/3164.js.map +1 -0
- package/3396.js +1 -1
- package/3396.js.map +1 -1
- package/3758.js +2 -0
- package/3758.js.map +1 -0
- package/385.js +2 -0
- package/385.js.map +1 -0
- package/4120.js +2 -0
- package/4120.js.map +1 -0
- package/4183.js +1 -1
- package/4183.js.map +1 -1
- package/4571.js +1 -1
- package/545.js +2 -0
- package/545.js.map +1 -0
- package/5605.js.map +1 -1
- package/566.js +2 -0
- package/566.js.map +1 -0
- package/{4407.css → 574.css} +1 -1
- package/574.css.map +1 -0
- package/574.js +2 -0
- package/574.js.map +1 -0
- package/{6046.js → 6211.js} +2 -2
- package/6211.js.map +1 -0
- package/6233.js +1 -1
- package/6233.js.map +1 -1
- package/6299.js.map +1 -1
- package/{5285.js → 6578.js} +2 -2
- package/6578.js.map +1 -0
- package/7198.js +2 -0
- package/7198.js.map +1 -0
- package/769.js +2 -0
- package/769.js.map +1 -0
- package/8594.js +2 -0
- package/8594.js.map +1 -0
- package/8684.js +1 -1
- package/{3294.js → 8768.js} +2 -2
- package/8768.js.map +1 -0
- package/9835.js +2 -0
- package/9835.js.map +1 -0
- package/package.json +1 -1
- package/remoteEntry.js +1 -1
- package/remoteEntry.js.map +1 -1
- package/3270.js +0 -2
- package/3270.js.map +0 -1
- package/3294.js.map +0 -1
- package/4407.css.map +0 -1
- package/4407.js +0 -2
- package/4407.js.map +0 -1
- package/5285.js.map +0 -1
- package/6046.js.map +0 -1
- package/6103.js +0 -2
- package/6103.js.map +0 -1
- package/6244.js +0 -2
- package/6244.js.map +0 -1
- package/6413.js +0 -3
- package/6413.js.map +0 -1
- package/6669.js +0 -2
- package/6669.js.map +0 -1
- package/6719.js +0 -2
- package/6719.js.map +0 -1
- package/6880.js +0 -2
- package/6880.js.map +0 -1
- package/8443.js +0 -2
- package/8443.js.map +0 -1
- package/8932.js +0 -2
- package/8932.js.map +0 -1
- package/929.js +0 -2
- package/929.js.map +0 -1
- package/9481.js +0 -2
- package/9481.js.map +0 -1
- package/9561.js +0 -2
- package/9561.js.map +0 -1
- package/9852.js +0 -2
- package/9852.js.map +0 -1
- /package/{6413.js.LICENSE.txt → 1901.js.LICENSE.txt} +0 -0
package/9481.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(self.webpackChunk_reltio_remotes=self.webpackChunk_reltio_remotes||[]).push([[9481],{98808:(e,t,n)=>{n.d(t,{K:()=>h,N:()=>m});var a=n(24328),r=n.n(a),o=n(71153),i=n.n(o),l=n(94079);const s=(0,n(79692).Z)((e=>({button:{padding:"9px 16px 9px 12px","& svg g path, & svg path":{fill:e.palette.primary.main,fillOpacity:1}},iconButton:{"& svg g path, & svg path":{fill:e.palette.primary.main,fillOpacity:1}},startIcon:{marginLeft:0,marginRight:"8px",width:"18px",height:"18px",alignItems:"center"},label:{whiteSpace:"nowrap",fontSize:"14px",lineHeight:"16px",letterSpacing:0},overflowStyle:{overflow:"hidden",whiteSpace:"nowrap",textOverflow:"ellipsis"},menuIcon:{marginRight:"12px"},menuItem:{minHeight:"28px",padding:"2px 16px 2px 12px"},menuText:{color:e.palette.text.primary,fontSize:"13px",lineHeight:"15px",letterSpacing:0}})));var c=n(31276),p=n(95613),u=n(8818);function d(){return d=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},d.apply(this,arguments)}let m;!function(e){e.iconButton="iconButton",e.button="button",e.menuItem="menuItem"}(m||(m={}));const h=(0,a.forwardRef)(((e,t)=>{let{className:n,mode:a=m.iconButton,label:o,disabled:h,icon:f,onClick:b=c.ZT,onMenuClose:g=c.ZT}=e,y=function(e,t){if(null==e)return{};var n,a,r=function(e,t){if(null==e)return{};var n,a,r={},o=Object.keys(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}(e,["className","mode","label","disabled","icon","onClick","onMenuClose"]);const x=s();return(()=>{switch(a){case"iconButton":return r().createElement(u.k,d({disabled:h,className:i()(x.iconButton,n),size:"S",tooltipTitle:o,onClick:b,icon:f,showForDisabled:!0},y));case"button":return r().createElement(l.Button,d({className:i()(x.button,n),disabled:h,startIcon:r().createElement(f,null),onClick:b,color:"primary",classes:{startIcon:x.startIcon,label:x.label}},y),r().createElement(p.Z,{value:o},r().createElement("div",{className:x.overflowStyle},o)));case"menuItem":{const e=()=>{g(),b()};return r().createElement(l.MenuItem,d({classes:{root:x.menuItem},onClick:e,disabled:h,ref:t},y),r().createElement(r().Fragment,null,r().createElement(f,{className:x.menuIcon}),r().createElement(l.Typography,{classes:{root:x.menuText}},o)))}}})()}));h.displayName="ActionButton"},58662:(e,t,n)=>{n.d(t,{Z:()=>y});var a=n(13980),r=n.n(a),o=n(24328),i=n.n(o),l=n(71153),s=n.n(l),c=n(94079),p=n(87918),u=n.n(p),d=n(31276),m=n(17440);const h=(0,n(79692).Z)({pagination:{display:"flex",alignItems:"center",justifyContent:"flex-end",height:"56px",borderTop:"1px solid rgba(0,0,0,0.12)",boxShadow:"none"},caption:{color:"rgba(0,0,0,0.6)",fontSize:"12px",lineHeight:"16px"},selectRoot:{marginLeft:"5px",marginRight:"36px"},select:{color:"rgba(0,0,0,0.6)",fontSize:"12px",lineHeight:"16px",textAlign:"right"},actions:{marginLeft:"32px"}});function f(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?Object(arguments[t]):{},a=Object.keys(n);"function"==typeof Object.getOwnPropertySymbols&&(a=a.concat(Object.getOwnPropertySymbols(n).filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable})))),a.forEach((function(t){b(e,t,n[t])}))}return e}function b(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}const g=e=>{let{classes:t={},count:n,rowsPerPageOptions:a,page:r,onChangePage:l,rowsPerPage:p,onChangeRowsPerPage:b,basicTableRef:g,labelRowsPerPage:y}=e;const x=h(),v=(0,o.useCallback)((()=>{(0,m.pathOr)(m.identity,["current","resetScrollbarPosition"],g)()}),[g]),O=(0,o.useCallback)((e=>{l(e),v()}),[l,v]),w=(0,o.useCallback)((e=>{l(0),b(e),v()}),[l,b,v]);return i().createElement(c.TablePagination,{classes:f({},t,{root:s()(x.pagination,t.root),select:s()(x.select,t.select),caption:x.caption,selectRoot:x.selectRoot,actions:x.actions}),component:"div",labelRowsPerPage:y||u().text("Rows per page:"),labelDisplayedRows:e=>{let{from:t,to:n,count:a}=e;return u().text("${fromRow}-${toRow} of ${countRows}",{fromRow:u().number(t,"0,0"),toRow:u().number(n,"0,0"),countRows:u().number(a,"0,0")})},count:n,rowsPerPageOptions:a,page:r,onChangePage:(0,m.pipe)((0,m.nthArg)(1),O),rowsPerPage:p,onChangeRowsPerPage:(0,m.pipe)(d.NA,w)})};g.propTypes={classes:r().object,rowsPerPageOptions:r().arrayOf(r().number),count:r().number,page:r().number,onChangePage:r().func,rowsPerPage:r().number,onChangeRowsPerPage:r().func,basicTableRef:r().shape({current:r().object}),labelRowsPerPage:r().string};const y=i().memo(g)},81137:(e,t,n)=>{n.d(t,{Z:()=>c});var a=n(24328),r=n.n(a),o=n(87918),i=n.n(o),l=n(94079);const s=(0,n(79692).Z)({paper:{minHeight:"180px"},title:{padding:"16px 16px 10px 16px",fontSize:"20px",fontWeight:500,letterSpacing:"0.25px",lineHeight:"24px"},content:{padding:"0 16px"},contentText:{marginBottom:0,fontSize:"16px",letterSpacing:"0.15px",lineHeight:"24px"},actionButtons:{display:"flex",paddingTop:"4px",fontSize:"14px",fontWeight:500,letterSpacing:0,lineHeight:"16px","& > div":{marginLeft:"auto"}},discardButton:{marginRight:"8px"}}),c=e=>{let{open:t,title:n,content:a,onCancel:o,cancelCaption:c=i().text("Cancel"),onDiscard:p,discardCaption:u="",onSave:d,saveCaption:m=i().text("Save"),disabledSave:h=!1}=e;const f=s();return r().createElement(l.Dialog,{open:t,onClose:o,classes:{paperScrollPaper:f.paper}},r().createElement(l.DialogTitle,{classes:{root:f.title}},n),r().createElement(l.DialogContent,{classes:{root:f.content}},r().createElement(l.DialogContentText,{classes:{root:f.contentText}},a)),r().createElement(l.DialogActions,{className:f.actionButtons,disableSpacing:!0},o&&r().createElement(l.Button,{onClick:o},c),r().createElement("div",null,p&&r().createElement(l.Button,{onClick:p,classes:{root:f.discardButton}},u),r().createElement(l.Button,{onClick:d,color:"primary",disabled:h,autoFocus:!0},m))))}},7154:(e,t,n)=>{n.d(t,{Z:()=>m});var a=n(24328),r=n.n(a),o=n(13980),i=n.n(o),l=n(67958),s=n(17440),c=n(89846),p=n(27185);function u(){return u=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},u.apply(this,arguments)}const d=e=>{let{relation:t={},inRelationTypes:n=[],outRelationTypes:o=[],onChange:i=s.identity,applyFirstByDefault:l=!1,reversedContextLabels:d=!1}=e,m=function(e,t){if(null==e)return{};var n,a,r=function(e,t){if(null==e)return{};var n,a,r={},o=Object.keys(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}(e,["relation","inRelationTypes","outRelationTypes","onChange","applyFirstByDefault","reversedContextLabels"]);const{getRelationTypesOptions:h,fromEditorValue:f,toEditorValue:b}=(0,c.n)({reversedContextLabels:d}),g=(0,a.useMemo)((()=>h(n,o)),[h,n,o]),y=(0,a.useCallback)((0,s.pipe)(f(n,o),i),[f,n,o,i]),x=!!t.relationType;return(0,a.useEffect)((()=>{l&&g.length&&!x&&y(g[0])}),[g,l,y,x]),r().createElement(p.Z,u({value:b(t,g),options:g,onChange:y},m))};d.propTypes={className:i().string,relation:l.bNA,inRelationTypes:i().arrayOf(l.IYE),outRelationTypes:i().arrayOf(l.IYE),applyFirstByDefault:i().bool,reversedContextLabels:i().bool,onChange:i().func};const m=d},68439:(e,t,n)=>{n.d(t,{Z:()=>m});var a=n(24328),r=n.n(a),o=n(52730),i=n(71153),l=n.n(i),s=n(94079),c=n(67958),p=n(49885),u=n(95613);const d=(0,n(79692).Z)({"entityType-overflow":{textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"nowrap"},"entityType-small":{padding:"1px 4px",fontSize:"10px",lineHeight:"normal",marginRight:"12px",borderRadius:"2px",flexShrink:0},"entityType-medium":{padding:"2px 8px 3px",borderRadius:"2px",fontSize:"13px",fontWeight:500,lineHeight:"15px",marginRight:"16px",flexShrink:0}}),m=e=>{let{entity:t,className:n,size:a="small"}=e;const i=d(),m=(0,o.useSelector)(p.ZP.selectors.getMetadata),h=t.type,f=(0,c.nt9)(m,h)||{},b=(0,c.VD3)(m,f,"typeColor")||c.rSc.palette.primary.main,g=(0,c.jFi)(m,t);return r().createElement(u.Z,{value:g,placement:"top"},r().createElement(s.Typography,{style:{backgroundColor:b,color:c.P6Y.Colors.getColor(b)?"#FFFFFF":"#212121"},className:l()(i[`entityType-${a}`],i["entityType-overflow"],n),component:"div"},g))}},64459:(e,t,n)=>{n.d(t,{Z:()=>g});var a=n(24328),r=n.n(a),o=n(71153),i=n.n(o),l=n(52730),s=n(17440),c=n(94079),p=n(87918),u=n.n(p),d=n(67958),m=n(49885),h=n(53180),f=n(68439);const b=(0,n(79692).Z)((e=>({profileBandWrapper:{flexShrink:0},profileBand:{display:"flex",padding:"16px 12px 16px 16px",alignItems:"flex-start",backgroundColor:"#fff",boxShadow:"0px 1px 0px rgba(0, 0, 0, 0.12)",marginBottom:"1px","&:after":{content:'""',minHeight:"inherit",fontSize:0}},inactive:{background:e.inactiveBackground},profileIcon:{marginRight:"12px"},imageProfileIcon:{width:"48px",height:"48px"},profileInfo:{display:"flex",flexDirection:"column",flex:"1 1 50%"},badge:{},label:{lineHeight:"1.2",letterSpacing:"0.25px",color:e.palette.text.primary,wordBreak:"break-word","&+ $specialInfo":{marginTop:"4px"}},secondaryLabel:{display:"inline-flex",color:e.palette.text.primary,marginTop:"2px",lineHeight:"16px",fontSize:"14px",fontWeight:400,"&+ $businessCard":{marginLeft:"12px"}},businessCard:{color:e.palette.text.secondary,display:"inline-flex",fontSize:"14px",marginTop:"4px",lineHeight:"1.2"},specialInfo:{display:"flex",justifyContent:"space-between",flexWrap:"wrap",width:"100%",marginTop:"8px"},entityType:{display:"flex",flexWrap:"wrap"},entityId:{fontSize:"13px",color:e.palette.text.secondary,whiteSpace:"nowrap",cursor:"pointer","&:hover":{textDecoration:"underline"}}}))),g=e=>{let{className:t,entity:n,children:o,classes:p,renderLabel:g=s.identity}=e;const y=b({classes:p}),x=(0,l.useSelector)(m.ZP.selectors.getMetadata),v=(0,l.useSelector)(m.ZP.selectors.getShowEntityId),O=(0,a.useCallback)((()=>{navigator.clipboard.writeText((0,d.BTI)(n))}),[n]);if((0,s.isNil)(n))return null;const w=(0,d.idV)(n.label),E=n.secondaryLabel,P=(0,d.ptG)(x,n),S=(0,d.Fn9)(n),C=n.uri,T=(0,d.BTI)(n);return r().createElement("div",{className:i()(y.profileBandWrapper,t)},r().createElement("div",{className:i()(y.profileBand,{[y.inactive]:!S}),"data-entity-uri":C},r().createElement(h.Z,{key:n.uri,entity:n,avatarClassName:y.profileIcon,imageClassName:y.imageProfileIcon}),r().createElement("div",{className:y.profileInfo},r().createElement("div",null,r().createElement(c.Typography,{variant:"h6",className:y.label},g(w)),E&&r().createElement(c.Typography,{variant:"subtitle2",className:y.secondaryLabel},E),P&&r().createElement(c.Typography,{variant:"subtitle1",className:y.businessCard},P)),r().createElement("div",{className:y.specialInfo},r().createElement("div",{className:y.entityType},r().createElement(f.Z,{entity:n,size:"medium",className:y.badge}),!(0,d.ZiX)(C)&&v&&r().createElement(c.Tooltip,{title:u().text("Copy to clipboard")},r().createElement(c.Typography,{display:"inline",variant:"body2",className:y.entityId,onClick:O},u().text("Entity ID"),": ",T))))),o&&r().createElement("div",null,o)))}},79618:(e,t,n)=>{n.d(t,{a:()=>B});var a=n(24328),r=n.n(a),o=n(94079),i=n(67766),l=n(42767),s=n(67958),c=n(71153),p=n.n(c),u=n(17440),d=n(87918),m=n.n(d),h=n(79468),f=n(83348),b=n(8818);const g=(0,n(79692).Z)({container:{display:"flex",alignItems:"center"},link:{whiteSpace:"nowrap",marginRight:"9px"}}),y=(0,f.Z)(o.Link),x=e=>{var t;let{className:n,total:o=0,onPrev:c,onNext:d,onSearchResultsClick:f,isPrevDisabled:x,isNextDisabled:v}=e;const O=g(),w=(0,a.useContext)(h.T),{OPEN_RESULTS:E,SEARCH_RESULT:P,SEARCH_RESULTS:S,NEXT_PROFILE:C,PREVIOUS_PROFILE:T}=(0,u.mergeRight)({OPEN_RESULTS:m().text("Go to search results"),SEARCH_RESULT:m().text("Search result"),SEARCH_RESULTS:m().text("Search results"),PREVIOUS_PROFILE:m().text("Go to previous profile"),NEXT_PROFILE:m().text("Go to next profile")},null!==(t=null==w?void 0:w.profileBand)&&void 0!==t?t:{});return r().createElement("div",{className:p()(O.container,n)},r().createElement(y,{className:O.link,component:"button",variant:"caption",onClick:f,underline:"none",tooltipTitle:E},(0,s.k7L)(o,1e6)," ",1===o?P:S),r().createElement(b.k,{size:"L",icon:i.Z,tooltipTitle:T,onClick:c,disabled:x,showForDisabled:!0}),r().createElement(b.k,{size:"L",icon:l.Z,tooltipTitle:C,onClick:d,disabled:v,showForDisabled:!0}))};var v=n(52730),O=n(49885),w=n(94622),E=n(47898),P=n(54198),S=n(85229);function C(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?Object(arguments[t]):{},a=Object.keys(n);"function"==typeof Object.getOwnPropertySymbols&&(a=a.concat(Object.getOwnPropertySymbols(n).filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable})))),a.forEach((function(t){T(e,t,n[t])}))}return e}function T(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}class j{constructor(e){var t=this;let{data:{query:n,sortField:a,sortOrder:r},tenant:o,searchTenant:i,apiPath:l,dtssPath:c,globalSearchRequestOptions:p}=e;this.query=void 0,this.sortField=void 0,this.sortOrder=void 0,this.tenant=void 0,this.searchTenant=void 0,this.apiPath=void 0,this.dtssPath=void 0,this.globalSearchRequestOptions=void 0,this.isDT=()=>this.tenant!==this.searchTenant,this.getQueryFilter=()=>({rawFilter:this.query}),this.getEntities=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const a=[t.getQueryFilter(),...e],r=C({},t.globalSearchRequestOptions,{sort:t.sortField,order:t.sortOrder,select:"uri,label,type",scoreEnabled:!1},n);return t.isDT()?(0,s.uqV)({filters:a,options:r,customerTenant:t.tenant,dataTenant:t.searchTenant,dtssPath:t.dtssPath}):(0,s.ZOr)(a,r)},this.checkEntity=e=>this.getEntities([{filter:"equals",fieldName:"uri",values:[e]}],{offset:0,max:1}).then((t=>t&&t.length>0&&t[0].uri===e)),this.requestEntities=(e,t)=>this.getEntities([],{offset:t,max:e}),this.requestTotal=()=>{const e=[this.getQueryFilter()],t=this.globalSearchRequestOptions;return(this.isDT()?(0,s.J$m)({filters:e,options:t,customerTenant:this.tenant,dataTenant:this.searchTenant,dtssPath:this.dtssPath}):(0,s.j_Q)(e,t)).then((e=>e.total))},this.query=n,this.sortField=a,this.sortOrder=r,this.tenant=o,this.searchTenant=i,this.apiPath=l,this.dtssPath=c,this.globalSearchRequestOptions=p}}function k(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?Object(arguments[t]):{},a=Object.keys(n);"function"==typeof Object.getOwnPropertySymbols&&(a=a.concat(Object.getOwnPropertySymbols(n).filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable})))),a.forEach((function(t){I(e,t,n[t])}))}return e}function I(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}class N{constructor(e){var t=this;let{data:n,tenant:a,apiPath:r}=e;this.searchBody=void 0,this.tenant=void 0,this.apiPath=void 0,this.getEntities=function(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const a=[{rawFilter:t.searchBody.filter},...e];return(0,s.P2h)({apiPath:t.apiPath,tenant:t.tenant,searchBody:k({},t.searchBody,{filter:e.length?(0,s.Uqd)()(a):t.searchBody.filter}),options:n})},this.checkEntity=e=>this.getEntities([{filter:"equals",fieldName:"id",values:[(0,s.BTI)({uri:e})]}],{from:0,max:1}).then((t=>t&&t.length>0&&t[0].uri===e)),this.requestEntities=(e,t)=>this.getEntities([],{from:t,max:e}),this.requestTotal=()=>(0,s.dED)({apiPath:this.apiPath,tenant:this.tenant,searchBody:this.searchBody}).then((e=>e.count)),this.searchBody=n,this.tenant=a,this.apiPath=r}}function R(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?Object(arguments[t]):{},a=Object.keys(n);"function"==typeof Object.getOwnPropertySymbols&&(a=a.concat(Object.getOwnPropertySymbols(n).filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable})))),a.forEach((function(t){Z(e,t,n[t])}))}return e}function Z(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}const L=(e,t)=>(0,u.pipe)((0,u.map)((0,u.prop)("uri")),(0,u.reject)((e=>t.includes(e))))(e),D=()=>{const e=(0,S._)(),t=(0,S._)(),n=(0,S._)(),{uri:r,index:o,total:i,tenant:l,cache:c}=(0,v.useSelector)(O.ZP.selectors.getSearchNavigationData)||{},{type:p,data:u}=(0,v.useSelector)(O.ZP.selectors.getSearchProviderData)||{},d=(0,v.useSelector)(O.ZP.selectors.getTenant),m=(0,v.useSelector)(O.ZP.selectors.getApiPath),h=(0,v.useSelector)(O.ZP.selectors.getDtssPath),f=(0,v.useSelector)((e=>O.ZP.selectors.getGlobalSearchRequestOptions(e,["ovOnly"]))),{updateEntitiesNavigationLoadingState:b}=(0,w.M)(),g=(0,a.useContext)(E.m),y=(0,v.useDispatch)(),[x,C]=(0,a.useState)(!1),T=(0,a.useMemo)((()=>((e,t)=>{switch(e){case"search":return new j(t);case"graphsearch":return new N(t)}})(p,{data:u,tenant:d,searchTenant:l,apiPath:m,dtssPath:h,globalSearchRequestOptions:f})),[p,u,d,l,m,h,f]),k=(0,a.useCallback)((e=>{y(O.yC.actions.updateSearchNavigationDataFields(e))}),[y]),I=(0,a.useCallback)((e=>{const t=d!==l?(0,s.wwR)({uri:e,dataTenant:l}):e;y(O.ui.actions.openEntity({uri:t,viewId:g,source:"navigation"}))}),[y,g,d,l]),Z=(0,a.useCallback)((()=>{y(O.ui.actions.openPerspective({perspectiveId:p,viewId:g}))}),[y,p,g]);(0,a.useEffect)((()=>{o>=i?k({index:i-1}):o<0&&k({index:0})}),[i,o,k]);const D=(0,P.u)();(0,a.useEffect)((()=>{const e=D(((e,t)=>{switch(e.type){case O.yC.constants.UPDATE_SEARCH_NAVIGATION_DATA_ON_MERGE:{const n=O.ZP.selectors.getSearchNavigationData(t);n&&k(((e,t)=>{const{winnerUri:n,losersUris:a=[]}=t,r=((e,t)=>{let{uri:n,index:a,total:r,cache:o}=e;if(t&&t!==n){if(o&&o.includes(n)){o=[...o];const e=o.indexOf(t);let i=o.indexOf(n);e>=0&&(o.splice(e,1),r--,e<i&&a--),i=o.indexOf(n),o.splice(i,1,t)}return n=t,R({},e,{uri:n,index:a,cache:o,total:r})}return e})(e,n);return((e,t)=>{const{cache:n=[],index:a,total:r,uri:o}=e,i=t.filter((e=>n.includes(e)));if(0===i.length)return e;const l=r-i.length,s=n.indexOf(o);let c=a;for(const e of i)n.indexOf(e)<s&&c--;const p=n.filter((e=>!i.includes(e)));return R({},e,{cache:p,index:c,total:l})})(r,a)})(n,e.payload));break}}}));return()=>e()}),[D,k]);const B=(0,a.useCallback)(((e,a,r)=>{C(!0),t(T.requestTotal()).then((e=>k({total:e})));const o=r+1;return n(T.requestEntities(15,o)).then((t=>{if(t){if(t.length){const n=L(t,e);if(n.length>0)return k({cache:e.concat(n),uri:n[0],index:o+t.length-n.length}),void I(n[0]);if(r+t.length<a-1)return B(e,a-t.length,r+t.length)}k({index:o})}})).finally((()=>{C(!1)}))}),[T,k,I]),F=(0,a.useCallback)(((e,a)=>{C(!0),t(T.requestTotal()).then((e=>k({total:e})));const r=a-1,o=Math.max(0,a-15),i=15+Math.min(0,a-15);return n(T.requestEntities(i,o)).then((t=>{if(t){if(t.length){const n=L(t,e);if(n.length>0)return k({cache:n.concat(e),uri:n[n.length-1],index:r-(t.length-n.length)}),void I(n[n.length-1]);if(a-t.length>0)return F(e,a-t.length)}k({index:0})}})).finally((()=>{C(!1)}))}),[T,k,I]),q=(0,a.useCallback)(((t,n,a,r)=>{if(n<t.length){const o=t[n];return C(!0),e(T.checkEntity(o)).then((e=>{if(!e){const e=[...t];return e.splice(n,1),q(e,n,a-1,r)}k({index:r+1,uri:o,cache:t,total:a}),I(o)})).finally((()=>{C(!1)}))}if(!(r>=a-1))return B(t,a,r);k({cache:t,total:a,index:a-1})}),[T,k,I,B]),H=(0,a.useCallback)(((t,n,a,r)=>{if(n>-1){const o=t[n];return C(!0),e(T.checkEntity(o)).then((e=>{if(!e){const e=[...t];return e.splice(n,1),H(e,n-1,a-1,r-1)}k({index:r-1,uri:o,cache:t,total:a}),I(o)})).finally((()=>{C(!1)}))}if(!(r<=0))return F(t,r);k({index:0,cache:t,total:a})}),[T,k,I,F]),U=(0,a.useCallback)((()=>{if(c&&r){const e=c.indexOf(r)-1;H(c,e,i,o)}}),[H,c,r,i,o]),z=(0,a.useCallback)((()=>{if(c&&r){const e=c.indexOf(r)+1;q(c,e,i,o)}}),[q,c,r,i,o]);return(0,a.useEffect)((()=>{b(x)}),[b,x]),(0,a.useEffect)((()=>()=>b(!1)),[]),{total:i,onPrev:U,onNext:z,onSearchResultsClick:Z,isPrevDisabled:x||o<=0,isNextDisabled:x||o>=i-1}},B=e=>{let{className:t}=e;const{total:n,onPrev:a,onNext:o,onSearchResultsClick:i,isPrevDisabled:l,isNextDisabled:c}=D();return(()=>{const{cache:e}=(0,v.useSelector)(O.ZP.selectors.getSearchNavigationData)||{},t=(0,v.useSelector)(O.ZP.selectors.getMode),n=(0,v.useSelector)(O.ZP.selectors.getEntity);return(0,s.uzs)(t)&&(null==e?void 0:e.includes(null==n?void 0:n.uri))})()?r().createElement(x,{className:t,total:n,onPrev:a,onNext:o,onSearchResultsClick:i,isPrevDisabled:l,isNextDisabled:c}):null}},33310:(e,t,n)=>{n.d(t,{Z:()=>O});var a=n(24328),r=n.n(a),o=n(71153),i=n.n(o),l=n(87918),s=n.n(l),c=n(67958),p=n(53180),u=n(31039),d=n(95613),m=n(68439),h=n(79692);const f=(0,h.Z)((e=>({image:{width:"40px",height:"40px"},info:{marginLeft:"12px",overflow:"hidden",display:"flex",flexDirection:"column"},label:{textOverflow:"ellipsis",overflow:"hidden",whiteSpace:"nowrap",fontWeight:400,fontSize:"13px",lineHeight:"15px",color:e.palette.primary.main},secondaryLabel:{marginTop:"4px",fontWeight:400,fontSize:"10px",lineHeight:"12px",color:e.palette.text.secondary,whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},link:{textDecoration:"none"},thirdRow:{display:"flex",overflow:"hidden",alignItems:"center",marginTop:"auto",paddingTop:"4px"},entityId:{display:"flex",overflow:"hidden",alignItems:"baseline",whiteSpace:"nowrap",fontWeight:400,fontSize:"12px",lineHeight:"16px"},entityIdLabel:{color:e.palette.text.secondary},entityIdValue:{marginLeft:"8px",color:e.palette.text.primary,overflow:"hidden",textOverflow:"ellipsis","&[aria-describedby]":{cursor:"pointer","&:hover":{textDecoration:"underline"}}}}))),b=e=>{let{entity:t,classes:n={}}=e;const o=f(),{secondaryLabel:l,label:h}=n,b=(0,c.idV)(t.label),{secondaryLabel:g}=t,y=(0,a.useCallback)((()=>{navigator.clipboard.writeText((0,c.BTI)(t))}),[t]);return r().createElement(r().Fragment,null,r().createElement(p.Z,{entity:t,imageClassName:o.image}),r().createElement("div",{className:o.info},r().createElement(u.Z,{value:(0,c.wwR)(t),className:o.link},r().createElement(d.Z,{value:b,placement:"top",showOnExceededHeight:!0},r().createElement("div",{className:i()(o.label,h)},b))),g&&r().createElement(d.Z,{value:g,placement:"top",showOnExceededHeight:!0},r().createElement("div",{className:i()(o.secondaryLabel,l)},g)),r().createElement("div",{className:o.thirdRow},r().createElement(m.Z,{entity:t,size:"medium"}),r().createElement("div",{className:o.entityId,onClick:y},r().createElement("div",{className:o.entityIdLabel},s().text("ID:")),r().createElement(d.Z,{value:`Copy to clipboard ${(0,c.BTI)(t)}`,placement:"top"},r().createElement("div",{className:o.entityIdValue},(0,c.BTI)(t)))))))},g=(0,h.Z)({"@keyframes keyframes-wave":{"0%":{transform:"translateX(-100%)"},"60%":{transform:"translateX(100%)"},"100%":{transform:"translateX(100%)"}},wave:{overflow:"hidden",position:"relative","&:after":{top:"0",left:"0",right:"0",bottom:"0",content:'""',position:"absolute",animation:"$keyframes-wave 1.6s linear 0.5s infinite",transform:"translateX(-100%)",background:"linear-gradient(90deg, transparent, rgba(0, 0, 0, 0.04), transparent);"}},avatar:{flex:"none",width:"40px",height:"40px",borderRadius:"50%",backgroundColor:"rgba(0, 0, 0, 0.11)"},info:{marginLeft:"12px",flex:"auto"},label:{width:"40%",height:"15px",borderRadius:"2px",backgroundColor:"rgba(0, 0, 0, 0.11)"},secondaryLabel:{marginTop:"4px",width:"100%",height:"12px",borderRadius:"2px",backgroundColor:"rgba(0, 0, 0, 0.11)"},thirdRow:{marginTop:"4px",width:"60%",height:"24px",borderRadius:"2px",backgroundColor:"rgba(0, 0, 0, 0.11)"}}),y=()=>{const e=g();return r().createElement(r().Fragment,null,r().createElement("div",{className:i()(e.avatar,e.wave)}),r().createElement("div",{className:e.info},r().createElement("div",{className:i()(e.label,e.wave)}),r().createElement("div",{className:i()(e.secondaryLabel,e.wave)}),r().createElement("div",{className:i()(e.thirdRow,e.wave)})))},x=(0,h.Z)({container:{display:"flex",padding:"16px",overflow:"hidden"}});function v(){return v=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},v.apply(this,arguments)}const O=(0,a.memo)((e=>{let{entity:t,classes:n={},variant:a="normal"}=e,o=function(e,t){if(null==e)return{};var n,a,r=function(e,t){if(null==e)return{};var n,a,r={},o=Object.keys(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}(e,["entity","classes","variant"]);const l=x(),{container:s}=n;return r().createElement("div",v({className:i()(l.container,s)},o),"normal"===a?r().createElement(b,{entity:t,classes:n}):r().createElement(y,null))}))},39827:(e,t,n)=>{n.d(t,{G:()=>m});var a=n(24328),r=n.n(a),o=n(71153),i=n.n(o),l=n(8818),s=n(79692),c=n(41128);const p=(0,s.Z)((e=>({container:{display:"flex",flexDirection:"column",flexShrink:0,width:"64px",paddingTop:"8px",backgroundColor:e.palette.background.paper,boxShadow:"0 1px 1px 0 rgba(0,0,0,0.14), 0 2px 1px -1px rgba(0,0,0,0.12), 0 1px 3px 0 rgba(0,0,0,0.2)"},active:{backgroundColor:(0,c.U1)(e.palette.primary.main,.12),color:e.palette.primary.main,"&:after":{content:'""',position:"absolute",height:"42px",width:"3px",backgroundColor:e.palette.primary.main,left:"-8px",borderRadius:"0 6px 6px 0"}},buttonWrapper:{position:"relative",width:"48px",height:"44px",display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"6px",margin:"2px 8px",color:e.palette.text.secondary}})));function u(){return u=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},u.apply(this,arguments)}function d(e,t){if(null==e)return{};var n,a,r=function(e,t){if(null==e)return{};var n,a,r={},o=Object.keys(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}const m=e=>{let{buttonsProps:t,activeIndexId:n,className:a,onButtonClick:o,classes:s={}}=e;const c=p(),{active:m,buttonWrapper:h}=s,f=d(s,["active","buttonWrapper"]);return r().createElement("div",{className:i()(c.container,a)},t.map((e=>{let{id:t}=e,a=d(e,["id"]);return r().createElement(l.k,u({},a,{classes:f,size:"S",key:t,className:i()({[i()(c.active,m)]:n===t},c.buttonWrapper,h),onClick:()=>o(t),"data-reltio-id":`reltio-profile-right-side-button-${t}`}))})))}},52043:(e,t,n)=>{n.d(t,{h:()=>i});var a=n(24328),r=n.n(a);const o=(0,n(79692).Z)((e=>({contentWrapper:{display:"flex",flexDirection:"column",backgroundColor:e.palette.background.paper,boxShadow:"0 1px 1px 0 rgba(0,0,0,0.14), 0 2px 1px -1px rgba(0,0,0,0.12), 0 1px 3px 0 rgba(0,0,0,0.2)",marginLeft:"3px",transition:e.transitions.create(["width"],{duration:e.transitions.duration.enteringScreen})}}))),i=e=>{let{width:t,open:n,children:a}=e;const i=o();return r().createElement("div",{className:i.contentWrapper,style:{width:`${n?t:0}px`}},n&&r().createElement(r().Fragment,null,a))}},27185:(e,t,n)=>{n.d(t,{Z:()=>P});var a=n(24328),r=n.n(a),o=n(13980),i=n.n(o),l=n(87918),s=n.n(l),c=n(17440),p=n(71153),u=n.n(p),d=n(94079);const m=(0,n(79692).Z)({container:{display:"flex",alignItems:"center",height:"32px",minHeight:"32px",padding:0},text:{display:"flex",width:"calc(100% - 68px)"},textItem:{fontSize:"13px",lineHeight:"15px",marginRight:10},primaryTextItem:{flex:"1 0",flexBasis:0,maxWidth:"50%",overflow:"hidden",textOverflow:"ellipsis"},secondaryTextItem:{flex:"1 0",flexBasis:0,overflow:"hidden",textOverflow:"ellipsis"},icons:{transform:"scale(0.5)",position:"relative",flexShrink:0,width:"68px",bottom:"10px"},iconTop:{position:"absolute",top:0,left:0,zIndex:1},iconBottom:{position:"absolute",top:0,left:26,zIndex:0}});var h=n(34e3),f=n(95613);function b(){return b=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},b.apply(this,arguments)}const g=e=>{let{innerRef:t,innerProps:n,selectOption:a,data:o}=e;const i=m(),{value:l,label:s,startObject:c,endObject:p}=o,g=c.objectType.label+" ↔ "+p.objectType.label;return r().createElement(d.MenuItem,b({className:i.container,ref:t,key:l,onClick:()=>a({label:s,value:l,startObject:c,endObject:p})},n),r().createElement("div",{className:i.icons},r().createElement(h.Z,{className:i.iconTop,entityType:c.objectType}),r().createElement(h.Z,{className:i.iconBottom,entityType:p.objectType})),r().createElement("div",{className:i.text},r().createElement(f.Z,{value:s},r().createElement(d.Typography,{className:u()(i.textItem,i.primaryTextItem)},s)),r().createElement(f.Z,{value:g},r().createElement(d.Typography,{color:"textSecondary",className:u()(i.textItem,i.secondaryTextItem)},g))))};g.propTypes={innerRef:i().oneOfType([i().oneOf([null]),i().func,i().shape({current:i().any.isRequired})]),innerProps:i().object.isRequired,selectOption:i().func.isRequired,data:i().shape({value:i().string.isRequired,label:i().string.isRequired,startObject:i().object,endObject:i().object})};const y=g;var x=n(24737);function v(){return v=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},v.apply(this,arguments)}function O(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}const w=e=>{let{value:t={},options:n=[],onChange:o=c.identity,TextFieldProps:i}=e,l=function(e,t){if(null==e)return{};var n,a,r=function(e,t){if(null==e)return{};var n,a,r={},o=Object.keys(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||(r[n]=e[n]);return r}(e,t);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(a=0;a<o.length;a++)n=o[a],t.indexOf(n)>=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(r[n]=e[n])}return r}(e,["value","options","onChange","TextFieldProps"]);const p=(0,a.useMemo)((()=>function(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?Object(arguments[t]):{},a=Object.keys(n);"function"==typeof Object.getOwnPropertySymbols&&(a=a.concat(Object.getOwnPropertySymbols(n).filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable})))),a.forEach((function(t){O(e,t,n[t])}))}return e}({},(0,c.defaultTo)({},i),{"data-reltio-id":"relation-type-selector"})),[i]);return r().createElement(x.Z,v({value:t,options:n,onChange:o,label:s().text("Select relationship type "),components:{Option:y},TextFieldProps:p},l))},E=i().shape({label:i().string.isRequired,value:i().string.isRequired,startObject:i().object,endObject:i().object});w.propTypes={value:E,options:i().arrayOf(E),onChange:i().func};const P=w},3409:(e,t,n)=>{n.d(t,{Z:()=>d});var a=n(24328),r=n.n(a),o=n(52730),i=n(49885),l=n(94079),s=n(17440),c=n(87918),p=n.n(c);const u=(0,n(79692).Z)({root:{display:"flex",alignItems:"flex-start"},slice:{fontWeight:500},cancelButton:{width:"88px",flexShrink:0,marginLeft:"15px"}}),d=()=>{const e=u(),t=(0,o.useSelector)(i.ZP.selectors.getHistoryEvent),n=(0,o.useDispatch)(),a=(0,s.pipe)(i.N5.history.actions.clearHistoryEvent,n);return t?r().createElement("div",{className:e.root},r().createElement(l.Typography,{component:"div"},p().text("You are viewing a historic slice:")," ",r().createElement("span",{className:e.slice},p().date(t.aStamp,"llll"))),r().createElement(l.Button,{className:e.cancelButton,variant:"contained",color:"primary",onClick:a},p().text("Cancel"))):null}},54198:(e,t,n)=>{n.d(t,{G:()=>i,u:()=>l});var a=n(24328),r=n.n(a);const o=(0,a.createContext)(null);o.displayName="ActionsHookContext";const i=e=>{let{children:t,hook:n}=e;return r().createElement(o.Provider,{value:n},t)},l=()=>{const e=(0,a.useContext)(o);if(!e)throw new Error("ActionsHookContext must be provided");return e}},94622:(e,t,n)=>{n.d(t,{f:()=>p,M:()=>u});var a=n(24328),r=n.n(a),o=n(31276);function i(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?Object(arguments[t]):{},a=Object.keys(n);"function"==typeof Object.getOwnPropertySymbols&&(a=a.concat(Object.getOwnPropertySymbols(n).filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable})))),a.forEach((function(t){l(e,t,n[t])}))}return e}function l(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}const s=r().createContext({isLoading:!1,updateEntityLoadingState:o.ZT,updateEntitiesNavigationLoadingState:o.ZT,resetLoadingState:o.ZT}),c={entitiesNavigation:!1,entity:!1},p=e=>{let{children:t}=e;const n=(()=>{const[e,t]=(0,a.useState)(c),n=(0,a.useCallback)((e=>{t((t=>i({},t,{entity:e})))}),[]),r=(0,a.useCallback)((e=>{t((t=>i({},t,{entitiesNavigation:e})))}),[]),o=(0,a.useCallback)((()=>{t(c)}),[]);return{isLoading:Object.values(e).includes(!0),updateEntityLoadingState:n,updateEntitiesNavigationLoadingState:r,resetLoadingState:o}})();return r().createElement(s.Provider,{value:n},t)},u=()=>(0,a.useContext)(s)},79468:(e,t,n)=>{n.d(t,{T:()=>r});var a=n(24328);const r=n.n(a)().createContext({profileBand:{}});r.displayName="LabelsContext"},7718:(e,t,n)=>{n.d(t,{C:()=>h});var a=n(24328),r=n(52730),o=n(17440),i=n(67958),l=n(49885);function s(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?Object(arguments[t]):{},a=Object.keys(n);"function"==typeof Object.getOwnPropertySymbols&&(a=a.concat(Object.getOwnPropertySymbols(n).filter((function(e){return Object.getOwnPropertyDescriptor(n,e).enumerable})))),a.forEach((function(t){c(e,t,n[t])}))}return e}function c(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}const p=(e,t)=>t.filter((t=>t.replyId!==e)),u=(e,t)=>{const n=e.replies.findIndex((e=>{let{replyId:n}=e;return n===t.replyId})),a=[...e.replies];return a[n]=t,a},d=[],m=e=>console.error("Collaboration error",e),h=e=>{let{objectIds:t=d,objectTypes:n,enabled:c=!0}=e;const h=(0,r.useSelector)(l.ZP.selectors.getEntity),f=(0,r.useSelector)(l.ZP.selectors.getTenant),b=(0,r.useSelector)(l.ZP.selectors.getCollaborationPath),g=(0,r.useSelector)(l.ZP.selectors.isCollaborationEnabled)&&c,[y,x]=(0,a.useState)(null),[v,O]=(0,a.useState)([]),[w,E]=(0,a.useState)(null),[P,S]=(0,a.useState)(null),[C,T]=(0,a.useState)(!1),[j,k]=(0,a.useState)(!1),[I,N]=(0,a.useState)({}),R=(0,a.useCallback)((e=>{E((t=>s({},t,e)))}),[]),Z=null==h?void 0:h.uri,L=(0,a.useCallback)((function(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];if(g&&Z&&!(0,i.ZiX)(Z)){const n=e=>{console.warn("Collaboration error",e),E(null)};(0,o.pipe)(i.$oF,(0,o.andThen)((0,o.map)((0,o.props)(["objectId","comments"]))),(0,o.andThen)(o.fromPairs),(0,o.andThen)(t?E:R),(0,o.otherwise)(n))({uris:e,tenant:f,collaborationPath:b})}else E(null)}),[R,b,Z,g,f]);(0,a.useEffect)((()=>{L(t,!0)}),[t,L]);const D=(0,a.useCallback)(((e,t)=>{(0,i.liG)({collaborationPath:b,tenant:f,relatedObjectUri:e,pageToken:t}).then((e=>{let{items:n,nextPageToken:a}=e;O((e=>t?(0,o.uniqBy)((0,o.prop)("commentId"),[...e,...n]):n)),x(a)})).catch(m)}),[b,f]),B=(0,a.useCallback)((e=>{k(!0),(0,i.d7q)({collaborationPath:b,tenant:f,commentId:e}).then(S).catch(m).finally((()=>k(!1)))}),[b,f]),F=(0,a.useCallback)((e=>{let{content:t,namedUsers:n,objectType:a,uri:r,relatedObjectUris:o}=e;T(!0);const l={objectId:r,content:t,relatedObjectUris:o,objectType:a,visibility:"public",namedUsers:n,permanentLink:`${window.location.href}&commentId=${encodeURIComponent("{commentId}")}`};return(0,i.Yrx)({collaborationPath:b,tenant:f,data:l}).then((e=>{let[t]=e;return((e,t)=>{S(e),E((n=>s({},n,{[t]:[...n[t]||[],{commentId:e.commentId,replies:0,status:"open"}]}))),O((t=>[e,...t]))})(t,r)})).catch(m).finally((()=>T(!1)))}),[b,f]),q=(0,a.useCallback)((e=>{let{content:t,namedUsers:n,objectType:a,uri:r,relatedObjectUris:l,commentId:c,replies:p}=e;T(!0);const u={objectId:r,content:t,relatedObjectUris:l,objectType:a,visibility:"public",namedUsers:n,commentId:c,replies:p};return(0,i.uAg)({collaborationPath:b,tenant:f,data:u}).then((e=>(e=>{S(e),O((0,o.map)((0,o.when)((0,o.propEq)("commentId",e.commentId),(0,o.always)(e))))})(s({},e,{replies:p})))).catch(m).finally((()=>T(!1)))}),[b,f]),H=(0,a.useCallback)((e=>{let{uri:t,commentId:n}=e;T(!0),(0,i.YFy)({collaborationPath:b,tenant:f,commentId:n}).then((()=>((e,t)=>{S(null),E((n=>{const a=n[t]||[];return s({},n,{[t]:a.filter((t=>t.commentId!==e))})})),O((t=>t.filter((t=>t.commentId!==e))))})(n,t))).catch(m).finally((()=>T(!1)))}),[b,f]),U=(0,a.useCallback)(((e,t,n,a)=>{const r="resolve"===e.action?"resolved":"open",{replyId:o}=e;S("resolved"===r?e=>{if(e)return null}:t=>{if(t)return s({},t,{replies:a?p(o,t.replies):[...t.replies,e]})}),E((e=>s({},e,{[t]:(e[t]||[]).map((e=>e.commentId===n?s({},e,{status:r,replies:a?e.replies-1:e.replies+1}):e))}))),O((t=>t.map((t=>t.commentId===n?s({},t,{status:r,replies:a?p(e.replyId,t.replies):[...t.replies,e]}):t))))}),[]),z=(0,a.useCallback)((e=>{let{uri:t,commentId:n,reply:a}=e;T(!0),(0,i.Mfr)({collaborationPath:b,tenant:f,commentId:n,replyId:a.replyId}).then((()=>U(a,t,n,!0))).catch(m).finally((()=>T(!1)))}),[b,U,f]),_=(0,a.useCallback)(((e,t)=>{S((t=>{if(t)return s({},t,{replies:u(t,e)})})),O((n=>n.map((n=>n.commentId===t?s({},n,{replies:u(n,e)}):n))))}),[]),A=(0,a.useCallback)((e=>{let{content:t,namedUsers:n,commentId:a,replyId:r}=e;T(!0);const o={content:t,namedUsers:n};return(0,i.ufV)({collaborationPath:b,tenant:f,commentId:a,replyId:r,data:o}).then((e=>_(e,a))).catch(m).finally((()=>T(!1)))}),[b,f,_]),$=(0,a.useCallback)((e=>{let{content:t,namedUsers:n,commentId:a,action:r,uri:o}=e;T(!0);const l={content:t,action:r,namedUsers:n};return(0,i.PP2)({collaborationPath:b,tenant:f,commentId:a,data:l}).then((e=>{let[t]=e;return U(t,o,a)})).catch(m).finally((()=>T(!1)))}),[b,f,U]),W=(0,a.useCallback)((e=>{let{commentId:t,uri:n}=e;$({content:"",namedUsers:[],commentId:t,action:"resolve",uri:n})}),[$]),M=(0,a.useCallback)((e=>{let{commentId:t,uri:n}=e;$({content:"",namedUsers:[],commentId:t,action:"reopen",uri:n})}),[$]);return{clearCurrentComment:(0,a.useCallback)((()=>{S(null)}),[]),comments:v,commentsMap:w,getCommentState:(e,t)=>(0,o.pathOr)({},[e,t],I),updateCommentState:(e,t,n)=>{N((a=>{const r=[e,t],i=(0,o.path)(r,a);return(0,o.assocPath)(r,(0,o.mergeRight)(i,n),a)}))},clearCommentState:(e,t)=>N((0,o.dissocPath)([e,t])),createComment:F,createReply:$,currentComment:P,deleteComment:H,editComment:q,getComment:B,getComments:D,getCommentsCount:L,loading:j,objectTypes:n,pageToken:y,reOpenThread:M,resolveThread:W,sending:C,deleteReply:z,editReply:A}}},89846:(e,t,n)=>{n.d(t,{n:()=>i});var a=n(24328),r=n(67958),o=n(17440);const i=e=>{let{reversedContextLabels:t}=e;return{getRelationTypesOptions:(0,a.useCallback)(((e,n)=>{const a={},i=(0,o.pipe)(r.PjQ,(0,o.tap)((e=>a[e]=(0,o.propOr)(0,e,a)+1))),l=(0,o.ascend)((0,o.prop)("label")),s=(0,o.curry)(((e,n)=>{let{uri:a,label:o,startObject:l,endObject:s}=n;const c=e===(t?r.Nsj.OUT:r.Nsj.IN)?l:s;return{label:{directionalLabel:i(c),typeLabel:o},value:`${a},${e}`,startObject:l,endObject:s}}));return e.map(s(r.Nsj.IN)).concat(n.map(s(r.Nsj.OUT))).map((0,o.evolve)({label:e=>{let{directionalLabel:t,typeLabel:n}=e;return t?a[t]>1?`${t} (${n})`:t:n}})).sort(l)}),[t]),fromEditorValue:(0,a.useCallback)(((e,t)=>n=>{const[a,i]=n.value.split(",");return{type:(i===r.Nsj.IN?e:t).find((0,o.propEq)("uri",a)),direction:i}}),[]),toEditorValue:(0,a.useCallback)(((e,t)=>t.find((0,o.propEq)("value",`${e.relationType},${e.direction}`))),[])}}}}]);
|
|
2
|
-
//# sourceMappingURL=9481.js.map
|
package/9481.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"9481.js","mappings":"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","sources":["webpack://@reltio/remotes/../components/src/components/ActionButton/styles.ts","webpack://@reltio/remotes/../components/src/components/ActionButton/ActionButton.tsx","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/ConfirmationDialog/styles.ts","webpack://@reltio/remotes/../components/src/components/ConfirmationDialog/ConfirmationDialog.tsx","webpack://@reltio/remotes/../components/src/components/ConnectionRelationTypeSelector/ConnectionRelationTypeSelector.js","webpack://@reltio/remotes/../components/src/components/EntityTypeBadge/styles.ts","webpack://@reltio/remotes/../components/src/components/EntityTypeBadge/EntityTypeBadge.tsx","webpack://@reltio/remotes/../components/src/components/ProfileBand/styles.ts","webpack://@reltio/remotes/../components/src/components/ProfileBand/ProfileBand.tsx","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/styles.ts","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/ProfileBandNavigationWidget.tsx","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/searchProviders/MainSearchProvider.ts","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/searchProviders/GraphSearchProvider.ts","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/helpers/index.ts","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/hooks/useSearchNavigation.ts","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/searchProviders/SearchProviderFactory.ts","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/ProfileBandNavigation.tsx","webpack://@reltio/remotes/../components/src/components/ProfileBandNavigation/hooks/useSearchNavigationVisibility.ts","webpack://@reltio/remotes/../components/src/components/ProfileCard/ProfileCardContent/styles.ts","webpack://@reltio/remotes/../components/src/components/ProfileCard/ProfileCardContent/ProfileCardContent.tsx","webpack://@reltio/remotes/../components/src/components/ProfileCard/ProfileCardPlaceholder/styles.ts","webpack://@reltio/remotes/../components/src/components/ProfileCard/ProfileCardPlaceholder/ProfileCardPlaceholder.tsx","webpack://@reltio/remotes/../components/src/components/ProfileCard/styles.ts","webpack://@reltio/remotes/../components/src/components/ProfileCard/ProfileCard.tsx","webpack://@reltio/remotes/../components/src/components/SideIconPanel/styles.ts","webpack://@reltio/remotes/../components/src/components/SideIconPanel/SideButtonsPanel.tsx","webpack://@reltio/remotes/../components/src/components/SidePanel/styles.ts","webpack://@reltio/remotes/../components/src/components/SidePanel/SidePanel.tsx","webpack://@reltio/remotes/../components/src/components/attributes/editMode/RelationTypeSelector/components/styles.js","webpack://@reltio/remotes/../components/src/components/attributes/editMode/RelationTypeSelector/components/RelationOption.js","webpack://@reltio/remotes/../components/src/components/attributes/editMode/RelationTypeSelector/RelationTypeSelector.js","webpack://@reltio/remotes/../components/src/components/history/ProfileBandHistory/styles.ts","webpack://@reltio/remotes/../components/src/components/history/ProfileBandHistory/ProfileBandHistory.tsx","webpack://@reltio/remotes/../components/src/contexts/ActionsHookContext/index.tsx","webpack://@reltio/remotes/../components/src/contexts/EntityLoadingIndicationContext/index.tsx","webpack://@reltio/remotes/../components/src/contexts/LabelsContext/index.ts","webpack://@reltio/remotes/../components/src/hooks/useCollaboration.ts","webpack://@reltio/remotes/../components/src/hooks/useRelationTypeSelector.js"],"sourcesContent":["import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n button: {\n padding: '9px 16px 9px 12px',\n '& svg g path, & svg path': {\n fill: theme.palette.primary.main,\n fillOpacity: 1\n }\n },\n iconButton: {\n '& svg g path, & svg path': {\n fill: theme.palette.primary.main,\n fillOpacity: 1\n }\n },\n startIcon: {\n marginLeft: 0,\n marginRight: '8px',\n width: '18px',\n height: '18px',\n alignItems: 'center'\n },\n label: {\n whiteSpace: 'nowrap',\n fontSize: '14px',\n lineHeight: '16px',\n letterSpacing: 0\n },\n overflowStyle: {\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis'\n },\n menuIcon: {\n marginRight: '12px'\n },\n menuItem: {\n minHeight: '28px',\n padding: '2px 16px 2px 12px'\n },\n menuText: {\n color: theme.palette.text.primary,\n fontSize: '13px',\n lineHeight: '15px',\n letterSpacing: 0\n }\n}));\n","import React, {forwardRef} from 'react';\nimport classnames from 'classnames';\nimport {Button as Button} from '@material-ui/core';\nimport {MenuItem as MenuItem} from '@material-ui/core';\nimport {Typography as Typography} from '@material-ui/core';\n\nimport {useStyles} from './styles';\nimport {noop} from '../../core';\nimport ExpandedValueTooltip from '../ExpandedValueTooltip/ExpandedValueTooltip';\nimport {SmallIconButtonWithTooltip} from '../SmallIconButton';\n\nexport enum ActionButtonMode {\n iconButton = 'iconButton',\n button = 'button',\n menuItem = 'menuItem'\n}\n\nexport type Props = {\n className?: string;\n disabled?: boolean;\n icon: React.ElementType;\n label: string;\n mode: ActionButtonMode;\n onClick: () => void;\n onMenuClose?: () => void;\n};\n\nexport const ActionButton = forwardRef<HTMLLIElement, Props>(\n (\n {\n className,\n mode = ActionButtonMode.iconButton,\n label,\n disabled,\n icon: Icon,\n onClick = noop,\n onMenuClose = noop,\n ...otherProps\n }: Props,\n ref: React.Ref<HTMLLIElement>\n ) => {\n const styles = useStyles();\n\n const getButtonView = () => {\n switch (mode) {\n case 'iconButton': {\n return (\n <SmallIconButtonWithTooltip\n disabled={disabled}\n className={classnames(styles.iconButton, className)}\n size=\"S\"\n tooltipTitle={label}\n onClick={onClick}\n icon={Icon}\n showForDisabled\n {...otherProps}\n />\n );\n }\n case 'button': {\n return (\n <Button\n className={classnames(styles.button, className)}\n disabled={disabled}\n startIcon={<Icon />}\n onClick={onClick}\n color=\"primary\"\n classes={{startIcon: styles.startIcon, label: styles.label}}\n {...otherProps}\n >\n <ExpandedValueTooltip value={label}>\n <div className={styles.overflowStyle}>{label}</div>\n </ExpandedValueTooltip>\n </Button>\n );\n }\n case 'menuItem': {\n const handleClick = () => {\n onMenuClose();\n onClick();\n };\n return (\n <MenuItem\n classes={{root: styles.menuItem}}\n onClick={handleClick}\n disabled={disabled}\n ref={ref}\n {...otherProps}\n >\n <>\n <Icon className={styles.menuIcon} />\n <Typography classes={{root: styles.menuText}}>{label}</Typography>\n </>\n </MenuItem>\n );\n }\n }\n };\n\n return getButtonView();\n }\n);\n\nActionButton.displayName = 'ActionButton';\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 {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 React, {useMemo, useCallback, useEffect} from 'react';\nimport PropTypes from 'prop-types';\nimport {ConnectionRelationType, RelationTypeType} from '@reltio/mdm-sdk';\nimport {identity, pipe} from 'ramda';\nimport {useRelationTypeSelector} from '../../hooks';\nimport RelationTypeSelector from '../attributes/editMode/RelationTypeSelector/RelationTypeSelector';\n\nconst ConnectionRelationTypeSelector = ({\n relation = {},\n inRelationTypes = [],\n outRelationTypes = [],\n onChange = identity,\n applyFirstByDefault = false,\n reversedContextLabels = false,\n ...otherProps\n}) => {\n const {getRelationTypesOptions, fromEditorValue, toEditorValue} = useRelationTypeSelector({reversedContextLabels});\n\n const relationsTypesOptions = useMemo(() => getRelationTypesOptions(inRelationTypes, outRelationTypes), [\n getRelationTypesOptions,\n inRelationTypes,\n outRelationTypes\n ]);\n\n const handleChange = useCallback(pipe(fromEditorValue(inRelationTypes, outRelationTypes), onChange), [\n fromEditorValue,\n inRelationTypes,\n outRelationTypes,\n onChange\n ]);\n\n const hasValue = !!relation.relationType;\n\n useEffect(() => {\n if (applyFirstByDefault && relationsTypesOptions.length && !hasValue) {\n handleChange(relationsTypesOptions[0]);\n }\n }, [relationsTypesOptions, applyFirstByDefault, handleChange, hasValue]);\n\n return (\n <RelationTypeSelector\n value={toEditorValue(relation, relationsTypesOptions)}\n options={relationsTypesOptions}\n onChange={handleChange}\n {...otherProps}\n />\n );\n};\n\nConnectionRelationTypeSelector.propTypes = {\n className: PropTypes.string,\n relation: ConnectionRelationType,\n inRelationTypes: PropTypes.arrayOf(RelationTypeType),\n outRelationTypes: PropTypes.arrayOf(RelationTypeType),\n applyFirstByDefault: PropTypes.bool,\n reversedContextLabels: PropTypes.bool,\n onChange: PropTypes.func\n};\n\nexport default ConnectionRelationTypeSelector;\n","import {makeStyles} from '@material-ui/core/styles';\n\nconst useStyles = makeStyles({\n 'entityType-overflow': {\n textOverflow: 'ellipsis',\n overflow: 'hidden',\n whiteSpace: 'nowrap'\n },\n\n 'entityType-small': {\n padding: '1px 4px',\n fontSize: '10px',\n lineHeight: 'normal',\n marginRight: '12px',\n borderRadius: '2px',\n flexShrink: 0\n },\n 'entityType-medium': {\n padding: '2px 8px 3px',\n borderRadius: '2px',\n fontSize: '13px',\n fontWeight: 500,\n lineHeight: '15px',\n marginRight: '16px',\n flexShrink: 0\n }\n});\n\nexport default useStyles;\n","import React from 'react';\nimport {useSelector} from 'react-redux';\nimport classnames from 'classnames';\nimport {Typography as Typography} from '@material-ui/core';\n\nimport {getEntityType, getEntityTypeLabel, getPropWithInheritance, theme, utils, Entity} from '@reltio/mdm-sdk';\nimport mdmModule from '@reltio/mdm-module';\nimport ExpandedValueTooltip from '../ExpandedValueTooltip/ExpandedValueTooltip';\nimport useStyles from './styles';\n\ntype Props = {\n entity: Entity;\n className?: string;\n size?: 'small' | 'medium';\n};\n\nconst EntityTypeBadge = ({entity, className, size = 'small'}: Props) => {\n const styles = useStyles();\n const metadata = useSelector(mdmModule.selectors.getMetadata);\n const entityTypeUri = entity.type;\n const entityType = getEntityType(metadata, entityTypeUri) || {};\n const entityTypeColor = getPropWithInheritance(metadata, entityType, 'typeColor') || theme.palette.primary.main;\n const entityTypeLabel = getEntityTypeLabel(metadata, entity);\n\n return (\n <ExpandedValueTooltip value={entityTypeLabel} placement=\"top\">\n <Typography\n style={{\n backgroundColor: entityTypeColor,\n color: utils.Colors.getColor(entityTypeColor) ? '#FFFFFF' : '#212121'\n }}\n className={classnames(styles[`entityType-${size}`], styles['entityType-overflow'], className)}\n component=\"div\"\n >\n {entityTypeLabel}\n </Typography>\n </ExpandedValueTooltip>\n );\n};\n\nexport default EntityTypeBadge;\n","import {makeStyles, Theme} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme: Theme & {inactiveBackground: string}) => ({\n profileBandWrapper: {\n // especially for IE (overflow fix)\n flexShrink: 0\n },\n profileBand: {\n display: 'flex',\n padding: '16px 12px 16px 16px',\n alignItems: 'flex-start',\n backgroundColor: '#fff',\n boxShadow: '0px 1px 0px rgba(0, 0, 0, 0.12)',\n marginBottom: '1px',\n '&:after': {\n // IE workaround for minHeight and centering items\n content: '\"\"',\n minHeight: 'inherit',\n fontSize: 0\n }\n },\n inactive: {\n background: theme.inactiveBackground\n },\n profileIcon: {\n marginRight: '12px'\n },\n imageProfileIcon: {\n width: '48px',\n height: '48px'\n },\n profileInfo: {\n display: 'flex',\n flexDirection: 'column',\n flex: '1 1 50%'\n },\n badge: {},\n label: {\n lineHeight: '1.2',\n letterSpacing: '0.25px',\n color: theme.palette.text.primary,\n wordBreak: 'break-word',\n\n '&+ $specialInfo': {\n marginTop: '4px'\n }\n },\n secondaryLabel: {\n display: 'inline-flex',\n color: theme.palette.text.primary,\n marginTop: '2px',\n lineHeight: '16px',\n fontSize: '14px',\n fontWeight: 400,\n\n '&+ $businessCard': {\n marginLeft: '12px'\n }\n },\n businessCard: {\n color: theme.palette.text.secondary,\n display: 'inline-flex',\n fontSize: '14px',\n marginTop: '4px',\n lineHeight: '1.2'\n },\n specialInfo: {\n display: 'flex',\n justifyContent: 'space-between',\n flexWrap: 'wrap',\n width: '100%',\n marginTop: '8px'\n },\n entityType: {\n display: 'flex',\n flexWrap: 'wrap'\n },\n entityId: {\n fontSize: '13px',\n color: theme.palette.text.secondary,\n whiteSpace: 'nowrap',\n cursor: 'pointer',\n '&:hover': {\n textDecoration: 'underline'\n }\n }\n}));\n\nexport default useStyles;\n","import React, {ReactNode, useCallback} from 'react';\nimport classnames from 'classnames';\nimport {useSelector} from 'react-redux';\nimport {isNil, identity} from 'ramda';\nimport {Typography as Typography} from '@material-ui/core';\nimport {Tooltip as Tooltip} from '@material-ui/core';\nimport i18n from 'ui-i18n';\n\nimport {getLabel, isActiveObject, getBusinessCardAttributesText, getEntityId, isTempUri, Entity} from '@reltio/mdm-sdk';\nimport mdmModule from '@reltio/mdm-module';\n\nimport EntityAvatar from '../EntityAvatar/EntityAvatar';\nimport EntityTypeBadge from '../EntityTypeBadge/EntityTypeBadge';\n\nimport useStyles from './styles';\n\ntype Props = {\n className?: string;\n entity?: Entity;\n children?: ReactNode;\n classes?: Partial<ReturnType<typeof useStyles>>;\n renderLabel?: (label: string) => React.ReactNode;\n};\n\nconst ProfileBand = ({className, entity, children, classes, renderLabel = identity}: Props) => {\n const styles = useStyles({classes});\n const metadata = useSelector(mdmModule.selectors.getMetadata);\n const showEntityId = useSelector(mdmModule.selectors.getShowEntityId);\n const handleCopyEntityIdToClipboard = useCallback(() => {\n navigator.clipboard.writeText(getEntityId(entity));\n }, [entity]);\n\n if (isNil(entity)) {\n return null;\n }\n\n const label = getLabel(entity.label);\n const secondaryLabel = entity.secondaryLabel;\n const businessCardText = getBusinessCardAttributesText(metadata, entity);\n const isActive = isActiveObject(entity);\n const entityUri = entity.uri;\n const entityId = getEntityId(entity);\n return (\n <div className={classnames(styles.profileBandWrapper, className)}>\n <div\n className={classnames(styles.profileBand, {\n [styles.inactive]: !isActive\n })}\n data-entity-uri={entityUri}\n >\n <EntityAvatar\n key={entity.uri}\n entity={entity}\n avatarClassName={styles.profileIcon}\n imageClassName={styles.imageProfileIcon}\n />\n <div className={styles.profileInfo}>\n <div>\n <Typography variant=\"h6\" className={styles.label}>\n {renderLabel(label)}\n </Typography>\n {secondaryLabel && (\n <Typography variant=\"subtitle2\" className={styles.secondaryLabel}>\n {secondaryLabel}\n </Typography>\n )}\n {businessCardText && (\n <Typography variant=\"subtitle1\" className={styles.businessCard}>\n {businessCardText}\n </Typography>\n )}\n </div>\n <div className={styles.specialInfo}>\n <div className={styles.entityType}>\n <EntityTypeBadge entity={entity} size=\"medium\" className={styles.badge} />\n {!isTempUri(entityUri) && showEntityId && (\n <Tooltip title={i18n.text('Copy to clipboard')}>\n <Typography\n display=\"inline\"\n variant=\"body2\"\n className={styles.entityId}\n onClick={handleCopyEntityIdToClipboard}\n >\n {i18n.text('Entity ID')}: {entityId}\n </Typography>\n </Tooltip>\n )}\n </div>\n </div>\n </div>\n {children && <div>{children}</div>}\n </div>\n </div>\n );\n};\n\nexport default ProfileBand;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles({\n container: {\n display: 'flex',\n alignItems: 'center'\n },\n link: {\n whiteSpace: 'nowrap',\n marginRight: '9px'\n }\n});\n","import React, {useContext} from 'react';\nimport {Link as Link} from '@material-ui/core';\nimport KeyboardArrowLeft from '@material-ui/icons/KeyboardArrowLeft';\nimport KeyboardArrowRight from '@material-ui/icons/KeyboardArrowRight';\nimport {formatNumberAsMetric} from '@reltio/mdm-sdk';\nimport classnames from 'classnames';\nimport {mergeRight} from 'ramda';\nimport i18n from 'ui-i18n';\nimport {LabelsContext} from '../../contexts/LabelsContext';\nimport {withTooltip} from '../../HOCs';\nimport {SmallIconButtonWithTooltip} from '../SmallIconButton';\n\nimport {useStyles} from './styles';\n\nconst LinkWithTooltip = withTooltip<typeof Link, {component: string}>(Link);\n\ntype Props = {\n className?: string;\n total?: number;\n onPrev?: () => void;\n onNext?: () => void;\n onSearchResultsClick?: () => void;\n isPrevDisabled?: boolean;\n isNextDisabled?: boolean;\n};\n\nconst ProfileBandNavigationWidget = ({\n className,\n total = 0,\n onPrev,\n onNext,\n onSearchResultsClick,\n isPrevDisabled,\n isNextDisabled\n}: Props) => {\n const styles = useStyles();\n const labels = useContext(LabelsContext);\n const {OPEN_RESULTS, SEARCH_RESULT, SEARCH_RESULTS, NEXT_PROFILE, PREVIOUS_PROFILE} = mergeRight(\n {\n OPEN_RESULTS: i18n.text('Go to search results'),\n SEARCH_RESULT: i18n.text('Search result'),\n SEARCH_RESULTS: i18n.text('Search results'),\n PREVIOUS_PROFILE: i18n.text('Go to previous profile'),\n NEXT_PROFILE: i18n.text('Go to next profile')\n },\n labels?.profileBand ?? {}\n );\n return (\n <div className={classnames(styles.container, className)}>\n <LinkWithTooltip\n className={styles.link}\n component=\"button\"\n variant=\"caption\"\n onClick={onSearchResultsClick}\n underline=\"none\"\n tooltipTitle={OPEN_RESULTS}\n >\n {formatNumberAsMetric(total, 1000000)} {total === 1 ? SEARCH_RESULT : SEARCH_RESULTS}\n </LinkWithTooltip>\n <SmallIconButtonWithTooltip\n size=\"L\"\n icon={KeyboardArrowLeft}\n tooltipTitle={PREVIOUS_PROFILE}\n onClick={onPrev}\n disabled={isPrevDisabled}\n showForDisabled\n />\n <SmallIconButtonWithTooltip\n size=\"L\"\n icon={KeyboardArrowRight}\n tooltipTitle={NEXT_PROFILE}\n onClick={onNext}\n disabled={isNextDisabled}\n showForDisabled\n />\n </div>\n );\n};\n\nexport {ProfileBandNavigationWidget, LinkWithTooltip};\n","import {\n Entity,\n getFilteredEntities,\n getFilteredEntitiesFromDataTenant,\n getTotals,\n getTotalFromDataTenant,\n TotalResponse\n} from '@reltio/mdm-sdk';\n\nimport {SearchProvider} from './SearchProvider';\n\nexport class MainSearchProvider implements SearchProvider {\n private readonly query;\n private readonly sortField;\n private readonly sortOrder;\n private readonly tenant;\n private readonly searchTenant;\n private readonly apiPath;\n private readonly dtssPath;\n private readonly globalSearchRequestOptions;\n\n constructor({\n data: {query, sortField, sortOrder},\n tenant,\n searchTenant,\n apiPath,\n dtssPath,\n globalSearchRequestOptions\n }) {\n this.query = query;\n this.sortField = sortField;\n this.sortOrder = sortOrder;\n this.tenant = tenant;\n this.searchTenant = searchTenant;\n this.apiPath = apiPath;\n this.dtssPath = dtssPath;\n this.globalSearchRequestOptions = globalSearchRequestOptions;\n }\n\n private isDT = () => this.tenant !== this.searchTenant;\n\n private getQueryFilter = () => ({rawFilter: this.query});\n\n private getEntities = (filters = [], options = {}): Promise<Entity[]> => {\n const requestFilters = [this.getQueryFilter(), ...filters];\n const requestOptions = {\n ...this.globalSearchRequestOptions,\n sort: this.sortField,\n order: this.sortOrder,\n select: 'uri,label,type',\n scoreEnabled: false,\n ...options\n };\n return this.isDT()\n ? getFilteredEntitiesFromDataTenant({\n filters: requestFilters,\n options: requestOptions,\n customerTenant: this.tenant,\n dataTenant: this.searchTenant,\n dtssPath: this.dtssPath\n })\n : getFilteredEntities(requestFilters, requestOptions);\n };\n\n checkEntity = (uri): Promise<boolean> => {\n return this.getEntities(\n [\n {\n filter: 'equals',\n fieldName: 'uri',\n values: [uri]\n }\n ],\n {offset: 0, max: 1}\n ).then((entities) => {\n return entities && entities.length > 0 && entities[0].uri === uri;\n });\n };\n\n requestEntities = (max, offset): Promise<Entity[]> => {\n return this.getEntities([], {offset, max});\n };\n\n requestTotal = (): Promise<number> => {\n const filters = [this.getQueryFilter()];\n const options = this.globalSearchRequestOptions;\n return (this.isDT()\n ? getTotalFromDataTenant({\n filters,\n options,\n customerTenant: this.tenant,\n dataTenant: this.searchTenant,\n dtssPath: this.dtssPath\n })\n : getTotals(filters, options)\n ).then((json) => (json as TotalResponse).total);\n };\n}\n","import {\n Entity,\n getGraphSearchCount,\n getGraphSearchEntities,\n getEntityId,\n buildFilterQueryString\n} from '@reltio/mdm-sdk';\n\nimport {SearchProvider} from './SearchProvider';\n\nexport class GraphSearchProvider implements SearchProvider {\n private readonly searchBody;\n private readonly tenant;\n private readonly apiPath;\n\n constructor({data, tenant, apiPath}) {\n this.searchBody = data;\n this.tenant = tenant;\n this.apiPath = apiPath;\n }\n\n private getEntities = (filters = [], options = {}): Promise<Entity[]> => {\n const allFilters = [\n {\n rawFilter: this.searchBody.filter\n },\n ...filters\n ];\n return getGraphSearchEntities({\n apiPath: this.apiPath,\n tenant: this.tenant,\n searchBody: {\n ...this.searchBody,\n filter: filters.length ? buildFilterQueryString()(allFilters) : this.searchBody.filter\n },\n options\n });\n };\n\n checkEntity = (uri): Promise<boolean> => {\n return this.getEntities(\n [\n {\n filter: 'equals',\n fieldName: 'id',\n values: [getEntityId({uri})]\n }\n ],\n {from: 0, max: 1}\n ).then((entities) => {\n return entities && entities.length > 0 && entities[0].uri === uri;\n });\n };\n\n requestEntities = (max, from): Promise<Entity[]> => {\n return this.getEntities([], {from, max});\n };\n\n requestTotal = (): Promise<number> => {\n return getGraphSearchCount({\n apiPath: this.apiPath,\n tenant: this.tenant,\n searchBody: this.searchBody\n }).then((json) => json.count);\n };\n}\n","import {SearchNavigationData} from '../types';\n\ntype Payload = {\n winnerUri: string;\n losersUris: string[];\n};\n\nconst replaceWithWinnerUri = (searchNavigationData: SearchNavigationData, winnerUri: string): SearchNavigationData => {\n let {uri, index, total, cache} = searchNavigationData;\n if (winnerUri && winnerUri !== uri) {\n if (cache && cache.includes(uri)) {\n cache = [...cache];\n const winnerIndex = cache.indexOf(winnerUri);\n let uriIndex = cache.indexOf(uri);\n if (winnerIndex >= 0) {\n cache.splice(winnerIndex, 1);\n total--;\n if (winnerIndex < uriIndex) {\n index--;\n }\n }\n uriIndex = cache.indexOf(uri);\n cache.splice(uriIndex, 1, winnerUri);\n }\n uri = winnerUri;\n return {\n ...searchNavigationData,\n uri,\n index,\n cache,\n total\n };\n }\n return searchNavigationData;\n};\n\nconst removeLosersUris = (searchNavigationData: SearchNavigationData, losersUris: string[]): SearchNavigationData => {\n const {cache = [], index, total, uri} = searchNavigationData;\n const losersInCache = losersUris.filter((uri) => cache.includes(uri));\n if (losersInCache.length === 0) {\n return searchNavigationData;\n }\n const updatedTotal = total - losersInCache.length;\n const uriIndex = cache.indexOf(uri);\n let updatedIndex = index;\n for (const loser of losersInCache) {\n const loserIndex = cache.indexOf(loser);\n if (loserIndex < uriIndex) {\n updatedIndex--;\n }\n }\n const updatedCache = cache.filter((uri) => !losersInCache.includes(uri));\n\n return {\n ...searchNavigationData,\n cache: updatedCache,\n index: updatedIndex,\n total: updatedTotal\n };\n};\n\nexport const applyMergeToSearchNavigationData = (\n searchNavigationData: SearchNavigationData,\n payload: Payload\n): SearchNavigationData => {\n const {winnerUri, losersUris = []} = payload;\n const updatedSearchNavigationData = replaceWithWinnerUri(searchNavigationData, winnerUri);\n return removeLosersUris(updatedSearchNavigationData, losersUris);\n};\n","import {useCallback, useContext, useEffect, useMemo, useState} from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport mdmModule, {search as mdmModuleSearch, ui as mdmModuleUi} from '@reltio/mdm-module';\nimport {getEntityUriForLink} from '@reltio/mdm-sdk';\nimport {map, pipe, prop, reject} from 'ramda';\nimport {useEntityLoadingIndication, useActionsHook, ViewIdContext} from '../../../contexts';\nimport {useSafePromise} from '../../../hooks';\nimport {getSearchProvider} from '../searchProviders/SearchProviderFactory';\nimport {SearchNavigationData, SearchProviderData} from '../types';\nimport {applyMergeToSearchNavigationData} from '../helpers';\n\nexport const REQUEST_PAGE_SIZE = 15;\n\nconst getNewUris = (entities, cache) =>\n pipe(\n map(prop('uri')),\n reject((uri) => cache.includes(uri))\n )(entities);\n\nconst useSearchNavigation = () => {\n const safeCheckEntityPromise = useSafePromise();\n const safeRequestTotalPromise = useSafePromise();\n const safeRequestEntitiesPromise = useSafePromise();\n const {\n uri,\n index,\n total,\n tenant: searchTenant,\n cache\n } = useSelector<unknown, SearchNavigationData>(mdmModule.selectors.getSearchNavigationData) || {};\n const {type, data} = useSelector<unknown, SearchProviderData>(mdmModule.selectors.getSearchProviderData) || {};\n const tenant = useSelector<unknown, string>(mdmModule.selectors.getTenant);\n const apiPath = useSelector<unknown, string>(mdmModule.selectors.getApiPath);\n const dtssPath = useSelector<unknown, string>(mdmModule.selectors.getDtssPath);\n const globalSearchRequestOptions = useSelector((state) =>\n mdmModule.selectors.getGlobalSearchRequestOptions(state, ['ovOnly'])\n );\n const {updateEntitiesNavigationLoadingState} = useEntityLoadingIndication();\n const viewId = useContext(ViewIdContext);\n const dispatch = useDispatch();\n const [loading, setLoading] = useState<boolean>(false);\n\n const searchProvider = useMemo(\n () => getSearchProvider(type, {data, tenant, searchTenant, apiPath, dtssPath, globalSearchRequestOptions}),\n [type, data, tenant, searchTenant, apiPath, dtssPath, globalSearchRequestOptions]\n );\n\n const updateNavigationData = useCallback(\n (data: Partial<SearchNavigationData>) => {\n dispatch(mdmModuleSearch.actions.updateSearchNavigationDataFields(data));\n },\n [dispatch]\n );\n\n const openEntity = useCallback(\n (uri: string) => {\n const preparedUri = tenant !== searchTenant ? getEntityUriForLink({uri, dataTenant: searchTenant}) : uri;\n dispatch(mdmModuleUi.actions.openEntity({uri: preparedUri, viewId, source: 'navigation'}));\n },\n [dispatch, viewId, tenant, searchTenant]\n );\n\n const onSearchResultsClick = useCallback(() => {\n dispatch(mdmModuleUi.actions.openPerspective({perspectiveId: type, viewId}));\n }, [dispatch, type, viewId]);\n\n useEffect(() => {\n if (index >= total) {\n updateNavigationData({\n index: total - 1\n });\n } else if (index < 0) {\n updateNavigationData({\n index: 0\n });\n }\n }, [total, index, updateNavigationData]);\n\n const listenToActions = useActionsHook();\n\n useEffect(() => {\n const stopListeningActions = listenToActions((action, state) => {\n switch (action.type) {\n case mdmModuleSearch.constants.UPDATE_SEARCH_NAVIGATION_DATA_ON_MERGE: {\n const searchNavigationData: SearchNavigationData =\n mdmModule.selectors.getSearchNavigationData(state);\n if (searchNavigationData) {\n updateNavigationData(applyMergeToSearchNavigationData(searchNavigationData, action.payload));\n }\n break;\n }\n }\n });\n return () => stopListeningActions();\n }, [listenToActions, updateNavigationData]);\n\n const requestNextPage = useCallback(\n (cache: string[], total: number, index: number): Promise<void> => {\n setLoading(true);\n safeRequestTotalPromise(searchProvider.requestTotal()).then((total) => updateNavigationData({total}));\n\n const newIndex = index + 1;\n return safeRequestEntitiesPromise(searchProvider.requestEntities(REQUEST_PAGE_SIZE, newIndex))\n .then((entities) => {\n if (!entities) {\n return;\n }\n if (entities.length) {\n const newUris = getNewUris(entities, cache);\n if (newUris.length > 0) {\n updateNavigationData({\n cache: cache.concat(newUris),\n uri: newUris[0],\n index: newIndex + entities.length - newUris.length\n });\n openEntity(newUris[0]);\n return;\n } else if (index + entities.length < total - 1) {\n return requestNextPage(cache, total - entities.length, index + entities.length);\n }\n }\n updateNavigationData({\n index: newIndex\n });\n })\n .finally(() => {\n setLoading(false);\n });\n },\n [searchProvider, updateNavigationData, openEntity]\n );\n\n const requestPrevPage = useCallback(\n (cache: string[], index: number): Promise<void> => {\n setLoading(true);\n safeRequestTotalPromise(searchProvider.requestTotal()).then((total) => updateNavigationData({total}));\n\n const newIndex = index - 1;\n const offset = Math.max(0, index - REQUEST_PAGE_SIZE);\n const max = REQUEST_PAGE_SIZE + Math.min(0, index - REQUEST_PAGE_SIZE);\n return safeRequestEntitiesPromise(searchProvider.requestEntities(max, offset))\n .then((entities) => {\n if (!entities) {\n return;\n }\n if (entities.length) {\n const newUris = getNewUris(entities, cache);\n if (newUris.length > 0) {\n updateNavigationData({\n cache: newUris.concat(cache),\n uri: newUris[newUris.length - 1],\n index: newIndex - (entities.length - newUris.length)\n });\n openEntity(newUris[newUris.length - 1]);\n return;\n } else if (index - entities.length > 0) {\n return requestPrevPage(cache, index - entities.length);\n }\n }\n updateNavigationData({\n index: 0\n });\n })\n .finally(() => {\n setLoading(false);\n });\n },\n [searchProvider, updateNavigationData, openEntity]\n );\n\n const stepForwardWithCheck = useCallback(\n (cache: string[], cacheIndex: number, total: number, index: number): Promise<void> | void => {\n if (cacheIndex < cache.length) {\n const uri = cache[cacheIndex];\n setLoading(true);\n return safeCheckEntityPromise(searchProvider.checkEntity(uri))\n .then((isExists) => {\n if (isExists) {\n updateNavigationData({\n index: index + 1,\n uri,\n cache,\n total\n });\n openEntity(uri);\n } else {\n const clearedCache = [...cache];\n clearedCache.splice(cacheIndex, 1);\n return stepForwardWithCheck(clearedCache, cacheIndex, total - 1, index);\n }\n })\n .finally(() => {\n setLoading(false);\n });\n } else if (index >= total - 1) {\n updateNavigationData({\n cache,\n total,\n index: total - 1\n });\n } else {\n return requestNextPage(cache, total, index);\n }\n },\n [searchProvider, updateNavigationData, openEntity, requestNextPage]\n );\n\n const stepBackWithCheck = useCallback(\n (cache: string[], cacheIndex: number, total: number, index: number): Promise<void> | void => {\n if (cacheIndex > -1) {\n const uri = cache[cacheIndex];\n setLoading(true);\n return safeCheckEntityPromise(searchProvider.checkEntity(uri))\n .then((isExists) => {\n if (isExists) {\n updateNavigationData({\n index: index - 1,\n uri,\n cache,\n total\n });\n openEntity(uri);\n } else {\n const clearedCache = [...cache];\n clearedCache.splice(cacheIndex, 1);\n return stepBackWithCheck(clearedCache, cacheIndex - 1, total - 1, index - 1);\n }\n })\n .finally(() => {\n setLoading(false);\n });\n } else if (index <= 0) {\n updateNavigationData({\n index: 0,\n cache,\n total\n });\n } else {\n return requestPrevPage(cache, index);\n }\n },\n [searchProvider, updateNavigationData, openEntity, requestPrevPage]\n );\n\n const onPrev = useCallback(() => {\n if (cache && uri) {\n const cacheIndex = cache.indexOf(uri) - 1;\n stepBackWithCheck(cache, cacheIndex, total, index);\n }\n }, [stepBackWithCheck, cache, uri, total, index]);\n\n const onNext = useCallback(() => {\n if (cache && uri) {\n const cacheIndex = cache.indexOf(uri) + 1;\n stepForwardWithCheck(cache, cacheIndex, total, index);\n }\n }, [stepForwardWithCheck, cache, uri, total, index]);\n\n useEffect(() => {\n updateEntitiesNavigationLoadingState(loading);\n }, [updateEntitiesNavigationLoadingState, loading]);\n\n useEffect(() => {\n return () => updateEntitiesNavigationLoadingState(false);\n }, []);\n\n const isPrevDisabled = loading || index <= 0;\n const isNextDisabled = loading || index >= total - 1;\n return {total, onPrev, onNext, onSearchResultsClick, isPrevDisabled, isNextDisabled};\n};\n\nexport {useSearchNavigation};\n","import {MainSearchProvider} from './MainSearchProvider';\nimport {GraphSearchProvider} from './GraphSearchProvider';\n\nexport const getSearchProvider = (type: string, options) => {\n switch (type) {\n case 'search':\n return new MainSearchProvider(options);\n case 'graphsearch':\n return new GraphSearchProvider(options);\n }\n};\n","import React from 'react';\n\nimport {ProfileBandNavigationWidget} from './ProfileBandNavigationWidget';\nimport {useSearchNavigation} from './hooks/useSearchNavigation';\nimport {useSearchNavigationVisibility} from './hooks/useSearchNavigationVisibility';\n\ntype Props = {\n className?: string;\n};\n\nconst ProfileBandNavigation = ({className}: Props) => {\n const {total, onPrev, onNext, onSearchResultsClick, isPrevDisabled, isNextDisabled} = useSearchNavigation();\n const isVisible = useSearchNavigationVisibility();\n return isVisible ? (\n <ProfileBandNavigationWidget\n className={className}\n total={total}\n onPrev={onPrev}\n onNext={onNext}\n onSearchResultsClick={onSearchResultsClick}\n isPrevDisabled={isPrevDisabled}\n isNextDisabled={isNextDisabled}\n />\n ) : null;\n};\n\nexport {ProfileBandNavigation};\n","import {useSelector} from 'react-redux';\nimport mdmModule from '@reltio/mdm-module';\nimport {Entity, isViewMode} from '@reltio/mdm-sdk';\nimport {SearchNavigationData} from '../types';\n\nconst useSearchNavigationVisibility = () => {\n const {cache} = useSelector<unknown, SearchNavigationData>(mdmModule.selectors.getSearchNavigationData) || {};\n const mode = useSelector<unknown, string>(mdmModule.selectors.getMode);\n const entity = useSelector<unknown, Entity>(mdmModule.selectors.getEntity);\n\n return isViewMode(mode) && cache?.includes(entity?.uri);\n};\n\nexport {useSearchNavigationVisibility};\n","import {makeStyles} from '@material-ui/core/styles';\n\nconst useStyles = makeStyles((theme) => ({\n image: {\n width: '40px',\n height: '40px'\n },\n info: {\n marginLeft: '12px',\n overflow: 'hidden',\n display: 'flex',\n flexDirection: 'column'\n },\n label: {\n textOverflow: 'ellipsis',\n overflow: 'hidden',\n whiteSpace: 'nowrap',\n fontWeight: 400,\n fontSize: '13px',\n lineHeight: '15px',\n color: theme.palette.primary.main\n },\n secondaryLabel: {\n marginTop: '4px',\n fontWeight: 400,\n fontSize: '10px',\n lineHeight: '12px',\n color: theme.palette.text.secondary,\n whiteSpace: 'nowrap',\n overflow: 'hidden',\n textOverflow: 'ellipsis'\n },\n link: {\n textDecoration: 'none'\n },\n thirdRow: {\n display: 'flex',\n overflow: 'hidden',\n alignItems: 'center',\n marginTop: 'auto',\n paddingTop: '4px'\n },\n entityId: {\n display: 'flex',\n overflow: 'hidden',\n alignItems: 'baseline',\n whiteSpace: 'nowrap',\n fontWeight: 400,\n fontSize: '12px',\n lineHeight: '16px'\n },\n entityIdLabel: {\n color: theme.palette.text.secondary\n },\n entityIdValue: {\n marginLeft: '8px',\n color: theme.palette.text.primary,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n '&[aria-describedby]': {\n cursor: 'pointer',\n '&:hover': {\n textDecoration: 'underline'\n }\n }\n }\n}));\n\nexport default useStyles;\n","import React, {useCallback} from 'react';\nimport i18n from 'ui-i18n';\nimport classnames from 'classnames';\nimport {Entity, getEntityId, getEntityUriForLink, getLabel} from '@reltio/mdm-sdk';\nimport EntityAvatar from '../../EntityAvatar/EntityAvatar';\nimport EntityUriLink from '../../EntityUriLink/EntityUriLink';\nimport ExpandedValueTooltip from '../../ExpandedValueTooltip/ExpandedValueTooltip';\nimport EntityTypeBadge from '../../EntityTypeBadge/EntityTypeBadge';\nimport useStyles from './styles';\n\ntype Props = {\n entity: Entity;\n classes?: {\n label?: string;\n secondaryLabel?: string;\n };\n};\n\nexport const ProfileCardContent = ({entity, classes = {}}: Props) => {\n const styles = useStyles();\n const {secondaryLabel: secondaryLabelClass, label: labelClass} = classes;\n const label = getLabel(entity.label);\n const {secondaryLabel} = entity;\n const handleCopyEntityIdToClipboard = useCallback(() => {\n navigator.clipboard.writeText(getEntityId(entity));\n }, [entity]);\n\n return (\n <>\n <EntityAvatar entity={entity} imageClassName={styles.image} />\n <div className={styles.info}>\n <EntityUriLink value={getEntityUriForLink(entity)} className={styles.link}>\n <ExpandedValueTooltip value={label} placement=\"top\" showOnExceededHeight={true}>\n <div className={classnames(styles.label, labelClass)}>{label}</div>\n </ExpandedValueTooltip>\n </EntityUriLink>\n\n {secondaryLabel && (\n <ExpandedValueTooltip value={secondaryLabel} placement=\"top\" showOnExceededHeight={true}>\n <div className={classnames(styles.secondaryLabel, secondaryLabelClass)}>{secondaryLabel}</div>\n </ExpandedValueTooltip>\n )}\n <div className={styles.thirdRow}>\n <EntityTypeBadge entity={entity} size=\"medium\" />\n <div className={styles.entityId} onClick={handleCopyEntityIdToClipboard}>\n <div className={styles.entityIdLabel}>{i18n.text('ID:')}</div>\n <ExpandedValueTooltip value={`Copy to clipboard ${getEntityId(entity)}`} placement=\"top\">\n <div className={styles.entityIdValue}>{getEntityId(entity)}</div>\n </ExpandedValueTooltip>\n </div>\n </div>\n </div>\n </>\n );\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles({\n '@keyframes keyframes-wave': {\n '0%': {\n transform: 'translateX(-100%)'\n },\n '60%': {\n transform: 'translateX(100%)'\n },\n '100%': {\n transform: 'translateX(100%)'\n }\n },\n wave: {\n overflow: 'hidden',\n position: 'relative',\n '&:after': {\n top: '0',\n left: '0',\n right: '0',\n bottom: '0',\n content: '\"\"',\n position: 'absolute',\n animation: '$keyframes-wave 1.6s linear 0.5s infinite',\n transform: 'translateX(-100%)',\n background: 'linear-gradient(90deg, transparent, rgba(0, 0, 0, 0.04), transparent);'\n }\n },\n avatar: {\n flex: 'none',\n width: '40px',\n height: '40px',\n borderRadius: '50%',\n backgroundColor: 'rgba(0, 0, 0, 0.11)'\n },\n info: {\n marginLeft: '12px',\n flex: 'auto'\n },\n label: {\n width: '40%',\n height: '15px',\n borderRadius: '2px',\n backgroundColor: 'rgba(0, 0, 0, 0.11)'\n },\n secondaryLabel: {\n marginTop: '4px',\n width: '100%',\n height: '12px',\n borderRadius: '2px',\n backgroundColor: 'rgba(0, 0, 0, 0.11)'\n },\n thirdRow: {\n marginTop: '4px',\n width: '60%',\n height: '24px',\n borderRadius: '2px',\n backgroundColor: 'rgba(0, 0, 0, 0.11)'\n }\n});\n","import React from 'react';\nimport classnames from 'classnames';\nimport {useStyles} from './styles';\n\nexport const ProfileCardPlaceholder = () => {\n const styles = useStyles();\n return (\n <>\n <div className={classnames(styles.avatar, styles.wave)} />\n <div className={styles.info}>\n <div className={classnames(styles.label, styles.wave)} />\n <div className={classnames(styles.secondaryLabel, styles.wave)} />\n <div className={classnames(styles.thirdRow, styles.wave)} />\n </div>\n </>\n );\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nconst useStyles = makeStyles({\n container: {\n display: 'flex',\n padding: '16px',\n overflow: 'hidden'\n }\n});\n\nexport default useStyles;\n","import React, {memo} from 'react';\nimport classnames from 'classnames';\nimport {Entity} from '@reltio/mdm-sdk';\nimport {ProfileCardContent} from './ProfileCardContent/ProfileCardContent';\nimport {ProfileCardPlaceholder} from './ProfileCardPlaceholder/ProfileCardPlaceholder';\nimport useStyles from './styles';\n\ntype Props = {\n entity: Entity;\n classes?: {\n label?: string;\n secondaryLabel?: string;\n container?: string;\n };\n variant?: 'loading' | 'normal';\n} & React.HTMLAttributes<HTMLDivElement>;\n\nconst ProfileCard = ({entity, classes = {}, variant = 'normal', ...otherProps}: Props) => {\n const styles = useStyles();\n const {container: containerClass} = classes;\n return (\n <div className={classnames(styles.container, containerClass)} {...otherProps}>\n {variant === 'normal' ? (\n <ProfileCardContent entity={entity} classes={classes} />\n ) : (\n <ProfileCardPlaceholder />\n )}\n </div>\n );\n};\n\nexport default memo(ProfileCard);\n","import {fade, makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n container: {\n display: 'flex',\n flexDirection: 'column',\n flexShrink: 0,\n width: '64px',\n paddingTop: '8px',\n backgroundColor: theme.palette.background.paper,\n boxShadow: '0 1px 1px 0 rgba(0,0,0,0.14), 0 2px 1px -1px rgba(0,0,0,0.12), 0 1px 3px 0 rgba(0,0,0,0.2)'\n },\n active: {\n backgroundColor: fade(theme.palette.primary.main, 0.12),\n color: theme.palette.primary.main,\n '&:after': {\n content: '\"\"',\n position: 'absolute',\n height: '42px',\n width: '3px',\n backgroundColor: theme.palette.primary.main,\n left: '-8px',\n borderRadius: '0 6px 6px 0'\n }\n },\n buttonWrapper: {\n position: 'relative',\n width: '48px',\n height: '44px',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n borderRadius: '6px',\n margin: '2px 8px',\n color: theme.palette.text.secondary\n }\n}));\n","import React, {ElementType} from 'react';\nimport classnames from 'classnames';\nimport {IconButtonProps} from '@material-ui/core/IconButton';\nimport {SmallIconButtonWithTooltip} from '../SmallIconButton';\nimport {useStyles} from './styles';\n\ntype Props = {\n buttonsProps: {\n icon: ElementType;\n tooltipTitle: string;\n id: number;\n disabled?: boolean;\n }[];\n classes?: {active?: string; buttonWrapper?: string} & IconButtonProps['classes'];\n activeIndexId: number;\n className?: string;\n onButtonClick: (id: number) => void;\n};\n\nexport const SideButtonsPanel = ({buttonsProps, activeIndexId, className, onButtonClick, classes = {}}: Props) => {\n const styles = useStyles();\n const {active, buttonWrapper, ...iconButtonClasses} = classes;\n\n return (\n <div className={classnames(styles.container, className)}>\n {buttonsProps.map(({id, ...buttonProps}) => {\n return (\n <SmallIconButtonWithTooltip\n {...buttonProps}\n classes={iconButtonClasses}\n size=\"S\"\n key={id}\n className={classnames(\n {[classnames(styles.active, active)]: activeIndexId === id},\n styles.buttonWrapper,\n buttonWrapper\n )}\n onClick={() => onButtonClick(id)}\n data-reltio-id={`reltio-profile-right-side-button-${id}`}\n />\n );\n })}\n </div>\n );\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n contentWrapper: {\n display: 'flex',\n flexDirection: 'column',\n backgroundColor: theme.palette.background.paper,\n boxShadow: '0 1px 1px 0 rgba(0,0,0,0.14), 0 2px 1px -1px rgba(0,0,0,0.12), 0 1px 3px 0 rgba(0,0,0,0.2)',\n marginLeft: '3px',\n transition: theme.transitions.create(['width'], {\n duration: theme.transitions.duration.enteringScreen\n })\n }\n}));\n","import React, {ReactNode, VFC} from 'react';\nimport {useStyles} from './styles';\n\ntype Props = {\n width: number;\n open: boolean;\n children: ReactNode;\n};\n\nexport const SidePanel: VFC<Props> = ({width, open, children}) => {\n const styles = useStyles();\n return (\n <div\n className={styles.contentWrapper}\n style={{\n width: `${open ? width : 0}px`\n }}\n >\n {open && <>{children}</>}\n </div>\n );\n};\n","import {makeStyles} from '@material-ui/core/styles';\n\nconst iconsWidth = '68px';\n\nexport const useOptionStyles = makeStyles({\n container: {\n display: 'flex',\n alignItems: 'center',\n height: '32px',\n minHeight: '32px',\n padding: 0\n },\n text: {\n display: 'flex',\n width: `calc(100% - ${iconsWidth})`\n },\n textItem: {\n fontSize: '13px',\n lineHeight: '15px',\n marginRight: 10\n },\n primaryTextItem: {\n flex: '1 0',\n flexBasis: 0,\n maxWidth: '50%',\n overflow: 'hidden',\n textOverflow: 'ellipsis'\n },\n secondaryTextItem: {\n flex: '1 0',\n flexBasis: 0,\n overflow: 'hidden',\n textOverflow: 'ellipsis'\n },\n icons: {\n transform: 'scale(0.5)',\n position: 'relative',\n flexShrink: 0,\n width: iconsWidth,\n bottom: '10px'\n },\n iconTop: {\n position: 'absolute',\n top: 0,\n left: 0,\n zIndex: 1\n },\n iconBottom: {\n position: 'absolute',\n top: 0,\n left: 26,\n zIndex: 0\n }\n});\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport classnames from 'classnames';\nimport {MenuItem as MenuItem} from '@material-ui/core';\nimport {Typography as Typography} from '@material-ui/core';\nimport {useOptionStyles} from './styles';\nimport EntityTypeIcon from '../../../../EntityTypeIcon/EntityTypeIcon';\nimport ExpandedValueTooltip from '../../../../ExpandedValueTooltip/ExpandedValueTooltip';\n\nconst RelationOption = ({innerRef, innerProps, selectOption, data}) => {\n const styles = useOptionStyles();\n const {value, label, startObject, endObject} = data;\n const secondaryLabel = startObject.objectType.label + ' \\u2194 ' + endObject.objectType.label;\n return (\n <MenuItem\n className={styles.container}\n ref={innerRef}\n key={value}\n onClick={() => selectOption({label, value, startObject, endObject})}\n {...innerProps}\n >\n <div className={styles.icons}>\n <EntityTypeIcon className={styles.iconTop} entityType={startObject.objectType} />\n <EntityTypeIcon className={styles.iconBottom} entityType={endObject.objectType} />\n </div>\n <div className={styles.text}>\n <ExpandedValueTooltip value={label}>\n <Typography className={classnames(styles.textItem, styles.primaryTextItem)}>{label}</Typography>\n </ExpandedValueTooltip>\n <ExpandedValueTooltip value={secondaryLabel}>\n <Typography color=\"textSecondary\" className={classnames(styles.textItem, styles.secondaryTextItem)}>\n {secondaryLabel}\n </Typography>\n </ExpandedValueTooltip>\n </div>\n </MenuItem>\n );\n};\n\nRelationOption.propTypes = {\n innerRef: PropTypes.oneOfType([\n PropTypes.oneOf([null]),\n PropTypes.func,\n PropTypes.shape({\n current: PropTypes.any.isRequired\n })\n ]),\n innerProps: PropTypes.object.isRequired,\n selectOption: PropTypes.func.isRequired,\n data: PropTypes.shape({\n value: PropTypes.string.isRequired,\n label: PropTypes.string.isRequired,\n startObject: PropTypes.object,\n endObject: PropTypes.object\n })\n};\n\nexport default RelationOption;\n","import React, {useMemo} from 'react';\nimport PropTypes from 'prop-types';\nimport i18n from 'ui-i18n';\nimport {identity, defaultTo} from 'ramda';\nimport RelationOption from './components/RelationOption';\nimport DropDownSelector from '../../../DropDownSelector/DropDownSelector';\n\nconst RelationTypeSelector = ({value = {}, options = [], onChange = identity, TextFieldProps, ...otherProps}) => {\n const textFieldProps = useMemo(\n () => ({\n ...defaultTo({}, TextFieldProps),\n ['data-reltio-id']: 'relation-type-selector'\n }),\n [TextFieldProps]\n );\n return (\n <DropDownSelector\n value={value}\n options={options}\n onChange={onChange}\n label={i18n.text('Select relationship type ')}\n components={{Option: RelationOption}}\n TextFieldProps={textFieldProps}\n {...otherProps}\n />\n );\n};\n\nconst ValueType = PropTypes.shape({\n label: PropTypes.string.isRequired,\n value: PropTypes.string.isRequired,\n startObject: PropTypes.object,\n endObject: PropTypes.object\n});\n\nRelationTypeSelector.propTypes = {\n value: ValueType,\n options: PropTypes.arrayOf(ValueType),\n onChange: PropTypes.func\n};\n\nexport default RelationTypeSelector;\n","import {makeStyles} from '@material-ui/core/styles';\n\nexport const useStyles = makeStyles({\n root: {\n display: 'flex',\n alignItems: 'flex-start'\n },\n slice: {\n fontWeight: 500\n },\n cancelButton: {\n width: '88px',\n flexShrink: 0,\n marginLeft: '15px'\n }\n});\n","import React from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport mdmModule, {profile} from '@reltio/mdm-module';\nimport {Button as Button} from '@material-ui/core';\nimport {Typography as Typography} from '@material-ui/core';\nimport {pipe} from 'ramda';\nimport i18n from 'ui-i18n';\n\nimport {useStyles} from './styles';\n\nconst ProfileBandHistory = () => {\n const styles = useStyles();\n\n const historyEvent = useSelector(mdmModule.selectors.getHistoryEvent);\n const dispatch = useDispatch();\n const onCancel = pipe(profile.history.actions.clearHistoryEvent, dispatch);\n\n return historyEvent ? (\n <div className={styles.root}>\n <Typography component={'div'}>\n {i18n.text('You are viewing a historic slice:')}{' '}\n <span className={styles.slice}>{i18n.date(historyEvent.aStamp, 'llll')}</span>\n </Typography>\n <Button className={styles.cancelButton} variant=\"contained\" color=\"primary\" onClick={onCancel}>\n {i18n.text('Cancel')}\n </Button>\n </div>\n ) : null;\n};\n\nexport default ProfileBandHistory;\n","import React, {createContext, useContext} from 'react';\nimport {AnyAction} from 'redux';\n\ntype ActionsHook = (listener: (action: AnyAction, state: any) => void) => () => void;\n\nconst ActionsHookContext = createContext<ActionsHook | null>(null);\nActionsHookContext.displayName = 'ActionsHookContext';\n\ntype ProviderProps = {\n hook: ActionsHook;\n children: React.ReactNode;\n};\n\nexport const ActionsHookProvider = ({children, hook}: ProviderProps) => {\n return <ActionsHookContext.Provider value={hook}>{children}</ActionsHookContext.Provider>;\n};\n\nexport const useActionsHook = () => {\n const listenToActions = useContext(ActionsHookContext);\n if (!listenToActions) {\n throw new Error('ActionsHookContext must be provided');\n }\n return listenToActions;\n};\n","import React, {useState, useCallback, useContext} from 'react';\nimport {noop} from '../../core/utils';\n\ntype LoadingState = {\n entitiesNavigation: boolean;\n entity: boolean;\n};\n\ntype ContextValue = {\n isLoading: boolean;\n updateEntityLoadingState: (loading: boolean) => void;\n updateEntitiesNavigationLoadingState: (loading: boolean) => void;\n resetLoadingState: () => void;\n};\n\nconst EntityLoadingIndicationContext = React.createContext<ContextValue>({\n isLoading: false,\n updateEntityLoadingState: noop,\n updateEntitiesNavigationLoadingState: noop,\n resetLoadingState: noop\n});\n\nconst defaultLoadingState: LoadingState = {entitiesNavigation: false, entity: false};\n\nconst useEntityLoadingIndicationHook = () => {\n const [loadingState, setLoadingState] = useState(defaultLoadingState);\n\n const updateEntityLoadingState = useCallback((loading: boolean) => {\n setLoadingState((prevLoadingState) => ({...prevLoadingState, entity: loading}));\n }, []);\n\n const updateEntitiesNavigationLoadingState = useCallback((loading: boolean) => {\n setLoadingState((prevLoadingState) => ({...prevLoadingState, entitiesNavigation: loading}));\n }, []);\n\n const resetLoadingState = useCallback(() => {\n setLoadingState(defaultLoadingState);\n }, []);\n\n const isLoading = Object.values(loadingState).includes(true);\n\n return {isLoading, updateEntityLoadingState, updateEntitiesNavigationLoadingState, resetLoadingState};\n};\n\ntype Props = {\n children: React.ReactNode;\n};\n\nexport const EntityLoadingIndicationProvider = ({children}: Props) => {\n const value = useEntityLoadingIndicationHook();\n return <EntityLoadingIndicationContext.Provider value={value}>{children}</EntityLoadingIndicationContext.Provider>;\n};\n\nexport const useEntityLoadingIndication = () => {\n return useContext(EntityLoadingIndicationContext);\n};\n","import React from 'react';\n\ntype Labels = {\n profileBand: {\n OPEN_RESULTS?: string;\n SEARCH_RESULT?: string;\n SEARCH_RESULTS?: string;\n NEXT_PROFILE?: string;\n PREVIOUS_PROFILE?: string;\n };\n};\nexport const LabelsContext = React.createContext<Labels>({\n profileBand: {}\n});\n\nLabelsContext.displayName = 'LabelsContext';\n","import {useCallback, useEffect, useState} from 'react';\nimport {useSelector} from 'react-redux';\nimport {\n andThen,\n fromPairs,\n map,\n otherwise,\n pipe,\n props,\n uniqBy,\n prop,\n propEq,\n when,\n always,\n assocPath,\n dissocPath,\n path,\n pathOr,\n mergeRight\n} from 'ramda';\nimport {\n CollaborationObjectTypes,\n Comment,\n CommentsMap,\n createComment as createCommentRequest,\n createReply as createReplyRequest,\n getComment as getCommentRequest,\n getCommentsCount as getCommentsCountRequest,\n Reply,\n updateComment as updateCommentRequest,\n updateReply as updateReplyRequest,\n deleteComment as deleteCommentRequest,\n deleteReply as deleteReplyRequest,\n getComments as getCommentsRequest,\n isTempUri,\n CollaborationStateMap,\n CommentState\n} from '@reltio/mdm-sdk';\nimport mdm from '@reltio/mdm-module';\n\ntype Props = {\n objectIds?: string[];\n objectTypes?: CollaborationObjectTypes[];\n enabled?: boolean;\n};\n\nconst filterReplies = (replyId: string, replies: Reply[]) => replies.filter((reply) => reply.replyId !== replyId);\n\nconst getUpdatedReplies = (comment: Comment, reply: Reply) => {\n const changedReplyIndex = comment.replies.findIndex(({replyId}) => replyId === reply.replyId);\n const newReplies = [...comment.replies];\n newReplies[changedReplyIndex] = reply;\n return newReplies;\n};\n\nconst defaultObjectIds = [];\nconst catchErrorInRequest = (e) => console.error('Collaboration error', e);\nexport const useCollaboration = ({objectIds = defaultObjectIds, objectTypes, enabled = true}: Props) => {\n const entity = useSelector(mdm.selectors.getEntity);\n const tenant: string = useSelector(mdm.selectors.getTenant);\n const collaborationPath: string = useSelector(mdm.selectors.getCollaborationPath);\n const isCollaborationEnabled = useSelector(mdm.selectors.isCollaborationEnabled) && enabled;\n\n const [pageToken, setPageToken] = useState<string | null>(null);\n const [comments, setComments] = useState<Comment[]>([]);\n const [commentsMap, setCommentsMap] = useState<CommentsMap>(null);\n const [currentComment, setCurrentComment] = useState<Comment | null>(null);\n const [sending, setSending] = useState(false);\n const [loading, setLoading] = useState(false);\n const [collaborationStateMap, setCollaborationStateMap] = useState<CollaborationStateMap>({});\n\n const addCommentsToCommentsMap = useCallback((commentsMap: CommentsMap) => {\n setCommentsMap((currentCommentsMap) => ({\n ...currentCommentsMap,\n ...commentsMap\n }));\n }, []);\n const entityUri = entity?.uri;\n const getCommentsCount = useCallback(\n (objectIds: string[], shouldResetCommentsMap = false) => {\n if (isCollaborationEnabled && entityUri && !isTempUri(entityUri)) {\n const onError = (e) => {\n console.warn('Collaboration error', e);\n setCommentsMap(null);\n };\n pipe(\n getCommentsCountRequest,\n andThen(map(props(['objectId', 'comments']))),\n andThen(fromPairs),\n andThen(shouldResetCommentsMap ? setCommentsMap : addCommentsToCommentsMap),\n otherwise(onError)\n )({uris: objectIds, tenant, collaborationPath});\n } else {\n setCommentsMap(null);\n }\n },\n [addCommentsToCommentsMap, collaborationPath, entityUri, isCollaborationEnabled, tenant]\n );\n\n useEffect(() => {\n getCommentsCount(objectIds, true);\n }, [objectIds, getCommentsCount]);\n\n const getComments = useCallback(\n (relatedObjectUri: string, pageToken?: string) => {\n getCommentsRequest({collaborationPath, tenant, relatedObjectUri, pageToken})\n .then(({items, nextPageToken}) => {\n setComments((prevComments) => {\n if (!pageToken) {\n return items;\n }\n return uniqBy(prop('commentId'), [...prevComments, ...items]);\n });\n setPageToken(nextPageToken);\n })\n .catch(catchErrorInRequest);\n },\n [collaborationPath, tenant]\n );\n\n const getComment = useCallback(\n (commentId: string) => {\n setLoading(true);\n\n getCommentRequest({collaborationPath, tenant, commentId})\n .then(setCurrentComment)\n .catch(catchErrorInRequest)\n .finally(() => setLoading(false));\n },\n [collaborationPath, tenant]\n );\n\n const addCommentToState = (comment: Comment, uri: string) => {\n setCurrentComment(comment);\n setCommentsMap((prevCommentsMap) => {\n return {\n ...prevCommentsMap,\n [uri]: [...(prevCommentsMap[uri] || []), {commentId: comment.commentId, replies: 0, status: 'open'}]\n };\n });\n setComments((prevComments) => [comment, ...prevComments]);\n };\n const updateCommentInState = (comment: Comment) => {\n setCurrentComment(comment);\n setComments(map(when(propEq('commentId', comment.commentId), always(comment))));\n };\n const deleteCommentFromState = (commentId: string, uri: string) => {\n setCurrentComment(null);\n setCommentsMap((prevCommentsMap) => {\n const comments = prevCommentsMap[uri] || [];\n return {\n ...prevCommentsMap,\n [uri]: comments.filter((c) => c.commentId !== commentId)\n };\n });\n setComments((prevComments) => {\n return prevComments.filter((comment) => comment.commentId !== commentId);\n });\n };\n const createComment = useCallback(\n ({content, namedUsers, objectType, uri, relatedObjectUris}) => {\n setSending(true);\n\n const data = {\n objectId: uri,\n content,\n relatedObjectUris,\n objectType,\n visibility: 'public',\n namedUsers,\n permanentLink: `${window.location.href}&commentId=${encodeURIComponent('{commentId}')}`\n };\n\n return createCommentRequest({collaborationPath, tenant, data})\n .then(([comment]) => addCommentToState(comment, uri))\n .catch(catchErrorInRequest)\n .finally(() => setSending(false));\n },\n [collaborationPath, tenant]\n );\n\n const editComment = useCallback(\n ({content, namedUsers, objectType, uri, relatedObjectUris, commentId, replies}) => {\n setSending(true);\n\n const data = {\n objectId: uri,\n content,\n relatedObjectUris,\n objectType,\n visibility: 'public',\n namedUsers,\n commentId,\n replies\n };\n\n return updateCommentRequest({collaborationPath, tenant, data})\n .then((comment) => updateCommentInState({...comment, replies}))\n .catch(catchErrorInRequest)\n .finally(() => setSending(false));\n },\n [collaborationPath, tenant]\n );\n\n const deleteComment = useCallback(\n ({uri, commentId}) => {\n setSending(true);\n\n deleteCommentRequest({collaborationPath, tenant, commentId})\n .then(() => deleteCommentFromState(commentId, uri))\n .catch(catchErrorInRequest)\n .finally(() => setSending(false));\n },\n [collaborationPath, tenant]\n );\n\n const updateReplyInState = useCallback((reply: Reply, uri: string, commentId: string, isDeleteReply?: boolean) => {\n const newStatus = reply.action === 'resolve' ? 'resolved' : 'open';\n const {replyId} = reply;\n if (newStatus === 'resolved') {\n setCurrentComment((prevCurrentComment) => {\n if (prevCurrentComment) {\n return null;\n }\n });\n } else {\n setCurrentComment((prevCurrentComment) => {\n if (prevCurrentComment) {\n return {\n ...prevCurrentComment,\n replies: isDeleteReply\n ? filterReplies(replyId, prevCurrentComment.replies)\n : [...prevCurrentComment.replies, reply]\n };\n }\n });\n }\n\n setCommentsMap((prevCommentsMap) => ({\n ...prevCommentsMap,\n [uri]: (prevCommentsMap[uri] || []).map((comment) => {\n if (comment.commentId === commentId) {\n return {\n ...comment,\n status: newStatus,\n replies: isDeleteReply ? comment.replies - 1 : comment.replies + 1\n };\n }\n\n return comment;\n })\n }));\n\n setComments((prevComments) => {\n return prevComments.map((comment) => {\n if (comment.commentId === commentId) {\n return {\n ...comment,\n status: newStatus,\n replies: isDeleteReply\n ? filterReplies(reply.replyId, comment.replies)\n : [...comment.replies, reply]\n };\n }\n\n return comment;\n });\n });\n }, []);\n\n const deleteReply = useCallback(\n ({uri, commentId, reply}) => {\n setSending(true);\n\n deleteReplyRequest({collaborationPath, tenant, commentId, replyId: reply.replyId})\n .then(() => updateReplyInState(reply, uri, commentId, true))\n .catch(catchErrorInRequest)\n .finally(() => setSending(false));\n },\n [collaborationPath, updateReplyInState, tenant]\n );\n\n const editReplyInState = useCallback((reply: Reply, commentId: string) => {\n setCurrentComment((prevCurrentComment) => {\n if (prevCurrentComment) {\n return {\n ...prevCurrentComment,\n replies: getUpdatedReplies(prevCurrentComment, reply)\n };\n }\n });\n\n setComments((prevComments) => {\n return prevComments.map((comment) => {\n if (comment.commentId === commentId) {\n return {\n ...comment,\n replies: getUpdatedReplies(comment, reply)\n };\n }\n\n return comment;\n });\n });\n }, []);\n\n const editReply = useCallback(\n ({content, namedUsers, commentId, replyId}) => {\n setSending(true);\n const data = {\n content,\n namedUsers\n };\n return updateReplyRequest({collaborationPath, tenant, commentId, replyId, data})\n .then((reply) => editReplyInState(reply, commentId))\n .catch(catchErrorInRequest)\n .finally(() => setSending(false));\n },\n [collaborationPath, tenant, editReplyInState]\n );\n\n const createReply = useCallback(\n ({content, namedUsers, commentId, action, uri}) => {\n setSending(true);\n\n const data = {\n content,\n action,\n namedUsers\n };\n\n return createReplyRequest({collaborationPath, tenant, commentId, data})\n .then(([reply]) => updateReplyInState(reply, uri, commentId))\n .catch(catchErrorInRequest)\n .finally(() => setSending(false));\n },\n [collaborationPath, tenant, updateReplyInState]\n );\n\n const resolveThread = useCallback(\n ({commentId, uri}) => {\n createReply({content: '', namedUsers: [], commentId, action: 'resolve', uri});\n },\n [createReply]\n );\n\n const reOpenThread = useCallback(\n ({commentId, uri}) => {\n createReply({content: '', namedUsers: [], commentId, action: 'reopen', uri});\n },\n [createReply]\n );\n\n const clearCurrentComment = useCallback(() => {\n setCurrentComment(null);\n }, []);\n\n const getCommentState = (uri: string, commentUri: string) => pathOr({}, [uri, commentUri], collaborationStateMap);\n\n const clearCommentState = (uri: string, commentUri: string) =>\n setCollaborationStateMap(dissocPath([uri, commentUri]));\n\n const updateCommentState = (uri: string, commentUri: string, newState: CommentState) => {\n setCollaborationStateMap((prevCollaborationStateMap) => {\n const pathToCommentState = [uri, commentUri];\n const prevCommentState = path(pathToCommentState, prevCollaborationStateMap);\n return assocPath(pathToCommentState, mergeRight(prevCommentState, newState), prevCollaborationStateMap);\n });\n };\n\n return {\n clearCurrentComment,\n comments,\n commentsMap,\n getCommentState,\n updateCommentState,\n clearCommentState,\n createComment,\n createReply,\n currentComment,\n deleteComment,\n editComment,\n getComment,\n getComments,\n getCommentsCount,\n loading,\n objectTypes,\n pageToken,\n reOpenThread,\n resolveThread,\n sending,\n deleteReply,\n editReply\n };\n};\n","import {useCallback} from 'react';\nimport {Directions, getDirectionalLabelFromObject} from '@reltio/mdm-sdk';\nimport {ascend, curry, evolve, pipe, prop, propEq, propOr, tap} from 'ramda';\n\nexport const useRelationTypeSelector = ({reversedContextLabels}) => {\n const getRelationTypesOptions = useCallback(\n (inRelations, outRelations) => {\n const labelsMap = {};\n const addLabelInMap = (label) => (labelsMap[label] = propOr(0, label, labelsMap) + 1);\n const getDirectionalLabel = pipe(getDirectionalLabelFromObject, tap(addLabelInMap));\n const byLabel = ascend(prop('label'));\n\n const prepareRelation = curry((direction, {uri, label, startObject, endObject}) => {\n const dirObject =\n direction === (reversedContextLabels ? Directions.OUT : Directions.IN) ? startObject : endObject;\n return {\n label: {directionalLabel: getDirectionalLabel(dirObject), typeLabel: label},\n value: `${uri},${direction}`,\n startObject,\n endObject\n };\n });\n\n return inRelations\n .map(prepareRelation(Directions.IN))\n .concat(outRelations.map(prepareRelation(Directions.OUT)))\n .map(\n evolve({\n label: ({directionalLabel, typeLabel}) => {\n return directionalLabel\n ? labelsMap[directionalLabel] > 1\n ? `${directionalLabel} (${typeLabel})`\n : directionalLabel\n : typeLabel;\n }\n })\n )\n .sort(byLabel);\n },\n [reversedContextLabels]\n );\n\n const fromEditorValue = useCallback(\n (inRelationTypes, outRelationTypes) => (relation) => {\n const [uri, direction] = relation.value.split(',');\n const type = (direction === Directions.IN ? inRelationTypes : outRelationTypes).find(propEq('uri', uri));\n return {type, direction};\n },\n []\n );\n\n const toEditorValue = useCallback(\n (relation, relationsTypesOptions) =>\n relationsTypesOptions.find(propEq('value', `${relation.relationType},${relation.direction}`)),\n []\n );\n\n return {\n getRelationTypesOptions,\n fromEditorValue,\n toEditorValue\n };\n};\n"],"names":["useStyles","makeStyles","theme","button","padding","fill","palette","primary","main","fillOpacity","iconButton","startIcon","marginLeft","marginRight","width","height","alignItems","label","whiteSpace","fontSize","lineHeight","letterSpacing","overflowStyle","overflow","textOverflow","menuIcon","menuItem","minHeight","menuText","color","text","ActionButtonMode","ActionButton","forwardRef","ref","className","mode","disabled","icon","Icon","onClick","noop","onMenuClose","otherProps","styles","SmallIconButton","classnames","size","tooltipTitle","showForDisabled","Button","classes","ExpandedValueTooltip","value","handleClick","MenuItem","root","Typography","getButtonView","displayName","pagination","display","justifyContent","borderTop","boxShadow","caption","selectRoot","select","textAlign","actions","BasicTablePagination","count","rowsPerPageOptions","page","onChangePage","rowsPerPage","onChangeRowsPerPage","basicTableRef","labelRowsPerPage","resetScrollbarPosition","useCallback","pathOr","identity","handleChangePage","handleChangeRowsPerPage","TablePagination","component","i18n","labelDisplayedRows","from","to","fromRow","toRow","countRows","pipe","nthArg","getValue","propTypes","PropTypes","current","React","paper","title","fontWeight","content","contentText","marginBottom","actionButtons","paddingTop","discardButton","open","onCancel","cancelCaption","onDiscard","discardCaption","onSave","saveCaption","disabledSave","Dialog","onClose","paperScrollPaper","DialogTitle","DialogContent","DialogContentText","DialogActions","disableSpacing","autoFocus","ConnectionRelationTypeSelector","relation","inRelationTypes","outRelationTypes","onChange","applyFirstByDefault","reversedContextLabels","getRelationTypesOptions","fromEditorValue","toEditorValue","useRelationTypeSelector","relationsTypesOptions","useMemo","handleChange","hasValue","relationType","useEffect","length","options","ConnectionRelationType","RelationTypeType","borderRadius","flexShrink","entity","metadata","useSelector","mdmModule","entityTypeUri","type","entityType","getEntityType","entityTypeColor","getPropWithInheritance","entityTypeLabel","getEntityTypeLabel","placement","style","backgroundColor","utils","profileBandWrapper","profileBand","inactive","background","inactiveBackground","profileIcon","imageProfileIcon","profileInfo","flexDirection","flex","badge","wordBreak","marginTop","secondaryLabel","businessCard","secondary","specialInfo","flexWrap","entityId","cursor","textDecoration","children","renderLabel","showEntityId","handleCopyEntityIdToClipboard","navigator","clipboard","writeText","getEntityId","isNil","getLabel","businessCardText","getBusinessCardAttributesText","isActive","isActiveObject","entityUri","uri","EntityAvatar","key","avatarClassName","imageClassName","variant","EntityTypeBadge","isTempUri","Tooltip","container","link","LinkWithTooltip","withTooltip","Link","ProfileBandNavigationWidget","total","onPrev","onNext","onSearchResultsClick","isPrevDisabled","isNextDisabled","labels","useContext","LabelsContext","OPEN_RESULTS","SEARCH_RESULT","SEARCH_RESULTS","NEXT_PROFILE","PREVIOUS_PROFILE","mergeRight","underline","formatNumberAsMetric","KeyboardArrowLeft","KeyboardArrowRight","MainSearchProvider","constructor","data","query","sortField","sortOrder","tenant","searchTenant","apiPath","dtssPath","globalSearchRequestOptions","isDT","this","getQueryFilter","rawFilter","getEntities","filters","requestFilters","requestOptions","sort","order","scoreEnabled","getFilteredEntitiesFromDataTenant","customerTenant","dataTenant","getFilteredEntities","checkEntity","filter","fieldName","values","offset","max","then","entities","requestEntities","requestTotal","getTotalFromDataTenant","getTotals","json","GraphSearchProvider","searchBody","allFilters","getGraphSearchEntities","buildFilterQueryString","getGraphSearchCount","getNewUris","cache","map","prop","reject","includes","useSearchNavigation","safeCheckEntityPromise","useSafePromise","safeRequestTotalPromise","safeRequestEntitiesPromise","index","state","updateEntitiesNavigationLoadingState","useEntityLoadingIndication","viewId","ViewIdContext","dispatch","useDispatch","loading","setLoading","useState","searchProvider","getSearchProvider","updateNavigationData","mdmModuleSearch","openEntity","preparedUri","getEntityUriForLink","mdmModuleUi","source","perspectiveId","listenToActions","useActionsHook","stopListeningActions","action","searchNavigationData","payload","winnerUri","losersUris","updatedSearchNavigationData","winnerIndex","indexOf","uriIndex","splice","replaceWithWinnerUri","losersInCache","updatedTotal","updatedIndex","loser","updatedCache","removeLosersUris","applyMergeToSearchNavigationData","requestNextPage","newIndex","newUris","concat","finally","requestPrevPage","Math","min","stepForwardWithCheck","cacheIndex","isExists","clearedCache","stepBackWithCheck","ProfileBandNavigation","isViewMode","useSearchNavigationVisibility","image","info","thirdRow","entityIdLabel","entityIdValue","ProfileCardContent","secondaryLabelClass","labelClass","EntityUriLink","showOnExceededHeight","transform","wave","position","top","left","right","bottom","animation","avatar","ProfileCardPlaceholder","memo","containerClass","active","fade","buttonWrapper","margin","SideButtonsPanel","buttonsProps","activeIndexId","onButtonClick","iconButtonClasses","id","buttonProps","contentWrapper","transition","transitions","create","duration","enteringScreen","SidePanel","useOptionStyles","textItem","primaryTextItem","flexBasis","maxWidth","secondaryTextItem","icons","iconTop","zIndex","iconBottom","RelationOption","innerRef","innerProps","selectOption","startObject","endObject","objectType","EntityTypeIcon","RelationTypeSelector","TextFieldProps","textFieldProps","defaultTo","DropDownSelector","components","Option","ValueType","slice","cancelButton","historyEvent","profile","aStamp","ActionsHookContext","createContext","ActionsHookProvider","hook","Provider","Error","EntityLoadingIndicationContext","isLoading","updateEntityLoadingState","resetLoadingState","defaultLoadingState","entitiesNavigation","EntityLoadingIndicationProvider","loadingState","setLoadingState","prevLoadingState","Object","useEntityLoadingIndicationHook","filterReplies","replyId","replies","reply","getUpdatedReplies","comment","changedReplyIndex","findIndex","newReplies","defaultObjectIds","catchErrorInRequest","e","console","error","useCollaboration","objectIds","objectTypes","enabled","mdm","collaborationPath","isCollaborationEnabled","pageToken","setPageToken","comments","setComments","commentsMap","setCommentsMap","currentComment","setCurrentComment","sending","setSending","collaborationStateMap","setCollaborationStateMap","addCommentsToCommentsMap","currentCommentsMap","getCommentsCount","shouldResetCommentsMap","onError","warn","getCommentsCountRequest","andThen","props","fromPairs","otherwise","uris","getComments","relatedObjectUri","getCommentsRequest","items","nextPageToken","prevComments","uniqBy","catch","getComment","commentId","getCommentRequest","createComment","namedUsers","relatedObjectUris","objectId","visibility","permanentLink","window","location","href","encodeURIComponent","createCommentRequest","prevCommentsMap","status","addCommentToState","editComment","updateCommentRequest","when","propEq","always","updateCommentInState","deleteComment","deleteCommentRequest","c","deleteCommentFromState","updateReplyInState","isDeleteReply","newStatus","prevCurrentComment","deleteReply","deleteReplyRequest","editReplyInState","editReply","updateReplyRequest","createReply","createReplyRequest","resolveThread","reOpenThread","clearCurrentComment","getCommentState","commentUri","updateCommentState","newState","prevCollaborationStateMap","pathToCommentState","prevCommentState","path","assocPath","clearCommentState","dissocPath","inRelations","outRelations","labelsMap","getDirectionalLabel","getDirectionalLabelFromObject","tap","propOr","byLabel","ascend","prepareRelation","curry","direction","dirObject","Directions","directionalLabel","typeLabel","evolve","split","find"],"sourceRoot":""}
|
package/9561.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(self.webpackChunk_reltio_remotes=self.webpackChunk_reltio_remotes||[]).push([[9561],{10237:(e,t,r)=>{r.d(t,{Z:()=>g});var n=r(27556),o=r(13980),a=r.n(o),i=r(24328),l=r.n(i);function s(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?Object(arguments[t]):{},n=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(n=n.concat(Object.getOwnPropertySymbols(r).filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable})))),n.forEach((function(t){d(e,t,r[t])}))}return e}function d(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}const c=(0,r(79692).Z)((e=>({"basic-view__paper":s({display:"flex",flexDirection:"column"},e.basicView)})));function h(){return h=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},h.apply(this,arguments)}const p=(0,i.forwardRef)(((e,t)=>{let{children:r,className:o}=e,a=function(e,t){if(null==e)return{};var r,n,o=function(e,t){if(null==e)return{};var r,n,o={},a=Object.keys(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||(o[r]=e[r]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(o[r]=e[r])}return o}(e,["children","className"]);const i=c();return l().createElement(n.Z,h({ref:t,className:o,classes:{root:i["basic-view__paper"]}},a),r)}));p.displayName="BasicView",p.propTypes={children:a().node,className:a().string};const g=p},93416:(e,t,r)=>{r.d(t,{Z:()=>d});var n=r(24328),o=r.n(n),a=r(71153),i=r.n(a),l=r(92778);const s=(0,r(79692).Z)({container:{padding:"0 16px",minHeight:"48px"},title:{fontSize:"16px",lineHeight:"19px",paddingTop:"16px",paddingBottom:"13px",justifyContent:"flex-start"}}),d=e=>{let{className:t,title:r,children:n}=e;const a=s();return o().createElement(l.Z,{title:r,classes:{root:i()(a.container,t),title:a.title}},n)}},5598:(e,t,r)=>{r.d(t,{Z:()=>m});var n=r(24328),o=r.n(n),a=r(71153),i=r.n(a),l=r(52730),s=r(49885),d=r(55400),c=r(66130),h=r(33310),p=r(72383),g=r(67958),u=r(85229);const f=(0,r(79692).Z)((e=>({link:{cursor:"pointer",color:e.palette.primary.main,lineHeight:"15px",wordBreak:"break-word"},selected:{fontWeight:"bold"},popper:{maxWidth:"345px",minWidth:"200px",boxShadow:"0 1px 1px 0 rgba(0,0,0,0.14), 0 2px 1px -1px rgba(0,0,0,0.12), 0 1px 3px 0 rgba(0,0,0,0.2)",backgroundColor:"white",borderRadius:"2px"}}))),m=e=>{let{title:t,isSelected:r,entityUri:a,viewId:m,anchorEl:b,withEntityDetails:x=!0}=e;const y=f(),D=(0,l.useDispatch)(),w=(0,l.useSelector)(s.ZP.selectors.getUIPath),{generateEntityUrl:I}=(0,n.useContext)(p.v),{isLoading:v,entityDetails:N,showEntityDetails:_,hideEntityDetails:C}=(e=>{const[t,r]=(0,n.useState)(null),[o,a]=(0,n.useState)(!1),i=(0,n.useRef)(null),l=(0,u._)(),s=(0,n.useCallback)((()=>l(Promise.resolve())),[l]),d=(0,n.useCallback)((()=>{i.current=setTimeout((()=>{a(!0),l((0,g.HvW)(e)).then(r).finally((()=>a(!1)))}),1e3)}),[e,l]),c=(0,n.useCallback)((()=>{s(),clearTimeout(i.current),a(!1),r(null)}),[s]);return(0,n.useEffect)((()=>()=>clearTimeout(i.current)),[]),{isLoading:o,entityDetails:t,showEntityDetails:d,hideEntityDetails:c}})(a),P=I({uiPath:w,uri:a}),O=Boolean(b)&&(Boolean(N)||v),T=(0,n.useCallback)((()=>{D(s.ui.actions.openEntity({uri:a,viewId:m}))}),[D,a,m]);return o().createElement(o().Fragment,null,o().createElement("span",{"data-reltio-id":"reltio-hierarchy-node-title",className:i()(y.link,{[y.selected]:r}),onMouseEnter:x?_:void 0,onMouseLeave:x?C:void 0},o().createElement(d.Z,{to:P,onClick:T},t)),o().createElement(c.Z,{anchorEl:b,className:y.popper,open:O,modal:!1,placement:"top-start"},o().createElement(h.Z,{entity:N,variant:v?"loading":"normal"})))}},55400:(e,t,r)=>{r.d(t,{Z:()=>i});var n=r(24328),o=r.n(n);const a=(0,r(79692).Z)({link:{textDecoration:"inherit",color:"inherit","&:visited":{textDecoration:"inherit",color:"inherit"}}}),i=e=>{let{to:t,children:r,onClick:n}=e;const i=a();return o().createElement("a",{href:t,onClick:e=>{n&&(n(),e.stopPropagation(),e.preventDefault())},className:i.link},r)}},37014:(e,t,r)=>{r.d(t,{Z:()=>i});var n=r(24328),o=r.n(n),a=r(67958);const i=e=>{let{className:t}=e;return o().createElement("img",{className:t,alt:"loading",src:(0,a.Uw1)("R0lGODlhFQALAKIAAP///8Hf75vL5Van0wB4v////wAAAAAAACH/C05FVFNDQVBFMi4wAwEAAAAh+QQJCgAFACwAAAIAFQAHAAADLFi6zPSQFEGpGhgXkrEUQShc1bB1wxcGYzGUZ6eKJGVy8lS1aJxJjaAiAkkAACH5BAkKAAUALAAAAwAUAAUAAAMiWLFbJRC6QakCODjBxIzDlW3dB4UBBmhPWQygwrCR9FZDAgAh+QQJCgAFACwIAAMADAAFAAADFBiqVfIvgBmaWHeC6rCklrdw0JMAACH5BAkKAAUALAAAAgAUAAcAAAMkSLpU/vCRQWmLLmg967hYAIxBV4GRSJoWlo1A6X1usXGMUkcJACH5BAkKAAUALAAAAgAOAAcAAAMdWLpF/qSMORudcYg97M2b0BHXAHIelV0pxizQkwAAOw==")})}},58600:(e,t,r)=>{r.d(t,{ZP:()=>U});var n=r(24328),o=r.n(n),a=r(13980),i=r.n(a),l=r(12335),s=r(17440),d=r(67121),c=r(13896),h=r(46847),p=r(15459),g=r(6521);function u(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return t.filter(Boolean).join(" ")}var f=r(79692);const m=(0,f.Z)((()=>({"@global .rst__node":{minWidth:"100%",whiteSpace:"nowrap",position:"relative",textAlign:"left"},"@global .rst__node.rst__rtl":{textAlign:"right"},"@global .rst__nodeContent":{position:"absolute",top:0,bottom:0},"@global .rst__lineBlock, .rst__absoluteLineBlock":{height:"100%",position:"relative",display:"inline-block"},"@global .rst__absoluteLineBlock":{position:"absolute",top:0},"@global .rst__lineHalfHorizontalRight::before, .rst__lineFullVertical::after, .rst__lineHalfVerticalTop::after, .rst__lineHalfVerticalBottom::after":{position:"absolute",content:"",backgroundColor:"black"},"@global .rst__lineHalfHorizontalRight::before":{height:"1px",top:"50%",right:0,width:"50%"},"@global .rst__rtl.rst__lineHalfHorizontalRight::before":{left:0,right:"initial"},"@global .rst__lineFullVertical::after, .rst__lineHalfVerticalTop::after, .rst__lineHalfVerticalBottom::after":{width:"1px",left:"50%",top:0,height:"100%"},"@global .rst__rtl.rst__lineFullVertical::after, .rst__rtl.rst__lineHalfVerticalTop::after, .rst__rtl.rst__lineHalfVerticalBottom::after":{right:"50%",left:"initial"},"@global .rst__lineHalfVerticalTop::after":{height:"50%"},"@global .rst__lineHalfVerticalBottom::after":{top:"auto",bottom:0,height:"50%"},"@global .rst__highlightLineVertical":{zIndex:3},"@global .rst__highlightLineVertical::before":{position:"absolute",content:"",backgroundColor:"#36c2f6",width:"8px",marginLeft:"-4px",left:"50%",top:0,height:"100%"},"@global .rst__rtl.rst__highlightLineVertical::before":{marginLeft:"initial",marginRight:"-4px",left:"initial",right:"50%"},"@keyframes arrow-pulse":{"0%":{transform:"translate(0, 0)",opacity:0},"30%":{transform:"translate(0, 300%)",opacity:1},"70%":{transform:"translate(0, 700%)",opacity:1},"100%":{transform:"translate(0, 1000%)",opacity:0}},"@global .rst__highlightLineVertical::after":{content:"",position:"absolute",height:0,marginLeft:"-4px",left:"50%",top:0,borderLeft:"4px solid transparent",borderRight:"4px solid transparent",borderTop:"4px solid white",animation:"arrow-pulse 1s infinite linear both"},"@global .rst__rtl.rst__highlightLineVertical::after":{marginLeft:"initial",marginRight:"-4px",right:"50%",left:"initial"},"@global .rst__highlightTopLeftCorner::before":{zIndex:3,content:"",position:"absolute",borderTop:"solid 8px #36c2f6",borderLeft:"solid 8px #36c2f6",boxSizing:"border-box",height:"calc(50% + 4px)",top:"50%",marginTop:"-4px",right:0,width:"calc(50% + 4px)"},"@global .rst__rtl.rst__highlightTopLeftCorner::before":{borderRight:"solid 8px #36c2f6",borderLeft:"none",left:0,right:"initial"},"@global .rst__highlightBottomLeftCorner":{zIndex:3},"@global .rst__highlightBottomLeftCorner::before":{content:"",position:"absolute",borderBottom:"solid 8px #36c2f6",borderLeft:"solid 8px #36c2f6",boxSizing:"border-box",height:"calc(100% + 4px)",top:0,right:"12px",width:"calc(50% - 8px)"},"@global .rst__rtl.rst__highlightBottomLeftCorner::before":{borderRight:"solid 8px #36c2f6",borderLeft:"none",left:"12px",right:"initial"},"@global .rst__highlightBottomLeftCorner::after":{content:"",position:"absolute",height:0,right:0,top:"100%",marginTop:"-12px",borderTop:"12px solid transparent",borderBottom:"12px solid transparent",borderLeft:"12px solid #36c2f6"},"@global .rst__rtl.rst__highlightBottomLeftCorner::after":{left:0,right:"initial",borderRight:"12px solid #36c2f6",borderLeft:"none"}})));function b(){return b=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},b.apply(this,arguments)}const x=e=>{let{children:t,listIndex:r,swapFrom:a,swapLength:i,swapDepth:l,scaffoldBlockPxWidth:s,lowerSiblingCounts:d,connectDropTarget:c,isOver:h,draggedNode:p,canDrop:g,treeIndex:f,treeId:x,getPrevRow:y,node:D,path:w,rowDirection:I}=e,v=function(e,t){if(null==e)return{};var r,n,o=function(e,t){if(null==e)return{};var r,n,o={},a=Object.keys(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||(o[r]=e[r]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(o[r]=e[r])}return o}(e,["children","listIndex","swapFrom","swapLength","swapDepth","scaffoldBlockPxWidth","lowerSiblingCounts","connectDropTarget","isOver","draggedNode","canDrop","treeIndex","treeId","getPrevRow","node","path","rowDirection"]);m();const N="rtl"===I?"rst__rtl":null,_=d.length,C=[];let P;return d.forEach(((e,t)=>{let n="";if(e>0?n=0===r?"rst__lineHalfHorizontalRight rst__lineHalfVerticalBottom":t===_-1?"rst__lineHalfHorizontalRight rst__lineFullVertical":"rst__lineFullVertical":0===r?n="rst__lineHalfHorizontalRight":t===_-1&&(n="rst__lineHalfVerticalTop rst__lineHalfHorizontalRight"),C.push(o().createElement("div",{key:`pre_${1+t}`,style:{width:s},className:u("rst__lineBlock",n,N)})),f!==r&&t===l){let e,n="";n=r===a+i-1?"rst__highlightBottomLeftCorner":f===a?"rst__highlightTopLeftCorner":"rst__highlightLineVertical",e="rtl"===I?{width:s,right:s*t}:{width:s,left:s*t},C.push(o().createElement("div",{key:t,style:e,className:u("rst__absoluteLineBlock",n,N)}))}})),P="rtl"===I?{right:s*_}:{left:s*_},c(o().createElement("div",b({},v,{className:u("rst__node",N)}),C,o().createElement("div",{className:"rst__nodeContent",style:P},n.Children.map(t,(e=>(0,n.cloneElement)(e,{isOver:h,canDrop:g,draggedNode:p}))))))};x.defaultProps={swapFrom:null,swapDepth:null,swapLength:null,canDrop:!1,draggedNode:null,rowDirection:"ltr"},x.propTypes={treeIndex:i().number.isRequired,treeId:i().string.isRequired,swapFrom:i().number,swapDepth:i().number,swapLength:i().number,scaffoldBlockPxWidth:i().number.isRequired,lowerSiblingCounts:i().arrayOf(i().number).isRequired,listIndex:i().number.isRequired,children:i().node.isRequired,connectDropTarget:i().func.isRequired,isOver:i().bool.isRequired,canDrop:i().bool,draggedNode:i().shape({}),getPrevRow:i().func.isRequired,node:i().shape({}).isRequired,path:i().arrayOf(i().oneOfType([i().string,i().number])).isRequired,rowDirection:i().string};const y=x;var D=r(21113);function w(){return w=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},w.apply(this,arguments)}function I(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?Object(arguments[t]):{},n=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(n=n.concat(Object.getOwnPropertySymbols(r).filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable})))),n.forEach((function(t){v(e,t,r[t])}))}return e}function v(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}const N=e=>{let{scaffoldBlockPxWidth:t,toggleChildrenVisibility:r,connectDragPreview:n,connectDragSource:a,isDragging:i,canDrop:l,canDrag:s,node:d,title:c,subtitle:h,draggedNode:p,path:g,treeIndex:f,isSearchMatch:m,isSearchFocus:b,buttons:x,className:y,style:v,didDrop:N,treeId:_,isOver:C,parentNode:P,rowDirection:O}=e,T=function(e,t){if(null==e)return{};var r,n,o=function(e,t){if(null==e)return{};var r,n,o={},a=Object.keys(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||(o[r]=e[r]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(o[r]=e[r])}return o}(e,["scaffoldBlockPxWidth","toggleChildrenVisibility","connectDragPreview","connectDragSource","isDragging","canDrop","canDrag","node","title","subtitle","draggedNode","path","treeIndex","isSearchMatch","isSearchFocus","buttons","className","style","didDrop","treeId","isOver","parentNode","rowDirection"]);const S=c||d.title,R=h||d.subtitle,A="rtl"===O?"rst__rtl":null;let E;s&&(E="function"==typeof d.children&&d.expanded?o().createElement("div",{className:"rst__loadingHandle"},o().createElement("div",{className:"rst__loadingCircle"},[...new Array(12)].map(((e,t)=>o().createElement("div",{key:t,className:u("rst__loadingCirclePoint",A)}))))):a(o().createElement("div",{className:"rst__moveHandle"}),{dropEffect:"copy"}));const k=p&&(0,D.SG)(p,d),M=!N&&i;let L={left:-.5*t};return"rtl"===O&&(L={right:-.5*t}),o().createElement("div",w({style:{height:"100%"}},T),r&&d.children&&(d.children.length>0||"function"==typeof d.children)&&o().createElement("div",null,o().createElement("button",{type:"button","aria-label":d.expanded?"Collapse":"Expand",className:u(d.expanded?"rst__collapseButton":"rst__expandButton",A),style:L,onClick:()=>r({node:d,path:g,treeIndex:f})}),d.expanded&&!i&&o().createElement("div",{style:{width:t},className:u("rst__lineChildren",A)})),o().createElement("div",{className:u("rst__rowWrapper",A)},n(o().createElement("div",{className:u("rst__row",M&&"rst__rowLandingPad",M&&!l&&"rst__rowCancelPad",m&&"rst__rowSearchMatch",b&&"rst__rowSearchFocus",A,y),style:I({opacity:k?.5:1},v)},E,o().createElement("div",{className:u("rst__rowContents",!s&&"rst__rowContentsDragDisabled",A)},o().createElement("div",{className:u("rst__rowLabel",A)},o().createElement("span",{className:u("rst__rowTitle",d.subtitle&&"rst__rowTitleWithSubtitle")},"function"==typeof S?S({node:d,path:g,treeIndex:f}):S),R&&o().createElement("span",{className:"rst__rowSubtitle"},"function"==typeof R?R({node:d,path:g,treeIndex:f}):R)),o().createElement("div",{className:"rst__rowToolbar"},x.map(((e,t)=>o().createElement("div",{key:t,className:"rst__toolbarButton"},e)))))))))};N.defaultProps={isSearchMatch:!1,isSearchFocus:!1,canDrag:!1,toggleChildrenVisibility:null,buttons:[],className:"",style:{},parentNode:null,draggedNode:null,canDrop:!1,title:null,subtitle:null,rowDirection:"ltr"},N.propTypes={node:i().shape({}).isRequired,title:i().oneOfType([i().func,i().node]),subtitle:i().oneOfType([i().func,i().node]),path:i().arrayOf(i().oneOfType([i().string,i().number])).isRequired,treeIndex:i().number.isRequired,treeId:i().string.isRequired,isSearchMatch:i().bool,isSearchFocus:i().bool,canDrag:i().bool,scaffoldBlockPxWidth:i().number.isRequired,toggleChildrenVisibility:i().func,buttons:i().arrayOf(i().node),className:i().string,style:i().shape({}),connectDragPreview:i().func.isRequired,connectDragSource:i().func.isRequired,parentNode:i().shape({}),isDragging:i().bool.isRequired,didDrop:i().bool.isRequired,draggedNode:i().shape({}),isOver:i().bool.isRequired,canDrop:i().bool,rowDirection:i().string};const _=N;function C(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}class P extends n.Component{render(){const e=this.props,{children:t,connectDropTarget:r,treeId:a,drop:i}=e,l=function(e,t){if(null==e)return{};var r,n,o=function(e,t){if(null==e)return{};var r,n,o={},a=Object.keys(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||(o[r]=e[r]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(o[r]=e[r])}return o}(e,["children","connectDropTarget","treeId","drop"]);return r(o().createElement("div",null,n.Children.map(t,(e=>(0,n.cloneElement)(e,function(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?Object(arguments[t]):{},n=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(n=n.concat(Object.getOwnPropertySymbols(r).filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable})))),n.forEach((function(t){C(e,t,r[t])}))}return e}({},l))))))}}P.defaultProps={canDrop:!1,draggedNode:null},P.propTypes={children:i().node.isRequired,connectDropTarget:i().func.isRequired,isOver:i().bool.isRequired,canDrop:i().bool,draggedNode:i().shape({}),treeId:i().string.isRequired,drop:i().func.isRequired};const O=P,T=(0,f.Z)((()=>({"@global .rst__placeholder":{position:"relative",height:"68px",maxWidth:"300px",padding:"10px"},"@global .rst__placeholder, .rst__placeholder > *":{boxSizing:"border-box"},"@global .rst__placeholder::before":{border:"3px dashed #d9d9d9",content:"",position:"absolute",top:"5px",right:"5px",bottom:"5px",left:"5px",zIndex:-1},"@global .rst__placeholderLandingPad, .rst__placeholderCancelPad":{border:"none !important",boxShadow:"none !important",outline:"none !important"},"@global .rst__placeholderLandingPad *, .rst__placeholderCancelPad *":{opacity:"0 !important"},"@global .rst__placeholderLandingPad::before, .rst__placeholderCancelPad::before":{backgroundColor:"lightblue",borderColor:"white"},"@global .rst__placeholderCancelPad::before":{backgroundColor:"#e6a8ad"}}))),S=e=>{let{isOver:t,canDrop:r}=e;return T(),o().createElement("div",{className:u("rst__placeholder",r&&"rst__placeholderLandingPad",r&&!t&&"rst__placeholderCancelPad")})};S.defaultProps={isOver:!1,canDrop:!1},S.propTypes={isOver:i().bool,canDrop:i().bool};const R=S,A=e=>{let t=[],r=[],n=null;return o=>{const a=Object.keys(o).sort(),i=a.map((e=>o[e]));return(i.length!==t.length||i.some(((e,r)=>e!==t[r]))||a.some(((e,t)=>e!==r[t])))&&(t=i,r=a,n=e(o)),n}},E=A(D.Lf),k=A(D.Pg),M=A(D.o5);var L=r(65758),F=r(75047);class j{constructor(e){this.hoverHandler=()=>{if(null===this.hoverProps)return;const{dropTargetProps:e,monitor:t,component:r}=this.hoverProps,n=t.getItem();if(!n)return;const o=this.getTargetDepth(e,t,r),a=n.node;(e.node!==this.lastDropTargetNode||o!==this.lastDropTargetDepth)&&(this.lastDropTargetNode=e.node,this.lastDropTargetDepth=o,this.dragHover({node:a,path:n.path,minimumTreeIndex:e.listIndex,depth:o}),this.hoverProps=null)},this.deferredCallHoverHandler=()=>{if(this.shouldSkipMoreFrames)return this.shouldSkipMoreFrames=!1,void(this.rafId=requestAnimationFrame(this.deferredCallHoverHandler));this.rafId=null,this.hoverHandler()},this.treeRef=e,this.resetDragVariables()}get startDrag(){return this.treeRef.startDrag}get dragHover(){return this.treeRef.dragHover}get endDrag(){return this.treeRef.endDrag}get drop(){return this.treeRef.drop}get treeId(){return this.treeRef.treeId}get dndType(){return this.treeRef.dndType}get treeData(){return this.treeRef.state.draggingTreeData||this.treeRef.props.treeData}get getNodeKey(){return this.treeRef.props.getNodeKey}get customCanDrop(){return this.treeRef.props.canDrop}get maxDepth(){return this.treeRef.props.maxDepth}resetDragVariables(){this.lastDropTargetNode=null,this.lastDropTargetDepth=null,this.hoverProps=null,this.lastCanDropResult=null,this.lastCanDropProps=null,this.shouldSkipMoreFrames=!1,this.rafId=null}getTargetDepth(e,t,r){let n=0;const o=e.getPrevRow();if(o){let{path:t}=o;!this.treeRef.canNodeHaveChildren(o.node)&&(t=t.slice(0,t.length-1)),n=Math.min(t.length,e.path.length)}let a,i=(t.getItem().path||[]).length;if(t.getItem().treeId!==this.treeId)if(i=0,r){const n=(0,F.findDOMNode)(r).getBoundingClientRect(),o=t.getSourceClientOffset().x-n.left;a=Math.round(o/e.scaffoldBlockPxWidth)}else a=e.path.length;else{const r="rtl"===e.rowDirection?-1:1;a=Math.round(r*t.getDifferenceFromInitialOffset().x/e.scaffoldBlockPxWidth)}let l=Math.min(n,Math.max(0,i+a-1));if(void 0!==this.maxDepth&&null!==this.maxDepth){const e=t.getItem().node,r=(0,D.hh)(e);l=Math.max(0,Math.min(l,this.maxDepth-r-1))}return l}canDrop(e,t){if(!t.isOver())return!1;const r=e.getPrevRow(),n=r?r.path:[],o=r?r.node:{},a=Math.round(t.getDifferenceFromInitialOffset().x/e.scaffoldBlockPxWidth),i={nodeId:void 0!==e.node.nodeId?e.node.nodeId:e.node,rowAbove:r,abovePath:n,aboveNodeId:void 0!==o.nodeId?o.nodeId:o,blocksOffset:a};if((0,s.equals)(this.lastCanDropProps,i))return this.lastCanDropResult;this.lastCanDropProps=i;const l=this.getTargetDepth(e,t,null);if(l>=n.length&&"function"==typeof o.children)return this.lastCanDropResult=!1;if("function"==typeof this.customCanDrop){const{node:r}=t.getItem(),n=E({treeData:this.treeData,newNode:r,depth:l,getNodeKey:this.getNodeKey,minimumTreeIndex:e.listIndex,expandParent:!0});return this.lastCanDropResult=this.customCanDrop({node:r,prevPath:t.getItem().path,prevParent:t.getItem().parentNode,prevTreeIndex:t.getItem().treeIndex,nextPath:n.path,nextParent:n.parentNode,nextTreeIndex:n.treeIndex})}return this.lastCanDropResult=!0}wrapSource(e){const t={beginDrag:e=>(this.startDrag(e),{node:e.node,parentNode:e.parentNode,path:e.path,treeIndex:e.treeIndex,treeId:e.treeId}),endDrag:(e,t)=>{this.rafId&&cancelAnimationFrame(this.rafId),this.endDrag(t.getDropResult()),this.resetDragVariables()},isDragging:(e,t)=>{const r=t.getItem().node;return e.node===r}};return(0,c.DragSource)(this.dndType,t,(function(e,t){return{connectDragSource:e.dragSource(),connectDragPreview:e.dragPreview(),isDragging:t.isDragging(),didDrop:t.didDrop()}}))(e)}wrapTarget(e){const t={drop:(e,t,r)=>{this.rafId&&cancelAnimationFrame(this.rafId);const n={node:t.getItem().node,path:t.getItem().path,treeIndex:t.getItem().treeIndex,treeId:this.treeId,minimumTreeIndex:e.treeIndex,depth:this.getTargetDepth(e,t,r)};return this.lastDropTargetNode=null,this.drop(n),n},hover:(e,t,r)=>{this.rafId?this.shouldSkipMoreFrames=!0:(this.shouldSkipMoreFrames=!1,this.hoverProps={dropTargetProps:e,monitor:t,component:r},this.rafId=requestAnimationFrame(this.deferredCallHoverHandler))},canDrop:this.canDrop.bind(this)};return(0,c.DropTarget)(this.dndType,t,(function(e,t){const r=t.getItem();return{connectDropTarget:e.dropTarget(),isOver:t.isOver(),canDrop:t.canDrop(),draggedNode:r?r.node:null}}))(e)}wrapPlaceholder(e){const t={drop:(e,t)=>{const{node:r,path:n,treeIndex:o}=t.getItem(),a={node:r,path:n,treeIndex:o,treeId:this.treeId,minimumTreeIndex:0,depth:0};return this.drop(a),a}};return(0,c.DropTarget)(this.dndType,t,(function(e,t){const r=t.getItem();return{connectDropTarget:e.dropTarget(),isOver:t.isOver(),canDrop:t.canDrop(),draggedNode:r?r.node:null}}))(e)}}function K(){return K=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},K.apply(this,arguments)}function V(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?Object(arguments[t]):{},n=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(n=n.concat(Object.getOwnPropertySymbols(r).filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable})))),n.forEach((function(t){H(e,t,r[t])}))}return e}function H(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}let B=1;const z=e=>{const t=V({},e,{style:V({},e.theme.style,e.style),innerStyle:V({},e.theme.innerStyle,e.innerStyle),reactVirtualizedListProps:V({},e.theme.reactVirtualizedListProps,e.reactVirtualizedListProps)}),r={nodeContentRenderer:_,placeholderRenderer:R,rowHeight:62,scaffoldBlockPxWidth:44,slideRegionSize:100,treeNodeRenderer:y};return Object.keys(r).forEach((n=>{null===e[n]&&(t[n]=void 0!==e.theme[n]?e.theme[n]:r[n])})),t};class Z extends n.Component{constructor(e){super(e);const{dndType:t,nodeContentRenderer:r,treeNodeRenderer:n,isVirtualized:o,slideRegionSize:a}=z(e);this.dndManager=new j(this),this.treeId=`rst__${B}`,B+=1,this.dndType=t||this.treeId,this.nodeContentRenderer=this.dndManager.wrapSource(r),this.treePlaceholderRenderer=this.dndManager.wrapPlaceholder(O),this.treeNodeRenderer=this.dndManager.wrapTarget(n),o&&(this.scrollZoneVirtualList=(d._t||d.ZP)(l.aV),this.vStrength=(0,d.Kx)(a),this.hStrength=(0,d.v7)(a)),this.state={draggingTreeData:null,draggedNode:null,draggedMinimumTreeIndex:null,draggedDepth:null,searchMatches:[],searchFocusTreeIndex:null,dragging:!1,draggingExpandedPaths:[],ignoreOneTreeUpdate:!1,instanceProps:{treeData:this.props.treeData||[],searchQuery:null,searchFocusOffset:null,ignoreTreeChanges:!1}},this.toggleChildrenVisibility=this.toggleChildrenVisibility.bind(this),this.moveNode=this.moveNode.bind(this),this.startDrag=this.startDrag.bind(this),this.dragHover=this.dragHover.bind(this),this.endDrag=this.endDrag.bind(this),this.drop=this.drop.bind(this),this.handleDndMonitorChange=this.handleDndMonitorChange.bind(this)}componentDidMount(){Z.loadLazyChildren(this.props);const e=Z.search(this.props,this.state,!0,!0,!1);this.setState(e),this.clearMonitorSubscription=this.props.dragDropManager.getMonitor().subscribeToStateChange(this.handleDndMonitorChange)}static getDerivedStateFromProps(e,t){const{instanceProps:r}=t,n={};return(0,s.equals)(r.searchQuery,e.searchQuery)?r.searchFocusOffset!==e.searchFocusOffset&&Object.assign(n,Z.search(e,t,!0,!0,!0)):Object.assign(n,Z.search(e,t,!0,!0,!1)),r.searchQuery=e.searchQuery,r.searchFocusOffset=e.searchFocusOffset,n.instanceProps=r,n}componentDidUpdate(e,t){if(this.state.dragging!==t.dragging&&this.props.onDragStateChanged&&this.props.onDragStateChanged({isDragging:this.state.dragging,draggedNode:this.state.draggedNode}),this.state.dragging)if((0,s.equals)(this.props.treeData,e.treeData))this.state.draggingTreeData&&t.draggingTreeData!==this.state.draggingTreeData&&(0,D._p)({treeData:this.state.draggingTreeData,getNodeKey:this.props.getNodeKey,callback:e=>{let{node:t,path:r,lowerSiblingCounts:n,treeIndex:o}=e;t.pending&&t.expanded&&this.props.onLazyLoadChildren({node:t,path:r,lowerSiblingCounts:n,treeIndex:o})}});else{const{treeData:e}=(0,D.ZF)({treeData:this.props.treeData,path:t.draggedPath,getNodeKey:this.props.getNodeKey});this.setState((t=>{let{draggingExpandedPaths:r}=t;return{draggingTreeData:r.reduce(((e,t)=>{let r;try{r=(0,D.Gm)({treeData:e,path:t,newNode:e=>{let{node:t}=e;return V({},t,{expanded:!0})},getNodeKey:this.props.getNodeKey})}catch(t){r=e}return r}),e)}}))}else if(this.props.treeData!==e.treeData){const t=(0,s.equals)(this.props.treeData,e.treeData),{ignoreOneTreeUpdate:r,instanceProps:n}=this.state,o={};t||(r?o.ignoreOneTreeUpdate=!1:(o.searchFocusTreeIndex=null,Z.loadLazyChildren(this.props),Object.assign(o,Z.search(this.props,this.state,!1,!1,!1))),o.draggingTreeData=null,o.draggedNode=null,o.draggedMinimumTreeIndex=null,o.draggedDepth=null,o.dragging=!1,o.draggingExpandedPaths=[],o.instanceProps=V({},n,{treeData:this.props.treeData}),this.setState(o))}}componentWillUnmount(){this.clearMonitorSubscription()}getRows(e){return k({ignoreCollapsed:!0,getNodeKey:this.props.getNodeKey,treeData:e})}handleDndMonitorChange(){!this.props.dragDropManager.getMonitor().isDragging()&&this.state.draggingTreeData&&this.endDrag()}toggleChildrenVisibility(e){let{node:t,path:r}=e;const{instanceProps:n}=this.state,o=(0,D.Gm)({treeData:n.treeData,path:r,newNode:e=>{let{node:t}=e;return V({},t,{expanded:!t.expanded})},getNodeKey:this.props.getNodeKey});this.props.onChange(o),this.props.onVisibilityToggle({treeData:o,node:t,expanded:!t.expanded,path:r})}moveNode(e){let{node:t,path:r,treeIndex:n,depth:o,minimumTreeIndex:a}=e;const{treeData:i,treeIndex:l,path:s,parentNode:d}=(0,D.Lf)({treeData:this.state.draggingTreeData,newNode:t,depth:o,minimumTreeIndex:a,expandParent:!0,getNodeKey:this.props.getNodeKey});this.setState({draggingTreeData:null,draggedNode:null,draggedMinimumTreeIndex:null,draggedDepth:null,dragging:!1,draggingExpandedPaths:[]},(()=>{this.props.onChange(i),this.props.onMoveNode({treeData:i,node:t,treeIndex:l,path:s,nextPath:s,nextTreeIndex:l,prevPath:r,prevTreeIndex:n,nextParentNode:d})}))}static search(e,t,r,n,o){const{onChange:a,getNodeKey:i,searchFinishCallback:l,searchQuery:s,searchMethod:d,searchFocusOffset:c,onlyExpandSearchedNodes:h}=e,{instanceProps:p}=t;if(!s&&!d)return l&&l([]),{searchMatches:[]};const g={},{treeData:u,matches:f}=(0,D.sE)({getNodeKey:i,treeData:h?(0,D.Vk)({treeData:p.treeData,expanded:!1}):p.treeData,searchQuery:s,searchMethod:d||L.v2,searchFocusOffset:c,expandAllMatchPaths:n&&!o,expandFocusMatchPaths:!!n});n&&(g.ignoreOneTreeUpdate=!0,a(u)),l&&l(f);let m=null;return r&&null!==c&&c<f.length&&(m=f[c].treeIndex),g.searchMatches=f,g.searchFocusTreeIndex=m,g}startDrag(e){let{path:t}=e;this.setState((e=>{const{treeData:r,node:n,treeIndex:o}=(0,D.ZF)({treeData:e.instanceProps.treeData,path:t,getNodeKey:this.props.getNodeKey});return{draggingTreeData:r,draggedNode:n,draggedDepth:t.length-1,draggedMinimumTreeIndex:o,draggedPath:t,dragging:!0}}))}dragHover(e){let{node:t,depth:r,minimumTreeIndex:n}=e;this.state.draggedDepth===r&&this.state.draggedMinimumTreeIndex===n||this.setState((e=>{let{draggingTreeData:o,instanceProps:a,draggingExpandedPaths:i}=e;const l=o||a.treeData,d=E({treeData:l,newNode:t,depth:r,minimumTreeIndex:n,expandParent:!0,getNodeKey:this.props.getNodeKey}),c=this.getRows(d.treeData)[d.treeIndex].path.slice(0,-1),h=(0,s.pipe)((0,s.when)((0,s.always)((0,s.gt)(c.length,0)),(0,s.append)(c)),(0,s.uniqWith)((0,s.eqBy)(String)))(i);return{draggedNode:t,draggedDepth:r,draggedMinimumTreeIndex:n,draggingTreeData:(0,D.Gm)({treeData:l,path:c,newNode:e=>{let{node:t}=e;return V({},t,{expanded:!0})},getNodeKey:this.props.getNodeKey}),searchFocusTreeIndex:null,dragging:!0,draggingExpandedPaths:h}}))}endDrag(e){const{instanceProps:t}=this.state;if(e){if(e.treeId!==this.treeId){const{node:r,path:n,treeIndex:o}=e;let a=this.props.shouldCopyOnOutsideDrop;"function"==typeof a&&(a=a({node:r,prevTreeIndex:o,prevPath:n}));let i=this.state.draggingTreeData||t.treeData;a&&(i=(0,D.Gm)({treeData:t.treeData,path:n,newNode:e=>{let{node:t}=e;return V({},t)},getNodeKey:this.props.getNodeKey})),this.props.onChange(i),this.props.onMoveNode({treeData:i,node:r,treeIndex:null,path:null,nextPath:null,nextTreeIndex:null,prevPath:n,prevTreeIndex:o})}}else(()=>{this.setState({draggingTreeData:null,draggedNode:null,draggedMinimumTreeIndex:null,draggedDepth:null,dragging:!1})})()}drop(e){this.moveNode(e)}canNodeHaveChildren(e){const{canNodeHaveChildren:t}=this.props;return!t||t(e)}static loadLazyChildren(e){(0,D._p)({treeData:e.treeData,getNodeKey:e.getNodeKey,callback:t=>{let{node:r,path:n,lowerSiblingCounts:o,treeIndex:a}=t;r.pending&&(r.expanded||e.loadCollapsedLazyChildren)&&e.onLazyLoadChildren({node:r,path:n,lowerSiblingCounts:o,treeIndex:a,done:t=>e.onChange((0,D.Gm)({treeData:e.treeData,path:n,newNode:e=>{let{node:n}=e;return n===r?V({},n,{children:t}):n},getNodeKey:e.getNodeKey}),!0)})}})}renderRow(e,t){let{listIndex:r,style:n,getPrevRow:a,matchKeys:i,swapFrom:l,swapDepth:s,swapLength:d}=t;const{node:c,parentNode:h,path:p,lowerSiblingCounts:g,treeIndex:u}=e,{canDrag:f,generateNodeProps:m,scaffoldBlockPxWidth:b,searchFocusOffset:x,rowDirection:y}=z(this.props),D=this.treeNodeRenderer,w=this.nodeContentRenderer,I=p[p.length-1],v=I in i,N=v&&i[I]===x,_={node:c,parentNode:h,path:p,lowerSiblingCounts:g,treeIndex:u,isSearchMatch:v,isSearchFocus:N},C=m?m(_):{},P="function"!=typeof f?f:f(_),O={treeIndex:u,scaffoldBlockPxWidth:b,node:c,path:p,treeId:this.treeId,rowDirection:y};return o().createElement(D,K({style:n,key:I,listIndex:r,getPrevRow:a,lowerSiblingCounts:g,swapFrom:l,swapLength:d,swapDepth:s},O),o().createElement(w,K({parentNode:h,isSearchMatch:v,isSearchFocus:N,canDrag:P,toggleChildrenVisibility:this.toggleChildrenVisibility},O,C)))}render(){const{dragDropManager:e,style:t,className:r,innerStyle:n,rowHeight:a,isVirtualized:i,placeholderRenderer:s,reactVirtualizedListProps:d,getNodeKey:c,rowDirection:h}=z(this.props),{searchMatches:p,searchFocusTreeIndex:g,draggedNode:f,draggedDepth:m,draggedMinimumTreeIndex:b}=this.state,x=this.state.draggingTreeData||this.props.treeData,y="rtl"===h?"rst__rtl":null;let D,w=null,I=null;if(f&&null!==b){const e=E({treeData:x,newNode:f,depth:m,minimumTreeIndex:b,expandParent:!0,getNodeKey:c}),t=b;w=e.treeIndex,I=1+M({node:f}),D=function(e,t,r){let n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1;const o=[...e.slice(0,t),...e.slice(t+n)];return[...o.slice(0,r),...e.slice(t,t+n),...o.slice(r)]}(this.getRows(e.treeData),w,t,I)}else D=this.getRows(x);const v={};p.forEach(((e,t)=>{let{path:r}=e;v[r[r.length-1]]=t}));const N=null!==g?{scrollToIndex:g}:{};let _,C=t;if(D.length<1){const e=this.treePlaceholderRenderer,t=s;_=o().createElement(e,{treeId:this.treeId,drop:this.drop},o().createElement(t,null))}else if(i){C=V({height:"100%"},C);const t=this.scrollZoneVirtualList;_=o().createElement(l.qj,null,(r=>{let{height:i,width:l}=r;return o().createElement(t,K({},N,{dragDropManager:e,verticalStrength:this.vStrength,horizontalStrength:this.hStrength,speed:30,scrollToAlignment:"start",className:this.props.classes.rst__virtualScrollOverride,width:l,onScroll:e=>{let{scrollTop:t}=e;this.scrollTop=t},height:i,style:n,rowCount:D.length,estimatedRowSize:"function"!=typeof a?a:void 0,rowHeight:"function"!=typeof a?a:e=>{let{index:t}=e;return a({index:t,treeIndex:t,node:D[t].node,path:D[t].path})},rowRenderer:e=>{let{index:t,style:r}=e;return this.renderRow(D[t],{listIndex:t,style:r,getPrevRow:()=>D[t-1]||null,matchKeys:v,swapFrom:w,swapDepth:m,swapLength:I})}},d))}))}else _=D.map(((e,t)=>this.renderRow(e,{listIndex:t,style:{height:"function"!=typeof a?a:a({index:t,treeIndex:t,node:e.node,path:e.path})},getPrevRow:()=>D[t-1]||null,matchKeys:v,swapFrom:w,swapDepth:m,swapLength:I})));return o().createElement("div",{className:u("rst__tree",r,y),style:C},_)}}Z.propTypes={classes:i().object,dragDropManager:i().shape({getMonitor:i().func}).isRequired,treeData:i().arrayOf(i().object).isRequired,style:i().shape({}),className:i().string,innerStyle:i().shape({}),rowHeight:i().oneOfType([i().number,i().func]),slideRegionSize:i().number,reactVirtualizedListProps:i().shape({}),scaffoldBlockPxWidth:i().number,maxDepth:i().number,searchMethod:i().func,searchQuery:i().any,searchFocusOffset:i().number,searchFinishCallback:i().func,generateNodeProps:i().func,isVirtualized:i().bool,treeNodeRenderer:i().func,nodeContentRenderer:i().func,placeholderRenderer:i().func,theme:i().shape({style:i().shape({}),innerStyle:i().shape({}),reactVirtualizedListProps:i().shape({}),scaffoldBlockPxWidth:i().number,slideRegionSize:i().number,rowHeight:i().oneOfType([i().number,i().func]),treeNodeRenderer:i().func,nodeContentRenderer:i().func,placeholderRenderer:i().func}),getNodeKey:i().func,onChange:i().func.isRequired,onMoveNode:i().func,canDrag:i().oneOfType([i().func,i().bool]),canDrop:i().func,canNodeHaveChildren:i().func,shouldCopyOnOutsideDrop:i().oneOfType([i().func,i().bool]),onVisibilityToggle:i().func,dndType:i().string,onDragStateChanged:i().func,onlyExpandSearchedNodes:i().bool,rowDirection:i().string,onLazyLoadChildren:i().func,ignoreTreeChanges:i().bool},Z.defaultProps={canDrag:!0,canDrop:null,canNodeHaveChildren:()=>!0,className:"",dndType:null,generateNodeProps:null,getNodeKey:L.TS,innerStyle:{},isVirtualized:!0,maxDepth:null,treeNodeRenderer:null,nodeContentRenderer:null,onMoveNode:()=>{},onVisibilityToggle:()=>{},placeholderRenderer:null,reactVirtualizedListProps:{},rowHeight:null,scaffoldBlockPxWidth:null,searchFinishCallback:null,searchFocusOffset:null,searchMethod:null,searchQuery:null,shouldCopyOnOutsideDrop:!1,slideRegionSize:null,style:{},theme:{},onDragStateChanged:()=>{},onlyExpandSearchedNodes:!1,rowDirection:"ltr",onLazyLoadChildren:()=>{},ignoreTreeChanges:!1},(0,h.polyfill)(Z);const q=(0,p.Z)((()=>({"@global .ReactVirtualized__Grid__innerScrollContainer":{overflow:"visible !important"},"@global .ReactVirtualized__Grid":{outline:"none"},"@global .ReactVirtualized__List":{},rst__virtualScrollOverride:{overflow:"auto !important"},"@global .rst__rtl .ReactVirtualized__Grid__innerScrollContainer":{direction:"rtl"}})))(Z),W=e=>o().createElement(c.DndContext.Consumer,null,(t=>{let{dragDropManager:r}=t;return void 0===r?null:o().createElement(q,K({},e,{dragDropManager:r}))})),U=e=>o().createElement(g.l,null,o().createElement(W,e))},65758:(e,t,r)=>{function n(e){let{treeIndex:t}=e;return t}function o(e){return"string"==typeof e?e:null===e||"object"!=typeof e||!e.props||!e.props.children||"string"!=typeof e.props.children&&"object"!=typeof e.props.children?"":"string"==typeof e.props.children?e.props.children:e.props.children.map((e=>o(e))).join("")}function a(e,t,r,n,a){return"function"==typeof r[e]?String(r[e]({node:r,path:n,treeIndex:a})).indexOf(t)>-1:"object"==typeof r[e]?o(r[e]).indexOf(t)>-1:r[e]&&String(r[e]).indexOf(t)>-1}function i(e){let{node:t,path:r,treeIndex:n,searchQuery:o}=e;return a("title",o,t,r,n)||a("subtitle",o,t,r,n)}r.d(t,{TS:()=>n,v2:()=>i,ZP:()=>l});const l={defaultSearchMethod:i,defaultGetNodeKey:n}},21113:(e,t,r)=>{function n(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?Object(arguments[t]):{},n=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(n=n.concat(Object.getOwnPropertySymbols(r).filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable})))),n.forEach((function(t){o(e,t,r[t])}))}return e}function o(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function a(e){let{targetIndex:t,node:r,currentIndex:n,getNodeKey:o,path:i=[],lowerSiblingCounts:l=[],ignoreCollapsed:s=!0,isPseudoRoot:d=!1}=e;const c=d?[]:[...i,o({node:r,treeIndex:n})];if(n===t)return{node:r,lowerSiblingCounts:l,path:c};if(!r.children||s&&!0!==r.expanded)return{nextIndex:n+1};let h=n+1;const p=r.children.length;for(let e=0;e<p;e+=1){const n=a({ignoreCollapsed:s,getNodeKey:o,targetIndex:t,node:r.children[e],currentIndex:h,lowerSiblingCounts:[...l,p-e-1],path:c});if(n.node)return n;h=n.nextIndex}return{nextIndex:h}}function i(e){let{node:t,ignoreCollapsed:r=!0}=e;return a({getNodeKey:()=>{},ignoreCollapsed:r,node:t,currentIndex:0,targetIndex:-1}).nextIndex-1}function l(e){let{callback:t,getNodeKey:r,ignoreCollapsed:n,isPseudoRoot:o=!1,node:a,parentNode:i=null,currentIndex:s,path:d=[],lowerSiblingCounts:c=[]}=e;const h=o?[]:[...d,r({node:a,treeIndex:s})];if(!o&&!1===t(o?null:{node:a,parentNode:i,path:h,lowerSiblingCounts:c,treeIndex:s}))return!1;if(!a.children||!0!==a.expanded&&n&&!o)return s;let p=s;const g=a.children.length;if("function"!=typeof a.children)for(let e=0;e<g;e+=1)if(p=l({callback:t,getNodeKey:r,ignoreCollapsed:n,node:a.children[e],parentNode:o?null:a,currentIndex:p+1,lowerSiblingCounts:[...c,g-e-1],path:h}),!1===p)return!1;return p}function s(e){let{callback:t,getNodeKey:r,ignoreCollapsed:o,isPseudoRoot:a=!1,node:i,parentNode:l=null,currentIndex:d,path:c=[],lowerSiblingCounts:h=[]}=e;const p=n({},i),g=a?[]:[...c,r({node:p,treeIndex:d})],u={node:p,parentNode:l,path:g,lowerSiblingCounts:h,treeIndex:d};if(!p.children||!0!==p.expanded&&o&&!a)return{treeIndex:d,node:t(u)};let f=d;const m=p.children.length;return"function"!=typeof p.children&&(p.children=p.children.map(((e,n)=>{const i=s({callback:t,getNodeKey:r,ignoreCollapsed:o,node:e,parentNode:a?null:p,currentIndex:f+1,lowerSiblingCounts:[...h,m-n-1],path:g});return f=i.treeIndex,i.node}))),{node:t(u),treeIndex:f}}function d(e){let{treeData:t,getNodeKey:r,callback:n,ignoreCollapsed:o=!0}=e;!t||t.length<1||l({callback:n,getNodeKey:r,ignoreCollapsed:o,isPseudoRoot:!0,node:{children:t},currentIndex:-1,path:[],lowerSiblingCounts:[]})}function c(e){let{treeData:t,getNodeKey:r,callback:n,ignoreCollapsed:o=!0}=e;return!t||t.length<1?[]:s({callback:n,getNodeKey:r,ignoreCollapsed:o,isPseudoRoot:!0,node:{children:t},currentIndex:-1,path:[],lowerSiblingCounts:[]}).node.children}function h(e){let{treeData:t,expanded:r=!0}=e;return c({treeData:t,callback:e=>{let{node:t}=e;return n({},t,{expanded:r})},getNodeKey:e=>{let{treeIndex:t}=e;return t},ignoreCollapsed:!1})}function p(e){let{treeData:t,path:r,newNode:o,getNodeKey:a,ignoreCollapsed:l=!0}=e;const s="RESULT_MISS",d=e=>{let{isPseudoRoot:t=!1,node:c,currentTreeIndex:h,pathIndex:p}=e;if(!t&&a({node:c,treeIndex:h})!==r[p])return s;if(p>=r.length-1)return"function"==typeof o?o({node:c,treeIndex:h}):o;if(!c.children)throw new Error("Path referenced children of node with no children.");let g=h+1;for(let e=0;e<c.children.length;e+=1){const t=d({node:c.children[e],currentTreeIndex:g,pathIndex:p+1});if(t!==s)return n({},c,t?{children:[...c.children.slice(0,e),t,...c.children.slice(e+1)]}:{children:[...c.children.slice(0,e),...c.children.slice(e+1)]});g+=1+i({node:c.children[e],ignoreCollapsed:l})}return s},c=d({node:{children:t},currentTreeIndex:-1,pathIndex:-1,isPseudoRoot:!0});if(c===s)throw new Error("No node found at the given path.");return c.children}function g(e){let{treeData:t,path:r,getNodeKey:n,ignoreCollapsed:o=!0}=e,a=null,i=null;return{treeData:p({treeData:t,path:r,getNodeKey:n,ignoreCollapsed:o,newNode:e=>{let{node:t,treeIndex:r}=e;return a=t,i=r,null}}),node:a,treeIndex:i}}function u(e){let{targetDepth:t,minimumTreeIndex:r,newNode:o,ignoreCollapsed:a,expandParent:l,isPseudoRoot:s=!1,isLastChild:d,node:c,currentIndex:h,currentDepth:p,getNodeKey:g,path:f=[]}=e;const m=e=>s?[]:[...f,g({node:e,treeIndex:h})];if(h>=r-1||d&&(!c.children||!c.children.length)){if("function"==typeof c.children)throw new Error("Cannot add to children defined by a function");{const e=n({},c,l?{expanded:!0}:{},{children:c.children?[o,...c.children]:[o]});return{node:e,nextIndex:h+2,insertedTreeIndex:h+1,parentPath:m(e),parentNode:s?null:e}}}if(p>=t-1){if(!c.children||"function"==typeof c.children||!0!==c.expanded&&a&&!s)return{node:c,nextIndex:h+1};let e=h+1,t=null,l=null;for(let n=0;n<c.children.length;n+=1){if(e>=r){t=e,l=n;break}e+=1+i({node:c.children[n],ignoreCollapsed:a})}if(null===l){if(e<r&&!d)return{node:c,nextIndex:e};t=e,l=c.children.length}const p=n({},c,{children:[...c.children.slice(0,l),o,...c.children.slice(l)]});return{node:p,nextIndex:e,insertedTreeIndex:t,parentPath:m(p),parentNode:s?null:p}}if(!c.children||"function"==typeof c.children||!0!==c.expanded&&a&&!s)return{node:c,nextIndex:h+1};let b=null,x=null,y=null,D=h+1,w=c.children;"function"!=typeof w&&(w=w.map(((e,n)=>{if(null!==b)return e;const i=u({targetDepth:t,minimumTreeIndex:r,newNode:o,ignoreCollapsed:a,expandParent:l,isLastChild:d&&n===w.length-1,node:e,currentIndex:D,currentDepth:p+1,getNodeKey:g,path:[]});return"insertedTreeIndex"in i&&({insertedTreeIndex:b,parentNode:y,parentPath:x}=i),D=i.nextIndex,i.node})));const I=n({},c,{children:w}),v={node:I,nextIndex:D};return null!==b&&(v.insertedTreeIndex=b,v.parentPath=[...m(I),...x],v.parentNode=y),v}function f(e){let{treeData:t,depth:r,minimumTreeIndex:n,newNode:o,getNodeKey:a=(()=>{}),ignoreCollapsed:i=!0,expandParent:l=!1}=e;if(!t&&0===r)return{treeData:[o],treeIndex:0,path:[a({node:o,treeIndex:0})],parentNode:null};const s=u({targetDepth:r,minimumTreeIndex:n,newNode:o,ignoreCollapsed:i,expandParent:l,getNodeKey:a,isPseudoRoot:!0,isLastChild:!0,node:{children:t},currentIndex:-1,currentDepth:-1});if(!("insertedTreeIndex"in s))throw new Error("No suitable position found to insert.");const d=s.insertedTreeIndex;return{treeData:s.node.children,treeIndex:d,path:[...s.parentPath,a({node:o,treeIndex:d})],parentNode:s.parentNode}}function m(e){let{treeData:t,getNodeKey:r,ignoreCollapsed:n=!0}=e;if(!t||t.length<1)return[];const o=[];return d({treeData:t,getNodeKey:r,ignoreCollapsed:n,callback:e=>{o.push(e)}}),o}function b(e,t){return!!e.children&&"function"!=typeof e.children&&e.children.some((e=>e===t||b(e,t)))}function x(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return e.children?"function"==typeof e.children?t+1:e.children.reduce(((e,r)=>Math.max(e,x(r,t+1))),t):t}function y(e){let{getNodeKey:t,treeData:r,searchQuery:o,searchMethod:a,searchFocusOffset:i,expandAllMatchPaths:l=!1,expandFocusMatchPaths:s=!0}=e,d=0;const c=e=>{let{isPseudoRoot:r=!1,node:h,currentIndex:p,path:g=[]}=e,u=[],f=!1,m=!1;const b=r?[]:[...g,t({node:h,treeIndex:p})],x=r?null:{path:b,treeIndex:p},y=h.children&&"function"!=typeof h.children&&h.children.length>0;!r&&a(n({},x,{node:h,searchQuery:o}))&&(d===i&&(m=!0),d+=1,f=!0);let D=p;const w=n({},h);return y&&(w.children=w.children.map((e=>{const t=c({node:e,currentIndex:D+1,path:b});return t.node.expanded?D=t.treeIndex:D+=1,(t.matches.length>0||t.hasFocusMatch)&&(u=[...u,...t.matches],t.hasFocusMatch&&(m=!0),(l&&t.matches.length>0||(l||s)&&t.hasFocusMatch)&&(w.expanded=!0)),t.node}))),r||w.expanded||(u=u.map((e=>n({},e,{treeIndex:null})))),f&&(u=[n({},x,{node:w}),...u]),{node:u.length>0?w:h,matches:u,hasFocusMatch:m,treeIndex:D}},h=c({node:{children:r},isPseudoRoot:!0,currentIndex:-1});return{matches:h.matches,treeData:h.node.children}}r.d(t,{o5:()=>i,_p:()=>d,Vk:()=>h,Gm:()=>p,ZF:()=>g,Lf:()=>f,Pg:()=>m,SG:()=>b,hh:()=>x,sE:()=>y,ZP:()=>D});const D={find:y,getDepth:x,isDescendant:b,getTreeFromFlatData:function(e){let{flatData:t,getKey:r=(e=>e.id),getParentKey:o=(e=>e.parentId),rootKey:a="0"}=e;if(!t)return[];const i={};if(t.forEach((e=>{const t=o(e);t in i?i[t].push(e):i[t]=[e]})),!(a in i))return[];const l=e=>{const t=r(e);return t in i?n({},e,{children:i[t].map((e=>l(e)))}):n({},e)};return i[a].map((e=>l(e)))},getFlatDataFromTree:m,insertNode:f,addNodeUnderParent:function(e){let{treeData:t,newNode:r,parentKey:o=null,getNodeKey:a,ignoreCollapsed:l=!0,expandParent:s=!1,addAsFirstChild:d=!1}=e;if(null===o)return d?{treeData:[r,...t||[]],treeIndex:0}:{treeData:[...t||[],r],treeIndex:(t||[]).length};let h=null,p=!1;const g=c({treeData:t,getNodeKey:a,ignoreCollapsed:l,callback:e=>{let{node:t,treeIndex:a,path:c}=e;const g=c?c[c.length-1]:null;if(p||g!==o)return t;p=!0;const u=n({},t);if(s&&(u.expanded=!0),!u.children)return h=a+1,n({},u,{children:[r]});if("function"==typeof u.children)throw new Error("Cannot add to children defined by a function");let f=a+1;for(let e=0;e<u.children.length;e+=1)f+=1+i({node:u.children[e],ignoreCollapsed:l});return h=f,n({},u,{children:d?[r,...u.children]:[...u.children,r]})}});if(!p)throw new Error("No node found with the given key.");return{treeData:g,treeIndex:h}},getNodeAtPath:function(e){let{treeData:t,path:r,getNodeKey:n,ignoreCollapsed:o=!0}=e,a=null;try{p({treeData:t,path:r,getNodeKey:n,ignoreCollapsed:o,newNode:e=>{let{node:t,treeIndex:r}=e;return a={node:t,treeIndex:r},t}})}catch(e){}return a},removeNode:g,removeNodeAtPath:function(e){let{treeData:t,path:r,getNodeKey:n,ignoreCollapsed:o=!0}=e;return p({treeData:t,path:r,getNodeKey:n,ignoreCollapsed:o,newNode:null})},changeNodeAtPath:p,toggleExpandedForAll:h,map:c,walk:d,getVisibleNodeInfoAtIndex:function(e){let{treeData:t,index:r,getNodeKey:n}=e;if(!t||t.length<1)return null;const o=a({targetIndex:r,getNodeKey:n,node:{children:t,expanded:!0},currentIndex:-1,path:[],lowerSiblingCounts:[],isPseudoRoot:!0});return o.node?o:null},getVisibleNodeCount:function(e){let{treeData:t}=e;const r=e=>e.children&&!0===e.expanded&&"function"!=typeof e.children?1+e.children.reduce(((e,t)=>e+r(t)),0):1;return t.reduce(((e,t)=>e+r(t)),0)},getDescendantCount:i}},43775:(e,t,r)=>{r.d(t,{Z:()=>h});var n=r(24328),o=r.n(n),a=r(13980),i=r.n(a),l=r(94079);const s=(0,r(79692).Z)({onlyValue:{color:"rgba(0,0,0,.6)",fontSize:"13px",fontWeight:"normal",whiteSpace:"nowrap",textOverflow:"ellipsis",overflow:"hidden"},select:{fontSize:"13px",color:"rgba(0,0,0,.6)",paddingLeft:"15px","&&":{paddingRight:"35px"}},selectMenu:{"& li":{fontSize:"13px",height:"32px"}},textField:{maxWidth:"100%"}});var d=r(79026);const c=e=>{let{value:t,onChange:r,options:a,classes:i={},emptyLabel:c}=e;const h=s(),[p,...g]=a,u=0===g.length;(0,n.useEffect)((()=>{u&&t!==p.value&&r(p.value)}),[p.value]);const f=!!c;return o().createElement("div",{className:i.root},u?o().createElement(l.Typography,{className:i.onlyValue||h.onlyValue,variant:"h6"},p.label):o().createElement(d.Z,{displayEmpty:f,disableUnderline:!0,classes:{select:i.select||h.select},TextFieldProps:{classes:{root:i.textField||h.textField}},MenuProps:{classes:{list:i.selectMenu||h.selectMenu}},value:t||"",entries:f?[{value:"",label:c},...a]:a,onChange:e=>r(e||null)}))};c.propTypes={value:i().string,onChange:i().func,options:i().arrayOf(i().shape({value:i().string,label:i().string})),classes:i().shape({root:i().string,onlyValue:i().string,select:i().string,selectMenu:i().string,textField:i().string}),emptyLabel:i().string};const h=c},8962:(e,t,r)=>{r.d(t,{Z:()=>R});var n=r(52730),o=r(49885),a=r(24328),i=r.n(a),l=r(67958),s=r(71153),d=r.n(s),c=r(87918),h=r.n(c),p=r(94079),g=r(60995),u=r(10237),f=r(93416),m=r(80931),b=r(8261),x=r(79692);const y=(0,x.Z)({attributesContainer:{padding:"0 16px 16px 16px"},header:{marginBottom:"4px"},noCaption:{paddingTop:"16px"},noData:{fontSize:"13px",color:"rgba(0,0,0,0.54)"}}),D=(0,n.connect)((e=>({metadata:o.ZP.selectors.getMetadata(e)})))((e=>{let{className:t,entity:r={},metadata:s,caption:c="",excludeUris:x=[],includeUris:D=[],attributesCount:w=16}=e;const I=y(),v=(0,n.useSelector)(o.ZP.selectors.getPivotingAttributes),N=(0,a.useMemo)((()=>(0,b.U)(s,r.type,D,x)),[x,D,s,r.type]),_=(0,l.fyF)(N,r).filter((e=>{let{values:t}=e;return!(0,l.O27)(t)})).length>0;return _||!(0,l.O27)(c)?i().createElement(g.J.Provider,{value:v},i().createElement(u.Z,{className:t},c&&i().createElement(f.Z,{className:I.header,title:c}),i().createElement(p.Box,{className:d()(I.attributesContainer,{[I.noCaption]:!c})},_?i().createElement(m.Z,{entity:r,attrTypes:N,parentUri:r.uri,drawLines:!1,max:w}):i().createElement(p.Typography,{className:I.noData},h().text("No data found"))))):null}));var w=r(17440),I=r(91262),v=r(47898),N=r(66784);const _=(0,x.Z)({attributesContainer:{overflow:"hidden",padding:"0 16px 16px 16px"},header:{marginBottom:"4px"},noCaption:{paddingTop:"16px"}});function C(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?Object(arguments[t]):{},n=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(n=n.concat(Object.getOwnPropertySymbols(r).filter((function(e){return Object.getOwnPropertyDescriptor(r,e).enumerable})))),n.forEach((function(t){P(e,t,r[t])}))}return e}function P(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}const O=(0,n.connect)((e=>({metadata:o.ZP.selectors.getMetadata(e)})))((e=>{let{className:t,entity:r={},mode:s,metadata:c,caption:h="",excludeUris:g=[],includeUris:m=[],pinnedAttributes:x}=e;const y=_(),D=(0,n.useDispatch)(),P=(0,a.useContext)(v.m),O=(0,n.useSelector)(o.ZP.selectors.getUserRoles),T=(0,a.useMemo)((()=>(0,l.mC3)(x,O)),[x,O]),S=(0,n.useSelector)((e=>o.ZP.selectors.getModifiedEntity(e,r.uri)||{})),R=(0,a.useMemo)((()=>(0,b.U)(c,S.type,m,g)),[g,m,c,S.type]),A=(0,a.useCallback)((e=>(0,w.pipe)(o.N5.actions.addAttributes,D)(e.map((e=>C({},e,{viewId:P}))))),[P,D]),E=(0,a.useCallback)((e=>(0,w.pipe)(o.N5.actions.modifyAttribute,D)(C({},e,{viewId:P}))),[P,D]),k=(0,a.useCallback)((e=>(0,w.pipe)(o.N5.actions.removeAttribute,D)(C({},e,{viewId:P}))),[P,D]);return i().createElement(u.Z,{className:t},h&&i().createElement(f.Z,{className:y.header,title:h}),i().createElement(p.Box,{className:d()(y.attributesContainer,{[y.noCaption]:!h})},i().createElement(N.c.Provider,{value:T},i().createElement(I.Z,{entity:S,attrTypes:R,parentUri:S.uri,drawLines:!1,mode:s,showEmptyEditors:(0,l.ZiX)(S.uri),crosswalks:S.crosswalks,onAddAttributes:A,onChangeAttribute:E,onDeleteAttribute:k}))))}));var T=r(3185);function S(){return S=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},S.apply(this,arguments)}const R=(0,n.connect)(((e,t)=>({entity:t.entity||o.ZP.selectors.getEntityWithDiff(e),mode:t.mode||o.ZP.selectors.getMode(e)})))((e=>{let{mode:t=l.ARY.Viewing,attributesCount:r,pinnedAttributes:n,entity:o}=e,a=function(e,t){if(null==e)return{};var r,n,o=function(e,t){if(null==e)return{};var r,n,o={},a=Object.keys(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||(o[r]=e[r]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n<a.length;n++)r=a[n],t.indexOf(r)>=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(o[r]=e[r])}return o}(e,["mode","attributesCount","pinnedAttributes","entity"]);return i().createElement(T.u.Provider,{value:o},(0,l.uzs)(t)?i().createElement(D,S({attributesCount:r,entity:o},a)):i().createElement(O,S({mode:t,pinnedAttributes:n,entity:o},a)))}))},75477:(e,t,r)=>{r.d(t,{F:()=>o});var n=r(24328);const o=r.n(n)().createContext(void 0);o.displayName="PageRequestsAbortingContext"},92898:(e,t,r)=>{r.d(t,{q:()=>o});var n=r(24328);const o=(e,t)=>{const r=(0,n.useRef)(!1);(0,n.useEffect)((()=>{t&&!r.current&&(r.current=!0,e())}),[e,t])}}}]);
|
|
2
|
-
//# sourceMappingURL=9561.js.map
|