@reltio/remotes 1.4.1621 → 1.4.1623
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/1039.js +1 -1
- package/1146.js +1 -1
- package/1148.js +1 -1
- package/1334.js +1 -1
- package/1425.js +1 -1
- package/1572.js +1 -1
- package/1572.js.map +1 -1
- package/1664.js +1 -1
- package/1707.js +1 -1
- package/1790.js +1 -1
- package/1840.js +1 -1
- package/1925.js +1 -1
- package/1925.js.map +1 -1
- package/2049.js +1 -1
- package/2066.js +1 -1
- package/2066.js.map +1 -1
- package/2201.js +1 -1
- package/2400.js +1 -1
- package/2400.js.map +1 -1
- package/2404.js +1 -1
- package/2404.js.map +1 -1
- package/2463.js +1 -1
- package/2641.js +1 -1
- package/2641.js.map +1 -1
- package/3096.js +1 -1
- package/3348.js +1 -1
- package/3358.js +1 -1
- package/3358.js.map +1 -1
- package/3373.js +1 -1
- package/3381.js +1 -1
- package/3383.js +1 -1
- package/3463.js +1 -1
- package/3469.js +1 -1
- package/3538.js +1 -1
- package/3538.js.map +1 -1
- package/356.js +1 -1
- package/3875.js +1 -1
- package/3902.js +1 -1
- package/3902.js.map +1 -1
- package/3926.js +1 -1
- package/3926.js.map +1 -1
- package/415.js +1 -1
- package/4212.js +1 -1
- package/4390.js +1 -1
- package/4481.js +1 -1
- package/4703.js +1 -1
- package/4780.js +1 -1
- package/4806.js +1 -1
- package/4838.js +1 -1
- package/50.js +1 -1
- package/5034.js +1 -1
- package/5039.js +1 -1
- package/5053.js +1 -1
- package/5108.js +1 -1
- package/5163.js +1 -1
- package/5163.js.map +1 -1
- package/5617.js +1 -1
- package/6020.js +1 -1
- package/6173.js +1 -1
- package/6228.js +1 -1
- package/6280.js +1 -1
- package/6287.js +1 -1
- package/6531.js +1 -1
- package/6606.js +1 -1
- package/6606.js.map +1 -1
- package/6799.js +1 -1
- package/6844.js +1 -1
- package/6853.js +1 -1
- package/6860.js +1 -1
- package/6903.js +1 -1
- package/7340.js +1 -1
- package/735.js +1 -1
- package/7422.js +1 -1
- package/7626.js +1 -1
- package/764.js +1 -1
- package/7896.js +1 -1
- package/8168.js +1 -1
- package/820.js +1 -1
- package/8207.js +1 -1
- package/8322.js +1 -1
- package/8481.js +2 -0
- package/8481.js.map +1 -0
- package/8565.js +1 -1
- package/8741.js +1 -1
- package/9016.js +1 -1
- package/9028.js +1 -1
- package/9028.js.map +1 -1
- package/9283.js +1 -1
- package/9309.js +1 -1
- package/9328.js +1 -1
- package/9387.js +1 -1
- package/9719.js +1 -1
- package/9736.js +1 -1
- package/9861.js +1 -1
- package/987.js +1 -1
- package/99.js +1 -1
- package/9945.js +2 -0
- package/9945.js.map +1 -0
- package/9960.js +1 -1
- package/main.js +1 -1
- package/package.json +1 -1
- package/remoteEntry.js +1 -1
- package/remoteEntry.js.map +1 -1
- package/3727.js +0 -2
- package/3727.js.map +0 -1
- package/673.js +0 -2
- package/673.js.map +0 -1
package/3538.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"3538.js","mappings":"m5BAEA,MAQA,EAR4DA,GAEpD,2BAAKC,MAAO,GAAIC,OAAQ,GAAIC,QAAQ,YAAYC,MAAM,8BAAiCJ,GACnF,0BAAMK,EAAE,4BAA4BC,KAAK,eAAeC,SAAS,UAAUC,OAAO,OAAOC,YAAa,KCHrGC,GAAYC,E,SAAAA,aAAYC,IAAD,CAChC,sBAAuB,CACnBC,MAAOD,EAAME,QAAQC,QAAQC,MAEjCC,UAAW,CACPC,SAAU,WACVC,MAAO,MACPC,OAAQ,MACRC,UAAW,cAEfC,OAAQ,CACJC,QAAS,YCJXC,EAAe,IAAwB,IAAvB,QAACC,EAAD,QAAUC,GAAa,EACzC,MAAMC,EAASjB,IAEf,OACI,kBAACkB,EAAA,EAAD,CAASC,MAAOJ,EAAUK,IAAAA,KAAU,qBAAuBA,IAAAA,KAAU,WACjE,kBAACC,EAAA,EAAD,CAAYL,QAASA,EAASM,QAAS,CAACC,KAAMN,EAAOL,QAASY,KAAK,SAC9DT,EACG,oCACI,kBAACU,EAAD,CAAYC,UAAWT,EAAO,yBAC9B,kBAACU,EAAA,QAAD,CAAWxB,MAAM,UAAUuB,UAAWT,EAAOV,aAGjD,kBAACkB,EAAD,SAOpBX,EAAac,UAAY,CACrBb,QAASc,IAAAA,KACTb,QAASa,IAAAA,MAGb,W,iIC/BO,MAAM7B,GAAYC,E,SAAAA,YAAW,CAChC6B,WAAY,CACRC,QAAS,OACTC,WAAY,SACZC,eAAgB,WAChBzC,OAAQ,OACR0C,WAAY,EACZC,UAAW,6BACXC,UAAW,OACXC,UAAW,aACXC,UAAW,SACXC,cAAe,cACf,uBAAwB,CACpBR,QAAS,OACT,gCAAiC,CAC7BA,QAAS,iBAIrBS,QAAS,CACLrC,MAAO,kBACPsC,SAAU,OACVC,WAAY,OACZX,QAAS,OACT,gCAAiC,CAC7BA,QAAS,UAGjBY,cAAe,CACXxC,MAAO,kBACPsC,SAAU,OACVC,WAAY,QAEhBE,WAAY,CACRC,WAAY,MACZC,YAAa,QAEjBC,OAAQ,CACJ5C,MAAO,kBACPsC,SAAU,OACVC,WAAY,OACZM,UAAW,SAEfC,QAAS,CACLJ,WAAY,oB,wcCzBpB,MAAMK,EAAuB,IAUI,IAVH,QAC1B5B,EAAU,GADgB,MAE1B6B,EAF0B,mBAG1BC,EAH0B,KAI1BC,EAJ0B,aAK1BC,EAL0B,YAM1BC,EAN0B,oBAO1BC,EAP0B,cAQ1BC,EAR0B,iBAS1BC,GAC6B,EAC7B,MAAMzC,EAASjB,IAST2D,GAAyBC,EAAAA,EAAAA,cAAY,MACvCC,EAAAA,EAAAA,QAAOC,EAAAA,SAAU,CAAC,UAAW,0BAA2BL,EAAxDI,KACD,CAACJ,IAEEM,GAAmBH,EAAAA,EAAAA,cACpBI,IACGV,EAAaU,GACbL,MAEJ,CAACL,EAAcK,IAEbM,GAA0BL,EAAAA,EAAAA,cAC3BI,IACGV,EAAa,GACbE,EAAoBQ,GACpBL,MAEJ,CAACL,EAAcE,EAAqBG,IAGxC,OACI,kBAACO,EAAA,EAAD,CACI5C,QAAO,KACAA,EADA,CAEHC,KAAM4C,GAAAA,CAAWlD,EAAOa,WAAYR,EAAQC,MAC5CwB,OAAQoB,GAAAA,CAAWlD,EAAO8B,OAAQzB,EAAQyB,QAC1CqB,YAAaD,GAAAA,CAAWlD,EAAOuB,QAASlB,EAAQ8C,aAChDzB,cAAewB,GAAAA,CAAWlD,EAAO0B,cAAerB,EAAQqB,eACxD0B,MAAOF,GAAAA,CAAWlD,EAAO2B,WAAYtB,EAAQsB,YAC7CK,QAAShC,EAAOgC,UAEpBqB,oBAAqB,CAAC9C,KAAM,SAC5B+C,oBAAqB,CAAC/C,KAAM,SAC5BgD,UAAU,MACVd,iBAAkBA,GAAoBtC,IAAAA,KAAU,kBAChDqD,mBA1CmB,QAAC,KAACC,EAAD,GAAOC,EAAP,MAAWxB,GAAZ,SACvB/B,IAAAA,KAAU,sCAAuC,CAC7CwD,QAASxD,IAAAA,OAAYsD,EAAM,OAC3BG,MAAOzD,IAAAA,OAAYuD,EAAI,OACvBG,UAAW1D,IAAAA,OAAY+B,EAAO,UAuC9BA,MAAOA,EACPC,mBAAoBA,EACpBC,KAAMA,EACN0B,cAAcC,EAAAA,EAAAA,OAAKC,EAAAA,EAAAA,QAAO,GAAIlB,GAC9BR,YAAaA,EACb2B,qBAAqBF,EAAAA,EAAAA,MAAKG,EAAAA,GAAUlB,MAKhDf,EAAqBkC,YAAc,uBAEnC,SAAeC,EAAAA,EAAAA,MAAKnC,I,ogBCtFpB,MAAMoC,EAAiB,iBACjBC,EAAiB,iBACjBC,EAAgB,gBAChBC,EAAc,cACdC,EAAc,cACdC,EAAuB,uBAEhB1C,EAAU,CACnB2C,eAAeC,EAAAA,EAAAA,IAAqBP,GACpCQ,eAAeD,EAAAA,EAAAA,IAAqBN,GACpCQ,cAAcF,EAAAA,EAAAA,IAAqBL,GACnCQ,YAAYH,EAAAA,EAAAA,IAAqBJ,GACjCQ,YAAYJ,EAAAA,EAAAA,IAAqBH,GACjCQ,mBAAmBL,EAAAA,EAAAA,IAAqBF,IAG/BQ,EAAuB,CAACC,EAAOC,KACxC,MAAMC,GAAiBC,EAAAA,EAAAA,YAAWH,EAAMI,eAAgBH,GAClDI,EAAmBC,GAAaJ,EAAeK,SAASD,GAC9D,OAAOE,EAAAA,EAAAA,QACH,CACIJ,gBAAgBK,EAAAA,EAAAA,QAAOR,GACvBS,SAASC,EAAAA,EAAAA,OACL,eAACD,EAAD,uDAAW,GAAX,OAAkBL,EAAgBK,EAAQE,UAC1C,KACI,MAAOC,GAAiBZ,EACxB,MAAO,CAACW,MAAOC,EAAeC,MAAO,UAG7CC,QAAUA,IACNC,EAAAA,EAAAA,MAAKD,GAASE,QACV,CAACC,EAAKZ,IAAcD,EAAgBC,IAAYa,EAAAA,EAAAA,QAAOb,EAAUY,GAAOA,GACxEH,IAGZf,IA4CR,GACIoB,QAzCmB,CAACpB,EAAOqB,KAC3B,OAAQA,EAAOC,MACX,KAAKpC,EAAgB,CACjB,MAAMqC,EAAYF,EAAOG,QACzB,OAAOzB,EAAqBC,EAAOuB,GAEvC,KAAKpC,EAAgB,CACjB,MAAMsC,GAAiBzB,EAAMe,QAC7B,YACOf,EADP,CAEIe,QAASU,EAAgB,GAAK,KAC9BxE,KAAMwE,EAAgBzB,EAAM/C,KAAO,IAG3C,KAAKmC,EAAe,CAChB,MAAM,SAACkB,EAAD,OAAWoB,GAAUL,EAAOG,QAClC,OAAOhB,EAAAA,EAAAA,QAAO,CAACO,QAASW,GAASC,EAAAA,EAAAA,OAAMrB,EAAUoB,IAAUP,EAAAA,EAAAA,QAAOb,GAAWrD,MAAMwD,EAAAA,EAAAA,QAAO,IAAKT,GAEnG,KAAKX,EAAa,CACd,MAAMwB,EAAgBQ,EAAOG,QACvBI,GAAgBC,EAAAA,EAAAA,MAAK,CAAC,UAAW,SAAU7B,GAC3C8B,GAAgBD,EAAAA,EAAAA,MAAK,CAAC,UAAW,SAAU7B,GACjD,YACOA,EADP,CAEIU,QAAS,CACLE,MAAOC,EACPC,OAAOiB,EAAAA,EAAAA,IAAgBlB,IAAkBe,EAAgBE,EAAgB,OAE7E7E,KAAM,IAGd,KAAKqC,EACD,YAAWU,EAAX,CAAkB/C,KAAMoE,EAAOG,UACnC,KAAKjC,EACD,YAAWS,EAAX,CAAkB7C,YAAakE,EAAOG,UAC1C,QACI,OAAOxB,IAMfnD,QAAAA,EACAkD,qBAAAA,I,4gBCnFG,MAAMnG,GAAYC,E,SAAAA,aAAYC,IAAD,CAChCkI,eAAgB,EAAF,CACVrG,QAAS,OACTsG,cAAe,UACZnI,EAAMoI,e,gNCFjB,MAAMC,GAAYC,EAAAA,EAAAA,aACd,CAAC,EAAkDC,KAAyC,IAA3F,SAACC,EAAD,UAAWhH,GAAgF,EAAlEiH,E,kXAAkE,6BACxF,MAAM1H,EAASjB,IACf,OACI,kBAAC4I,EAAA,EAAD,GAAOH,IAAKA,EAAK/G,UAAWA,EAAWJ,QAAS,CAACC,KAAMN,EAAOmH,iBAAqBO,GAC9ED,MAMjBH,EAAUnD,YAAc,YAExB,W,4ICfA,MAAMpF,GAAYC,E,SAAAA,YAAW,CACzB4I,MAAO,CACHC,UAAW,SAEf3H,MAAO,CACHN,QAAS,sBACT4B,SAAU,OACVsG,WAAY,IACZC,cAAe,SACftG,WAAY,QAEhBuG,QAAS,CACLpI,QAAS,UAEbqI,YAAa,CACTC,aAAc,EACd1G,SAAU,OACVuG,cAAe,SACftG,WAAY,QAEhB0G,cAAe,CACXrH,QAAS,OACTsH,WAAY,MACZ5G,SAAU,OACVsG,WAAY,IACZC,cAAe,EACftG,WAAY,OACZ,UAAW,CACPG,WAAY,SAGpByG,cAAe,CACXxG,YAAa,SC2BrB,EArC2B,IAWd,IAXe,KACxByG,EADwB,MAExBpI,EAFwB,QAGxB8H,EAHwB,SAIxBO,EAJwB,cAKxBC,EAAgBrI,IAAAA,KAAU,UALF,UAMxBsI,EANwB,eAOxBC,EAAiB,GAPO,OAQxBC,EARwB,YASxBC,EAAczI,IAAAA,KAAU,QATA,aAUxB0I,GAAe,GACN,EACT,MAAM7I,EAASjB,IAEf,OACI,kBAAC+J,EAAA,EAAD,CAAQR,KAAMA,EAAMS,QAASR,EAAUlI,QAAS,CAAC2I,iBAAkBhJ,EAAO4H,QACtE,kBAACqB,EAAA,EAAD,CAAa5I,QAAS,CAACC,KAAMN,EAAOE,QAASA,GAC7C,kBAACgJ,EAAA,EAAD,CAAe7I,QAAS,CAACC,KAAMN,EAAOgI,UAClC,kBAACmB,EAAA,EAAD,CAAmB9I,QAAS,CAACC,KAAMN,EAAOiI,cAAeD,IAE7D,kBAACoB,EAAA,EAAD,CAAe3I,UAAWT,EAAOmI,cAAekB,gBAAc,GACzDd,GAAY,kBAACe,EAAA,EAAD,CAAQvJ,QAASwI,GAAWC,GACzC,6BACKC,GACG,kBAACa,EAAA,EAAD,CAAQvJ,QAAS0I,EAAWpI,QAAS,CAACC,KAAMN,EAAOqI,gBAC9CK,GAGT,kBAACY,EAAA,EAAD,CAAQvJ,QAAS4I,EAAQzJ,MAAM,UAAUqK,SAAUV,EAAcW,WAAS,GACrEZ,Q,yJCnDlB,MAAM7J,GAAYC,E,SAAAA,aAAYC,IAAD,CAChCwK,SAAU,CACNlL,OAAQ,QAEZmL,SAAU,CACNxK,MAAOD,EAAME,QAAQwK,KAAKvK,QAC1BoC,SAAU,OACVC,WAAY,QAEhBmI,SAAU,CACNhK,QAAS,EACTiC,YAAa,YCAfgI,GAA2BtC,EAAAA,EAAAA,aAAW,CAAC,EAAuCC,KAAkC,IAAzE,KAACsC,EAAD,YAAOC,EAAclH,EAAAA,UAAoD,EAClH,MAAM7C,EAASjB,KACT,KAAC4K,EAAD,QAAO5J,EAAP,GAAgBiK,EAAhB,SAAoBC,GAAYH,EAMtC,OACI,kBAACI,EAAA,EAAD,CACI7J,QAAS,CAACC,KAAMN,EAAOyJ,UACvB1J,QARaoK,IACjBJ,EAAYI,GACZpK,EAAQoK,IAOJ3C,IAAKA,EACL,gBACA,iBAAiB,4BAA2BwC,KAE5C,kBAACI,EAAA,EAAD,CAAUC,QAASJ,EAAUxJ,UAAWT,EAAO4J,SAAU1K,MAAM,YAC/D,kBAACoL,EAAA,EAAD,CAAYjK,QAAS,CAACC,KAAMN,EAAO0J,WAAYC,OAK3DE,EAAyB1F,YAAc,2BAEvC,UCRA,EAhBqB,IAA4B,IAA3B,MAACoG,EAAD,OAAQC,GAAmB,EAC7C,OACI,kBAACC,EAAA,EAAD,CACIC,gBAAiBC,EAAAA,EACjBC,YAAa,CACTC,KAAMC,EAAAA,EACNC,aAAc5K,IAAAA,KAAU,YACxBI,KAAM,KAEViK,OAAQA,EACRQ,UAAWT,EACXU,iBAAkBpB,M,6ECrB9B,MAAMqB,EAAkB,QAAC,OAAC3M,EAAD,OAAS4M,GAAV,SACpB,yBACIC,MAAO,CACH9M,MAAO,MACPC,OAAS,GAAEA,MACX8M,WAAY,6BACZF,OAAS,KAAIA,MACblK,WAAY,QAKxBiK,EAAgBvK,UAAY,CACxBpC,OAAQqC,IAAAA,OACRuK,OAAQvK,IAAAA,QAGZ,W,mLCLO,MAAM0K,EAAyB,QAAC,QAACtJ,EAAD,SAAUuJ,GAAX,SAClCC,EAAAA,EAAAA,UACI,IACIC,OAAOC,QAAQ1J,GAASoE,QAAO,CAACC,EAAD,KAAsC,IAA/BsF,EAAYC,GAAmB,EACjE,O,8UAAA,IAAWvF,EAAX,CAAgB,CAACsF,IAAa5H,EAAAA,EAAAA,MAAK6H,EAAeL,OACnD,KACP,CAACA,EAAUvJ,M,0jBCoBnB,MAAM6J,GAAoB/F,EAAAA,EAAAA,MACtBjD,EAAAA,UACAkB,EAAAA,EAAAA,MACI+H,EAAAA,IACAC,EAAAA,QACAC,EAAAA,EAAAA,QAAOC,GAAMA,EAAI,MAKZC,EAAqB,IAUrB,IAVsB,QAC/BrG,EAD+B,OAE/BgB,EAF+B,KAG/BzE,EAH+B,YAI/BE,EAJ+B,OAK/B6J,EAL+B,OAM/BC,EAN+B,uBAO/BC,EAP+B,KAQ/BC,EAR+B,WAS/BC,GAAa,GACJ,EACT,MAAOC,EAAWC,IAAgBC,EAAAA,EAAAA,WAAS,GACrCnB,GAAWoB,EAAAA,EAAAA,eACXC,GAASC,EAAAA,EAAAA,aAAYC,EAAAA,GAAAA,UAAAA,WACrBC,GAAWF,EAAAA,EAAAA,aAAYC,EAAAA,GAAAA,UAAAA,aACvBE,GAAWH,EAAAA,EAAAA,aAAYC,EAAAA,GAAAA,UAAAA,cACvB,eAACG,EAAD,aAAiBC,IACnBL,EAAAA,EAAAA,aAAYC,EAAAA,GAAAA,UAAAA,gCAAgD,GAC1DK,GAAiBN,EAAAA,EAAAA,aAAYC,EAAAA,GAAAA,UAAAA,0BAC7BM,GAAcC,EAAAA,EAAAA,KAEdC,EAAkBtF,IACpB,MAAMuF,GAASzH,EAAAA,EAAAA,MAAK0H,EAAAA,KAAUC,EAAAA,EAAAA,MAAK,QAC7BC,GAAiB3J,EAAAA,EAAAA,MAAKwJ,GAAQI,EAAAA,EAAAA,KAA2BZ,IAE/D,OAAOpH,EAAAA,EAAAA,QAAO,CACViI,aAAaC,EAAAA,EAAAA,SAASC,EAAAA,EAAAA,KAAyBf,IAC/CgB,aAAaF,EAAAA,EAAAA,QAASH,GACtBM,cAAcH,EAAAA,EAAAA,QAASH,GACvBO,UAAWX,GAJR3H,CAKJqC,IAGDkG,EAAY/B,EAAO+B,UACnBC,GAAU3C,EAAAA,EAAAA,UACZ,KAAM,CACFe,WAAAA,KAEJ,CAACA,IAEC6B,GAAgBzL,EAAAA,EAAAA,cAAY,KAC9B,GAAIyJ,MAAAA,GAAAA,EAAQiC,IAAK,CACb,MACMC,EAAgB,EAAH,GADKhB,EAAenB,EAAOnE,SAC3B,CAEfuG,OAAQ1I,MAAAA,OAAF,EAAEA,EAASE,MACjBE,MAAOJ,MAAAA,OAAF,EAAEA,EAASI,MAChBuI,aAAa,EACbC,eAAe,EACfC,WAAY,CACRC,SAAUtC,GAA0BuC,EAAAA,IAAAA,IACpCxC,OAAQa,GAEZ4B,IAAKvM,EACLwM,OAAQ1M,EAAOE,EACfuE,QAAQkI,EAAAA,EAAAA,KAAuB7B,EAAcrG,SAAWmI,EACxDd,UAAWrC,EAAkBqC,KAE3Be,EAAU,CAACX,GAAeY,QAC5BC,EAAAA,EAAAA,QACItM,EAAAA,UACAkB,EAAAA,EAAAA,MAAK+H,EAAAA,KAAsBoC,GACvBA,EAAUkB,KAAI,CAACjD,EAAQkD,IAAT,KAAoBlD,EAApB,CAA4BnC,GAAIsE,EAAcJ,UAAUmB,UAE1EzJ,EAAAA,EAAAA,QAAO,IALXuJ,CAMEjB,IAGAoB,GAA2DC,EAAAA,EAAAA,MAAK,CAClE,EAACxL,EAAAA,EAAAA,OAAK0J,EAAAA,EAAAA,MAAK,OAAQ+B,EAAAA,KAAY,IAAMC,QAAQC,QAAQ,CAAC,CAACC,MAAO,MAC9D,CACIC,EAAAA,IACCxD,IACGyD,EAAAA,EAAAA,KAAgC,CAC5BC,UAAW1D,EAAOiC,IAClBY,QAASA,EACTc,eAAgBnD,EAChBoD,WAAY5D,EAAO4D,WACnBhD,SAAAA,EACAmB,QAAAA,KAGZ,CAAC8B,EAAAA,EAAI7D,IAAW8D,EAAAA,EAAAA,KAAsB9D,EAAOiC,IAAKY,EAASd,MAE/D1B,GAAa,GACbW,EAAYkC,EAAQlD,IACf+D,MAAMC,IACH,IAAKC,MAAMC,QAAQF,GACf,MAAMG,MAAMC,KAAKC,UAAUL,IAE/B,OAAO,YAACM,EAAD,MAAcf,IAAUS,EAC/B7E,EAASoF,EAAAA,GAAAA,UAAAA,QAAAA,gBAA0C,CAAC3G,GAAImC,EAAOnC,GAAI0G,YAAAA,EAAaf,MAAAA,QAEnFiB,OAAOzG,IACJ0G,QAAQC,KAAK,gCAAiC3G,MAEjD4G,SAAQ,KACLtE,GAAa,SAI1B,CACCQ,EACAF,EACAZ,EACAZ,EACAyB,EACAZ,MAAAA,OAND,EAMCA,EAAQiC,IACRjC,MAAAA,OAPD,EAOCA,EAAQ4D,WACRnJ,EACAqG,EACA9K,EACAiK,EACA/J,EACA8K,EACAvH,EACA+G,EACAuB,EACAhB,IAEE6D,GAAmBC,EAAAA,EAAAA,SAAgB,GACzCD,EAAiBE,SAAU,GAC3BC,EAAAA,EAAAA,YAAU,KACNH,EAAiBE,SAAU,EAC3B9C,MACD,CAACA,IAEJ,MAAMgD,GAAWC,EAAAA,EAAAA,GAAY/E,GAO7B,OANA6E,EAAAA,EAAAA,YAAU,KACF7E,IAASgF,EAAAA,IAAAA,SAAiBN,EAAiBE,SAAWE,IAAa9E,IACnE0E,EAAiBE,SAAU,EAC3B9C,OAEL,CAACA,EAAe9B,EAAM8E,IAClB,CAAC5E,UAAAA,EAAW+E,OAAQnD,K,yuBCjL/B,MAAMoD,EAAsB,CACxBC,eAAgB,GAChBC,gBAAiB,I,wDCCrB,MAAMC,EAA0B,gBAC1BC,EAAuB,sBAEhBC,EAAuB,CAChC,CACI7H,GAAI,eACA8H,YACA,OAAO3R,IAAAA,KAAU,YAErB4R,mBAAoB,CAChBtL,KAAMuL,EAAAA,IAAAA,aAEVC,UAAU,EACVC,YAAY,EACZC,aAAc,IACdC,YAAY,GAEhB,CACIpI,GAAI2H,EACAG,YACA,OAAO3R,IAAAA,KAAU,UAGzB,CACI6J,GAAI,iBACA8H,YACA,OAAO3R,IAAAA,KAAU,sBAErB+R,YAAY,EACZH,mBAAoB,CAChBtL,KAAMuL,EAAAA,IAAAA,cAGd,CACIhI,GAAI,gCACA8H,YACA,OAAO3R,IAAAA,KAAU,eAErB4R,mBAAoB,CAChBtL,KAAMuL,EAAAA,IAAAA,uBAGd,CACIhI,GAAI,8BACA8H,YACA,OAAO3R,IAAAA,KAAU,aAErB4R,mBAAoB,CAChBtL,KAAMuL,EAAAA,IAAAA,uBAGd,CACIhI,GAAI4H,EACAE,YACA,OAAO3R,IAAAA,KAAU,eAErBkS,UAAU,EACVH,YAAY,EACZI,eAAgB,IAIXC,GAAkBC,EAAAA,EAAAA,OAAM,KAAMX,GAC9BY,EAAoB,CAACd,EAAyBC,GAE9Cc,EAAwB,CAAC,GAAI,GAAI,KAExCC,GAAyB5O,EAAAA,EAAAA,MAAK6O,EAAAA,KAAyB1D,EAAAA,EAAAA,QAAO,cAE9D2D,GAAuC9O,EAAAA,EAAAA,OACzCqL,EAAAA,EAAAA,MAAK0D,IAAD,CACA9I,GAAI2I,EAAuBG,EAAKzE,KAChCyD,MAAOgB,EAAKhB,MACZiB,YAAaD,MAAAA,OAAF,EAAEA,EAAMC,YACnBhB,oBAAoBiB,EAAAA,EAAAA,KAA0BF,QAElDG,EAAAA,EAAAA,SAAOxF,EAAAA,EAAAA,MAAK,Q,wcC1DhB,MAAMyF,EAAuB,uBACvBC,EAAoB,oBACpBC,EAAqB,qBAErBpR,EAAU,KACTqR,EAAAA,GAAAA,QADM,CAETC,oBAAoB1O,EAAAA,EAAAA,IAAqBsO,GACzCK,iBAAiB3O,EAAAA,EAAAA,IAAqBuO,GACtCK,kBAAkB5O,EAAAA,EAAAA,IAAqBwO,KAGrCK,GAAkB3M,EAAAA,EAAAA,OAAM,OAAQ,GAEhC4M,EAAkDvO,IAC7CpB,EAAAA,EAAAA,OACH0J,EAAAA,EAAAA,MAAK,mBACL0B,EAAAA,EAAAA,SAAOvJ,EAAAA,EAAAA,QAAOT,EAAMwO,sBAAsBC,EAAAA,EAAAA,SAAQnB,IAAoBvD,EAAAA,EAAAA,QAAOuD,KAC7EoB,EAAAA,EAAAA,cAAatB,GAHVxO,CAILoB,GAGA2O,EAAgD3O,IAClD6B,EAAAA,EAAAA,MAAK,CAAC,iCAAmC,GAAE7B,EAAMwO,uBAAwBxO,GAEvE4O,EAA8C5O,IAChD,MAAMC,GAAqB4O,EAAAA,EAAAA,QACvBF,EACAJ,EAFuBM,CAGzB7O,GACF,OAAOkO,EAAAA,GAAAA,qBAAyClO,EAAOC,IAGrD6O,GAA2BlQ,EAAAA,EAAAA,OAC7BmQ,EAAAA,EAAAA,QAAO,KAAM,YACbC,EAAAA,EAAAA,QACIC,EAAAA,OACAvN,EAAAA,EAAAA,SAAO,QAAC,OAACA,EAAD,MAAS9D,GAAV,SAAqBsR,EAAAA,EAAAA,KAAoBxN,EAAQ9D,QAI1DuR,EAA4CnP,IAC9C,MAAM,oBAACwO,EAAD,eAAsBpO,GAAkBJ,EAC9C,OAAOQ,EAAAA,EAAAA,QACH,CACI4O,gCAAgCzN,EAAAA,EAAAA,OAAO,GAAE6M,IAAuBpO,IAEpEJ,IAIFqP,GAAiBzQ,EAAAA,EAAAA,MACnBuQ,GACAG,EAAAA,EAAAA,MAAK,CAAC,sBAAuB,iCAAkC,UAAW,a,2HC/EvE,MAAM1V,IAAYC,EAAAA,GAAAA,YAAW,CAChC8C,OAAQ,CACJN,SAAU,OACVtC,MAAO,iBACPwV,YAAa,QAEjBC,WAAY,CACR,OAAQ,CACJnT,SAAU,OACVjD,OAAQ,SAGhBqW,UAAW,CACPC,SAAU,UCoClB,GArC6B,IAAwD,IAAvD,MAAC9R,EAAD,SAAQ+R,EAAR,cAAkBC,EAAlB,UAAiCtU,GAAsB,EACjF,MAAMT,EAASjB,KACT2M,GAAUF,EAAAA,EAAAA,UACZ,KACIzH,EAAAA,EAAAA,OACIqL,EAAAA,EAAAA,MAAI,QAAC,MAAC0C,EAAD,IAAQzD,GAAT,QAAmB,CAACyD,MAAAA,EAAO/O,MAAOsL,OACtCa,EAAAA,EAAAA,QAAO,CAAC,CAACnM,MAAO,GAAI+O,MAAO3R,IAAAA,KAAU,gBAFzC4D,CAGEgR,IACN,CAACA,IAGL,OACI,yBAAKtU,UAAWA,GACZ,kBAACuU,GAAA,EAAD,CACIC,cAAY,EACZC,kBAAgB,EAChB7U,QAAS,CACLyB,OAAQ9B,EAAO8B,QAEnBqT,eAAgB,CACZ9U,QAAS,CACLC,KAAMN,EAAO4U,YAGrBQ,UAAW,CACP/U,QAAS,CACLgV,KAAMrV,EAAO2U,aAGrB5R,MAAOA,GAAS,GAChB2I,QAASA,EACToJ,SAAW/R,GAAkB+R,EAAS/R,GAAS,UC3ClDhE,IAAYC,EAAAA,GAAAA,aAAYC,IAAD,CAChCqW,OAAQ,CACJ/W,OAAQ,OACR6C,UAAW,aACXmU,aAAc,QAElBrV,MAAO,CACHsB,SAAU,QAEdmO,MAAO,CACHnO,SAAU,OACVtC,MAAOD,EAAME,QAAQwK,KAAK6L,UAC1BvU,WAAY,EACZY,YAAa,OAEjB4T,qBAAsB,CAClBtK,OAAQ,kBACRuK,SAAU,cC6ElB,IAAetR,EAAAA,EAAAA,OA/DkB,IAcpB,IAdqB,MAC9BuL,EAD8B,iBAE9BgG,EAF8B,gBAG9BC,EAH8B,YAI9BC,EAJ8B,gBAK9BC,EAL8B,oBAM9BnC,EAN8B,qBAO9BoC,EAP8B,cAQ9BhB,EAR8B,gBAS9BiB,EAT8B,WAU9BzJ,EAV8B,mBAW9B0J,EAX8B,aAY9BC,EAZ8B,qBAa9BC,GACS,EACT,MAAMnW,EAASjB,KAETqX,GAAe5K,EAAAA,EAAAA,UAAiC,IAC3C,CACH,CACIvB,SAAUsC,EACV5C,KAAMxJ,IAAAA,KAAU,qBAChBJ,QAASkW,EACTjM,GAAI,aAER,CACIC,SAAUiM,EACVvM,KAAMxJ,IAAAA,KAAU,+BAChBJ,QAASoW,EACTnM,GAAI,kBAGb,CAACiM,EAAoB1J,EAAY4J,EAAsBD,IAE1D,OACI,kBAACG,GAAA,EAAD,CAAiBnW,MAAOC,IAAAA,KAAU,iBAAkBE,QAAS,CAACC,KAAMN,EAAOsV,OAAQpV,MAAOF,EAAOE,QAC5F6U,EAAchJ,OAAS,GACpB,kBAAC,GAAD,CACItL,UAAWT,EAAOyV,qBAClB1S,MAAO4Q,EACPmB,SAAUiB,EACVhB,cAAeA,IAGvB,kBAAC7J,GAAA,EAAD,CAAiB3M,OAAQ,GAAI4M,OAAQ,KACrC,kBAACb,GAAA,EAAD,CAAYgM,QAAQ,UAAU7V,UAAWT,EAAO2P,OACjC,IAAVA,EACKxP,IAAAA,KAAU,kBAAmB,CAAC+B,MAAOyN,IACrCxP,IAAAA,KAAU,mBAAoB,CAAC+B,MAAOyN,KAEhD,kBAAC4G,GAAA,EAAD,MACA,kBAACC,GAAA,EAAD,CAAcjM,MAAO6L,EAAc5L,OAAO,gCAC1C,kBAAC3K,GAAA,EAAD,CAAcC,QAAS6V,EAAkB5V,QAAS6V,IAClD,kBAAC1K,GAAA,EAAD,CAAiB3M,OAAQ,GAAI4M,OAAQ,IACrC,kBAACsL,GAAA,EAAD,CACIZ,YAAaA,EACbC,gBAAiBA,EACjBE,gBAAiBA,Q,oDCxF1B,MAAMU,GAAyBC,KACjCC,EAAAA,EAAAA,KAAeD,MAAAA,OAAD,EAACA,EAAYhI,aAAciI,EAAAA,EAAAA,KAAeD,MAAAA,OAAD,EAACA,EAAYvK,Q,mDCDlE,MAAMrN,IAAYC,EAAAA,GAAAA,aAAYC,IAAD,CAChC4X,SAAU,CACN/V,QAAS,OACTC,WAAY,SACZxC,OAAQ,OACRD,MAAO,OACPkD,SAAU,OACVtC,MAAOD,EAAME,QAAQwK,KAAK6L,UAC1BsB,WAAY,4EAEhBC,QAAS,CACLvV,SAAU,OACVkU,SAAU,SACVsB,aAAc,cAElBC,gBAAiB,CACbC,QAAS,IAEbC,eAAgB,CACZvX,QAAS,mBACT,eAAgB,CACZwX,cAAe,SAGvBC,WAAY,CACRvW,QAAS,OACTC,WAAY,aACZnB,QAAS,QAEb0X,aAAc,CACV5X,UAAW,aACXyL,OAAQ,uBAEZoM,qBAAsB,CAClB7B,SAAU,UACV,UAAW,CACP1N,QAAS,KACTzI,SAAU,WACViY,gBAAiB,qBACjBC,OAAQ,6BACRC,aAAc,MACdpZ,MAAO,OACPkB,MAAO,EACPC,OAAQ,EACRlB,OAAQ,QAEZ,UAAW,CACPmZ,aAAc,MACdhC,SAAU,WAGlBiC,YAAa,CACTzY,MAAOD,EAAME,QAAQC,QAAQC,KAC7BuY,eAAgB,OAChB9P,WAAY,KAEhB+P,kBAAmB,CACfjY,QAAS,sBACTV,MAAO,oBAEX4Y,kBAAmB,CACflW,WAAY,QAEhBmR,YAAa,CACTnR,WAAY,aCjDpB,IAAemW,EAAAA,GAAAA,IAXW1Z,IACtB,MAAM2B,EAASjB,MACT,YAACgU,GAAe1U,MAAAA,OAAhB,EAAgBA,EAAO2Z,aAC7B,OACI,yBAAKvX,UAAWT,EAAO6W,UACnB,kBAACoB,GAAA,QAA4B5Z,GAC7B,kBAAC6Z,GAAA,EAAD,CAAiBnF,YAAaA,EAAatS,UAAWT,EAAO+S,kB,2ECazE,MA8BA,GA9B8B,IAAwE,IAAtEhQ,OAAO,OAACqJ,EAAD,WAAS+L,EAAT,SAAqBxJ,GAA7B,mBAAwCyJ,GAA+B,EAClG,MAAMpY,EAASjB,KACTsZ,GAAmBxL,EAAAA,EAAAA,aAAYyL,EAAAA,GAAAA,UAAAA,cACrC,OACI,yBAAK7X,UAAWyC,IAAAA,CAAWlD,EAAOqX,WAAYkB,GAAAA,IAC1C,kBAACC,GAAA,EAAD,CACI/X,UAAWyC,IAAAA,CAAWlD,EAAOsX,aAAc,CAAC,CAACtX,EAAOuX,sBAAuBa,IAC3ED,WAAYA,IAEhB,kBAACM,GAAA,EAAD,CACI1V,OAAO2V,EAAAA,EAAAA,KAAoB,CAACrK,IAAKjC,EAAO0D,UAAWE,WAAY5D,EAAO4D,aACtEvP,UAAWT,EAAO2X,cAEjBgB,EAAAA,EAAAA,KAASvM,EAAOuL,cAErB,yBAAKlX,UAAWT,EAAO8X,kBAAmB/X,QAAUoK,GAAMA,EAAEyO,mBACxD,kBAACC,GAAA,EAAD,CACIxK,IAAKM,EAASmK,YACdC,mBAAmBC,EAAAA,EAAAA,KAAwBC,EAAAA,IAAAA,SAAmC,CAC1EnJ,UAAWuI,EACX1B,WAAY,CAAChI,SAAAA,EAAUvC,OAAAA,KAE3B8M,WAAYD,EAAAA,IAAAA,SACZE,qBAAmB,O,gBClCvC,MAeA,GAf2B,IAA8D,IAA7D,WAACC,EAAYrW,OAAO,WAACsW,EAAD,eAAaC,IAA4B,EACrF,MAAMtZ,EAASjB,KAEf,OACI,yBAAK0B,UAAWT,EAAO6X,kBAAmB9X,QAAUoK,GAAMA,EAAEyO,mBACxD,kBAAC,KAAD,CACI/J,IAAKuK,EAAW9G,eAChBlG,OAAQ,CAACiN,WAAAA,GACTE,UAAWD,EACXE,WAAW,M,gBCb3B,MASA,GATiC,IAAsD,IAArD,MAACzW,EAAOqW,YAAY,mBAACrH,IAAgC,EACnF,MAAM/R,EAASjB,KACf,OACI,yBAAK0B,UAAWT,EAAOmX,gBACnB,kBAACsC,GAAA,EAAD,CAAe1W,MAAOA,EAAOgP,mBAAoBA,M,yHCL7D,MAAM2H,IAA0B3V,EAAAA,EAAAA,OAAK4V,EAAAA,EAAAA,OAAM,MAAMC,EAAAA,EAAAA,OAAM,EAAGC,EAAAA,IA0CpDC,GAA2BrU,IAC7B,GAAIA,EAASsU,WAAW,uBAAwB,CAC5C,MAAMC,EAAWN,GAAwBjU,GACzC,OAAOuU,EAASjO,OAAS,EAAIiO,EAASJ,MAAM,GAAI,GAAK,KAErD,OAAO,MAITK,GAAwBxU,IAC1B,OAAQA,GACJ,IAAK,eACD,OAAOyU,GACX,IAAK,sBACD,OAAOC,GACX,QACI,OAAOC,KAabC,IAA2BjL,EAAAA,EAAAA,MATAgK,G,+UAAD,EAC5B/G,UAAU,EACViI,WAAW,GACRlB,EAHyB,CAI5BmB,iBAAkBC,GAClBC,WAAYX,GAAwBV,EAAWpP,IAC/C0Q,qBAAsBT,GAAqBb,EAAWpP,QAYpD2Q,IAAyBpL,EAAAA,EAAAA,MAAK,CAChC,EAACqL,EAAAA,EAAAA,QAAO,CAAC,aAAc,MAAO,uBARI,IAAwB,IAAvB,WAACxB,EAAD,KAAayB,GAAU,EAC1D,MAAMC,GAAkB/W,EAAAA,EAAAA,OAAKiD,EAAAA,EAAAA,MAAK,CAAC,SAAU,EAAG,eAAgB+T,EAAAA,OAAQhP,EAAAA,OAAhDhI,CAAwD8W,GAChF,OAAOC,EAAkB1B,EAAW9G,eACF,GAA5B8G,EAAW9G,eAAsB,GACf,GAAlBwI,EAAuB,KAK7B,CAAC7K,EAAAA,EAAG+K,GAAAA,K,mNC/ER,MAWA,GAXwB,IAAqD,IAApD,KAACH,EAAD,kBAAOI,GAA6C,EAAvBvT,E,kXAAuB,iCACzE,MAAM1H,EAASjB,KACf,OACI,yBAAK0B,UAAWyC,IAAAA,CAAWlD,EAAO+W,QAAS,CAAC,CAAC/W,EAAOiX,iBAAkBvP,EAAW0Q,sBAC5EyC,EAAKE,OAAO3L,KAAI,CAACrM,EAAOmY,IACrB,kBAACD,EAAD,IAAmBE,IAAKD,EAAOnY,MAAOA,GAAW2E,Q,uFCf1D,MAAM3I,IAAYC,EAAAA,GAAAA,aAAYC,IAAD,CAChCwK,SAAU,CACN5B,UAAW,OACX3I,MAAOD,EAAME,QAAQwK,KAAK6L,WAE9B9L,SAAU,CACNxK,MAAOD,EAAME,QAAQwK,KAAKvK,QAC1BoC,SAAU,OACVC,WAAY,OACZsG,cAAe,EACfnG,WAAY,QAEhBwZ,QAAS,CACLta,QAAS,OACTC,WAAY,SACZwU,aAAc,WCXhB8F,IAAsBC,EAAAA,GAAAA,GAAYpR,GAAAA,GAelCe,IAAmB1D,EAAAA,EAAAA,aAAW,CAAC,EAAmCC,KAAkC,IAArE,KAACsC,EAAD,YAAOC,EAAcwR,EAAAA,IAAgD,EACtG,MAAMvb,EAASjB,MACT,KAAC8L,EAAD,SAAOtB,EAAP,KAAiBI,EAAjB,QAAuB6R,EAAvB,QAAgCzb,GAAW+J,EAMjD,OACI,kBAACuR,GAAD,CACItQ,aAAcyQ,EACdC,iBAAiB,EACjBpb,QAAS,CAACC,KAAMN,EAAOyJ,UACvB1J,QAVaoK,IACjBJ,IACAhK,EAAQoK,IASJZ,SAAUA,EACV/B,IAAKA,GAEJqD,EACD,kBAACP,GAAA,EAAD,CAAYjK,QAAS,CAACC,KAAMN,EAAO0J,WAAYC,OAI3DsB,GAAiB9G,YAAc,mBAE/B,YCgDA,GAxEsC,IAMzB,IAN0B,cACnCuX,EACA/E,YAAY,OAACvK,EAAD,SAASuC,GAFc,WAGnCgN,EAAaJ,EAAAA,GAHsB,YAInCxR,EAAcwR,EAAAA,GAJqB,SAKnCK,GACS,EACT,MAAM5b,EAASjB,KAETgO,GAAWF,EAAAA,EAAAA,aAAYyL,EAAAA,GAAAA,UAAAA,aAEvBuD,GAAsB9X,EAAAA,EAAAA,OACxB0J,EAAAA,EAAAA,MAAK,iBACLqO,EAAAA,EAAAA,KAAgB/O,IAChBgP,EAAAA,EAAAA,KAAwBC,EAAAA,IAAAA,QAHAjY,CAI1B4K,GAEIsN,GAAaP,GAAiBG,GAE7BK,EAAiBC,IAAsBzP,EAAAA,EAAAA,WAAS,GAEjD0P,EAAyB,IAAMD,GAAmB,GAElDna,EAAU,CACZ,CACIuH,UAAW0S,EACXtS,KAAMxJ,IAAAA,KAAU,UAChB0K,KAAM,kBAACwR,GAAA,EAAD,MACNb,QAASS,EAAY,KAAO9b,IAAAA,KAAU,wCACtCJ,QATuB,IAAMoc,GAAmB,KAalDG,GAAkB3Z,EAAAA,EAAAA,cAAY,KAC3BuZ,GACDnS,MAEL,CAACmS,EAAiBnS,IAGrB,OACI,yBAAKtJ,UAAWT,EAAOob,SACnB,kBAAC3Q,GAAA,EAAD,CACIQ,iBAAkBA,GAClBT,OAAQ,8BACRE,gBAAiB6R,GAAAA,EACjB3R,YAAa,CACTC,KAAM2R,GAAAA,EACNjc,KAAM,KAEVyK,UAAWhJ,EACX2Z,WAAYA,EACZ5R,YAAauS,IAEjB,kBAACG,GAAA,EAAD,CACInU,KAAM4T,EACNhc,MAAOC,IAAAA,KAAU,iDAAkD,CAC/D2R,OAnBcnI,GAmBcgP,EAAAA,EAAAA,KAASvM,EAAOuL,aAnBZhO,EAAKoC,OAAS,GAAM,GAAEpC,EAAK+S,UAAU,EAAG,SAAW/S,KAqBvF3B,QAAS7H,IAAAA,KACL,4JAGJwI,QAAQ5E,EAAAA,EAAAA,MAAKqY,EAAwBrS,EAAa6R,GAClDnT,WAAW1E,EAAAA,EAAAA,MAAKqY,EAAwBrS,GACxCnB,YAAazI,IAAAA,KAAU,UACvBuI,eAAgBvI,IAAAA,KAAU,aA5BRwJ,IAAAA,GCzDrB5K,IAAYC,EAAAA,GAAAA,YAAW,CAChC2d,eAAgB,CACZC,KAAM,EACNlH,SAAU,SACV5U,QAAS,OACT+b,OAAQ,GAEZC,8BAA+B,CAC3Bxe,MAAO,OACPye,cAAe,kBAEnBC,oBAAqB,CACjBzd,SAAU,WACV0d,IAAK,mBACLzd,MAAO,EACPud,cAAe,OAEnBG,cAAe,CACX5e,MAAO,OACPC,OAAQ,S,mNCahB,MA8GA,IAAe6F,EAAAA,EAAAA,OA9GY,IAYd,IAZe,SACxB2I,EADwB,YAExB2D,EAFwB,YAGxBmF,EAHwB,QAIxBhQ,EAJwB,OAKxBsX,EALwB,QAMxBjX,EANwB,SAOxBkX,EAPwB,WAQxBC,EARwB,SASxBC,EATwB,SAUxB1B,EAVwB,SAWxB2B,GACS,EACT,MAAMvd,EAASjB,KAETye,GAAgBhS,EAAAA,EAAAA,UAClB,INZsB,EAC1BuB,EACA8I,EACAnF,KAEQA,GAAe,IAAItB,KAAKuH,IAC5B5S,EAAAA,EAAAA,OACIqC,EAAAA,EAAAA,SAAO,CAACC,EAAD,SAAM,GAAC2D,GAAP,SAAelD,EAAAA,EAAAA,OAAMkD,EA/BV,EAAC+C,EAAD,EAAqDtH,KAAqB,IAArD,OAAC2G,EAAD,SAASuC,GAA4C,EACpG,OAAQlJ,GACJ,IAAK,eACD,MAAO,CAAC2G,OAAAA,EAAQ+L,YAAYsF,EAAAA,EAAAA,KAAc1Q,EAAUX,EAAO+L,YAAaxJ,SAAAA,GAC5E,IAAK,gBACD,OAAOA,EAAS+O,aACpB,IAAK,iBACD,OAAO/O,EAASgP,cACpB,IAAK,gCACD,OAAOhP,EAASiP,UACpB,IAAK,8BACD,OAAOjP,EAASkP,QACpB,IAAK,sBACD,MAAO,CACHxE,WAAY1K,EAASmP,OAAOzE,WAC5BC,gBAAgBwC,EAAAA,EAAAA,KAAgB/O,EAAU4B,EAAS+O,cAAcrE,YAEzE,QAEI,MAtBuB,EAACW,EAAUrL,KAC1C5K,EAAAA,EAAAA,OAAKiD,EAAAA,EAAAA,MAAK,CAAC,SAAU,gBAAgB+W,EAAAA,EAAAA,KAA2B/D,GAAhEjW,CAA2E4K,GAqB5DqP,CADUtE,GAAwBjU,GACGkJ,KAYZsP,CAAsBlR,EAAU4J,EAAY3M,GAAK3D,KAAM,KACvFS,EAAAA,EAAAA,OAAM,WAAY6P,GAFtB5S,CAGE8R,KMGIqI,CAAsBnR,EAAU8I,EAAanF,IACnD,CAAC3D,EAAU2D,EAAamF,IAEtBsI,GAAmB3S,EAAAA,EAAAA,UAAQ,IAAM6O,GAAyBxE,IAAc,CAACA,KAEzE,wBAACuI,EAAD,oBAA0BC,IAAuBC,EAAAA,GAAAA,KACjDC,GAAmB5b,EAAAA,EAAAA,cAAYqR,EAAAA,EAAAA,QAAOoK,EAAyBzD,IAAyB,CAC1FyD,EACAzD,MAEG6D,EAAeC,IAAoB/R,EAAAA,EAAAA,UAAiB,MAErDgS,GAAgB/b,EAAAA,EAAAA,cACjBtE,IACG,MAAM+Z,EAAqB1B,GAAsBrY,EAAMsgB,SAASC,UAChE,OACI,kBAACC,GAAA,EAAD,IAAkBC,eAAgBT,GAAyBhgB,GACvD,kBAAC,GAAD,MAAqBA,EAArB,CAA4B+Z,mBAAoBA,QAI5D,CAACiG,KAGEU,EAAmBC,IAAwBtS,EAAAA,EAAAA,WAAS,GAErDuS,GAAwBtc,EAAAA,EAAAA,cAAY,IAAMqc,GAAqB,IAAO,IACtEE,GAAyBvc,EAAAA,EAAAA,cAAY,KACvC8b,EAAiB,MACjBO,GAAqB,KACtB,IAEGG,GAAaxc,EAAAA,EAAAA,cACdyc,GAAaX,GAAkBY,GAAuBN,EAAoBM,EAAoBD,KAC/F,CAACL,IAGCO,GAAyB9T,EAAAA,EAAAA,UAAQ,KACnC,MAAMmL,EAA0C,MAAjB6H,EAAwBhB,EAAcgB,GAAeI,SAAW,KACzFxG,EAAqB1B,GAAsBC,GAEjD,OACIA,GACI,oCACI,kBAAC1W,GAAA,EAAD,CACIkb,IAAKxE,EAAWhI,SAASmK,YACzBxQ,MAAOyW,GAAqB3G,EAC5BlY,MAAOC,IAAAA,KAAU,aAEjB,yBAAKM,UAAWT,EAAOkd,iBAE3B,yBAAKzc,UAAWT,EAAOgd,qBACnB,kBAAC,GAAD,CACItB,cAAe6B,EACf5G,WAAYA,EACZgF,WAAYsD,EACZlV,YAAamV,EACbtD,SAAU,IAAMA,EAASjF,EAAWhI,SAASmK,mBAMlE,CAACiG,EAAmBnD,EAAU4B,EAAegB,IAEhD,OACI,yBAAK/d,UAAWT,EAAO2c,gBACnB,kBAAC4C,GAAA,EAAD,CACIC,gBAAgB,EAChB3J,YAAasI,EACbsB,SAAUjC,EACV3X,QAASA,EACTsX,OAAQA,EACRjX,QAASA,EACTkX,SAAUA,EACVsC,mBAAoB,IACpBC,sBAAuB,IACvBC,cAAe,GACfrB,iBAAkBA,EAClBG,cAAeA,EACfrB,WAAYA,EACZ7V,IAAK8V,EACLuC,mBAAmB,EACnBrB,cAAeA,EACfW,WAAYA,EACZG,uBAAwBA,EACxBjf,QAAS,CACLyc,8BAA+B9c,EAAO8c,qC,4KChInD,MCPM/d,IAAYC,EAAAA,GAAAA,aAAW,KAAM,CACtC8gB,SAAU,CACN,QAAS,CACLC,UAAW,OAEf5U,OAAQ,OACR0J,SAAU,a,yHCiBlB,MAwDA,IAAezQ,EAAAA,EAAAA,OAxDK,IAOP,IAPQ,SACjBmZ,EADiB,SAEjB5O,EAFiB,SAGjB5B,EAHiB,uBAIjBiT,EAJiB,kBAKjBC,EALiB,gBAMjBC,GACS,EACT,MAAMlgB,EAASjB,KAET2e,GAA8B5B,EAAAA,EAAAA,KAAgB/O,EAAU4B,EAASlI,MAEjEgZ,GAAWjU,EAAAA,EAAAA,UACb,IF7B0B,SAACmD,GAAiF,IAA7DqR,EAA6D,uDAAnB,GAC7F,OAAOjc,EAAAA,EAAAA,OACHmQ,EAAAA,EAAAA,QAAO,GAAI,eACX9E,EAAAA,EAAAA,MAAItI,EAAAA,EAAAA,OAAM,YAAa,YACvBqZ,EAAAA,GAAAA,GAAiCxR,EAASlI,KAAMuZ,GAH7Cjc,CAIL4K,GEwBQyR,CAAmBzR,EAAUqR,IACnC,CAACrR,EAAUqR,KAERK,EAAiBC,IAAsB5T,EAAAA,EAAAA,UAAmB,IAE3D6T,GAAe5d,EAAAA,EAAAA,cAChB6d,IACGP,EAAkB,CAACnQ,UAAWnB,EAASN,IAAKmS,YAAAA,MAEhD,CAACP,EAAmBtR,EAASN,MAG3BoS,GAAa9d,EAAAA,EAAAA,cACd+d,IACGR,E,+UAAgB,EAACpQ,UAAWnB,EAASN,KAAQqS,MAEjD,CAACR,EAAiBvR,EAASN,MAG/B,OACI,6BACKoR,EAASrQ,KAAI,IAAiC,IAAhC,OAACuR,EAAD,kBAASC,GAAuB,EAC3C,OACI,yBAAKzF,IAAKwF,EAAQlgB,UAAWT,EAAO8f,UAChC,kBAACe,GAAA,EAAD,CACIF,OAAQA,EACRC,kBAAmBA,EACnBE,SAAUT,EAAgB3a,SAASib,GACnCI,uBAAuBC,EAAAA,EAAAA,KAAsBtD,IAAiBH,EAC9D0D,yBAAyBC,EAAAA,EAAAA,KAAwBxD,IAAiBH,EAClE4D,OAAQV,EACR7E,SAAU2E,EACVa,iBAAkB,KACdd,GAAmBnR,EAAAA,EAAAA,SAAOzJ,EAAAA,EAAAA,UAASib,IAAS/M,EAAAA,EAAAA,SAAQ,CAAC+M,KAAUU,EAAAA,EAAAA,QAAOV,gB,gBCrE/F,MAAM5hB,IAAYC,EAAAA,GAAAA,aAAYC,IAAD,CAChCqW,OAAQ,CACJxU,QAAS,OACTsG,cAAe,MACfrG,WAAY,SACZnB,QAAS,YACT0hB,aAAc,iCAElBphB,MAAO,CACH4H,WAAY,IACZtG,SAAU,OACVC,WAAY,OACZsG,cAAe,SACf7I,MAAOD,EAAME,QAAQwK,KAAKvK,QAC1BwC,WAAY,QAEhB2f,KAAM,CACFriB,MAAOD,EAAME,QAAQwK,KAAK6L,UAC1B1U,QAAS,OACTsG,cAAe,MACfrG,WAAY,SACZygB,UAAW,aACXrW,OAAQ,iBAEZsW,SAAU,CACN7f,WAAY,MACZJ,SAAU,OACVC,WAAY,QAEhB2Z,QAAS,CACLta,QAAS,OACTlB,QAAS,eAEb8hB,YAAa,CACTlgB,SAAU,OACVsG,WAAY,IACZrG,WAAY,QAEhBoJ,KAAM,CACFrJ,SAAU,OACVK,YAAa,OAEjB8f,OAAQ,CACJjN,YAAa,GACbvJ,OAAQ,OACR0J,SAAU,QACVzT,UAAW,aACX8G,aAAc,OAElByU,eAAgB,CACZtb,UAAW,OACXugB,UAAW,SACXlN,YAAa,OACba,aAAc,WC7BhBsM,IAAoBvG,EAAAA,GAAAA,GAAYhS,GAAAA,GAyEtC,IAAelF,EAAAA,EAAAA,OA7DK,IAQP,IARQ,UACjB3D,EADiB,SAEjB8c,EAFiB,SAGjB5O,EAHiB,uBAIjBqR,EAJiB,eAKjB8B,EALiB,kBAMjB7B,EANiB,gBAOjBC,GACS,EACT,MAAMlgB,EAASjB,KAETgO,GAAqBF,EAAAA,EAAAA,aAAYyL,EAAAA,GAAAA,UAAAA,aACjCoF,GAA8B5B,EAAAA,EAAAA,KAAgB/O,EAAU4B,EAASlI,OAEhEsb,EAAYC,IAAiBtV,EAAAA,EAAAA,WAAS,GACvCuV,GAASC,EAAAA,EAAAA,KAAwBxE,KAAkBH,EAEzD,OACI,yBAAK9c,UAAWA,GACZ,yBAAKA,UAAWT,EAAOsV,QACnB,0BAAM7U,UAAWT,EAAOE,OAAQC,IAAAA,KAAU,YAE9C,yBAAKM,UAAWT,EAAOob,SACnB,kBAACyG,GAAD,CACI3iB,MAAM,UACNuc,iBAAiB,EACjBlS,UAAW0Y,EACXlX,aAAckX,EAAS,KAAO9hB,IAAAA,KAAU,+CACxCJ,QAAS,IAAMiiB,GAAc,IAE7B,kBAACG,GAAA,EAAD,CAAS1hB,UAAWT,EAAO6K,OAC3B,yBAAKpK,UAAWT,EAAO0hB,aAAcvhB,IAAAA,KAAU,gBAGvD,yBAAKM,UAAWT,EAAOuhB,MACnB,kBAACa,GAAA,EAAD,CAAU3hB,UAAWT,EAAO6K,OAC5B,0BAAMpK,UAAWT,EAAOyhB,UACnBthB,IAAAA,KAAU,oEAGnB,yBAAKM,UAAWT,EAAO2c,gBAClBoF,GACG,kBAACM,GAAA,EAAD,CACI5hB,UAAWT,EAAO2hB,OAClBW,MAAQC,GAAcT,EAAe,CAAC1V,OAAQuC,EAAU4T,UAAAA,IACxDxZ,QAAS,IAAMiZ,GAAc,KAGrC,kBAAC,GAAD,CACIzE,SAAUA,EACVxQ,SAAUA,EACV4B,SAAUA,EACVqR,uBAAwBA,EACxBC,kBAAmBA,EACnBC,gBAAiBA,S,gEC1F9B,MAAMnhB,IAAYC,EAAAA,GAAAA,aAAYC,IAAD,CAChCujB,WAAY,CACR5F,KAAM,WACNlH,SAAU,SACV+M,SAAU,SAEdC,qBAAsB,CAClB5hB,QAAS,OACTC,WAAY,SACZ2U,SAAU,UAEdiC,YAAa,CACTlW,WAAY,MACZsG,cAAe,SACf7I,MAAOD,EAAME,QAAQwK,KAAKvK,SAE9BujB,SAAU,CACNnhB,SAAU,OACVtC,MAAOD,EAAME,QAAQwK,KAAK6L,UAC1B5T,WAAY,OAEhBghB,YAAa,CACTzX,OAAQ,QACR0J,SAAU,SAEdgO,gBAAiB,CACb9C,UAAW,WCOnB,GAvBmB,IAAqB,IAApB,OAAC3T,GAAmB,EACpC,MAAMpM,EAASjB,KACT+S,GAAQ6G,EAAAA,EAAAA,KAASvM,EAAO0F,OAC9B,OACI,yBAAKrR,UAAWT,EAAOwiB,YACnB,yBAAK/hB,UAAWT,EAAO0iB,sBACnB,kBAACI,GAAA,EAAD,CAAsB/f,MAAO+O,GACzB,kBAACxH,GAAA,EAAD,CAAYgM,QAAQ,KAAK7V,UAAWT,EAAO2X,YAAaoL,QAAM,GACzDjR,IAGT,kBAACkR,GAAA,EAAD,CACI9iB,MAAO,kBAAC+iB,GAAA,EAAD,CAAaxiB,UAAWT,EAAO4iB,YAAaxW,OAAQA,IAC3D8W,UAAW,SAEX,kBAACd,GAAA,EAAD,CAAU3hB,UAAWT,EAAO2iB,aAGpC,kBAACQ,GAAA,EAAD,CAAiB1iB,UAAWT,EAAO6iB,gBAAiBzW,OAAQA,EAAQ7L,KAAM,aC5BzExB,IAAYC,EAAAA,GAAAA,aAAYC,IAAD,CAChCqB,KAAM,CACFW,WAAY,EACZyU,SAAU,SACVpX,MAAO,SAEXwT,MAAO,CACH5S,MAAOD,EAAME,QAAQwK,KAAK6L,UAC1BhU,SAAU,YCsBlB,GArB0B,IAAuB,IAAtB,SAACmN,GAAqB,EAC7C,MAAM3O,EAASjB,MACT,UAACqkB,EAAD,cAAYzF,GAAiBhP,EACnC,OACI,yBAAKlO,UAAWT,EAAOM,MACnB,kBAACwiB,GAAA,EAAD,CAAsB/f,MAAO4a,GACzB,kBAACrT,GAAA,EAAD,CAAYgM,QAAS,YAAa7V,UAAWT,EAAO8R,MAAOuR,MAAO,SAAUN,QAAM,GAC7EpF,IAGT,yBAAKrf,MAAM,MAAMC,OAAO,KAAKI,KAAK,QAAQ2kB,YAAY,OACnC,QAAdF,GAAuB,6BAASG,OAAO,6CACzB,kBAAdH,GACG,6BAASG,OAAO,iEAEL,OAAdH,GAAsB,6BAASG,OAAO,kD,wCCxBhD,MAAMxkB,IAAYC,EAAAA,GAAAA,aAAW,KAAM,CACtCsB,KAAM,CACF,sBAAuB,CACnBkjB,WAAY,YAGpBC,WAAY,CACRD,WAAY,SACZ5hB,WAAY,MACZsG,aAAc,OAElBN,MAAO,CACHtJ,MAAO,QACPmZ,OAAQ,+BACRC,aAAc,MACdtW,UAAW,aACXsU,SAAU,cC0DlB,GA9DqB,IAA+C,IAA9C,MAAC3S,EAAQ,KAAT,SAAe+R,EAAf,SAAyByI,GAAqB,EAChE,MAAMvd,EAASjB,KACTyI,GAAMyJ,EAAAA,EAAAA,WAELyS,EAAYC,IAAiBjX,EAAAA,EAAAA,WAAS,GAEvCkX,EAAc,IAAMD,GAAc,IAEjCE,EAAaC,IAAkBpX,EAAAA,EAAAA,UAAS3J,GAEzCghB,EAAuB,KACrBF,IAAgB9gB,GAChB+R,EAAS+O,GAEbD,KAQJ,OACI,0BAAMpc,IAAKA,EAAK/G,UAAWT,EAAOM,MAC7ByC,IAASihB,EAAAA,EAAAA,KAAWjhB,GACrB,kBAACwZ,GAAA,EAAD,CACIhT,SAAUgU,EACV1S,KAAMoZ,GAAAA,EACN1jB,KAAM,MACNE,UAAWT,EAAOyjB,WAClB1jB,QAzBO,IAAM4jB,GAAc,KA2B/B,kBAACO,GAAA,GAAD,CACI7jB,QAAS,CAACuH,MAAO5H,EAAO4H,OACxBU,KAAMob,EACNS,SAAU3c,EAAI0J,QACdkT,aAAc,CAACC,SAAU,MAAOC,WAAY,QAC5CC,gBAAiB,CAACF,SAAU,GAAIC,WAAY,IAC5CE,QArBK9D,IACK,UAAdA,EAAMvF,IAAiB4I,IACJ,WAAdrD,EAAMvF,KAAkByI,KAoBzBa,gBAAiBV,GAEjB,kBAACW,GAAA,EAAD,CACI5S,WAAO9C,EACPjM,MAAO8gB,GAAe,IAAIc,KAAKd,GAC/B/O,SAAW/R,GAAU+gB,EAAe/gB,GAASA,EAAM6hB,WACnDC,UAAW,CACPjQ,UAAW,CACPrU,KAAM,QACNukB,aAAa,EACbC,WAAY,CACRvb,WAAW,EACX0L,kBAAkB,EAClB8P,WAAW,UChE9BjmB,IAAYC,EAAAA,GAAAA,aAAYC,IAAD,CAChCgmB,aAAc,CACVhkB,WAAY,EACZE,UAAW,sCACXvB,QAAS,aAEbslB,qBAAsB,CAClBhO,QAAS,GACTJ,WAAY,6BAEhBqO,QAAS,CACLrkB,QAAS,OACTC,WAAY,SACZqkB,IAAK,OACLld,aAAc,QAElBmd,SAAU,CACNvkB,QAAS,OACTskB,IAAK,OACLxjB,WAAY,QAEhB0jB,YAAa,CACTxkB,QAAS,OACTskB,IAAK,OACLxjB,WAAY,OACZme,UAAW,OACX7gB,MAAOD,EAAME,QAAQwK,KAAK6L,UAC1BhU,SAAU,QAEd+jB,YAAa,CACTrmB,MAAOD,EAAME,QAAQwK,KAAKvK,QAC1B6B,WAAY,EACZY,YAAa,OAEjB2jB,iBAAkB,CACd1kB,QAAS,OACT4U,SAAU,SACV,SAAU,CACNA,SAAU,SACV+P,aAAc,WACdC,WAAY,WAGpBC,aAAc,CACV1kB,WAAY,GAEhB6W,kBAAmB,CACfjW,YAAa,Y,2cCnBrB,MA8DA,IAAeuC,EAAAA,EAAAA,OA9DU,IAA6F,IAA5F,SAACmZ,EAAD,OAAWnR,EAAX,WAAmBuK,EAAnB,eAA+BiP,EAA/B,SAA+ChK,EAA/C,uBAAyDiK,GAAmC,EAClH,MAAMzN,EAAqB1B,GAAsBC,GAC3C3W,EAASjB,KACf,OACI,yBACI0B,UAAWyC,IAAAA,CAAWlD,EAAOilB,aAAc1M,GAAAA,EAAoC,CAC3E,CAACvY,EAAOklB,sBAAuB9M,IAEnC,iBAAe,6BAEf,yBAAK3X,UAAWT,EAAOmlB,SACnB,kBAAC5I,GAAA,EAAD,CAAiB1R,KAAMib,GAAAA,EAAevlB,KAAM,IAAKR,QAAS,IAAM6lB,MAChE,kBAACtb,GAAA,EAAD,CAAYgM,QAAS,YAAaxV,QAAS,UACtCX,IAAAA,KAAU,0BAEf,kBAACoW,GAAA,EAAD,MACA,yBAAK9V,UAAWT,EAAO8X,mBACnB,kBAACe,GAAA,EAAD,CACIxK,IAAKsI,EAAWhI,SAASmK,YACzBC,mBAAmBC,EAAAA,EAAAA,KAAwBC,EAAAA,IAAAA,SAAmC,CAC1EnJ,UAAW1D,MAAAA,OAAF,EAAEA,EAAQiC,IACnBsI,WAAAA,IAEJuC,WAAYD,EAAAA,IAAAA,SACZE,qBAAmB,KAG3B,kBAAC,GAAD,CAAwBxC,WAAYA,EAAYiF,SAAUA,EAAUF,cAAe6B,KAEvF,yBAAK9c,UAAWT,EAAOqlB,UACnB,kBAAC,GAAD,CAAYjZ,OAAQA,IACpB,kBAAC,GAAD,CAAmBuC,SAAUgI,EAAWhI,WACxC,kBAAC,GAAD,CAAYvC,OAAM,MAAMuK,EAAWvK,OAAO0R,OAAxB,CAAgC9N,WAAY2G,EAAWvK,OAAO4D,gBAEpF,yBAAKvP,UAAWT,EAAOslB,aACnB,yBAAK7kB,UAAWT,EAAOwlB,kBACnB,0BAAM/kB,UAAWT,EAAOulB,aAAcplB,IAAAA,KAAU,uBAChD,kBAAC2iB,GAAA,EAAD,CAAsB/f,MAAO4T,EAAWhI,SAASgP,eAC7C,8BAAOhH,EAAWhI,SAASgP,iBAGnC,yBAAKld,UAAWT,EAAO2lB,cACnB,0BAAMllB,UAAWT,EAAOulB,aAAcplB,IAAAA,KAAU,gBAChD,kBAAC,GAAD,CACI4C,MAAO4T,EAAWhI,SAASiP,UAC3B9I,SAAW/R,GAAU8iB,EAAuB,YAAa9iB,GACzDwa,SAAUA,KAGlB,yBAAK9c,UAAWT,EAAO2lB,cACnB,0BAAMllB,UAAWT,EAAOulB,aAAcplB,IAAAA,KAAU,cAChD,kBAAC,GAAD,CACI4C,MAAO4T,EAAWhI,SAASkP,QAC3B/I,SAAW/R,GAAU8iB,EAAuB,UAAW9iB,GACvDwa,SAAUA,UChFrBwI,GAAoBC,IAC7BnV,QAAQmV,MAAMA,GACdC,EAAAA,EAAAA,SAAoB,CAChB/lB,MAAOC,IAAAA,KAAU,SACjB+lB,SAASC,EAAAA,EAAAA,KAAuBH,EAAO7lB,IAAAA,KAAU,4B,4BCNlD,MAAMpB,IAAYC,EAAAA,GAAAA,YAAW,CAChConB,YAAa,CACT7mB,SAAU,WACV0d,IAAK,EACLoJ,KAAM,EACN7mB,MAAO,EACPC,OAAQ,EACRiW,SAAU,UAEd4Q,OAAQ,CACJvJ,cAAe,QAEnBwJ,sBAAuB,CACnBC,SAAU,GAEdC,KAAM,CACFlnB,SAAU,WACV0d,IAAK,EACLoJ,KAAM,EACN7mB,MAAO,EACPC,OAAQ,EACRqB,QAAS,OACTsG,cAAe,SACfsO,SAAU,YCsKlB,IAAetR,EAAAA,EAAAA,OA9Ia,IASf,IATgB,OACzBgI,EADyB,WAEzBuK,EAFyB,eAGzBpR,EAHyB,QAIzBwD,EAJyB,mBAKzB2d,EALyB,mBAMzBC,EANyB,uBAOzBC,EAPyB,SAQzBrJ,GACS,EACT,MAAMvd,EAASjB,KACT8nB,ECxD0B,MAChC,MAAOC,EAAuBC,IAA4Bra,EAAAA,EAAAA,UAA0B,IAC9Esa,GAA6B/V,EAAAA,EAAAA,QAAO,IACpCgW,GAA6BtkB,EAAAA,EAAAA,cAC/BukB,EAAAA,EAAAA,MAAS,KACLH,EAAyB,IAAIC,EAA2B9V,YACzD,IACH,IAEEiW,GAA6BxkB,EAAAA,EAAAA,cAC9BykB,IACGJ,EAA2B9V,QAAUkW,EACrCH,EAA2BG,KAE/B,CAACH,IAGCI,GAA0B1kB,EAAAA,EAAAA,cAC5B,CAAC4f,EAA0B+E,KAClB/E,GAED4E,EADAG,EAC2B,CAAC/E,GAED,MAGnC,CAAC4E,KAGEI,EAAmBC,IAAwB9a,EAAAA,EAAAA,UAA0B,IAOtE+a,GAAuB9kB,EAAAA,EAAAA,cAAa4f,IACjCA,GACLiF,GAAsBE,IAAcC,OARJC,EAQ+B,CAACrF,GARTsF,EAQqBH,GAP5ExY,EAAAA,EAAAA,QACI0Y,EAAK/gB,QAAQihB,KAAmBC,EAAAA,EAAAA,MAAIC,EAAAA,EAAAA,KAAaF,GAAgBD,KACjEA,EAAKhhB,QAAQohB,KAAmBF,EAAAA,EAAAA,MAAIC,EAAAA,EAAAA,KAAaC,GAAgBL,MAHtC,IAACA,EAAuBC,OASxD,IAEH,MAAO,CACHf,uBAAuBtb,EAAAA,EAAAA,UACnB,IAAM,IAAIsb,KAA0BS,IACpC,CAACT,EAAuBS,IAE5BA,kBAAAA,EACAE,qBAAAA,EACAJ,wBAAAA,IDQiBa,IACdC,EAAUC,IAAe1b,EAAAA,EAAAA,WAzBb,KA0Bb2b,GAAuB1lB,EAAAA,EAAAA,cAAY,QAAC,eAAC2lB,GAAF,SAAsBF,EAAYE,KAAiB,KAErFC,EAAmBC,IAAwB9b,EAAAA,EAAAA,aAC3CF,EAAWC,IAAgBC,EAAAA,EAAAA,WAAS,GACrCoM,EAAcnC,EAAWhI,SAASmK,YAElC1L,GAAcC,EAAAA,GAAAA,KACdob,GAAS9lB,EAAAA,EAAAA,cAAY,IAAM8J,GAAa,IAAO,IAC/Cic,GAAW/lB,EAAAA,EAAAA,cAAY,IAAM8J,GAAa,IAAQ,IAClDkc,GAAmBhmB,EAAAA,EAAAA,cAAYoB,EAAAA,EAAAA,MAAK2iB,EAAoB+B,GAAS,KAChEG,EAASC,IAAkBrd,EAAAA,EAAAA,UAAQ,KACtC,MAAMod,EAAW5C,IACTA,EAAM8C,YAAcC,EAAAA,IAAAA,qBACpBhD,GAAiBC,GACjB6C,KACO7C,EAAM8C,YAAcC,EAAAA,IAAAA,iBAC3BhgB,EAAQid,IAERD,GAAiBC,GACjB0C,MAGFG,EAAiB,KACnBzb,GAAY4b,EAAAA,EAAAA,KAAYlQ,IACnB3I,MAAM8Y,IACHtC,GAAmBuC,EAAAA,EAAAA,WAAU,CAAC,WAAY,UAAWD,EAAatS,IAClE+R,OAEH9X,MAAMgY,IAEf,MAAO,CAACA,EAASC,KAClB,CAAClS,EAAY+R,EAAU/B,EAAoB5d,KAExC,eACFogB,EADE,cAEFC,EAFE,uBAGFC,EAHE,eAIFC,EAJE,kBAKFC,EALE,eAMFC,EANE,gBAOFC,EAPE,kBAQFC,EARE,uBASFC,IACAC,EAAAA,GAAAA,GAAkB,CAClBxd,OAAQuK,EAAWhI,SAASmP,OAC5B+L,SAAUhB,EACVD,QAAAA,EACAH,OAAAA,KAGE,aAACqB,EAAD,gBAAeC,EAAf,cAAgCC,IAAiBC,EAAAA,GAAAA,GAAoB,CACvEC,UAAWrB,EACXD,QAAAA,EACAH,OAAAA,IAGE5C,GAAyBljB,EAAAA,EAAAA,cAC3B,CAACwnB,EAAuBpnB,KACpB0lB,KACgB1lB,GACVqnB,EAAAA,EAAAA,KAA0B,CAACta,UAAWgJ,EAAaqR,cAAAA,EAAepnB,MAAAA,IAAQoN,MAAK,IAC7EwW,GAAmBuC,EAAAA,EAAAA,WAAU,CAAC,WAAYiB,GAAgBpnB,EAAO4T,OAEnE0T,EAAAA,EAAAA,KAA0B,CAACva,UAAWgJ,EAAaqR,cAAAA,IAAgBha,MAAK,IACtEwW,GAAmB2D,EAAAA,EAAAA,YAAW,CAAC,WAAYH,GAAgBxT,OAE3DxG,KAAKuY,GAAU9X,MAAMgY,KAEjC,CAACjS,EAAY8R,EAAQC,EAAUE,IAGnC,OACI,kBAACthB,GAAA,EAAD,CAAW7G,UAAWT,EAAOomB,aACzB,kBAAC,MAA8BS,EAC3B,kBAAC,GAAA0D,YAAD,CAAaC,QAASC,GAAAA,SAClB,kBAACC,GAAA,EAAD,MACA,kBAACC,GAAA,EAAD,CACIlqB,UAAWyC,IAAAA,CAAWlD,EAAOumB,sBAAuB,CAAC,CAACvmB,EAAOsmB,QAAS9Z,IACtEoe,YAAa,WACbrqB,KAAM4nB,EACN0C,QA5GD,IA6GCC,SA3GD,IA4GCC,aAAa,EACbjW,SAAUuT,GAEV,yBAAK5nB,UAAWT,EAAOymB,MACnB,kBAAC,GAAD,CACIlJ,SAAUA,EACVnR,OAAQA,EACRuK,WAAYA,EACZiP,eAAgB7c,EAChB6S,SAAU+M,EACV9C,uBAAwBA,IAE5B,kBAAC,KAAD,CAA4BmF,cAAe3B,GACvC,kBAAC4B,GAAA,EAAD,CACI1N,SAAUA,EACVnR,OAAQ+c,EACRC,cAAeA,EACf5c,UAAWA,EACX0e,MAAO5B,EACP6B,SAAU5B,EACVpI,OAAQsI,EACRnH,MAAOkH,EACP5N,SAAU8N,EACVC,uBAAwBA,EACxB3J,uBAAwBuI,EACxB6C,uBAAwB5C,EACxBjjB,eAAgBA,EAChBqhB,uBAAwBA,MAIpC,kBAAC,GAAD,CACIrJ,SAAUA,EACV9c,UAAWT,EAAOymB,KAClB9X,SAAUgI,EAAWhI,SAASmP,OAC9BkC,uBAAwBuI,EACxBzG,eAAgBgI,EAChB7J,kBAAmB8J,EACnB7J,gBAAiB8J,WEpLhCjrB,IAAYC,EAAAA,GAAAA,YAAW,CAChCqsB,kBAAmB,CACf9rB,SAAU,WACV0d,IAAK,EACLoJ,KAAM,EACN7mB,MAAO,EACPC,OAAQ,EACRmiB,UAAW,SACXvgB,UAAW,OACXiqB,WAAY,uCACZxqB,QAAS,OACTsG,cAAe,UAEnB,4BAA6B,CACzBkkB,WAAY,wCAEhB,iCAAkC,CAC9BA,WAAY,wCAEhB7E,KAAM,CACF3lB,QAAS,OACTsG,cAAe,SACfwV,KAAM,EACNlH,SAAU,SACVnW,SAAU,cC0VlB,IAAegsB,EAAAA,EAAAA,UATS,CAACpmB,EAAD,KAA2B,IAAlBgH,QAAQ,GAACnC,IAAS,EAC/C,MAAO,CACHoC,OAAQkM,EAAAA,GAAAA,UAAAA,UAA8BnT,GACtC4H,SAAUuL,EAAAA,GAAAA,UAAAA,YAAgCnT,GAC1CuL,YAAa4H,EAAAA,GAAAA,UAAAA,uBAA2CnT,EAAO6E,GAC/D2F,MAAO2I,EAAAA,GAAAA,UAAAA,iBAAqCnT,EAAO6E,MAI3D,EA3S0B,IASb,IATc,OACvBmC,EADuB,OAEvBC,EAFuB,SAGvBW,EAHuB,YAIvB2D,EAJuB,MAKvBf,EALuB,UAMvB6b,EANuB,cAOvBC,EAPuB,SAQvBlgB,GACS,EACT,MAAMvL,EAASjB,KACTue,GAAWrM,EAAAA,EAAAA,UAEXya,GAAa9b,EAAAA,EAAAA,KAAmBxD,IAE/BG,EAAYof,IAAiBjf,EAAAA,EAAAA,WAAS,IACtCwJ,EAAc0V,IAAmBlf,EAAAA,EAAAA,WAAS,IAE1CjG,KAAMolB,GAAiBzf,GAAU,KAEpC,eACI7G,EADJ,QAEIW,EAFJ,KAGI9D,EAHJ,YAIIE,EAJJ,QAKIuD,GALJ,oBAMI8N,GANJ,YAOImY,GAPJ,8BAQIC,KAEJ,cACIpnB,GADJ,cAEIE,GAFJ,aAGIC,GAHJ,WAIIE,GAJJ,kBAKIC,GALJ,WAMIF,GANJ,mBAOIuO,GAPJ,iBAQIE,GARJ,gBASID,KpC5ByB,KAAiE,IAAhE,eAACyY,EAAD,eAAiBC,EAAjB,mBAAiCC,GAA+B,EAClG,MAAMC,EAAY,CACd5mB,eAAgBymB,EAChB9lB,QAAS,KACTL,QAASomB,EACT7pB,KAAM,EACNE,YAAa4pB,EACbvY,oBAAqB,KACrBmY,YAAa,KACbvX,+BAAgC,GAChCwX,8BAA+B,OAE5B5mB,EAAOoG,IAAY6gB,EAAAA,EAAAA,aAAW,CAACjnB,EAAOqB,KACzC,OAAQA,EAAOC,MACX,KAAKyM,EAAsB,CACvB,MAAMmZ,EAAmB7lB,EAAOG,QAChC,OAAO5C,EAAAA,EAAAA,MACHuQ,GACAxN,EAAAA,EAAAA,OAAM,sBAAuBulB,GAC7BtY,EACAN,EAJG1P,CAKLoB,GAEN,KAAKgO,EAAmB,CACpB,MAAM,WAACmZ,EAAD,cAAaT,GAAiBrlB,EAAOG,QACrCpB,EAAiB+mB,EACjBxY,EAA6CwY,GAC7CnnB,EAAMI,eAEZ,YACOJ,EACAmnB,EAFP,CAGIpmB,QAJYomB,EAAarY,EAAyBqY,GAAcnnB,EAAMe,QAKtEX,eAAAA,EACAwmB,8BAA+BF,IAGvC,KAAKzY,EACD,YACOjO,EADP,CAEI2mB,YAAatX,EAAerP,KAGpC,QACI,OAAOkO,EAAAA,GAAAA,QAA4BlO,EAAOqB,MAEnD2lB,GAEH,MAAO,CAAChnB,GADamG,EAAAA,EAAAA,GAAW,CAACtJ,QAAAA,EAASuJ,SAAAA,MoCjBtCghB,CAAsB,CACtBP,eAAgBzZ,EAChB2Z,mBAAoBxZ,EAAsB,GAC1CuZ,eAAgB,CACZlmB,MAAOwM,EAAgB,GACvBtM,MAAO,SAITumB,GAAsBT,KAAkCF,GAG1Drf,UAAWigB,GADT,yBAEFC,GAFE,0BAGFC,GAHE,+BAIFC,GAJE,gCAKFC,ItCrHc,KAA+C,UAA9C,cAACpB,EAAD,UAAgBD,EAAhB,cAA2BK,GAAmB,EACjE,MAAOS,EAAYQ,IAAiBpgB,EAAAA,EAAAA,UAAkC8E,IAC/Dub,EAAuBC,IAA4BtgB,EAAAA,EAAAA,UAAmD,OAQ7GugB,EAAAA,EAAAA,IAN4C,KACpCF,IACAD,EAAc,EAAD,GAAKR,EAAL,CAAiB7a,eAAgBsb,KAC9CC,EAAyB,SAGuB,CAACnB,IAEzD,MAaOrf,EAAWC,IAAgBC,EAAAA,EAAAA,WAAS,GAU3C,OARAyE,EAAAA,EAAAA,YAAU,KACNsa,IACKtb,MAAMmc,IACHQ,EAAcR,GAAc9a,MAE/BrB,MAAM+c,GAAMzgB,GAAa,KACzBmE,OAAOsc,GAAMzgB,GAAa,OAChC,IACI,CACHD,UAAAA,EACAkgB,yBAAwB,UAAEJ,EAAW7a,sBAAb,aAAE,EAA4Boa,GACtDc,0BAA2BL,EAAW5a,gBACtCkb,+BA3BoCd,IACpC,MAAMqB,EAAyD,EAAH,GACrDb,EAAW7a,eAD0C,CAExD,CAACoa,GAAgBC,IAErBkB,EAAyBG,GACzB3B,EAAU,EAAD,GAAKc,EAAL,CAAiB7a,eAAgB0b,MAsB1CN,gCAnBqCf,IACrCN,EAAU,EAAD,GAAKc,EAAL,CAAiB5a,gBAAiBoa,QsCgG3CsB,CAAc,CACd3B,cAAAA,EACAD,UAAAA,EACAK,cAAAA,KAGGwB,GAA+BC,KAAoC5gB,EAAAA,EAAAA,aAE1EyE,EAAAA,EAAAA,YAAU,KACDsb,IACDlZ,GAAgB,CAAC+Y,WAAYI,GAA0Bb,cAAAA,MAE5D,CAACY,GAAqBZ,KAEzB1a,EAAAA,EAAAA,YAAU,KACDsb,IACDa,GAAiCX,MAAAA,QAAD,EAACA,GAA2BpnB,kBAEjE,CAACknB,MAEJQ,EAAAA,EAAAA,IAAmB,KACXT,IACAI,GAA+Bd,MAEpC,CAACA,MAKJmB,EAAAA,EAAAA,IAHkB,KACdjoB,GAAW,KAEe,CAACoH,IAE/B,MAAOmhB,GAAyBC,KAA8B9gB,EAAAA,EAAAA,YACxD+gB,IAAwB9qB,EAAAA,EAAAA,cAAY,KACtC6qB,GAA2B,QAC5B,IAEGzY,IAAiCvJ,EAAAA,EAAAA,UAAQ,KAC3C,MAAMkiB,GAAkBC,EAAAA,EAAAA,KAAmB5gB,EAAU8e,GAGrD,OAAO9e,EAASgI,cAAclO,QAC1B+mB,EAAAA,EAAAA,OAAK7R,EAAAA,EAAAA,KAAwBC,EAAAA,IAAAA,OAHH,QAAC,YAAC6R,EAAD,UAAcC,GAAf,SAC1BJ,EAAgBK,MAAK/Z,EAAAA,EAAAA,SAAOga,EAAAA,EAAAA,QAAOH,EAAYI,gBAAgBD,EAAAA,EAAAA,QAAOF,EAAUG,uBAIrF,CAAClhB,EAAU8e,IAERhW,IAAcrK,EAAAA,EAAAA,UAChB,IrC5EsB,EAACuJ,EAAgCpB,IAC3DA,GACM5P,EAAAA,EAAAA,OACEmqB,EAAAA,EAAAA,OAAMxQ,GAAgCA,EAAarP,MAAQsF,IAC3Dwa,EAAAA,IACAtb,GACA3D,EAAAA,EAAAA,QAAO2C,IACPuc,EAAAA,EAAAA,SAAO,QAAC,GAACpkB,GAAF,SAAUyI,EAAkB/M,SAASsE,MAL9CjG,CAMAgR,GAXwBA,CAAAA,IAC9BsZ,OAJwCC,GAIExnB,EAAAA,EAAAA,OAAM,qBATjBiO,CAAAA,IAAD,CAC9BtO,KAAMuL,EAAAA,IAAAA,YACN7D,QAAS4G,EAAc3F,KAAI,QAAC,IAACf,EAAD,MAAMyD,GAAP,QAAmB,CAAC/O,MAAOsL,EAAKyD,MAAAA,QAOWyc,CAA0BxZ,IAJ1Cc,IACtD2Y,EAAAA,EAAAA,QAAO3Y,EAAY4Y,WAAUC,EAAAA,EAAAA,QAAO,KAGnB/c,kBAHqC2c,EAAUzY,GAD3C,IAAmByY,GAelCK,CAAyB5Z,EAAzB4Z,CAAwC9c,GqCmEpC+c,CAAe7Z,GAAepB,KACpC,CAACoB,GAAepB,KAEdkb,IAAqBrjB,EAAAA,EAAAA,UACvB,IAAMjG,EAAe6J,KAAKpF,GAAO6L,GAAYqY,MAAKQ,EAAAA,EAAAA,QAAO,KAAM1kB,MAAMnD,OAAOhE,EAAAA,WAC5E,CAAC0C,EAAgBsQ,KAGfiZ,IAAkBtjB,EAAAA,EAAAA,UAAQ,KAC5B,MAAMujB,GAAYhrB,EAAAA,EAAAA,OACd+B,EAAAA,EAAAA,OAAKF,EAAAA,EAAAA,QAAO+N,KAAsB9M,EAAAA,EAAAA,SAAO6nB,EAAAA,EAAAA,QAAO,MAAO/a,OACvDvE,EAAAA,EAAAA,MAAI3B,EAAAA,EAAAA,MAAK,QAFK1J,CAGhBgR,IACF,MAAO,CACH/K,GAAImC,EAAOnC,GACXhC,QAAS,CACL+F,YAAaghB,EACb/gB,aAAc+gB,MAGvB,CAAC5iB,EAAOnC,GAAI2J,GAAqBoB,KAE9Bia,IAAiBxjB,EAAAA,EAAAA,UACnB,ICpMgC,EACpCtF,EACA2P,KAEA,MAAMoZ,GAAgBC,EAAAA,GAAAA,IAAmBrZ,EAAa3P,GAEtD,OAAO,IAAIipB,EAAAA,KAAgBC,UAAUH,GAAeI,SD8L1CC,CAAyBppB,EAAS2oB,KACxC,CAAC3oB,EAAS2oB,MAGPriB,UAAW+iB,GAAoBhe,OAAQie,KAAmBtjB,EAAAA,EAAAA,GAAmB,CAChF9J,KAAAA,EACAE,YAAAA,EACA6J,OAAQ2iB,GACR1iB,OAAQogB,GAAsBpgB,EAAS,KACvCvF,OAAQmoB,GACR1iB,KAAMgF,EAAAA,IAAAA,QACNzL,QAAAA,GACA0G,WAAAA,EACAF,uBAAwB6J,EAAetH,EAAAA,IAAAA,IAAqBA,EAAAA,IAAAA,cAG1DpC,IAAaggB,IAAuB+C,GAEpCpS,IAASxa,EAAAA,EAAAA,cAAYoB,EAAAA,EAAAA,MAAKgB,GAAYyO,IAAmB,CAACzO,GAAYyO,KACtE4J,IAAWza,EAAAA,EAAAA,cAAYoB,EAAAA,EAAAA,MAAKe,GAAc0O,IAAmB,CAAC1O,GAAc0O,KAC5EoC,IAAkBjT,EAAAA,EAAAA,cAAYoB,EAAAA,EAAAA,MAAKc,GAAe2O,IAAmB,CAAC3O,GAAe2O,KACrFwC,IAAkBrT,EAAAA,EAAAA,cAAYoB,EAAAA,EAAAA,MAAKY,GAAe6O,IAAmB,CAAC7O,GAAe6O,KACrFuC,IAAuBpT,EAAAA,EAAAA,cAAYoB,EAAAA,EAAAA,MAAKuP,GAAoBE,IAAmB,CACjFF,GACAE,KAEEic,IAA0B9sB,EAAAA,EAAAA,cAC3B4C,IACG+nB,GAAiC/nB,GACjCsnB,GAAgC,CAACtnB,eAAAA,MAErC,CAACsnB,KAGC6C,GAAqBhf,MAAAA,OAAH,EAAGA,EAAc6c,IACnCoC,IAA6BhtB,EAAAA,EAAAA,cAC9BitB,IACGrkB,EACIoF,EAAAA,GAAAA,UAAAA,QAAAA,gBAA0C,CACtC3G,GAAImC,EAAOnC,GACX0G,aAAamf,EAAAA,EAAAA,QAAOtC,GAAyBqC,EAAelf,GAC5Df,MAAAA,OAIZ,CAAC+f,MAEEI,GAAWC,KAAevkB,EAAAA,EAAAA,UAAQ,IAC9B,EAACwkB,EAAAA,EAAAA,KAA0Ctf,GAAc,CAACuI,EAAAA,IAAAA,YAClE,CAACvI,IAEEuf,IAAgBC,EAAAA,EAAAA,GAAiB,CAACJ,UAAAA,GAAWC,YAAAA,GAAajwB,SAAU4rB,IACpEyE,IAAc3kB,EAAAA,EAAAA,UAAQ,KAAM4kB,EAAAA,EAAAA,KAA6B1f,IAAc,CAACA,IAExE2f,IAAc1tB,EAAAA,EAAAA,cACfqjB,IACGD,GAAiBC,GACbA,EAAM8C,YAAcC,EAAAA,IAAAA,kBACpByG,OAGR,CAACA,KAGCc,IAAiB3tB,EAAAA,EAAAA,cAClBmW,KACG/U,EAAAA,EAAAA,MAAKwsB,EAAAA,KAAgBC,EAAAA,EAAAA,SAAQhB,KAAkBiB,EAAAA,EAAAA,WAAUJ,IAAzDtsB,CAAuE+U,KAE3E,CAAC0W,GAAiBa,KAGhBK,IAAgC/tB,EAAAA,EAAAA,cAAY,MAC9CoB,EAAAA,EAAAA,MACIwsB,EAAAA,KACAC,EAAAA,EAAAA,UAAQzsB,EAAAA,EAAAA,MAAK0pB,GAAuB+B,MACpCiB,EAAAA,EAAAA,YAAWzK,IACHA,EAAM8C,YAAcC,EAAAA,IAAAA,kBACpB0E,KAEJ4C,GAAYrK,MAPpBjiB,CASE2rB,GAAmB/gB,SAASmK,eAC/B,CAAC4W,GAAoBF,GAAiB/B,GAAuB4C,KAE1DM,IAA2BhuB,EAAAA,EAAAA,cAC5BqjB,IACOA,GAAOqK,GAAYrK,GACvByH,OAEJ,CAAC4C,GAAa5C,KAGZxX,IAAqBtT,EAAAA,EAAAA,cAAY,KACnCgpB,EAAciF,EAAAA,OACf,IAEGza,IAAuBxT,EAAAA,EAAAA,cAAY,KACrCipB,EAAgBgF,EAAAA,OACjB,IAEH,OACI,kBAACC,EAAA,EAAD,CAA8BZ,cAAeA,IACzC,kBAACa,EAAA,WAAD,CAA6B/tB,MAAOotB,IAChC,yBAAK1vB,UAAWT,EAAOqrB,mBACnB,kBAAC0F,EAAA,EAAD,CAAmB3kB,OAAQA,IAC3B,kBAAC,GAAD,CACIuD,MAAOA,EACPgG,mBAAoBzP,EACpB0P,gBAAiBA,GACjBC,YAAaA,GACbC,gBAAiBvQ,EACjByQ,gBAAiBA,GACjBjB,cAAeA,GACfpB,oBAAqBA,GACrBoC,qBAAsBA,GACtBxJ,WAAYA,EACZ0J,mBAAoBA,GACpBC,aAAcA,EACdC,qBAAsBA,KAE1B,yBAAK1V,UAAWT,EAAOymB,MAClBja,IAAa,kBAACwkB,EAAA,EAAD,MACd,kBAAC,GAAD,CACIzT,SAAUmO,EACV3e,SAAUA,EACV2D,YAAaA,EACbmF,YAAagZ,GACbhpB,QAASA,GACTsX,OAAQA,GACRjX,QAASA,EACTkX,SAAUA,GACVC,WAAYmQ,GACZlQ,SAAUA,EACV1B,SAAU0U,KAEd,kBAACruB,EAAA,EAAD,CACIC,MAAOyN,EACPxN,mBAAoBuQ,EACpBtQ,KAAMA,EACNC,aAAc2C,GACd1C,YAAaA,EACbC,oBAAqB0C,GACrBzC,cAAe8a,KAGtBoS,IACG,kBAAC,GAAD,CACInS,SAAUmO,EACVtf,OAAQA,EACR7G,eAAgB8nB,GAChBzG,uBAAwB6I,GACxB9Y,WAAY+Y,GACZ3mB,QAAS4nB,GACTjK,mBAAoBgK,GACpB/J,mBAAoBgJ,W,yHEnVhD,MAAMsB,IAAoBC,EAAAA,EAAAA,GAAwB,CAC9CC,iBAAkB,2BAClBC,eAAe,EACfC,KAAM,SChBV,GD2BiC,IAAgE,IAA/D,OAACllB,EAAD,MAASmlB,EAAT,SAAgBC,EAAhB,UAA0B/F,EAA1B,cAAqCC,GAA0B,EAC7F,MAAM+F,GAAmE7uB,EAAAA,EAAAA,cACrE8uB,EAAAA,EAAAA,KAAkBhG,GAClB,CAACA,IAECiG,GAAkBC,EAAAA,EAAAA,YAAWC,EAAAA,GAC7BC,EAAkBvZ,EAAAA,GAAAA,UAAAA,4BAAgDgZ,EAAMQ,YACxEC,GAAWvmB,EAAAA,EAAAA,UAAQ,I,+UAAM,IAAKkmB,EAAX,CAA4BG,gBAAAA,KAAmB,CAACH,EAAiBG,IAE1F,OACI,kBAAC,EAAAG,SAAD,CAAUV,MAAOA,GACb,kBAACW,EAAA,WAAD,CAAwBlvB,MAAOoJ,EAAOnC,IAClC,kBAAC4nB,EAAA,WAAD,CAA0B7uB,MAAOgvB,GAC7B,kBAACG,EAAA,GAAD,CAAgBjB,kBAAmBA,IAC/B,kBAACkB,EAAA,EAAD,CAAsBC,YAAaC,EAAAA,GAC/B,kBAAC,IAAD,CACIC,cAAY,EACZf,SAAU,CAACjzB,EAAOC,IAAWgzB,MAAAA,OAAnB,EAAmBA,EAAWgB,KAAKC,MAAMl0B,GAAQi0B,KAAKC,MAAMj0B,MAEzE4N,GACG,kBAAC,GAAD,CACIA,OAAQA,EACRqf,UAAWA,EACXC,cAAe+F,IAGvB,kBAACvL,EAAA,EAAD","sources":["webpack://@reltio/remotes/../components/src/icons/Filter.tsx","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTableHeader/FilterButton/styles.js","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTableHeader/FilterButton/FilterButton.js","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTablePagination/styles.ts","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTablePagination/BasicTablePagination.tsx","webpack://@reltio/remotes/../components/src/components/BasicTableView/viewState/basicTableViewState.js","webpack://@reltio/remotes/../components/src/components/BasicView/styles.ts","webpack://@reltio/remotes/../components/src/components/BasicView/BasicView.tsx","webpack://@reltio/remotes/../components/src/components/ConfirmationDialog/styles.ts","webpack://@reltio/remotes/../components/src/components/ConfirmationDialog/ConfirmationDialog.tsx","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenuItemRender/styles.ts","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenuItemRender/SettingsMenuItemRender.tsx","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenu.tsx","webpack://@reltio/remotes/../components/src/components/VerticalDivider/VerticalDivider.js","webpack://@reltio/remotes/../components/src/hooks/useActions.ts","webpack://@reltio/remotes/../components/src/hooks/useRelationsLoader.ts","webpack://@reltio/remotes/../relationships/src/hooks/useSavedState.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/helpers/tableHelpers.ts","webpack://@reltio/remotes/../relationships/src/hooks/useRelationshipsTable.ts","webpack://@reltio/remotes/../relationships/src/components/RelationTypeSelector/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationTypeSelector/RelationTypeSelector.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTableHeader/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTableHeader/RelationshipsTableHeader.tsx","webpack://@reltio/remotes/../relationships/src/services/helpers.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/HeadCellRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/EntityProfileRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/AttributesRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/DefaultCellValueRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/helpers.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/RowCellRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/MenuItemRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/RelationshipMenuButton.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/RelationshipsTable.tsx","webpack://@reltio/remotes/../relationships/src/components/LegendTable/helpers.ts","webpack://@reltio/remotes/../relationships/src/components/LegendTable/styles.ts","webpack://@reltio/remotes/../relationships/src/components/LegendTable/LegendTable.tsx","webpack://@reltio/remotes/../relationships/src/components/LegendPanel/styles.ts","webpack://@reltio/remotes/../relationships/src/components/LegendPanel/LegendPanel.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/EntityInfo/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/EntityInfo/EntityInfo.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDirection/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDirection/RelationDirection.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDate/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDate/RelationDate.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationshipBand.tsx","webpack://@reltio/remotes/../relationships/src/services/errors.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipDetails/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipDetails/RelationshipDetails.tsx","webpack://@reltio/remotes/../relationships/src/hooks/useCrosswalksDisplay.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/RelationshipsView.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/helpers/filtersHelpers.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/index.tsx","webpack://@reltio/remotes/./src/relationships.ts"],"sourcesContent":["import React from 'react';\n\nconst SvgFilter: React.FC<React.SVGProps<SVGSVGElement>> = (props) => {\n return (\n <svg width={18} height={18} viewBox=\"0 0 18 18\" xmlns=\"http://www.w3.org/2000/svg\" {...props}>\n <path d=\"M18 2V0H0v2l7 8v8l4-2v-6z\" fill=\"currentColor\" fillRule=\"nonzero\" stroke=\"none\" strokeWidth={1} />\n </svg>\n );\n};\n\nexport default SvgFilter;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n 'filterIcon--enabled': {\n color: theme.palette.primary.main\n },\n closeIcon: {\n position: 'absolute',\n right: '3px',\n bottom: '3px',\n transform: 'scale(0.5)'\n },\n button: {\n padding: '11px'\n }\n}));\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport i18n from 'ui-i18n';\nimport IconButton from '@mui/material/IconButton';\nimport CloseIcon from '@mui/icons-material/Close';\nimport Tooltip from '@mui/material/Tooltip';\nimport FilterIcon from '../../../../icons/Filter';\nimport {useStyles} from './styles';\n\nconst FilterButton = ({enabled, onClick}) => {\n const styles = useStyles();\n\n return (\n <Tooltip title={enabled ? i18n.text('Clear all filters') : i18n.text('Filter')}>\n <IconButton onClick={onClick} classes={{root: styles.button}} size=\"large\">\n {enabled ? (\n <>\n <FilterIcon className={styles['filterIcon--enabled']} />\n <CloseIcon color=\"primary\" className={styles.closeIcon} />\n </>\n ) : (\n <FilterIcon />\n )}\n </IconButton>\n </Tooltip>\n );\n};\n\nFilterButton.propTypes = {\n enabled: PropTypes.bool,\n onClick: PropTypes.func\n};\n\nexport default FilterButton;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n pagination: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'flex-end',\n height: '56px',\n flexShrink: 0,\n borderTop: '1px solid rgba(0,0,0,0.12)',\n boxShadow: 'none',\n boxSizing: 'border-box',\n overflowY: 'hidden',\n containerType: 'inline-size',\n '& .MuiInputBase-root': {\n display: 'none',\n '@container (min-width: 420px)': {\n display: 'inline-flex'\n }\n }\n },\n caption: {\n color: 'rgba(0,0,0,0.6)',\n fontSize: '12px',\n lineHeight: '16px',\n display: 'none',\n '@container (min-width: 420px)': {\n display: 'block'\n }\n },\n displayedRows: {\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!important' //we need it, because of the more specific rule in the mui\n }\n});\n","import React, {useCallback, memo} from 'react';\nimport classnames from 'classnames';\nimport i18n from 'ui-i18n';\nimport {getValue} from '../../../core/utils';\nimport {nthArg, pipe, pathOr, identity} from 'ramda';\nimport TablePagination, {TablePaginationProps} from '@mui/material/TablePagination';\n\nimport {useStyles} from './styles';\n\ntype BasicTablePaginationProps = {\n classes?: TablePaginationProps['classes'];\n basicTableRef?: React.Ref<HTMLElement>;\n count?: number;\n page?: number;\n rowsPerPage?: number;\n labelRowsPerPage?: React.ReactNode;\n rowsPerPageOptions?: TablePaginationProps['rowsPerPageOptions'];\n onChangePage?: (value: number) => void;\n onChangeRowsPerPage?: (value: number) => void;\n};\n\nconst BasicTablePagination = ({\n classes = {},\n count,\n rowsPerPageOptions,\n page,\n onChangePage,\n rowsPerPage,\n onChangeRowsPerPage,\n basicTableRef,\n labelRowsPerPage\n}: BasicTablePaginationProps) => {\n const styles = useStyles();\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\n const resetScrollbarPosition = useCallback(() => {\n pathOr(identity, ['current', 'resetScrollbarPosition'], basicTableRef)();\n }, [basicTableRef]);\n\n const handleChangePage = useCallback(\n (value: number) => {\n onChangePage(value);\n resetScrollbarPosition();\n },\n [onChangePage, resetScrollbarPosition]\n );\n const handleChangeRowsPerPage = useCallback(\n (value: number) => {\n onChangePage(0);\n onChangeRowsPerPage(value);\n resetScrollbarPosition();\n },\n [onChangePage, onChangeRowsPerPage, resetScrollbarPosition]\n );\n\n return (\n <TablePagination\n classes={{\n ...classes,\n root: classnames(styles.pagination, classes.root),\n select: classnames(styles.select, classes.select),\n selectLabel: classnames(styles.caption, classes.selectLabel),\n displayedRows: classnames(styles.displayedRows, classes.displayedRows),\n input: classnames(styles.selectRoot, classes.selectRoot),\n actions: styles.actions\n }}\n backIconButtonProps={{size: 'large'}}\n nextIconButtonProps={{size: 'large'}}\n component=\"div\"\n labelRowsPerPage={labelRowsPerPage || i18n.text('Rows per page:')}\n labelDisplayedRows={labelDisplayedRows}\n count={count}\n rowsPerPageOptions={rowsPerPageOptions}\n page={page}\n onPageChange={pipe(nthArg(1), handleChangePage)}\n rowsPerPage={rowsPerPage}\n onRowsPerPageChange={pipe(getValue, handleChangeRowsPerPage)}\n />\n );\n};\n\nBasicTablePagination.displayName = 'BasicTablePagination';\n\nexport default memo(BasicTablePagination);\n","import {always, assoc, difference, dissoc, evolve, keys, path, when} from 'ramda';\nimport {createStandardAction, toggleSortOrder} from '../../../core';\n\nconst CHANGE_COLUMNS = 'CHANGE_COLUMNS';\nconst TOGGLE_FILTERS = 'TOGGLE_FILTERS';\nconst CHANGE_FILTER = 'CHANGE_FILTER';\nconst TOGGLE_SORT = 'TOGGLE_SORT';\nconst CHANGE_PAGE = 'CHANGE_PAGE';\nconst CHANGE_ROWS_PER_PAGE = 'CHANGE_ROWS_PER_PAGE';\n\nexport const actions = {\n changeColumns: createStandardAction(CHANGE_COLUMNS),\n toggleFilters: createStandardAction(TOGGLE_FILTERS),\n changeFilter: createStandardAction(CHANGE_FILTER),\n toggleSort: createStandardAction(TOGGLE_SORT),\n changePage: createStandardAction(CHANGE_PAGE),\n changeRowsPerPage: createStandardAction(CHANGE_ROWS_PER_PAGE)\n};\n\nexport const changeVisibleColumns = (state, nextVisibleColumns) => {\n const removedColumns = difference(state.visibleColumns, nextVisibleColumns);\n const isRemovedColumn = (columnId) => removedColumns.includes(columnId);\n return evolve(\n {\n visibleColumns: always(nextVisibleColumns),\n sorting: when(\n (sorting = {}) => isRemovedColumn(sorting.field),\n () => {\n const [nextSortField] = nextVisibleColumns;\n return {field: nextSortField, order: 'asc'};\n }\n ),\n filters: (filters) =>\n keys(filters).reduce(\n (acc, columnId) => (isRemovedColumn(columnId) ? dissoc(columnId, acc) : acc),\n filters\n )\n },\n state\n );\n};\n\nexport const reducer = (state, action) => {\n switch (action.type) {\n case CHANGE_COLUMNS: {\n const columnIds = action.payload;\n return changeVisibleColumns(state, columnIds);\n }\n case TOGGLE_FILTERS: {\n const enableFilters = !state.filters;\n return {\n ...state,\n filters: enableFilters ? {} : null,\n page: enableFilters ? state.page : 0\n };\n }\n case CHANGE_FILTER: {\n const {columnId, filter} = action.payload;\n return evolve({filters: filter ? assoc(columnId, filter) : dissoc(columnId), page: always(0)}, state);\n }\n case TOGGLE_SORT: {\n const nextSortField = action.payload;\n const prevSortField = path(['sorting', 'field'], state);\n const prevSortOrder = path(['sorting', 'order'], state);\n return {\n ...state,\n sorting: {\n field: nextSortField,\n order: toggleSortOrder(nextSortField === prevSortField ? prevSortOrder : null)\n },\n page: 0\n };\n }\n case CHANGE_PAGE:\n return {...state, page: action.payload};\n case CHANGE_ROWS_PER_PAGE:\n return {...state, rowsPerPage: action.payload};\n default:\n return state;\n }\n};\n\nexport default {\n reducer,\n actions,\n changeVisibleColumns\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n basicViewPaper: {\n display: 'flex',\n flexDirection: 'column',\n ...theme.basicView\n }\n}));\n","import React, {forwardRef} from 'react';\nimport Paper, {PaperProps} from '@mui/material/Paper';\nimport {useStyles} from './styles';\n\nconst BasicView = forwardRef(\n ({children, className, ...otherProps}: PaperProps, ref: React.RefObject<HTMLDivElement>) => {\n const styles = useStyles();\n return (\n <Paper ref={ref} className={className} classes={{root: styles.basicViewPaper}} {...otherProps}>\n {children}\n </Paper>\n );\n }\n);\n\nBasicView.displayName = 'BasicView';\n\nexport default BasicView;\n","import {makeStyles} from '@mui/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 from '@mui/material/Button';\nimport Dialog from '@mui/material/Dialog';\nimport DialogActions from '@mui/material/DialogActions';\nimport DialogContent from '@mui/material/DialogContent';\nimport DialogContentText from '@mui/material/DialogContentText';\nimport DialogTitle from '@mui/material/DialogTitle';\n\nimport {useStyles} from './styles';\n\nexport type Props = {\n open: boolean;\n title: React.ReactNode;\n content: React.ReactNode;\n cancelCaption?: string;\n discardCaption?: string;\n saveCaption?: string;\n disabledSave?: boolean;\n onCancel?: () => void;\n onDiscard?: () => void;\n onSave: () => void;\n};\n\nconst ConfirmationDialog = ({\n open,\n title,\n content,\n onCancel,\n cancelCaption = i18n.text('Cancel'),\n onDiscard,\n discardCaption = '',\n onSave,\n saveCaption = i18n.text('Save'),\n disabledSave = false\n}: Props) => {\n const styles = useStyles();\n\n return (\n <Dialog open={open} onClose={onCancel} classes={{paperScrollPaper: styles.paper}}>\n <DialogTitle classes={{root: styles.title}}>{title}</DialogTitle>\n <DialogContent classes={{root: styles.content}}>\n <DialogContentText classes={{root: styles.contentText}}>{content}</DialogContentText>\n </DialogContent>\n <DialogActions className={styles.actionButtons} disableSpacing>\n {onCancel && <Button onClick={onCancel}>{cancelCaption}</Button>}\n <div>\n {onDiscard && (\n <Button onClick={onDiscard} classes={{root: styles.discardButton}}>\n {discardCaption}\n </Button>\n )}\n <Button onClick={onSave} color=\"primary\" disabled={disabledSave} autoFocus>\n {saveCaption}\n </Button>\n </div>\n </DialogActions>\n </Dialog>\n );\n};\n\nexport default ConfirmationDialog;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n menuItem: {\n height: '32px'\n },\n menuText: {\n color: theme.palette.text.primary,\n fontSize: '13px',\n lineHeight: '15px'\n },\n checkbox: {\n padding: 0,\n marginRight: '15px'\n }\n}));\n","import React, {forwardRef} from 'react';\nimport {identity} from 'ramda';\nimport Checkbox from '@mui/material/Checkbox';\nimport MenuItem from '@mui/material/MenuItem';\nimport Typography from '@mui/material/Typography';\nimport {DropDownMenuItem} from '../../../types';\nimport {useStyles} from './styles';\n\ntype Props = {\n item: DropDownMenuItem;\n onMenuClose?: (e) => void;\n};\n\nconst SettingsMenuItemRenderer = forwardRef(({item, onMenuClose = identity}: Props, ref: React.Ref<HTMLLIElement>) => {\n const styles = useStyles();\n const {text, onClick, id, selected} = item;\n const handleClick = (e) => {\n onMenuClose(e);\n onClick(e);\n };\n\n return (\n <MenuItem\n classes={{root: styles.menuItem}}\n onClick={handleClick}\n ref={ref}\n data-modal\n data-reltio-id={`reltio-settings-menu-item${id}`}\n >\n <Checkbox checked={selected} className={styles.checkbox} color=\"primary\" />\n <Typography classes={{root: styles.menuText}}>{text}</Typography>\n </MenuItem>\n );\n});\n\nSettingsMenuItemRenderer.displayName = 'SettingsMenuItemRenderer';\n\nexport default SettingsMenuItemRenderer;\n","import React from 'react';\nimport SettingsIcon from '@mui/icons-material/Settings';\nimport i18n from 'ui-i18n';\nimport {DropDownMenuItem} from '../../types';\nimport {SmallIconButtonWithTooltip} from '../SmallIconButton';\nimport DropDownMenuButton from '../DropDownMenuButton/DropDownMenuButton';\nimport SettingsMenuItemRenderer from './SettingsMenuItemRender/SettingsMenuItemRender';\n\ntype Props = {\n items: Array<DropDownMenuItem>;\n menuId: string;\n};\n\nconst SettingsMenu = ({items, menuId}: Props) => {\n return (\n <DropDownMenuButton\n buttonComponent={SmallIconButtonWithTooltip}\n buttonProps={{\n icon: SettingsIcon,\n tooltipTitle: i18n.text('Settings'),\n size: 'L'\n }}\n menuId={menuId}\n menuItems={items}\n MenuItemRenderer={SettingsMenuItemRenderer}\n />\n );\n};\n\nexport default SettingsMenu;\n","import PropTypes from 'prop-types';\nimport React from 'react';\n\nconst VerticalDivider = ({height, margin}) => (\n <div\n style={{\n width: '1px',\n height: `${height}px`,\n borderLeft: '1px solid rgba(0,0,0,0.38)',\n margin: `0 ${margin}px`,\n flexShrink: '0'\n }}\n />\n);\n\nVerticalDivider.propTypes = {\n height: PropTypes.number,\n margin: PropTypes.number\n};\n\nexport default VerticalDivider;\n","import {useMemo} from 'react';\nimport {pipe} from 'ramda';\n\ntype UseActions = ({\n actions,\n dispatch\n}: {\n actions: {\n [key: string]: <T>(payload: T) => {type: string; payload: T};\n };\n dispatch: <T>({type, payload}: {type: string; payload: T}) => void;\n}) => {\n [key in keyof typeof actions]: <T>(payload: T) => void;\n};\n\nexport const useActions: UseActions = ({actions, dispatch}) =>\n useMemo(\n () =>\n Object.entries(actions).reduce((acc, [actionName, actionCreator]) => {\n return {...acc, [actionName]: pipe(actionCreator, dispatch)};\n }, {}),\n [dispatch, actions]\n );\n","import {useCallback, useEffect, useMemo, useRef, useState} from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport {cond, pipe, prop, T, evolve, filter as filterFn, when, identity, times, length, ifElse, always} from 'ramda';\nimport mdm, {profile} from '@reltio/mdm-module';\nimport {\n ActivityFilter,\n addGlobalFilterToQuery,\n Connection,\n Entity,\n getRelationsForDataTenantEntity,\n getRelationsForEntity,\n GlobalSearchRequestOptions,\n isAvailableEntityTypeUri,\n isAvailableRelationTypeUri,\n isDataTenantEntity,\n isObject,\n isTempUri,\n Metadata,\n Mode,\n RelationsContent,\n RelationsViewConfig,\n wrapInArrayIfNeeded\n} from '@reltio/mdm-sdk';\nimport {useSafePromise} from './useSafePromise';\nimport {usePrevious} from './usePrevious';\n\ntype Props = {\n sorting?: {\n field: string;\n order: string;\n };\n filter?: string;\n page: number;\n rowsPerPage: number;\n config: Pick<RelationsViewConfig, 'suggested' | 'content' | 'id'>;\n entity: Entity;\n relationActivityFilter?: ActivityFilter;\n mode: Mode;\n searchByOv?: boolean;\n};\n\nconst buildSuggestedIds = when(\n identity,\n pipe(\n wrapInArrayIfNeeded,\n length,\n times((n) => n + 1)\n )\n);\ntype ConnectionResponse = Array<{connections?: Connection[]; total: number}>;\n\nexport const useRelationsLoader = ({\n sorting,\n filter,\n page,\n rowsPerPage,\n config,\n entity,\n relationActivityFilter,\n mode,\n searchByOv = false\n}: Props) => {\n const [isLoading, setIsLoading] = useState(false);\n const dispatch = useDispatch();\n const tenant = useSelector(mdm.selectors.getTenant) as string;\n const metadata = useSelector(mdm.selectors.getMetadata) as Metadata;\n const dtssPath = useSelector(mdm.selectors.getDtssPath) as string;\n const {activityFilter, globalFilter}: GlobalSearchRequestOptions =\n useSelector(mdm.selectors.getGlobalSearchRequestOptions) || {};\n const lastLoadedTime = useSelector(mdm.selectors.getProfileLastLoadedTime);\n const safePromise = useSafePromise();\n\n const processContent = (content: RelationsContent) => {\n const getUri = when(isObject, prop('uri'));\n const filterRelation = pipe(getUri, isAvailableRelationTypeUri(metadata));\n\n return evolve({\n entityTypes: filterFn(isAvailableEntityTypeUri(metadata)),\n inRelations: filterFn(filterRelation),\n outRelations: filterFn(filterRelation),\n nextEntry: processContent\n })(content);\n };\n\n const suggested = config.suggested;\n const options = useMemo(\n () => ({\n searchByOv\n }),\n [searchByOv]\n );\n const loadRelations = useCallback(() => {\n if (entity?.uri) {\n const processedConfig = processContent(config.content);\n const requestConfig = {\n ...processedConfig,\n sortBy: sorting?.field,\n order: sorting?.order,\n returnDates: true,\n returnObjects: true,\n activeness: {\n relation: relationActivityFilter || ActivityFilter.ALL,\n entity: activityFilter\n },\n max: rowsPerPage,\n offset: page * rowsPerPage,\n filter: addGlobalFilterToQuery(globalFilter, filter) || undefined,\n suggested: buildSuggestedIds(suggested)\n };\n const configs = [requestConfig].concat(\n ifElse(\n identity,\n pipe(wrapInArrayIfNeeded, (suggested) =>\n suggested.map((config, i) => ({...config, id: requestConfig.suggested[i]}))\n ),\n always([])\n )(suggested)\n );\n\n const request: (entity: Entity) => Promise<ConnectionResponse> = cond([\n [pipe(prop('uri'), isTempUri), () => Promise.resolve([{total: 0}])],\n [\n isDataTenantEntity,\n (entity) =>\n getRelationsForDataTenantEntity({\n entityUri: entity.uri,\n configs: configs,\n customerTenant: tenant,\n dataTenant: entity.dataTenant,\n dtssPath,\n options\n })\n ],\n [T, (entity) => getRelationsForEntity(entity.uri, configs, options)]\n ]);\n setIsLoading(true);\n safePromise(request(entity))\n .then((result) => {\n if (!Array.isArray(result)) {\n throw Error(JSON.stringify(result));\n }\n const [{connections, total}] = result;\n dispatch(profile.relations.actions.relationsLoaded({id: config.id, connections, total}));\n })\n .catch((e) => {\n console.warn('Failed to load relations data', e);\n })\n .finally(() => {\n setIsLoading(false);\n });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n activityFilter,\n metadata,\n config,\n dispatch,\n dtssPath,\n entity?.uri,\n entity?.dataTenant,\n filter,\n globalFilter,\n page,\n relationActivityFilter,\n rowsPerPage,\n safePromise,\n sorting,\n tenant,\n options,\n lastLoadedTime\n ]);\n const isRequestSentRef = useRef<boolean>(false);\n isRequestSentRef.current = false;\n useEffect(() => {\n isRequestSentRef.current = true;\n loadRelations();\n }, [loadRelations]);\n\n const prevMode = usePrevious(mode);\n useEffect(() => {\n if (mode === Mode.Viewing && !isRequestSentRef.current && prevMode !== mode) {\n isRequestSentRef.current = true;\n loadRelations();\n }\n }, [loadRelations, mode, prevMode]);\n return {isLoading, reload: loadRelations};\n};\n","import {useEffect, useState} from 'react';\nimport {useDidUpdateEffect} from '@reltio/components';\nimport {\n RelationshipsSavedState,\n RelationsTableSavedState,\n AttributesTableSavedState\n} from './../types/RelationshipsSavedState';\n\nconst DEFAULT_SAVED_STATE = {\n relationsTable: {},\n attributesTable: {}\n};\n\nconst useSavedState = ({getSavedState, saveState, entityTypeUri}) => {\n const [savedState, setSavedState] = useState<RelationshipsSavedState>(DEFAULT_SAVED_STATE);\n const [changedRelationsState, setRelationsChangedState] = useState<Record<string, RelationsTableSavedState>>(null);\n\n const saveChangesLocallyForPrevEntityType = () => {\n if (changedRelationsState) {\n setSavedState({...savedState, relationsTable: changedRelationsState});\n setRelationsChangedState(null);\n }\n };\n useDidUpdateEffect(saveChangesLocallyForPrevEntityType, [entityTypeUri]);\n\n const updateRelationsTableSavedState = (stateToSave: RelationsTableSavedState) => {\n const changedState: Record<string, RelationsTableSavedState> = {\n ...savedState.relationsTable,\n [entityTypeUri]: stateToSave\n };\n setRelationsChangedState(changedState);\n saveState({...savedState, relationsTable: changedState});\n };\n\n const updateAttributesTableSavedState = (stateToSave: AttributesTableSavedState) => {\n saveState({...savedState, attributesTable: stateToSave});\n };\n\n const [isLoading, setIsLoading] = useState(true);\n\n useEffect(() => {\n getSavedState()\n .then((savedState) => {\n setSavedState(savedState || DEFAULT_SAVED_STATE);\n })\n .then((_) => setIsLoading(false))\n .catch((_) => setIsLoading(false));\n }, []); // eslint-disable-line\n return {\n isLoading,\n relationsTableSavedState: savedState.relationsTable?.[entityTypeUri],\n attributesTableSavedState: savedState.attributesTable,\n updateRelationsTableSavedState,\n updateAttributesTableSavedState\n };\n};\n\nexport default useSavedState;\n","import {\n attributeUriToSearchUri,\n DataTypes,\n getAttrDataTypeDefinition,\n getReadableAttributesList,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {adjust, assoc, concat, find, map, pipe, pluck, prop, propEq, reject, uniqBy} from 'ramda';\nimport i18n from 'ui-i18n';\nimport {RelationshipsTableColumnData} from '../../../types';\n\nconst RELATION_TYPE_COLUMN_ID = 'relation.type';\nconst ATTRIBUTES_COLUMN_ID = 'relation.attributes';\n\nexport const DEFAULT_COLUMNS_DATA = [\n {\n id: 'entity.label',\n get label() {\n return i18n.text('Profile');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_STRING\n },\n hideable: false,\n filterable: false,\n initialWidth: 280,\n autoResize: false\n },\n {\n id: RELATION_TYPE_COLUMN_ID,\n get label() {\n return i18n.text('Type');\n }\n },\n {\n id: 'relation.label',\n get label() {\n return i18n.text('Directional Label');\n },\n filterable: false,\n dataTypeDefinition: {\n type: DataTypes.TYPE_STRING\n }\n },\n {\n id: 'relation.activeness.startDate',\n get label() {\n return i18n.text('Start Date');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_ACTIVENESS_DATE\n }\n },\n {\n id: 'relation.activeness.endDate',\n get label() {\n return i18n.text('End Date');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_ACTIVENESS_DATE\n }\n },\n {\n id: ATTRIBUTES_COLUMN_ID,\n get label() {\n return i18n.text('Attributes');\n },\n sortable: false,\n filterable: false,\n maxAttrsToShow: 7\n }\n];\n\nexport const DEFAULT_COLUMNS = pluck('id', DEFAULT_COLUMNS_DATA);\nexport const ALL_TYPES_COLUMNS = [RELATION_TYPE_COLUMN_ID, ATTRIBUTES_COLUMN_ID];\n\nexport const ROWS_PER_PAGE_OPTIONS = [20, 50, 100];\n\nconst getColumnIdFromAttrUri = pipe(attributeUriToSearchUri, concat('relation.'));\n\nconst getColumnsDataFromRelationAttributes = pipe(\n map((attr) => ({\n id: getColumnIdFromAttrUri(attr.uri),\n label: attr.label,\n description: attr?.description,\n dataTypeDefinition: getAttrDataTypeDefinition(attr)\n })),\n uniqBy(prop('id'))\n);\n\nconst getRelationColumnDataType = (relationTypes: TRelationType[]) => ({\n type: DataTypes.TYPE_SELECT,\n options: relationTypes.map(({uri, label}) => ({value: uri, label}))\n});\n\nconst updateColumnData = (columnId: string, updateFn) => (columnsData: RelationshipsTableColumnData[]) =>\n adjust(columnsData.findIndex(propEq('id', columnId)), updateFn, columnsData);\n\nconst updateRelationTypeColumn = (relationTypes: TRelationType[]) =>\n updateColumnData(RELATION_TYPE_COLUMN_ID, assoc('dataTypeDefinition', getRelationColumnDataType(relationTypes)));\n\nexport const getColumnsData = (relationTypes: TRelationType[], currentRelationType: string) =>\n currentRelationType\n ? pipe(\n find((relationType: TRelationType) => relationType.uri === currentRelationType),\n getReadableAttributesList,\n getColumnsDataFromRelationAttributes,\n concat(DEFAULT_COLUMNS_DATA),\n reject(({id}) => ALL_TYPES_COLUMNS.includes(id))\n )(relationTypes)\n : updateRelationTypeColumn(relationTypes)(DEFAULT_COLUMNS_DATA);\n","import {\n assoc,\n pipe,\n evolve,\n either,\n path,\n prop,\n propOr,\n ifElse,\n always,\n without,\n concat,\n intersection,\n pick,\n unless,\n isNil,\n filter\n} from 'ramda';\nimport {useReducer} from 'react';\nimport {basicTableViewState, createStandardAction, Sorting, useActions} from '@reltio/components';\nimport {ALL_TYPES_COLUMNS, DEFAULT_COLUMNS} from '../components/RelationshipsView/helpers/tableHelpers';\nimport {validateFilterValue} from '@reltio/mdm-sdk';\n\ntype Props = {\n defaultColumns: string[];\n defaultSorting: Sorting;\n defaultRowsPerPage: number;\n};\n\nconst CHANGE_RELATION_TYPE = 'CHANGE_RELATION_TYPE';\nconst APPLY_SAVED_STATE = 'APPLY_SAVED_STATE';\nconst SAVE_CURRENT_STATE = 'SAVE_CURRENT_STATE';\n\nconst actions = {\n ...basicTableViewState.actions,\n changeRelationType: createStandardAction(CHANGE_RELATION_TYPE),\n applySavedState: createStandardAction(APPLY_SAVED_STATE),\n saveCurrentState: createStandardAction(SAVE_CURRENT_STATE)\n};\n\nconst resetPageNumber = assoc('page', 0);\n\nconst getDefaultVisibleColumnsForCurrentRelationType = (state) => {\n return pipe(\n prop('visibleColumns'),\n ifElse(always(state.currentRelationType), without(ALL_TYPES_COLUMNS), concat(ALL_TYPES_COLUMNS)),\n intersection(DEFAULT_COLUMNS)\n )(state);\n};\n\nconst getSavedVisibleColumnsForCurrentRelationType = (state) =>\n path(['visibleColumnsForRelationTypes', `${state.currentRelationType}`], state);\n\nconst changeVisibleColumnsForCurrentRelationType = (state) => {\n const nextVisibleColumns = either(\n getSavedVisibleColumnsForCurrentRelationType,\n getDefaultVisibleColumnsForCurrentRelationType\n )(state);\n return basicTableViewState.changeVisibleColumns(state, nextVisibleColumns);\n};\n\nconst getFiltersFromSavedState = pipe(\n propOr(null, 'filters'),\n unless(\n isNil,\n filter(({filter, value}) => validateFilterValue(filter, value))\n )\n);\n\nconst saveVisibleColumnsForCurrentRelationType = (state) => {\n const {currentRelationType, visibleColumns} = state;\n return evolve(\n {\n visibleColumnsForRelationTypes: assoc(`${currentRelationType}`, visibleColumns)\n },\n state\n );\n};\n\nconst getStateToSave = pipe(\n saveVisibleColumnsForCurrentRelationType,\n pick(['currentRelationType', 'visibleColumnsForRelationTypes', 'filters', 'sorting'])\n);\n\nexport const useRelationshipsTable = ({defaultColumns, defaultSorting, defaultRowsPerPage}: Props) => {\n const initState = {\n visibleColumns: defaultColumns,\n filters: null,\n sorting: defaultSorting,\n page: 0,\n rowsPerPage: defaultRowsPerPage,\n currentRelationType: null,\n stateToSave: null,\n visibleColumnsForRelationTypes: {},\n entityTypeOfAppliedSavedState: null\n };\n const [state, dispatch] = useReducer((state, action) => {\n switch (action.type) {\n case CHANGE_RELATION_TYPE: {\n const nextRelationType = action.payload;\n return pipe(\n saveVisibleColumnsForCurrentRelationType,\n assoc('currentRelationType', nextRelationType),\n changeVisibleColumnsForCurrentRelationType,\n resetPageNumber\n )(state);\n }\n case APPLY_SAVED_STATE: {\n const {savedState, entityTypeUri} = action.payload;\n const visibleColumns = savedState\n ? getSavedVisibleColumnsForCurrentRelationType(savedState)\n : state.visibleColumns;\n const filters = savedState ? getFiltersFromSavedState(savedState) : state.filters;\n return {\n ...state,\n ...savedState,\n filters,\n visibleColumns,\n entityTypeOfAppliedSavedState: entityTypeUri\n };\n }\n case SAVE_CURRENT_STATE: {\n return {\n ...state,\n stateToSave: getStateToSave(state)\n };\n }\n default:\n return basicTableViewState.reducer(state, action);\n }\n }, initState);\n const tableActions = useActions({actions, dispatch});\n return [state, tableActions];\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n select: {\n fontSize: '13px',\n color: 'rgba(0,0,0,.6)',\n paddingLeft: '15px'\n },\n selectMenu: {\n '& li': {\n fontSize: '13px',\n height: '32px'\n }\n },\n textField: {\n maxWidth: '100%'\n }\n});\n","import React, {useMemo} from 'react';\nimport i18n from 'ui-i18n';\nimport {map, concat, pipe} from 'ramda';\nimport {TRelationType} from '@reltio/mdm-sdk';\nimport {DropDownEditor} from '@reltio/components';\nimport {useStyles} from './styles';\n\ntype Props = {\n value: string;\n onChange: (value: string) => void;\n relationTypes: TRelationType[];\n className?: string;\n};\n\nconst RelationTypeSelector = ({value, onChange, relationTypes, className}: Props) => {\n const styles = useStyles();\n const entries = useMemo(\n () =>\n pipe(\n map(({label, uri}) => ({label, value: uri})),\n concat([{value: '', label: i18n.text('All types')}])\n )(relationTypes),\n [relationTypes]\n );\n\n return (\n <div className={className}>\n <DropDownEditor\n displayEmpty\n disableUnderline\n classes={{\n select: styles.select\n }}\n TextFieldProps={{\n classes: {\n root: styles.textField\n }\n }}\n MenuProps={{\n classes: {\n list: styles.selectMenu\n }\n }}\n value={value || ''}\n entries={entries}\n onChange={(value: string) => onChange(value || null)}\n />\n </div>\n );\n};\n\nexport default RelationTypeSelector;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n header: {\n height: '56px',\n boxSizing: 'border-box',\n paddingRight: '10px'\n },\n title: {\n fontSize: '16px'\n },\n total: {\n fontSize: '14px',\n color: theme.palette.text.secondary,\n flexShrink: 0,\n marginRight: '5px'\n },\n relationTypeSelector: {\n margin: '0px 10px 0 30px',\n overflow: 'hidden'\n }\n}));\n","import React, {memo, useMemo} from 'react';\nimport i18n from 'ui-i18n';\nimport {TRelationType} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport {\n BasicViewHeader,\n ColumnsSettings,\n DropDownMenuItem,\n FilterButton,\n SettingsMenu,\n Spacer,\n VerticalDivider\n} from '@reltio/components';\nimport RelationTypeSelector from '../RelationTypeSelector/RelationTypeSelector';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n total: number;\n filteringEnabled: boolean;\n onToggleFilters: () => void;\n columnsData: Record<string, unknown>[];\n selectedColumns: string[];\n currentRelationType: string;\n onRelationTypeChange: (value: string) => void;\n relationTypes: TRelationType[];\n onChangeColumns: (columns: string[]) => void;\n searchByOv: boolean;\n onToggleSearchByOv: () => void;\n showInactive: boolean;\n onToggleShowInactive: () => void;\n};\n\nconst RelationshipsTableHeader = ({\n total,\n filteringEnabled,\n onToggleFilters,\n columnsData,\n selectedColumns,\n currentRelationType,\n onRelationTypeChange,\n relationTypes,\n onChangeColumns,\n searchByOv,\n onToggleSearchByOv,\n showInactive,\n onToggleShowInactive\n}: Props) => {\n const styles = useStyles();\n\n const settingItems = useMemo<Array<DropDownMenuItem>>(() => {\n return [\n {\n selected: searchByOv,\n text: i18n.text('Search by OV only'),\n onClick: onToggleSearchByOv,\n id: 'showNonOv'\n },\n {\n selected: showInactive,\n text: i18n.text('Show inactive relationships'),\n onClick: onToggleShowInactive,\n id: 'showInactive'\n }\n ];\n }, [onToggleSearchByOv, searchByOv, onToggleShowInactive, showInactive]);\n\n return (\n <BasicViewHeader title={i18n.text('Relationships')} classes={{root: styles.header, title: styles.title}}>\n {relationTypes.length > 0 && (\n <RelationTypeSelector\n className={styles.relationTypeSelector}\n value={currentRelationType}\n onChange={onRelationTypeChange}\n relationTypes={relationTypes}\n />\n )}\n <VerticalDivider height={28} margin={20} />\n <Typography variant=\"caption\" className={styles.total}>\n {total === 1\n ? i18n.text('${count} record', {count: total})\n : i18n.text('${count} records', {count: total})}\n </Typography>\n <Spacer />\n <SettingsMenu items={settingItems} menuId=\"relationships-view-settings\" />\n <FilterButton enabled={filteringEnabled} onClick={onToggleFilters} />\n <VerticalDivider height={28} margin={8} />\n <ColumnsSettings\n columnsData={columnsData}\n selectedColumns={selectedColumns}\n onChangeColumns={onChangeColumns}\n />\n </BasicViewHeader>\n );\n};\n\nexport default memo(RelationshipsTableHeader);\n","import {Connection, isActiveObject} from '@reltio/mdm-sdk';\n\nexport const getIsInactiveRelation = (connection: Connection) =>\n !isActiveObject(connection?.relation) || !isActiveObject(connection?.entity);\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n headCell: {\n display: 'flex',\n alignItems: 'center',\n height: '100%',\n width: '100%',\n fontSize: '12px',\n color: theme.palette.text.secondary,\n background: 'linear-gradient(0deg, rgba(0, 0, 0, 0.06), rgba(0, 0, 0, 0.06)), #FFFFFF'\n },\n rowCell: {\n fontSize: '13px',\n overflow: 'hidden',\n overflowWrap: 'break-word'\n },\n inactiveRowCell: {\n opacity: 0.6\n },\n defaultWrapper: {\n padding: '15px 25px 0 25px',\n '&:last-child': {\n paddingBottom: '15px'\n }\n },\n entityCell: {\n display: 'flex',\n alignItems: 'flex-start',\n padding: '15px'\n },\n entityAvatar: {\n transform: 'scale(0.5)',\n margin: '-10px 0 -10px -10px'\n },\n inactiveEntityAvatar: {\n overflow: 'initial',\n '&:after': {\n content: '\"\"',\n position: 'absolute',\n backgroundColor: 'rgb(209, 206, 206)',\n border: '1px solid rgba(0, 0, 0, 1)',\n borderRadius: '2px',\n width: '12px',\n right: 0,\n bottom: 0,\n height: '12px'\n },\n '& > img': {\n borderRadius: '50%',\n overflow: 'hidden'\n }\n },\n entityLabel: {\n color: theme.palette.primary.main,\n textDecoration: 'none',\n fontWeight: 500\n },\n attributesWrapper: {\n padding: '15px 25px 10px 25px',\n color: 'rgba(0,0,0,0.87)'\n },\n commentsContainer: {\n marginLeft: 'auto'\n },\n description: {\n marginLeft: '-22px'\n }\n}));\n","import React from 'react';\nimport DefaultHeadCellRenderer from 'react-components/dist/Table/DefaultHeadCellRenderer/DefaultHeadCellRenderer';\nimport {DescriptionIcon, withFilterAtBottom} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\nconst HeadCellRenderer = (props) => {\n const styles = useStyles();\n const {description} = props?.headCellData;\n return (\n <div className={styles.headCell}>\n <DefaultHeadCellRenderer {...props} />\n <DescriptionIcon description={description} className={styles.description} />\n </div>\n );\n};\n\nexport default withFilterAtBottom(HeadCellRenderer);\n","import React from 'react';\nimport classnames from 'classnames';\nimport {useSelector} from 'react-redux';\nimport {CommentsContainer, COMMENTS_CONTAINER_VISIBILITY_AREA, EntityTypeIcon, EntityUriLink} from '@reltio/components';\nimport {\n CollaborationObjectTypes,\n ConnectionEntity,\n ConnectionRelation,\n createRelatedObjectUris,\n getEntityUriForLink,\n getLabel,\n TEntityType\n} from '@reltio/mdm-sdk';\nimport mdmModule from '@reltio/mdm-module';\nimport {useStyles} from './styles';\n\ntype Props = {\n value: {\n entity: ConnectionEntity;\n relation: ConnectionRelation;\n entityType: TEntityType;\n };\n isInactiveRelation?: boolean;\n};\n\nconst EntityProfileRenderer = ({value: {entity, entityType, relation}, isInactiveRelation}: Props) => {\n const styles = useStyles();\n const currentEntityUri = useSelector(mdmModule.selectors.getEntityUri);\n return (\n <div className={classnames(styles.entityCell, COMMENTS_CONTAINER_VISIBILITY_AREA)}>\n <EntityTypeIcon\n className={classnames(styles.entityAvatar, {[styles.inactiveEntityAvatar]: isInactiveRelation})}\n entityType={entityType}\n />\n <EntityUriLink\n value={getEntityUriForLink({uri: entity.entityUri, dataTenant: entity.dataTenant})}\n className={styles.entityLabel}\n >\n {getLabel(entity.entityLabel)}\n </EntityUriLink>\n <div className={styles.commentsContainer} onClick={(e) => e.stopPropagation()}>\n <CommentsContainer\n uri={relation.relationUri}\n relatedObjectUris={createRelatedObjectUris(CollaborationObjectTypes.RELATION, {\n entityUri: currentEntityUri,\n connection: {relation, entity}\n })}\n objectType={CollaborationObjectTypes.RELATION}\n allowOnlyOneComment\n />\n </div>\n </div>\n );\n};\n\nexport default EntityProfileRenderer;\n","import React from 'react';\nimport {ReadOnlyAttributesList} from '@reltio/components';\nimport {AttributeType, RecordAttributesType} from '@reltio/mdm-sdk';\nimport {RelationshipsTableColumnData} from '../../../types';\nimport {useStyles} from './styles';\n\ntype Props = {\n columnData: RelationshipsTableColumnData;\n value: {\n attributeTypes: AttributeType[];\n attributes: RecordAttributesType;\n };\n};\n\nconst AttributesRenderer = ({columnData, value: {attributes, attributeTypes}}: Props) => {\n const styles = useStyles();\n\n return (\n <div className={styles.attributesWrapper} onClick={(e) => e.stopPropagation()}>\n <ReadOnlyAttributesList\n max={columnData.maxAttrsToShow}\n entity={{attributes}}\n attrTypes={attributeTypes}\n drawLines={false}\n />\n </div>\n );\n};\n\nexport default AttributesRenderer;\n","import React from 'react';\nimport {DataTypeValue} from '@reltio/components';\nimport {useStyles} from './styles';\nimport {RelationshipsTableColumnData} from '../../../types';\n\ntype Props = {\n columnData: RelationshipsTableColumnData;\n value: unknown;\n};\n\nconst DefaultCellValueRenderer = ({value, columnData: {dataTypeDefinition}}: Props) => {\n const styles = useStyles();\n return (\n <div className={styles.defaultWrapper}>\n <DataTypeValue value={value} dataTypeDefinition={dataTypeDefinition} />\n </div>\n );\n};\n\nexport default DefaultCellValueRenderer;\n","import {assoc, split, slice, values, length, path, cond, map, pathEq, pipe, reduce, T} from 'ramda';\nimport {defaultGetRowCellHeight} from '@reltio/components';\nimport {Connection, getEntityType, getRelationType, getOvAttributeValuesByPath, Metadata} from '@reltio/mdm-sdk';\nimport HeadCellRenderer from './cell-renderers/HeadCellRenderer';\nimport EntityProfileRenderer from './cell-renderers/EntityProfileRenderer';\nimport AttributesRenderer from './cell-renderers/AttributesRenderer';\nimport DefaultCellValueRenderer from './cell-renderers/DefaultCellValueRenderer';\nimport {RelationshipsTableColumnData} from '../../types';\n\nconst getAttrPathFromColumnId = pipe(split('.'), slice(2, Infinity));\n\nconst getRelationAttributeValues = (attrPath, relation) =>\n pipe(path(['object', 'attributes']), getOvAttributeValuesByPath(attrPath))(relation);\n\nconst getRowValueByColumnId = (metadata: Metadata, {entity, relation}: Connection, columnId: string) => {\n switch (columnId) {\n case 'entity.label':\n return {entity, entityType: getEntityType(metadata, entity.entityType), relation};\n case 'relation.type':\n return relation.relationType;\n case 'relation.label':\n return relation.relationLabel;\n case 'relation.activeness.startDate':\n return relation.startDate;\n case 'relation.activeness.endDate':\n return relation.endDate;\n case 'relation.attributes':\n return {\n attributes: relation.object.attributes,\n attributeTypes: getRelationType(metadata, relation.relationType).attributes\n };\n default: {\n const attrPath = getAttrPathFromColumnId(columnId);\n return getRelationAttributeValues(attrPath, relation);\n }\n }\n};\n\nconst getBasicTableRowsData = (\n metadata: Metadata,\n columnsData: RelationshipsTableColumnData[],\n connections: Connection[]\n) => {\n return (connections || []).map((connection) =>\n pipe(\n reduce((acc, {id}) => assoc(id, getRowValueByColumnId(metadata, connection, id), acc), {}),\n assoc('rawValue', connection)\n )(columnsData)\n );\n};\n\nconst getNestedPathByColumnId = (columnId: string) => {\n if (columnId.startsWith('relation.attributes')) {\n const attrPath = getAttrPathFromColumnId(columnId);\n return attrPath.length > 1 ? attrPath.slice(0, -1) : null;\n } else {\n return null;\n }\n};\n\nconst getCellValueRenderer = (columnId: string) => {\n switch (columnId) {\n case 'entity.label':\n return EntityProfileRenderer;\n case 'relation.attributes':\n return AttributesRenderer;\n default:\n return DefaultCellValueRenderer;\n }\n};\n\nconst getColumnDataByColumnId = (columnData: RelationshipsTableColumnData) => ({\n sortable: true,\n resizable: true,\n ...columnData,\n headCellRenderer: HeadCellRenderer,\n nestedPath: getNestedPathByColumnId(columnData.id),\n rowCellValueRenderer: getCellValueRenderer(columnData.id)\n});\n\nconst getBasicTableColumnsData = map(getColumnDataByColumnId);\n\nconst calculateAttributesCellHeight = ({columnData, cell}) => {\n const attributesCount = pipe(path(['values', 0, 'attributes']), values, length)(cell);\n return attributesCount > columnData.maxAttrsToShow\n ? columnData.maxAttrsToShow * 26 + 49\n : attributesCount * 26 + 25;\n};\n\nconst getStaticRowCellHeight = cond([\n [pathEq(['columnData', 'id'], 'relation.attributes'), calculateAttributesCellHeight],\n [T, defaultGetRowCellHeight]\n]);\n\nexport {getBasicTableRowsData, getBasicTableColumnsData, getStaticRowCellHeight};\n","import React from 'react';\nimport classnames from 'classnames';\nimport {useStyles} from './styles';\n\ntype Props = {\n cell: {\n values: unknown[];\n };\n CellValueRenderer: React.ElementType;\n isInactiveRelation?: boolean;\n};\n\nconst RowCellRenderer = ({cell, CellValueRenderer, ...otherProps}: Props) => {\n const styles = useStyles();\n return (\n <div className={classnames(styles.rowCell, {[styles.inactiveRowCell]: otherProps.isInactiveRelation})}>\n {cell.values.map((value, index) => (\n <CellValueRenderer key={index} value={value} {...otherProps} />\n ))}\n </div>\n );\n};\n\nexport default RowCellRenderer;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n menuItem: {\n minHeight: '32px',\n color: theme.palette.text.secondary\n },\n menuText: {\n color: theme.palette.text.primary,\n fontSize: '13px',\n lineHeight: '15px',\n letterSpacing: 0,\n marginLeft: '16px'\n },\n buttons: {\n display: 'flex',\n alignItems: 'center',\n paddingRight: '5px'\n }\n}));\n","import React, {forwardRef, ReactNode} from 'react';\nimport MenuItem from '@mui/material/MenuItem';\nimport Typography from '@mui/material/Typography';\nimport {noop, withTooltip} from '@reltio/components';\nimport {useStyles} from './styles';\n\nconst MenuItemWithTooltip = withTooltip(MenuItem);\n\ntype Item = {\n text?: string;\n disabled?: boolean;\n icon: ReactNode;\n tooltip?: string;\n onClick?: (e) => void;\n};\n\ntype Props = {\n item: Item;\n onMenuClose?: () => void;\n};\n\nconst MenuItemRenderer = forwardRef(({item, onMenuClose = noop}: Props, ref: React.Ref<HTMLLIElement>) => {\n const styles = useStyles();\n const {icon, disabled, text, tooltip, onClick} = item;\n const handleClick = (e) => {\n onMenuClose();\n onClick(e);\n };\n\n return (\n <MenuItemWithTooltip\n tooltipTitle={tooltip}\n showForDisabled={true}\n classes={{root: styles.menuItem}}\n onClick={handleClick}\n disabled={disabled}\n ref={ref}\n >\n {icon}\n <Typography classes={{root: styles.menuText}}>{text}</Typography>\n </MenuItemWithTooltip>\n );\n});\nMenuItemRenderer.displayName = 'MenuItemRenderer';\n\nexport default MenuItemRenderer;\n","import React, {useCallback, useState} from 'react';\nimport {useSelector} from 'react-redux';\nimport mdmModule from '@reltio/mdm-module';\nimport i18n from 'ui-i18n';\nimport DeleteIcon from '@mui/icons-material/Delete';\nimport MoreVertIcon from '@mui/icons-material/MoreVert';\nimport {ConfirmationDialog, DropDownMenuButton, noop, SmallIconButton} from '@reltio/components';\nimport MenuItemRenderer from './MenuItemRenderer';\nimport {checkMetadataPermission, Connection, getLabel, getRelationType, MetadataPermissions} from '@reltio/mdm-sdk';\nimport {pipe, prop} from 'ramda';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n disableDelete?: boolean;\n connection: Connection;\n onMenuOpen?: () => void;\n onMenuClose?: () => void;\n onDelete: () => void;\n};\n\nexport const RelationshipMenuButton = ({\n disableDelete,\n connection: {entity, relation},\n onMenuOpen = noop,\n onMenuClose = noop,\n onDelete\n}: Props) => {\n const styles = useStyles();\n\n const metadata = useSelector(mdmModule.selectors.getMetadata);\n\n const hasDeletePermission = pipe(\n prop('relationType'),\n getRelationType(metadata),\n checkMetadataPermission(MetadataPermissions.DELETE)\n )(relation);\n\n const canDelete = !disableDelete && hasDeletePermission;\n\n const [pendingDeletion, setPendingDeletion] = useState(false);\n const showDeleteConfirmation = () => setPendingDeletion(true);\n const hideDeleteConfirmation = () => setPendingDeletion(false);\n\n const actions = [\n {\n disabled: !canDelete,\n text: i18n.text('Delete'),\n icon: <DeleteIcon />,\n tooltip: canDelete ? null : i18n.text(\"You don't have permissions to delete\"),\n onClick: showDeleteConfirmation\n }\n ];\n\n const handleMenuClose = useCallback(() => {\n if (!pendingDeletion) {\n onMenuClose();\n }\n }, [pendingDeletion, onMenuClose]);\n const truncateWithEllipsis = (text: string) => (text.length > 17 ? `${text.substring(0, 17)}...` : text);\n\n return (\n <div className={styles.buttons}>\n <DropDownMenuButton\n MenuItemRenderer={MenuItemRenderer}\n menuId={'relationships-table-actions'}\n buttonComponent={SmallIconButton}\n buttonProps={{\n icon: MoreVertIcon,\n size: 'S'\n }}\n menuItems={actions}\n onMenuOpen={onMenuOpen}\n onMenuClose={handleMenuClose}\n />\n <ConfirmationDialog\n open={pendingDeletion}\n title={i18n.text('Do you want to delete relationship \"${label}\"?', {\n label: truncateWithEllipsis(getLabel(entity.entityLabel))\n })}\n content={i18n.text(\n 'This relationship will be removed and all the values in the relationship will be permanently deleted. \\\nAre you sure you want to delete this relationship?'\n )}\n onSave={pipe(hideDeleteConfirmation, onMenuClose, onDelete)}\n onDiscard={pipe(hideDeleteConfirmation, onMenuClose)}\n saveCaption={i18n.text('Delete')}\n discardCaption={i18n.text('Cancel')}\n />\n </div>\n );\n};\n\nexport default RelationshipMenuButton;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n tableContainer: {\n flex: 1,\n overflow: 'hidden',\n display: 'flex',\n zIndex: 0\n },\n hoveredRowRightContentWrapper: {\n width: '100%',\n pointerEvents: 'none!important' as any\n },\n menuButtonContainer: {\n position: 'absolute',\n top: 'calc(50% - 12px)',\n right: 0,\n pointerEvents: 'all'\n },\n tooltipAnchor: {\n width: '100%',\n height: '1px'\n }\n});\n","import React, {ForwardedRef, memo, useCallback, useMemo, useState} from 'react';\nimport {Connection, Metadata} from '@reltio/mdm-sdk';\nimport {\n BasicTable,\n ColumnData,\n ColumnFilter,\n RowCellAutoSizer,\n Sorting,\n useDynamicRowCellHeight\n} from '@reltio/components';\nimport Tooltip from '@mui/material/Tooltip';\nimport i18n from 'ui-i18n';\nimport {either} from 'ramda';\nimport {getIsInactiveRelation} from '../../services/helpers';\nimport {getBasicTableColumnsData, getBasicTableRowsData, getStaticRowCellHeight} from './helpers';\nimport RowCellRenderer from './cell-renderers/RowCellRenderer';\nimport RelationshipMenuButton from '../RelationshipMenuButton/RelationshipMenuButton';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n metadata: Metadata;\n connections: Connection[];\n columnsData: ColumnData[];\n sorting: Sorting;\n onSort: (field: string) => void;\n filters?: Record<string, ColumnFilter>;\n onFilter: (event: {columnId: string; filter: ColumnFilter}) => void;\n onRowClick: (rowIndex: number) => void;\n onDelete: (relationUri: string) => void;\n tableRef: ForwardedRef<unknown>;\n readOnly?: boolean;\n};\n\nconst RelationshipsTable = ({\n metadata,\n connections,\n columnsData,\n sorting,\n onSort,\n filters,\n onFilter,\n onRowClick,\n tableRef,\n onDelete,\n readOnly\n}: Props) => {\n const styles = useStyles();\n\n const tableRowsData = useMemo(\n () => getBasicTableRowsData(metadata, columnsData, connections),\n [metadata, connections, columnsData]\n );\n const tableColumnsData = useMemo(() => getBasicTableColumnsData(columnsData), [columnsData]);\n\n const {getDynamicRowCellHeight, changeRowCellHeight} = useDynamicRowCellHeight();\n const getRowCellHeight = useCallback(either(getDynamicRowCellHeight, getStaticRowCellHeight), [\n getDynamicRowCellHeight,\n getStaticRowCellHeight\n ]);\n const [hoverRowIndex, setHoverRowIndex] = useState<number>(null);\n\n const renderRowCell = useCallback(\n (props) => {\n const isInactiveRelation = getIsInactiveRelation(props.rowValue.rawValue);\n return (\n <RowCellAutoSizer onChangeHeight={changeRowCellHeight} {...props}>\n <RowCellRenderer {...props} isInactiveRelation={isInactiveRelation} />\n </RowCellAutoSizer>\n );\n },\n [changeRowCellHeight]\n );\n\n const [isActionsMenuOpen, setIsActionsMenuOpen] = useState(false);\n\n const handleActionsMenuOpen = useCallback(() => setIsActionsMenuOpen(true), []);\n const handleActionsMenuClose = useCallback(() => {\n setHoverRowIndex(null);\n setIsActionsMenuOpen(false);\n }, []);\n\n const onRowHover = useCallback(\n (rowIndex) => setHoverRowIndex((prevHoverRowIndex) => (isActionsMenuOpen ? prevHoverRowIndex : rowIndex)),\n [isActionsMenuOpen]\n );\n\n const hoveredRowRightContent = useMemo(() => {\n const connection: Connection = hoverRowIndex != null ? tableRowsData[hoverRowIndex].rawValue : null;\n const isInactiveRelation = getIsInactiveRelation(connection);\n\n return (\n connection && (\n <>\n <Tooltip\n key={connection.relation.relationUri}\n open={!isActionsMenuOpen && isInactiveRelation}\n title={i18n.text('Inactive')}\n >\n <div className={styles.tooltipAnchor} />\n </Tooltip>\n <div className={styles.menuButtonContainer}>\n <RelationshipMenuButton\n disableDelete={readOnly}\n connection={connection}\n onMenuOpen={handleActionsMenuOpen}\n onMenuClose={handleActionsMenuClose}\n onDelete={() => onDelete(connection.relation.relationUri)}\n />\n </div>\n </>\n )\n );\n }, [isActionsMenuOpen, onDelete, tableRowsData, hoverRowIndex]);\n\n return (\n <div className={styles.tableContainer}>\n <BasicTable\n fixFirstColumn={true}\n columnsData={tableColumnsData}\n rowsData={tableRowsData}\n sorting={sorting}\n onSort={onSort}\n filters={filters}\n onFilter={onFilter}\n defaultColumnWidth={250}\n defaultColumnMinWidth={200}\n headRowHeight={48}\n getRowCellHeight={getRowCellHeight}\n renderRowCell={renderRowCell}\n onRowClick={onRowClick}\n ref={tableRef}\n hoverStateEnabled={true}\n hoverRowIndex={hoverRowIndex}\n onRowHover={onRowHover}\n hoveredRowRightContent={hoveredRowRightContent}\n classes={{\n hoveredRowRightContentWrapper: styles.hoveredRowRightContentWrapper\n }}\n />\n </div>\n );\n};\n\nexport default memo(RelationshipsTable);\n","import {AttributeType, Relation} from '@reltio/mdm-sdk';\nimport {CrosswalksByTypes, groupCrosswalksByTypesAndSources} from '@reltio/components';\nimport {assoc, map, pipe, propOr} from 'ramda';\n\ntype TableRow = {\n source: string;\n crosswalksByTypes: CrosswalksByTypes;\n};\n\nexport const buildTableRowsData = (relation: Relation, selectedAttributeTypes: AttributeType[] = []): TableRow[] => {\n return pipe(\n propOr([], 'crosswalks'),\n map(assoc('ownerType', 'entity')),\n groupCrosswalksByTypesAndSources(relation.type, selectedAttributeTypes)\n )(relation);\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles(() => ({\n tableRow: {\n '& + &': {\n marginTop: '4px'\n },\n margin: 'auto',\n maxWidth: '448px'\n }\n}));\n","import React, {memo, useCallback, useMemo, useState} from 'react';\nimport {\n AttributeType,\n checkCanDeleteCrosswalk,\n checkCanEditCrosswalk,\n getRelationType,\n Metadata,\n Relation,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {DeleteCrosswalkEvent, EditCrosswalkEvent, SourceCrosswalksRow} from '@reltio/components';\nimport {append, ifElse, includes, without} from 'ramda';\nimport {buildTableRowsData} from './helpers';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n readOnly?: boolean;\n relation: Relation;\n metadata: Metadata;\n selectedAttributeTypes?: AttributeType[];\n onDeleteCrosswalk: (event: DeleteCrosswalkEvent) => void;\n onEditCrosswalk: (event: EditCrosswalkEvent) => void;\n};\n\nconst LegendTable = ({\n readOnly,\n relation,\n metadata,\n selectedAttributeTypes,\n onDeleteCrosswalk,\n onEditCrosswalk\n}: Props) => {\n const styles = useStyles();\n\n const relationType: TRelationType = getRelationType(metadata, relation.type);\n\n const rowsData = useMemo(\n () => buildTableRowsData(relation, selectedAttributeTypes),\n [relation, selectedAttributeTypes]\n );\n const [expandedSources, setExpandedSources] = useState<string[]>([]);\n\n const handleDelete = useCallback(\n (crosswalkId: string) => {\n onDeleteCrosswalk({entityUri: relation.uri, crosswalkId});\n },\n [onDeleteCrosswalk, relation.uri]\n );\n\n const handleEdit = useCallback(\n (event: Omit<EditCrosswalkEvent, 'entityUri'>) => {\n onEditCrosswalk({entityUri: relation.uri, ...event});\n },\n [onEditCrosswalk, relation.uri]\n );\n\n return (\n <div>\n {rowsData.map(({source, crosswalksByTypes}) => {\n return (\n <div key={source} className={styles.tableRow}>\n <SourceCrosswalksRow\n source={source}\n crosswalksByTypes={crosswalksByTypes}\n expanded={expandedSources.includes(source)}\n disableEditCrosswalk={!checkCanEditCrosswalk(relationType) || readOnly}\n disableDeleteCrosswalk={!checkCanDeleteCrosswalk(relationType) || readOnly}\n onEdit={handleEdit}\n onDelete={handleDelete}\n onToggleExpanded={() => {\n setExpandedSources(ifElse(includes(source), without([source]), append(source)));\n }}\n />\n </div>\n );\n })}\n </div>\n );\n};\n\nexport default memo(LegendTable);\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n header: {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n padding: '20px 12px',\n borderBottom: '1px solid rgba(0, 0, 0, 0.12)'\n },\n title: {\n fontWeight: 500,\n fontSize: '20px',\n lineHeight: '23px',\n letterSpacing: '0.25px',\n color: theme.palette.text.primary,\n marginLeft: '12px'\n },\n hint: {\n color: theme.palette.text.secondary,\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n alignSelf: 'flex-start',\n margin: '4px 14px 10px'\n },\n hintText: {\n marginLeft: '8px',\n fontSize: '12px',\n lineHeight: '16px'\n },\n buttons: {\n display: 'flex',\n padding: '8px 6px 4px'\n },\n buttonLabel: {\n fontSize: '14px',\n fontWeight: 500,\n lineHeight: '16px'\n },\n icon: {\n fontSize: '18px',\n marginRight: '8px'\n },\n editor: {\n paddingLeft: 25,\n margin: 'auto',\n maxWidth: '448px',\n boxSizing: 'border-box',\n marginBottom: '4px'\n },\n tableContainer: {\n overflowY: 'auto',\n overflowX: 'hidden',\n paddingLeft: '16px',\n paddingRight: '6px'\n }\n}));\n","import React, {memo, useState} from 'react';\nimport i18n from 'ui-i18n';\nimport {useSelector} from 'react-redux';\nimport mdmModule from '@reltio/mdm-module';\nimport InfoIcon from '@mui/icons-material/Info';\nimport AddIcon from '@mui/icons-material/Add';\nimport Button from '@mui/material/Button';\nimport LegendTable from '../LegendTable/LegendTable';\nimport {\n AttributeType,\n checkCanCreateCrosswalk,\n getRelationType,\n Metadata,\n Relation,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {\n AddCrosswalkEvent,\n CrosswalkEditor,\n DeleteCrosswalkEvent,\n EditCrosswalkEvent,\n withTooltip\n} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\nconst ButtonWithTooltip = withTooltip(Button);\n\ntype Props = {\n className?: string;\n readOnly?: boolean;\n relation: Relation;\n selectedAttributeTypes?: AttributeType[];\n onAddCrosswalk: (event: AddCrosswalkEvent) => void;\n onDeleteCrosswalk: (event: DeleteCrosswalkEvent) => void;\n onEditCrosswalk: (event: EditCrosswalkEvent) => void;\n};\n\nconst LegendPanel = ({\n className,\n readOnly,\n relation,\n selectedAttributeTypes,\n onAddCrosswalk,\n onDeleteCrosswalk,\n onEditCrosswalk\n}: Props) => {\n const styles = useStyles();\n\n const metadata: Metadata = useSelector(mdmModule.selectors.getMetadata);\n const relationType: TRelationType = getRelationType(metadata, relation.type);\n\n const [openEditor, setOpenEditor] = useState(false);\n const canAdd = checkCanCreateCrosswalk(relationType) && !readOnly;\n\n return (\n <div className={className}>\n <div className={styles.header}>\n <span className={styles.title}>{i18n.text('Legend')}</span>\n </div>\n <div className={styles.buttons}>\n <ButtonWithTooltip\n color=\"primary\"\n showForDisabled={true}\n disabled={!canAdd}\n tooltipTitle={canAdd ? null : i18n.text(\"You don't have permissions to add crosswalk\")}\n onClick={() => setOpenEditor(true)}\n >\n <AddIcon className={styles.icon} />\n <div className={styles.buttonLabel}>{i18n.text('Crosswalk')}</div>\n </ButtonWithTooltip>\n </div>\n <div className={styles.hint}>\n <InfoIcon className={styles.icon} />\n <span className={styles.hintText}>\n {i18n.text('You can drag a crosswalk to add values to attributes swimlanes')}\n </span>\n </div>\n <div className={styles.tableContainer}>\n {openEditor && (\n <CrosswalkEditor\n className={styles.editor}\n onAdd={(crosswalk) => onAddCrosswalk({entity: relation, crosswalk})}\n onClose={() => setOpenEditor(false)}\n />\n )}\n <LegendTable\n readOnly={readOnly}\n metadata={metadata}\n relation={relation}\n selectedAttributeTypes={selectedAttributeTypes}\n onDeleteCrosswalk={onDeleteCrosswalk}\n onEditCrosswalk={onEditCrosswalk}\n />\n </div>\n </div>\n );\n};\n\nexport default memo(LegendPanel);\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n entityInfo: {\n flex: '0 1 auto',\n overflow: 'hidden',\n minWidth: '100px'\n },\n entityLabelContainer: {\n display: 'flex',\n alignItems: 'center',\n overflow: 'hidden'\n },\n entityLabel: {\n lineHeight: '1.2',\n letterSpacing: '0.25px',\n color: theme.palette.text.primary\n },\n infoIcon: {\n fontSize: '16px',\n color: theme.palette.text.secondary,\n marginLeft: '5px'\n },\n profileBand: {\n margin: '-10px',\n maxWidth: '500px'\n },\n entityTypeBadge: {\n marginTop: '7px'\n }\n}));\n","import React from 'react';\nimport {Entity, getLabel} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport {ExpandedValueTooltip, LightArrowTooltip, ProfileBand, EntityTypeBadge} from '@reltio/components';\nimport InfoIcon from '@mui/icons-material/Info';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n entity: Entity;\n};\n\nconst EntityInfo = ({entity}: Props) => {\n const styles = useStyles();\n const label = getLabel(entity.label);\n return (\n <div className={styles.entityInfo}>\n <div className={styles.entityLabelContainer}>\n <ExpandedValueTooltip value={label}>\n <Typography variant=\"h6\" className={styles.entityLabel} noWrap>\n {label}\n </Typography>\n </ExpandedValueTooltip>\n <LightArrowTooltip\n title={<ProfileBand className={styles.profileBand} entity={entity} />}\n placement={'right'}\n >\n <InfoIcon className={styles.infoIcon} />\n </LightArrowTooltip>\n </div>\n <EntityTypeBadge className={styles.entityTypeBadge} entity={entity} size={'medium'} />\n </div>\n );\n};\n\nexport default EntityInfo;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n root: {\n flexShrink: 0,\n overflow: 'hidden',\n width: '110px'\n },\n label: {\n color: theme.palette.text.secondary,\n fontSize: '13px'\n }\n}));\n","import React from 'react';\nimport {ConnectionRelation} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport {ExpandedValueTooltip} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n relation: ConnectionRelation;\n};\n\nconst RelationDirection = ({relation}: Props) => {\n const styles = useStyles();\n const {direction, relationLabel} = relation;\n return (\n <div className={styles.root}>\n <ExpandedValueTooltip value={relationLabel}>\n <Typography variant={'subtitle2'} className={styles.label} align={'center'} noWrap>\n {relationLabel}\n </Typography>\n </ExpandedValueTooltip>\n <svg width=\"110\" height=\"12\" fill=\"black\" fillOpacity=\"0.3\">\n {direction === 'out' && <polygon points=\"94 0, 110 6, 94 12, 94 9, 0 9, 0 3, 94 3\" />}\n {direction === 'bidirectional' && (\n <polygon points=\"94 0, 110 6, 94 12, 94 9, 16 9, 16 12, 0 6, 16 0, 16 3, 94 3\" />\n )}\n {direction === 'in' && <polygon points=\"16 12, 0 6, 16 0, 16 3, 110 3, 110 9, 16 9\" />}\n </svg>\n </div>\n );\n};\n\nexport default RelationDirection;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles(() => ({\n root: {\n '&:hover $editButton': {\n visibility: 'visible'\n }\n },\n editButton: {\n visibility: 'hidden',\n marginLeft: '4px',\n marginBottom: '4px'\n },\n paper: {\n width: '150px',\n border: '3px solid rgba(0, 0, 0, 0.3)',\n borderRadius: '4px',\n boxSizing: 'border-box',\n overflow: 'hidden'\n }\n}));\n","import React, {KeyboardEvent, useRef, useState} from 'react';\nimport {formatDate} from '@reltio/mdm-sdk';\nimport {DateEditor, SmallIconButton} from '@reltio/components';\nimport EditIcon from '@mui/icons-material/Edit';\nimport Popover from '@mui/material/Popover';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n value: number;\n onChange: (value: number) => void;\n readOnly?: boolean;\n};\n\nconst RelationDate = ({value = null, onChange, readOnly}: Props) => {\n const styles = useStyles();\n const ref = useRef<HTMLSpanElement>();\n\n const [showEditor, setShowEditor] = useState(false);\n const openEditor = () => setShowEditor(true);\n const closeEditor = () => setShowEditor(false);\n\n const [editedValue, setEditedValue] = useState(value);\n\n const applyChangesAndClose = () => {\n if (editedValue !== value) {\n onChange(editedValue);\n }\n closeEditor();\n };\n\n const onKeyUp = (event: KeyboardEvent<HTMLDivElement>) => {\n if (event.key === 'Enter') applyChangesAndClose();\n else if (event.key === 'Escape') closeEditor();\n };\n\n return (\n <span ref={ref} className={styles.root}>\n {value && formatDate(value)}\n <SmallIconButton\n disabled={readOnly}\n icon={EditIcon}\n size={'XXS'}\n className={styles.editButton}\n onClick={openEditor}\n />\n <Popover\n classes={{paper: styles.paper}}\n open={showEditor}\n anchorEl={ref.current}\n anchorOrigin={{vertical: 'top', horizontal: 'left'}}\n transformOrigin={{vertical: 14, horizontal: 20}}\n onKeyUp={onKeyUp}\n onBackdropClick={applyChangesAndClose}\n >\n <DateEditor\n label={undefined}\n value={editedValue && new Date(editedValue)}\n onChange={(value) => setEditedValue(value && value.valueOf())}\n slotProps={{\n textField: {\n size: 'small',\n hiddenLabel: true,\n InputProps: {\n autoFocus: true,\n disableUnderline: true,\n fullWidth: true\n }\n }\n }}\n />\n </Popover>\n </span>\n );\n};\n\nexport default RelationDate;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n relationBand: {\n flexShrink: 0,\n boxShadow: 'inset 0px -1px 0px rgba(0,0,0,0.06)',\n padding: '16px 19px'\n },\n inactiveRelationBand: {\n opacity: 0.6,\n background: 'rgba(185, 188, 197, 0.18)'\n },\n toolbar: {\n display: 'flex',\n alignItems: 'center',\n gap: '16px',\n marginBottom: '10px'\n },\n mainInfo: {\n display: 'flex',\n gap: '16px',\n marginLeft: '40px'\n },\n detailsInfo: {\n display: 'flex',\n gap: '34px',\n marginLeft: '40px',\n marginTop: '17px',\n color: theme.palette.text.secondary,\n fontSize: '13px'\n },\n detailTitle: {\n color: theme.palette.text.primary,\n flexShrink: 0,\n marginRight: '4px'\n },\n directionalLabel: {\n display: 'flex',\n overflow: 'hidden',\n '& span': {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap'\n }\n },\n relationDate: {\n flexShrink: 0\n },\n commentsContainer: {\n marginRight: '18px'\n }\n}));\n","import React, {memo} from 'react';\nimport {CollaborationObjectTypes, Connection, createRelatedObjectUris, Entity} from '@reltio/mdm-sdk';\nimport {\n CommentsContainer,\n COMMENTS_CONTAINER_VISIBILITY_AREA,\n ExpandedValueTooltip,\n SmallIconButton,\n Spacer\n} from '@reltio/components';\nimport classnames from 'classnames';\nimport ArrowBackIcon from '@mui/icons-material/ArrowBack';\nimport Typography from '@mui/material/Typography';\nimport i18n from 'ui-i18n';\nimport EntityInfo from './EntityInfo/EntityInfo';\nimport RelationDirection from './RelationDirection/RelationDirection';\nimport RelationDate from './RelationDate/RelationDate';\nimport {getIsInactiveRelation} from '../../services/helpers';\nimport RelationshipMenuButton from '../RelationshipMenuButton/RelationshipMenuButton';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n readOnly?: boolean;\n entity: Entity;\n connection: Connection;\n onNavigateBack: () => void;\n onDelete: () => void;\n onChangeActivenessDate: (attributeName: string, value: number) => void;\n};\n\nconst RelationshipBand = ({readOnly, entity, connection, onNavigateBack, onDelete, onChangeActivenessDate}: Props) => {\n const isInactiveRelation = getIsInactiveRelation(connection);\n const styles = useStyles();\n return (\n <div\n className={classnames(styles.relationBand, COMMENTS_CONTAINER_VISIBILITY_AREA, {\n [styles.inactiveRelationBand]: isInactiveRelation\n })}\n data-reltio-id=\"relationship-band-wrapper\"\n >\n <div className={styles.toolbar}>\n <SmallIconButton icon={ArrowBackIcon} size={'S'} onClick={() => onNavigateBack()} />\n <Typography variant={'subtitle2'} display={'inline'}>\n {i18n.text('Back to relationships')}\n </Typography>\n <Spacer />\n <div className={styles.commentsContainer}>\n <CommentsContainer\n uri={connection.relation.relationUri}\n relatedObjectUris={createRelatedObjectUris(CollaborationObjectTypes.RELATION, {\n entityUri: entity?.uri,\n connection\n })}\n objectType={CollaborationObjectTypes.RELATION}\n allowOnlyOneComment\n />\n </div>\n <RelationshipMenuButton connection={connection} onDelete={onDelete} disableDelete={readOnly} />\n </div>\n <div className={styles.mainInfo}>\n <EntityInfo entity={entity} />\n <RelationDirection relation={connection.relation} />\n <EntityInfo entity={{...connection.entity.object, dataTenant: connection.entity.dataTenant}} />\n </div>\n <div className={styles.detailsInfo}>\n <div className={styles.directionalLabel}>\n <span className={styles.detailTitle}>{i18n.text('Directional label:')}</span>\n <ExpandedValueTooltip value={connection.relation.relationLabel}>\n <span>{connection.relation.relationLabel}</span>\n </ExpandedValueTooltip>\n </div>\n <div className={styles.relationDate}>\n <span className={styles.detailTitle}>{i18n.text('Start date:')}</span>\n <RelationDate\n value={connection.relation.startDate}\n onChange={(value) => onChangeActivenessDate('startDate', value)}\n readOnly={readOnly}\n />\n </div>\n <div className={styles.relationDate}>\n <span className={styles.detailTitle}>{i18n.text('End date:')}</span>\n <RelationDate\n value={connection.relation.endDate}\n onChange={(value) => onChangeActivenessDate('endDate', value)}\n readOnly={readOnly}\n />\n </div>\n </div>\n </div>\n );\n};\n\nexport default memo(RelationshipBand);\n","import {ErrorPopup} from '@reltio/components';\nimport i18n from 'ui-i18n';\nimport {getRequestErrorMessage} from '@reltio/mdm-sdk';\n\nexport const showErrorMessage = (error: unknown) => {\n console.error(error); // eslint-disable-line\n ErrorPopup.addError({\n title: i18n.text('Error'),\n message: getRequestErrorMessage(error, i18n.text('Something went wrong'))\n });\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n detailsView: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n overflow: 'hidden'\n },\n locked: {\n pointerEvents: 'none'\n },\n resizablePanesWrapper: {\n flexGrow: 1\n },\n pane: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n display: 'flex',\n flexDirection: 'column',\n overflow: 'hidden'\n }\n});\n","import React, {memo, useCallback, useMemo, useState} from 'react';\nimport classnames from 'classnames';\nimport {\n ApiError,\n ApiErrorCode,\n AttributeType,\n Connection,\n deleteActivenessAttribute,\n Entity,\n getRelation,\n Relation,\n updateActivenessAttribute\n} from '@reltio/mdm-sdk';\nimport {\n AttributesTable,\n BasicView,\n CrosswalkDragLayer,\n CrosswalksDisplayProvider,\n ExpandedAttributesProvider,\n ResizablePanes,\n useCrosswalkActions,\n useModifiedEntity,\n useSafePromise\n} from '@reltio/components';\nimport LegendPanel from '../LegendPanel/LegendPanel';\nimport RelationshipBand from '../RelationshipBand/RelationshipBand';\nimport {assocPath, dissocPath, pipe} from 'ramda';\nimport {showErrorMessage} from '../../services/errors';\nimport {useCrosswalksDisplay} from '../../hooks/useCrosswalksDisplay';\nimport HTML5Backend from 'react-dnd-html5-backend';\nimport {DndProvider} from 'react-dnd';\n\nimport {useStyles} from './styles';\n\nconst MIN_PANE1_SIZE = 600;\nconst MIN_PANE2_SIZE = 480;\nconst MAX_PANE1_SIZE = -MIN_PANE2_SIZE;\n\ntype Props = {\n entity: Entity;\n connection: Connection;\n visibleColumns?: string[];\n onClose: (error?: ApiError) => void;\n onDeleteConnection: () => void;\n onChangeConnection: (connection: Connection) => void;\n onChangeVisibleColumns: (visibleColumns: string[]) => void;\n readOnly?: boolean;\n};\n\nconst RelationshipDetails = ({\n entity,\n connection,\n visibleColumns,\n onClose,\n onDeleteConnection,\n onChangeConnection,\n onChangeVisibleColumns,\n readOnly\n}: Props) => {\n const styles = useStyles();\n const displayProps = useCrosswalksDisplay();\n const [paneSize, setPaneSize] = useState(MAX_PANE1_SIZE);\n const handlePaneSizeChange = useCallback(({percentageSize}) => setPaneSize(percentageSize), []);\n\n const [selectedAttrTypes, setSelectedAttrTypes] = useState<AttributeType[]>();\n const [isLoading, setIsLoading] = useState(false);\n const relationUri = connection.relation.relationUri;\n\n const safePromise = useSafePromise();\n const onLoad = useCallback(() => setIsLoading(true), []);\n const onLoaded = useCallback(() => setIsLoading(false), []);\n const onDeleteRelation = useCallback(pipe(onDeleteConnection, onLoad), []);\n const [onError, reloadRelation] = useMemo(() => {\n const onError = (error: ApiError) => {\n if (error.errorCode === ApiErrorCode.CROSSWALK_NOT_FOUND) {\n showErrorMessage(error);\n reloadRelation();\n } else if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n onClose(error);\n } else {\n showErrorMessage(error);\n onLoaded();\n }\n };\n const reloadRelation = () => {\n safePromise(getRelation(relationUri))\n .then((newRelation: Relation) => {\n onChangeConnection(assocPath(['relation', 'object'], newRelation, connection));\n onLoaded();\n })\n .catch(onError);\n };\n return [onError, reloadRelation];\n }, [connection, onLoaded, onChangeConnection, onClose]);\n\n const {\n modifiedEntity,\n crosswalksMap,\n newlyCreatedAttributes,\n onPinAttribute,\n onIgnoreAttribute,\n onAddAttribute,\n onEditAttribute,\n onDeleteAttribute,\n emptyTempAttributeUris\n } = useModifiedEntity({\n entity: connection.relation.object,\n onModify: reloadRelation,\n onError,\n onLoad\n });\n\n const {addCrosswalk, deleteCrosswalk, editCrosswalk} = useCrosswalkActions({\n onSuccess: reloadRelation,\n onError,\n onLoad\n });\n\n const onChangeActivenessDate = useCallback(\n (attributeName: string, value: number) => {\n onLoad();\n const request = value\n ? updateActivenessAttribute({entityUri: relationUri, attributeName, value}).then(() =>\n onChangeConnection(assocPath(['relation', attributeName], value, connection))\n )\n : deleteActivenessAttribute({entityUri: relationUri, attributeName}).then(() =>\n onChangeConnection(dissocPath(['relation', attributeName], connection))\n );\n request.then(onLoaded).catch(onError);\n },\n [connection, onLoad, onLoaded, onError]\n );\n\n return (\n <BasicView className={styles.detailsView}>\n <CrosswalksDisplayProvider {...displayProps}>\n <DndProvider backend={HTML5Backend}>\n <CrosswalkDragLayer />\n <ResizablePanes\n className={classnames(styles.resizablePanesWrapper, {[styles.locked]: isLoading})}\n orientation={'vertical'}\n size={paneSize}\n minSize={MIN_PANE1_SIZE}\n maxSize={MAX_PANE1_SIZE}\n allowResize={true}\n onChange={handlePaneSizeChange}\n >\n <div className={styles.pane}>\n <RelationshipBand\n readOnly={readOnly}\n entity={entity}\n connection={connection}\n onNavigateBack={onClose}\n onDelete={onDeleteRelation}\n onChangeActivenessDate={onChangeActivenessDate}\n />\n <ExpandedAttributesProvider attributeUris={newlyCreatedAttributes}>\n <AttributesTable\n readOnly={readOnly}\n entity={modifiedEntity}\n crosswalksMap={crosswalksMap}\n isLoading={isLoading}\n onPin={onPinAttribute}\n onIgnore={onIgnoreAttribute}\n onEdit={onEditAttribute}\n onAdd={onAddAttribute}\n onDelete={onDeleteAttribute}\n emptyTempAttributeUris={emptyTempAttributeUris}\n selectedAttributeTypes={selectedAttrTypes}\n onSelectAttributeTypes={setSelectedAttrTypes}\n visibleColumns={visibleColumns}\n onChangeVisibleColumns={onChangeVisibleColumns}\n />\n </ExpandedAttributesProvider>\n </div>\n <LegendPanel\n readOnly={readOnly}\n className={styles.pane}\n relation={connection.relation.object}\n selectedAttributeTypes={selectedAttrTypes}\n onAddCrosswalk={addCrosswalk}\n onDeleteCrosswalk={deleteCrosswalk}\n onEditCrosswalk={editCrosswalk}\n />\n </ResizablePanes>\n </DndProvider>\n </CrosswalksDisplayProvider>\n </BasicView>\n );\n};\n\nexport default memo(RelationshipDetails);\n","import {useCallback, useMemo, useState, useRef} from 'react';\nimport {CrosswalkBase, debounce, eqCrosswalks} from '@reltio/mdm-sdk';\nimport {any, concat} from 'ramda';\n\nexport const useCrosswalksDisplay = () => {\n const [highlightedCrosswalks, setHighlightedCrosswalks] = useState<CrosswalkBase[]>([]);\n const highlightedCrosswalksCache = useRef([]);\n const applyHighlightedCrosswalks = useCallback(\n debounce(() => {\n setHighlightedCrosswalks([...highlightedCrosswalksCache.current]);\n }, 50),\n []\n );\n const cacheHighlightedCrosswalks = useCallback(\n (arr) => {\n highlightedCrosswalksCache.current = arr;\n applyHighlightedCrosswalks(arr);\n },\n [applyHighlightedCrosswalks]\n );\n\n const setCrosswalkHighlighted = useCallback(\n (crosswalk: CrosswalkBase, highlighted: boolean) => {\n if (!crosswalk) return;\n if (highlighted) {\n cacheHighlightedCrosswalks([crosswalk]);\n } else {\n cacheHighlightedCrosswalks([]);\n }\n },\n [cacheHighlightedCrosswalks]\n );\n\n const [focusedCrosswalks, setFocusedCrosswalks] = useState<CrosswalkBase[]>([]);\n const calculateFocusedCrosswalks = (prev: CrosswalkBase[], next: CrosswalkBase[]) =>\n concat(\n prev.filter((prevCrosswalk) => !any(eqCrosswalks(prevCrosswalk), next)),\n next.filter((nextCrosswalk) => !any(eqCrosswalks(nextCrosswalk), prev))\n );\n\n const toggleCrosswalkFocus = useCallback((crosswalk: CrosswalkBase) => {\n if (!crosswalk) return;\n setFocusedCrosswalks((prevValue) => calculateFocusedCrosswalks([crosswalk], prevValue));\n }, []);\n\n return {\n highlightedCrosswalks: useMemo(\n () => [...highlightedCrosswalks, ...focusedCrosswalks],\n [highlightedCrosswalks, focusedCrosswalks]\n ),\n focusedCrosswalks,\n toggleCrosswalkFocus,\n setCrosswalkHighlighted\n };\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n relationshipsView: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n overflowX: 'hidden',\n overflowY: 'auto',\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif',\n display: 'flex',\n flexDirection: 'column'\n },\n '@global div[role=tooltip]': {\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif'\n },\n '@global div[role=presentation]': {\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif'\n },\n pane: {\n display: 'flex',\n flexDirection: 'column',\n flex: 1,\n overflow: 'hidden',\n position: 'relative'\n }\n});\n","import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react';\nimport {Dispatch} from 'redux';\nimport {connect} from 'react-redux';\nimport {\n always,\n andThen,\n both,\n either,\n equals,\n filter,\n identity,\n map,\n otherwise,\n pipe,\n prop,\n propEq,\n update,\n when,\n not\n} from 'ramda';\nimport mdmModule, {profile} from '@reltio/mdm-module';\nimport {\n ApiError,\n ApiErrorCode,\n checkMetadataPermission,\n CollaborationObjectTypes,\n Connection,\n Entity,\n getEntitiesMapForConnections,\n getInheritancePath,\n getRelationshipsObjectIdsForCollaboration,\n isDataTenantEntity,\n Metadata,\n MetadataPermissions,\n Mode,\n RelationshipsPerspectiveConfig,\n removeRelation,\n TRelationType,\n ActivityFilter\n} from '@reltio/mdm-sdk';\nimport {\n BasicTablePagination,\n CollaborationContextProvider,\n EntitiesMapContext,\n LinearLoadIndicator,\n ScreenProfileBand,\n useCollaboration,\n useDidUpdateEffect,\n useRelationsLoader\n} from '@reltio/components';\nimport useSavedState from '../../hooks/useSavedState';\nimport {useRelationshipsTable} from '../../hooks/useRelationshipsTable';\nimport {RelationshipsSavedState} from '../../types';\nimport {DEFAULT_COLUMNS, getColumnsData, ROWS_PER_PAGE_OPTIONS} from './helpers/tableHelpers';\nimport {buildRelationshipsFilter} from './helpers/filtersHelpers';\nimport RelationshipsTableHeader from '../RelationshipsTableHeader/RelationshipsTableHeader';\nimport RelationshipsTable from '../RelationshipsTable/RelationshipsTable';\nimport RelationshipDetails from '../RelationshipDetails/RelationshipDetails';\nimport {showErrorMessage} from '../../services/errors';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n config: RelationshipsPerspectiveConfig;\n entity: Entity;\n metadata: Metadata;\n connections: Connection[];\n total: number;\n saveState: (state: RelationshipsSavedState) => void;\n getSavedState: () => Promise<RelationshipsSavedState>;\n dispatch: Dispatch;\n};\n\nconst RelationshipsView = ({\n config,\n entity,\n metadata,\n connections,\n total,\n saveState,\n getSavedState,\n dispatch\n}: Props) => {\n const styles = useStyles();\n const tableRef = useRef();\n\n const isDTEntity = isDataTenantEntity(entity);\n\n const [searchByOv, setSearchByOv] = useState(false);\n const [showInactive, setShowInactive] = useState(false);\n\n const {type: entityTypeUri} = entity || {};\n const [\n {\n visibleColumns,\n filters,\n page,\n rowsPerPage,\n sorting,\n currentRelationType,\n stateToSave,\n entityTypeOfAppliedSavedState\n },\n {\n changeColumns,\n toggleFilters,\n changeFilter,\n changePage,\n changeRowsPerPage,\n toggleSort,\n changeRelationType,\n saveCurrentState,\n applySavedState\n }\n ] = useRelationshipsTable({\n defaultColumns: DEFAULT_COLUMNS,\n defaultRowsPerPage: ROWS_PER_PAGE_OPTIONS[0],\n defaultSorting: {\n field: DEFAULT_COLUMNS[0],\n order: 'asc'\n }\n });\n\n const isSavedStateApplied = entityTypeOfAppliedSavedState === entityTypeUri;\n\n const {\n isLoading: isSavedStateLoading,\n relationsTableSavedState,\n attributesTableSavedState,\n updateRelationsTableSavedState,\n updateAttributesTableSavedState\n } = useSavedState({\n getSavedState,\n saveState,\n entityTypeUri\n });\n\n const [attributesTableVisibleColumns, setAttributesTableVisibleColumns] = useState<string[]>();\n\n useEffect(() => {\n if (!isSavedStateLoading) {\n applySavedState({savedState: relationsTableSavedState, entityTypeUri});\n }\n }, [isSavedStateLoading, entityTypeUri]); // eslint-disable-line\n\n useEffect(() => {\n if (!isSavedStateLoading) {\n setAttributesTableVisibleColumns(attributesTableSavedState?.visibleColumns);\n }\n }, [isSavedStateLoading]); // eslint-disable-line\n\n useDidUpdateEffect(() => {\n if (isSavedStateApplied) {\n updateRelationsTableSavedState(stateToSave);\n }\n }, [stateToSave]);\n\n const resetPage = () => {\n changePage(0);\n };\n useDidUpdateEffect(resetPage, [entity]);\n\n const [detailedConnectionIndex, setDetailedConnectionIndex] = useState<number>();\n const hideConnectionDetails = useCallback(() => {\n setDetailedConnectionIndex(null);\n }, []);\n\n const relationTypes: TRelationType[] = useMemo(() => {\n const inheritancePath = getInheritancePath(metadata, entityTypeUri);\n const isRelatedToEntityType = ({startObject, endObject}) =>\n inheritancePath.some(either(equals(startObject.objectTypeURI), equals(endObject.objectTypeURI)));\n return metadata.relationTypes.filter(\n both(checkMetadataPermission(MetadataPermissions.READ), isRelatedToEntityType)\n );\n }, [metadata, entityTypeUri]);\n\n const columnsData = useMemo(\n () => getColumnsData(relationTypes, currentRelationType),\n [relationTypes, currentRelationType]\n );\n const visibleColumnsData = useMemo(\n () => visibleColumns.map((id) => columnsData.find(propEq('id', id))).filter(identity),\n [visibleColumns, columnsData]\n );\n\n const relationsConfig = useMemo(() => {\n const relations = pipe(\n when(always(currentRelationType), filter(propEq('uri', currentRelationType))),\n map(prop('uri'))\n )(relationTypes);\n return {\n id: config.id,\n content: {\n inRelations: relations,\n outRelations: relations\n }\n };\n }, [config.id, currentRelationType, relationTypes]);\n\n const relationFilter = useMemo(\n () => buildRelationshipsFilter(filters, visibleColumnsData),\n [filters, visibleColumnsData]\n );\n\n const {isLoading: isRelationsLoading, reload: reloadRelations} = useRelationsLoader({\n page,\n rowsPerPage,\n config: relationsConfig,\n entity: isSavedStateApplied ? entity : null,\n filter: relationFilter,\n mode: Mode.Viewing,\n sorting,\n searchByOv,\n relationActivityFilter: showInactive ? ActivityFilter.ALL : ActivityFilter.ACTIVE_ONLY\n });\n\n const isLoading = !isSavedStateApplied || isRelationsLoading;\n\n const onSort = useCallback(pipe(toggleSort, saveCurrentState), [toggleSort, saveCurrentState]);\n const onFilter = useCallback(pipe(changeFilter, saveCurrentState), [changeFilter, saveCurrentState]);\n const onToggleFilters = useCallback(pipe(toggleFilters, saveCurrentState), [toggleFilters, saveCurrentState]);\n const onChangeColumns = useCallback(pipe(changeColumns, saveCurrentState), [changeColumns, saveCurrentState]);\n const onRelationTypeChange = useCallback(pipe(changeRelationType, saveCurrentState), [\n changeRelationType,\n saveCurrentState\n ]);\n const onChangeDetailedColumns = useCallback(\n (visibleColumns: string[]) => {\n setAttributesTableVisibleColumns(visibleColumns);\n updateAttributesTableSavedState({visibleColumns});\n },\n [updateAttributesTableSavedState]\n );\n\n const detailedConnection = connections?.[detailedConnectionIndex];\n const onChangeDetailedConnection = useCallback(\n (newConnection: Connection) => {\n dispatch(\n profile.relations.actions.relationsLoaded({\n id: config.id,\n connections: update(detailedConnectionIndex, newConnection, connections),\n total\n })\n );\n },\n [detailedConnection]\n );\n const [objectIds, objectTypes] = useMemo(() => {\n return [getRelationshipsObjectIdsForCollaboration(connections), [CollaborationObjectTypes.RELATION]];\n }, [connections]);\n\n const collaboration = useCollaboration({objectIds, objectTypes, enabled: !isDTEntity});\n const entitiesMap = useMemo(() => getEntitiesMapForConnections(connections), [connections]);\n\n const handleError = useCallback(\n (error: ApiError) => {\n showErrorMessage(error);\n if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n reloadRelations();\n }\n },\n [reloadRelations]\n );\n\n const deleteRelation = useCallback(\n (relationUri: string) => {\n pipe(removeRelation, andThen(reloadRelations), otherwise(handleError))(relationUri);\n },\n [reloadRelations, handleError]\n );\n\n const deleteRelationAndCloseDetails = useCallback(() => {\n pipe(\n removeRelation,\n andThen(pipe(hideConnectionDetails, reloadRelations)),\n otherwise((error: ApiError) => {\n if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n hideConnectionDetails();\n }\n handleError(error);\n })\n )(detailedConnection.relation.relationUri);\n }, [detailedConnection, reloadRelations, hideConnectionDetails, handleError]);\n\n const onCloseConnectionDetails = useCallback(\n (error?: ApiError) => {\n if (error) handleError(error);\n hideConnectionDetails();\n },\n [handleError, hideConnectionDetails]\n );\n\n const onToggleSearchByOv = useCallback(() => {\n setSearchByOv(not);\n }, []);\n\n const onToggleShowInactive = useCallback(() => {\n setShowInactive(not);\n }, []);\n\n return (\n <CollaborationContextProvider collaboration={collaboration}>\n <EntitiesMapContext.Provider value={entitiesMap}>\n <div className={styles.relationshipsView}>\n <ScreenProfileBand entity={entity} />\n <RelationshipsTableHeader\n total={total}\n filteringEnabled={!!filters}\n onToggleFilters={onToggleFilters}\n columnsData={columnsData}\n selectedColumns={visibleColumns}\n onChangeColumns={onChangeColumns}\n relationTypes={relationTypes}\n currentRelationType={currentRelationType}\n onRelationTypeChange={onRelationTypeChange}\n searchByOv={searchByOv}\n onToggleSearchByOv={onToggleSearchByOv}\n showInactive={showInactive}\n onToggleShowInactive={onToggleShowInactive}\n />\n <div className={styles.pane}>\n {isLoading && <LinearLoadIndicator />}\n <RelationshipsTable\n readOnly={isDTEntity}\n metadata={metadata}\n connections={connections}\n columnsData={visibleColumnsData}\n sorting={sorting}\n onSort={onSort}\n filters={filters}\n onFilter={onFilter}\n onRowClick={setDetailedConnectionIndex}\n tableRef={tableRef}\n onDelete={deleteRelation}\n />\n <BasicTablePagination\n count={total}\n rowsPerPageOptions={ROWS_PER_PAGE_OPTIONS}\n page={page}\n onChangePage={changePage}\n rowsPerPage={rowsPerPage}\n onChangeRowsPerPage={changeRowsPerPage}\n basicTableRef={tableRef}\n />\n </div>\n {detailedConnection && (\n <RelationshipDetails\n readOnly={isDTEntity}\n entity={entity}\n visibleColumns={attributesTableVisibleColumns}\n onChangeVisibleColumns={onChangeDetailedColumns}\n connection={detailedConnection}\n onClose={onCloseConnectionDetails}\n onDeleteConnection={deleteRelationAndCloseDetails}\n onChangeConnection={onChangeDetailedConnection}\n />\n )}\n </div>\n </EntitiesMapContext.Provider>\n </CollaborationContextProvider>\n );\n};\n\nconst mapStateToProps = (state, {config: {id}}) => {\n return {\n entity: mdmModule.selectors.getEntity(state),\n metadata: mdmModule.selectors.getMetadata(state),\n connections: mdmModule.selectors.getConnectionsByViewId(state, id),\n total: mdmModule.selectors.getTotalByViewId(state, id)\n };\n};\n\nexport default connect(mapStateToProps)(RelationshipsView);\n","import {buildColumnsFilter, ColumnFilter} from '@reltio/components';\nimport {FilterBuilder} from '@reltio/mdm-sdk';\nimport {RelationshipsTableColumnData} from '../../../types';\n\nexport const buildRelationshipsFilter = (\n filters: Record<string, ColumnFilter>,\n columnsData: RelationshipsTableColumnData[]\n) => {\n const filtersClause = buildColumnsFilter(columnsData, filters);\n\n return new FilterBuilder().addClause(filtersClause).build();\n};\n","import React, {useCallback, useContext, useMemo} from 'react';\nimport {Provider} from 'react-redux';\nimport {Store} from 'redux';\n\nimport createGenerateClassName from '@mui/styles/createGenerateClassName';\nimport StylesProvider from '@mui/styles/StylesProvider';\nimport ReactResizeDetector from 'react-resize-detector';\nimport {LocalizationProvider} from '@mui/x-date-pickers/LocalizationProvider';\nimport {AdapterMoment} from '@mui/x-date-pickers/AdapterMoment';\nimport {ErrorPopup, ViewIdContext, FeaturesContext} from '@reltio/components';\nimport mdmModule from '@reltio/mdm-module';\nimport {RelationshipsSavedState} from '../../types';\nimport RelationshipsView from './RelationshipsView';\nimport {promisifyCallback, RelationshipsPerspectiveConfig} from '@reltio/mdm-sdk';\n\nconst generateClassName = createGenerateClassName({\n productionPrefix: 'relationshipsPerspective',\n disableGlobal: true,\n seed: 'relP'\n});\n\ntype Props = {\n config: RelationshipsPerspectiveConfig;\n store: Store<unknown>;\n onResize?: (width: number, height: number) => void;\n saveState: (state: RelationshipsSavedState) => void;\n getSavedState: (clb: (state: RelationshipsSavedState) => void) => void;\n};\n\nconst RelationshipsPerspective = ({config, store, onResize, saveState, getSavedState}: Props) => {\n const getSavedStatePromisified: () => Promise<RelationshipsSavedState> = useCallback(\n promisifyCallback(getSavedState),\n [getSavedState]\n );\n const featuresContext = useContext(FeaturesContext);\n const showDescription = mdmModule.selectors.getShowAttributeDescription(store.getState());\n const features = useMemo(() => ({...featuresContext, showDescription}), [featuresContext, showDescription]);\n\n return (\n <Provider store={store}>\n <ViewIdContext.Provider value={config.id}>\n <FeaturesContext.Provider value={features}>\n <StylesProvider generateClassName={generateClassName}>\n <LocalizationProvider dateAdapter={AdapterMoment}>\n <ReactResizeDetector\n handleHeight\n onResize={(width, height) => onResize?.(Math.floor(width), Math.floor(height))}\n />\n {config && (\n <RelationshipsView\n config={config}\n saveState={saveState}\n getSavedState={getSavedStatePromisified}\n />\n )}\n <ErrorPopup />\n </LocalizationProvider>\n </StylesProvider>\n </FeaturesContext.Provider>\n </ViewIdContext.Provider>\n </Provider>\n );\n};\n\nexport default RelationshipsPerspective;\n","import {RelationshipsView} from '@reltio/relationships';\n\nexport default RelationshipsView;\n"],"names":["props","width","height","viewBox","xmlns","d","fill","fillRule","stroke","strokeWidth","useStyles","makeStyles","theme","color","palette","primary","main","closeIcon","position","right","bottom","transform","button","padding","FilterButton","enabled","onClick","styles","Tooltip","title","i18n","IconButton","classes","root","size","Filter","className","Close","propTypes","PropTypes","pagination","display","alignItems","justifyContent","flexShrink","borderTop","boxShadow","boxSizing","overflowY","containerType","caption","fontSize","lineHeight","displayedRows","selectRoot","marginLeft","marginRight","select","textAlign","actions","BasicTablePagination","count","rowsPerPageOptions","page","onChangePage","rowsPerPage","onChangeRowsPerPage","basicTableRef","labelRowsPerPage","resetScrollbarPosition","useCallback","pathOr","identity","handleChangePage","value","handleChangeRowsPerPage","TablePagination","classnames","selectLabel","input","backIconButtonProps","nextIconButtonProps","component","labelDisplayedRows","from","to","fromRow","toRow","countRows","onPageChange","pipe","nthArg","onRowsPerPageChange","getValue","displayName","memo","CHANGE_COLUMNS","TOGGLE_FILTERS","CHANGE_FILTER","TOGGLE_SORT","CHANGE_PAGE","CHANGE_ROWS_PER_PAGE","changeColumns","createStandardAction","toggleFilters","changeFilter","toggleSort","changePage","changeRowsPerPage","changeVisibleColumns","state","nextVisibleColumns","removedColumns","difference","visibleColumns","isRemovedColumn","columnId","includes","evolve","always","sorting","when","field","nextSortField","order","filters","keys","reduce","acc","dissoc","reducer","action","type","columnIds","payload","enableFilters","filter","assoc","prevSortField","path","prevSortOrder","toggleSortOrder","basicViewPaper","flexDirection","basicView","BasicView","forwardRef","ref","children","otherProps","Paper","paper","minHeight","fontWeight","letterSpacing","content","contentText","marginBottom","actionButtons","paddingTop","discardButton","open","onCancel","cancelCaption","onDiscard","discardCaption","onSave","saveCaption","disabledSave","Dialog","onClose","paperScrollPaper","DialogTitle","DialogContent","DialogContentText","DialogActions","disableSpacing","Button","disabled","autoFocus","menuItem","menuText","text","checkbox","SettingsMenuItemRenderer","item","onMenuClose","id","selected","MenuItem","e","Checkbox","checked","Typography","items","menuId","DropDownMenuButton","buttonComponent","SmallIconButtonWithTooltip","buttonProps","icon","SettingsIcon","tooltipTitle","menuItems","MenuItemRenderer","VerticalDivider","margin","style","borderLeft","useActions","dispatch","useMemo","Object","entries","actionName","actionCreator","buildSuggestedIds","wrapInArrayIfNeeded","length","times","n","useRelationsLoader","config","entity","relationActivityFilter","mode","searchByOv","isLoading","setIsLoading","useState","useDispatch","tenant","useSelector","mdm","metadata","dtssPath","activityFilter","globalFilter","lastLoadedTime","safePromise","useSafePromise","processContent","getUri","isObject","prop","filterRelation","isAvailableRelationTypeUri","entityTypes","filterFn","isAvailableEntityTypeUri","inRelations","outRelations","nextEntry","suggested","options","loadRelations","uri","requestConfig","sortBy","returnDates","returnObjects","activeness","relation","ActivityFilter","max","offset","addGlobalFilterToQuery","undefined","configs","concat","ifElse","map","i","request","cond","isTempUri","Promise","resolve","total","isDataTenantEntity","getRelationsForDataTenantEntity","entityUri","customerTenant","dataTenant","T","getRelationsForEntity","then","result","Array","isArray","Error","JSON","stringify","connections","profile","catch","console","warn","finally","isRequestSentRef","useRef","current","useEffect","prevMode","usePrevious","Mode","reload","DEFAULT_SAVED_STATE","relationsTable","attributesTable","RELATION_TYPE_COLUMN_ID","ATTRIBUTES_COLUMN_ID","DEFAULT_COLUMNS_DATA","label","dataTypeDefinition","DataTypes","hideable","filterable","initialWidth","autoResize","sortable","maxAttrsToShow","DEFAULT_COLUMNS","pluck","ALL_TYPES_COLUMNS","ROWS_PER_PAGE_OPTIONS","getColumnIdFromAttrUri","attributeUriToSearchUri","getColumnsDataFromRelationAttributes","attr","description","getAttrDataTypeDefinition","uniqBy","CHANGE_RELATION_TYPE","APPLY_SAVED_STATE","SAVE_CURRENT_STATE","basicTableViewState","changeRelationType","applySavedState","saveCurrentState","resetPageNumber","getDefaultVisibleColumnsForCurrentRelationType","currentRelationType","without","intersection","getSavedVisibleColumnsForCurrentRelationType","changeVisibleColumnsForCurrentRelationType","either","getFiltersFromSavedState","propOr","unless","isNil","validateFilterValue","saveVisibleColumnsForCurrentRelationType","visibleColumnsForRelationTypes","getStateToSave","pick","paddingLeft","selectMenu","textField","maxWidth","onChange","relationTypes","DropDownEditor","displayEmpty","disableUnderline","TextFieldProps","MenuProps","list","header","paddingRight","secondary","relationTypeSelector","overflow","filteringEnabled","onToggleFilters","columnsData","selectedColumns","onRelationTypeChange","onChangeColumns","onToggleSearchByOv","showInactive","onToggleShowInactive","settingItems","BasicViewHeader","variant","Spacer","SettingsMenu","ColumnsSettings","getIsInactiveRelation","connection","isActiveObject","headCell","background","rowCell","overflowWrap","inactiveRowCell","opacity","defaultWrapper","paddingBottom","entityCell","entityAvatar","inactiveEntityAvatar","backgroundColor","border","borderRadius","entityLabel","textDecoration","attributesWrapper","commentsContainer","withFilterAtBottom","headCellData","DefaultHeadCellRenderer","DescriptionIcon","entityType","isInactiveRelation","currentEntityUri","mdmModule","COMMENTS_CONTAINER_VISIBILITY_AREA","EntityTypeIcon","EntityUriLink","getEntityUriForLink","getLabel","stopPropagation","CommentsContainer","relationUri","relatedObjectUris","createRelatedObjectUris","CollaborationObjectTypes","objectType","allowOnlyOneComment","columnData","attributes","attributeTypes","attrTypes","drawLines","DataTypeValue","getAttrPathFromColumnId","split","slice","Infinity","getNestedPathByColumnId","startsWith","attrPath","getCellValueRenderer","EntityProfileRenderer","AttributesRenderer","DefaultCellValueRenderer","getBasicTableColumnsData","resizable","headCellRenderer","HeadCellRenderer","nestedPath","rowCellValueRenderer","getStaticRowCellHeight","pathEq","cell","attributesCount","values","defaultGetRowCellHeight","CellValueRenderer","index","key","buttons","MenuItemWithTooltip","withTooltip","noop","tooltip","showForDisabled","disableDelete","onMenuOpen","onDelete","hasDeletePermission","getRelationType","checkMetadataPermission","MetadataPermissions","canDelete","pendingDeletion","setPendingDeletion","hideDeleteConfirmation","Delete","handleMenuClose","SmallIconButton","MoreVertIcon","ConfirmationDialog","substring","tableContainer","flex","zIndex","hoveredRowRightContentWrapper","pointerEvents","menuButtonContainer","top","tooltipAnchor","onSort","onFilter","onRowClick","tableRef","readOnly","tableRowsData","getEntityType","relationType","relationLabel","startDate","endDate","object","getOvAttributeValuesByPath","getRelationAttributeValues","getRowValueByColumnId","getBasicTableRowsData","tableColumnsData","getDynamicRowCellHeight","changeRowCellHeight","useDynamicRowCellHeight","getRowCellHeight","hoverRowIndex","setHoverRowIndex","renderRowCell","rowValue","rawValue","RowCellAutoSizer","onChangeHeight","isActionsMenuOpen","setIsActionsMenuOpen","handleActionsMenuOpen","handleActionsMenuClose","onRowHover","rowIndex","prevHoverRowIndex","hoveredRowRightContent","BasicTable","fixFirstColumn","rowsData","defaultColumnWidth","defaultColumnMinWidth","headRowHeight","hoverStateEnabled","tableRow","marginTop","selectedAttributeTypes","onDeleteCrosswalk","onEditCrosswalk","groupCrosswalksByTypesAndSources","buildTableRowsData","expandedSources","setExpandedSources","handleDelete","crosswalkId","handleEdit","event","source","crosswalksByTypes","SourceCrosswalksRow","expanded","disableEditCrosswalk","checkCanEditCrosswalk","disableDeleteCrosswalk","checkCanDeleteCrosswalk","onEdit","onToggleExpanded","append","borderBottom","hint","alignSelf","hintText","buttonLabel","editor","overflowX","ButtonWithTooltip","onAddCrosswalk","openEditor","setOpenEditor","canAdd","checkCanCreateCrosswalk","Add","Info","CrosswalkEditor","onAdd","crosswalk","entityInfo","minWidth","entityLabelContainer","infoIcon","profileBand","entityTypeBadge","ExpandedValueTooltip","noWrap","LightArrowTooltip","ProfileBand","placement","EntityTypeBadge","direction","align","fillOpacity","points","visibility","editButton","showEditor","setShowEditor","closeEditor","editedValue","setEditedValue","applyChangesAndClose","formatDate","EditIcon","Popover","anchorEl","anchorOrigin","vertical","horizontal","transformOrigin","onKeyUp","onBackdropClick","DateEditor","Date","valueOf","slotProps","hiddenLabel","InputProps","fullWidth","relationBand","inactiveRelationBand","toolbar","gap","mainInfo","detailsInfo","detailTitle","directionalLabel","textOverflow","whiteSpace","relationDate","onNavigateBack","onChangeActivenessDate","ArrowBackIcon","showErrorMessage","error","ErrorPopup","message","getRequestErrorMessage","detailsView","left","locked","resizablePanesWrapper","flexGrow","pane","onDeleteConnection","onChangeConnection","onChangeVisibleColumns","displayProps","highlightedCrosswalks","setHighlightedCrosswalks","highlightedCrosswalksCache","applyHighlightedCrosswalks","debounce","cacheHighlightedCrosswalks","arr","setCrosswalkHighlighted","highlighted","focusedCrosswalks","setFocusedCrosswalks","toggleCrosswalkFocus","prevValue","calculateFocusedCrosswalks","prev","next","prevCrosswalk","any","eqCrosswalks","nextCrosswalk","useCrosswalksDisplay","paneSize","setPaneSize","handlePaneSizeChange","percentageSize","selectedAttrTypes","setSelectedAttrTypes","onLoad","onLoaded","onDeleteRelation","onError","reloadRelation","errorCode","ApiErrorCode","getRelation","newRelation","assocPath","modifiedEntity","crosswalksMap","newlyCreatedAttributes","onPinAttribute","onIgnoreAttribute","onAddAttribute","onEditAttribute","onDeleteAttribute","emptyTempAttributeUris","useModifiedEntity","onModify","addCrosswalk","deleteCrosswalk","editCrosswalk","useCrosswalkActions","onSuccess","attributeName","updateActivenessAttribute","deleteActivenessAttribute","dissocPath","DndProvider","backend","HTML5Backend","CrosswalkDragLayer","ResizablePanes","orientation","minSize","maxSize","allowResize","attributeUris","AttributesTable","onPin","onIgnore","onSelectAttributeTypes","relationshipsView","fontFamily","connect","saveState","getSavedState","isDTEntity","setSearchByOv","setShowInactive","entityTypeUri","stateToSave","entityTypeOfAppliedSavedState","defaultColumns","defaultSorting","defaultRowsPerPage","initState","useReducer","nextRelationType","savedState","useRelationshipsTable","isSavedStateApplied","isSavedStateLoading","relationsTableSavedState","attributesTableSavedState","updateRelationsTableSavedState","updateAttributesTableSavedState","setSavedState","changedRelationsState","setRelationsChangedState","useDidUpdateEffect","_","changedState","useSavedState","attributesTableVisibleColumns","setAttributesTableVisibleColumns","detailedConnectionIndex","setDetailedConnectionIndex","hideConnectionDetails","inheritancePath","getInheritancePath","both","startObject","endObject","some","equals","objectTypeURI","find","getReadableAttributesList","reject","updateColumnData","updateFn","getRelationColumnDataType","adjust","findIndex","propEq","updateRelationTypeColumn","getColumnsData","visibleColumnsData","relationsConfig","relations","relationFilter","filtersClause","buildColumnsFilter","FilterBuilder","addClause","build","buildRelationshipsFilter","isRelationsLoading","reloadRelations","onChangeDetailedColumns","detailedConnection","onChangeDetailedConnection","newConnection","update","objectIds","objectTypes","getRelationshipsObjectIdsForCollaboration","collaboration","useCollaboration","entitiesMap","getEntitiesMapForConnections","handleError","deleteRelation","removeRelation","andThen","otherwise","deleteRelationAndCloseDetails","onCloseConnectionDetails","not","CollaborationContext","EntitiesMapContext","ScreenProfileBand","LinearLoadIndicator","generateClassName","createGenerateClassName","productionPrefix","disableGlobal","seed","store","onResize","getSavedStatePromisified","promisifyCallback","featuresContext","useContext","FeaturesContext","showDescription","getState","features","Provider","ViewIdContext","StylesProvider","LocalizationProvider","dateAdapter","AdapterMoment","handleHeight","Math","floor"],"sourceRoot":""}
|
|
1
|
+
{"version":3,"file":"3538.js","mappings":"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","sources":["webpack://@reltio/remotes/../components/src/icons/Filter.tsx","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTableHeader/FilterButton/styles.js","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTableHeader/FilterButton/FilterButton.js","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTablePagination/styles.ts","webpack://@reltio/remotes/../components/src/components/BasicTableView/BasicTablePagination/BasicTablePagination.tsx","webpack://@reltio/remotes/../components/src/components/BasicTableView/viewState/basicTableViewState.js","webpack://@reltio/remotes/../components/src/components/BasicView/styles.ts","webpack://@reltio/remotes/../components/src/components/BasicView/BasicView.tsx","webpack://@reltio/remotes/../components/src/components/ConfirmationDialog/styles.ts","webpack://@reltio/remotes/../components/src/components/ConfirmationDialog/ConfirmationDialog.tsx","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenuItemRender/styles.ts","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenuItemRender/SettingsMenuItemRender.tsx","webpack://@reltio/remotes/../components/src/components/SettingsMenu/SettingsMenu.tsx","webpack://@reltio/remotes/../components/src/components/VerticalDivider/VerticalDivider.js","webpack://@reltio/remotes/../components/src/hooks/useActions.ts","webpack://@reltio/remotes/../components/src/hooks/useRelationsLoader.ts","webpack://@reltio/remotes/../relationships/src/hooks/useSavedState.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/helpers/tableHelpers.ts","webpack://@reltio/remotes/../relationships/src/hooks/useRelationshipsTable.ts","webpack://@reltio/remotes/../relationships/src/components/RelationTypeSelector/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationTypeSelector/RelationTypeSelector.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTableHeader/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTableHeader/RelationshipsTableHeader.tsx","webpack://@reltio/remotes/../relationships/src/services/helpers.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/HeadCellRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/EntityProfileRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/AttributesRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/DefaultCellValueRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/helpers.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/cell-renderers/RowCellRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/MenuItemRenderer.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipMenuButton/RelationshipMenuButton.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsTable/RelationshipsTable.tsx","webpack://@reltio/remotes/../relationships/src/components/LegendTable/helpers.ts","webpack://@reltio/remotes/../relationships/src/components/LegendTable/styles.ts","webpack://@reltio/remotes/../relationships/src/components/LegendTable/LegendTable.tsx","webpack://@reltio/remotes/../relationships/src/components/LegendPanel/styles.ts","webpack://@reltio/remotes/../relationships/src/components/LegendPanel/LegendPanel.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/EntityInfo/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/EntityInfo/EntityInfo.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDirection/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDirection/RelationDirection.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDate/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationDate/RelationDate.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipBand/RelationshipBand.tsx","webpack://@reltio/remotes/../relationships/src/services/errors.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipDetails/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipDetails/RelationshipDetails.tsx","webpack://@reltio/remotes/../relationships/src/hooks/useCrosswalksDisplay.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/styles.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/RelationshipsView.tsx","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/helpers/filtersHelpers.ts","webpack://@reltio/remotes/../relationships/src/components/RelationshipsView/index.tsx","webpack://@reltio/remotes/./src/relationships.ts"],"sourcesContent":["import React from 'react';\n\nconst SvgFilter: React.FC<React.SVGProps<SVGSVGElement>> = (props) => {\n return (\n <svg width={18} height={18} viewBox=\"0 0 18 18\" xmlns=\"http://www.w3.org/2000/svg\" {...props}>\n <path d=\"M18 2V0H0v2l7 8v8l4-2v-6z\" fill=\"currentColor\" fillRule=\"nonzero\" stroke=\"none\" strokeWidth={1} />\n </svg>\n );\n};\n\nexport default SvgFilter;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n 'filterIcon--enabled': {\n color: theme.palette.primary.main\n },\n closeIcon: {\n position: 'absolute',\n right: '3px',\n bottom: '3px',\n transform: 'scale(0.5)'\n },\n button: {\n padding: '11px'\n }\n}));\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport i18n from 'ui-i18n';\nimport IconButton from '@mui/material/IconButton';\nimport CloseIcon from '@mui/icons-material/Close';\nimport Tooltip from '@mui/material/Tooltip';\nimport FilterIcon from '../../../../icons/Filter';\nimport {useStyles} from './styles';\n\nconst FilterButton = ({enabled, onClick}) => {\n const styles = useStyles();\n\n return (\n <Tooltip title={enabled ? i18n.text('Clear all filters') : i18n.text('Filter')}>\n <IconButton onClick={onClick} classes={{root: styles.button}} size=\"large\">\n {enabled ? (\n <>\n <FilterIcon className={styles['filterIcon--enabled']} />\n <CloseIcon color=\"primary\" className={styles.closeIcon} />\n </>\n ) : (\n <FilterIcon />\n )}\n </IconButton>\n </Tooltip>\n );\n};\n\nFilterButton.propTypes = {\n enabled: PropTypes.bool,\n onClick: PropTypes.func\n};\n\nexport default FilterButton;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n pagination: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'flex-end',\n height: '56px',\n flexShrink: 0,\n borderTop: '1px solid rgba(0,0,0,0.12)',\n boxShadow: 'none',\n boxSizing: 'border-box',\n overflowY: 'hidden',\n containerType: 'inline-size',\n '& .MuiInputBase-root': {\n display: 'none',\n '@container (min-width: 420px)': {\n display: 'inline-flex'\n }\n }\n },\n caption: {\n color: 'rgba(0,0,0,0.6)',\n fontSize: '12px',\n lineHeight: '16px',\n display: 'none',\n '@container (min-width: 420px)': {\n display: 'block'\n }\n },\n displayedRows: {\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!important' //we need it, because of the more specific rule in the mui\n }\n});\n","import React, {useCallback, memo} from 'react';\nimport classnames from 'classnames';\nimport i18n from 'ui-i18n';\nimport {getValue} from '../../../core/utils';\nimport {nthArg, pipe, pathOr, identity} from 'ramda';\nimport TablePagination, {TablePaginationProps} from '@mui/material/TablePagination';\n\nimport {useStyles} from './styles';\n\ntype BasicTablePaginationProps = {\n classes?: TablePaginationProps['classes'];\n basicTableRef?: React.Ref<HTMLElement>;\n count?: number;\n page?: number;\n rowsPerPage?: number;\n labelRowsPerPage?: React.ReactNode;\n rowsPerPageOptions?: TablePaginationProps['rowsPerPageOptions'];\n onChangePage?: (value: number) => void;\n onChangeRowsPerPage?: (value: number) => void;\n};\n\nconst BasicTablePagination = ({\n classes = {},\n count,\n rowsPerPageOptions,\n page,\n onChangePage,\n rowsPerPage,\n onChangeRowsPerPage,\n basicTableRef,\n labelRowsPerPage\n}: BasicTablePaginationProps) => {\n const styles = useStyles();\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\n const resetScrollbarPosition = useCallback(() => {\n pathOr(identity, ['current', 'resetScrollbarPosition'], basicTableRef)();\n }, [basicTableRef]);\n\n const handleChangePage = useCallback(\n (value: number) => {\n onChangePage(value);\n resetScrollbarPosition();\n },\n [onChangePage, resetScrollbarPosition]\n );\n const handleChangeRowsPerPage = useCallback(\n (value: number) => {\n onChangePage(0);\n onChangeRowsPerPage(value);\n resetScrollbarPosition();\n },\n [onChangePage, onChangeRowsPerPage, resetScrollbarPosition]\n );\n\n return (\n <TablePagination\n classes={{\n ...classes,\n root: classnames(styles.pagination, classes.root),\n select: classnames(styles.select, classes.select),\n selectLabel: classnames(styles.caption, classes.selectLabel),\n displayedRows: classnames(styles.displayedRows, classes.displayedRows),\n input: classnames(styles.selectRoot, classes.selectRoot),\n actions: styles.actions\n }}\n backIconButtonProps={{size: 'large'}}\n nextIconButtonProps={{size: 'large'}}\n component=\"div\"\n labelRowsPerPage={labelRowsPerPage || i18n.text('Rows per page:')}\n labelDisplayedRows={labelDisplayedRows}\n count={count}\n rowsPerPageOptions={rowsPerPageOptions}\n page={page}\n onPageChange={pipe(nthArg(1), handleChangePage)}\n rowsPerPage={rowsPerPage}\n onRowsPerPageChange={pipe(getValue, handleChangeRowsPerPage)}\n />\n );\n};\n\nBasicTablePagination.displayName = 'BasicTablePagination';\n\nexport default memo(BasicTablePagination);\n","import {always, assoc, difference, dissoc, evolve, keys, path, when} from 'ramda';\nimport {createStandardAction, toggleSortOrder} from '../../../core';\n\nconst CHANGE_COLUMNS = 'CHANGE_COLUMNS';\nconst TOGGLE_FILTERS = 'TOGGLE_FILTERS';\nconst CHANGE_FILTER = 'CHANGE_FILTER';\nconst TOGGLE_SORT = 'TOGGLE_SORT';\nconst CHANGE_PAGE = 'CHANGE_PAGE';\nconst CHANGE_ROWS_PER_PAGE = 'CHANGE_ROWS_PER_PAGE';\n\nexport const actions = {\n changeColumns: createStandardAction(CHANGE_COLUMNS),\n toggleFilters: createStandardAction(TOGGLE_FILTERS),\n changeFilter: createStandardAction(CHANGE_FILTER),\n toggleSort: createStandardAction(TOGGLE_SORT),\n changePage: createStandardAction(CHANGE_PAGE),\n changeRowsPerPage: createStandardAction(CHANGE_ROWS_PER_PAGE)\n};\n\nexport const changeVisibleColumns = (state, nextVisibleColumns) => {\n const removedColumns = difference(state.visibleColumns, nextVisibleColumns);\n const isRemovedColumn = (columnId) => removedColumns.includes(columnId);\n return evolve(\n {\n visibleColumns: always(nextVisibleColumns),\n sorting: when(\n (sorting = {}) => isRemovedColumn(sorting.field),\n () => {\n const [nextSortField] = nextVisibleColumns;\n return {field: nextSortField, order: 'asc'};\n }\n ),\n filters: (filters) =>\n keys(filters).reduce(\n (acc, columnId) => (isRemovedColumn(columnId) ? dissoc(columnId, acc) : acc),\n filters\n )\n },\n state\n );\n};\n\nexport const reducer = (state, action) => {\n switch (action.type) {\n case CHANGE_COLUMNS: {\n const columnIds = action.payload;\n return changeVisibleColumns(state, columnIds);\n }\n case TOGGLE_FILTERS: {\n const enableFilters = !state.filters;\n return {\n ...state,\n filters: enableFilters ? {} : null,\n page: enableFilters ? state.page : 0\n };\n }\n case CHANGE_FILTER: {\n const {columnId, filter} = action.payload;\n return evolve({filters: filter ? assoc(columnId, filter) : dissoc(columnId), page: always(0)}, state);\n }\n case TOGGLE_SORT: {\n const nextSortField = action.payload;\n const prevSortField = path(['sorting', 'field'], state);\n const prevSortOrder = path(['sorting', 'order'], state);\n return {\n ...state,\n sorting: {\n field: nextSortField,\n order: toggleSortOrder(nextSortField === prevSortField ? prevSortOrder : null)\n },\n page: 0\n };\n }\n case CHANGE_PAGE:\n return {...state, page: action.payload};\n case CHANGE_ROWS_PER_PAGE:\n return {...state, rowsPerPage: action.payload};\n default:\n return state;\n }\n};\n\nexport default {\n reducer,\n actions,\n changeVisibleColumns\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n basicViewPaper: {\n display: 'flex',\n flexDirection: 'column',\n ...theme.basicView\n }\n}));\n","import React, {forwardRef} from 'react';\nimport Paper, {PaperProps} from '@mui/material/Paper';\nimport {useStyles} from './styles';\n\nconst BasicView = forwardRef(\n ({children, className, ...otherProps}: PaperProps, ref: React.RefObject<HTMLDivElement>) => {\n const styles = useStyles();\n return (\n <Paper ref={ref} className={className} classes={{root: styles.basicViewPaper}} {...otherProps}>\n {children}\n </Paper>\n );\n }\n);\n\nBasicView.displayName = 'BasicView';\n\nexport default BasicView;\n","import {makeStyles} from '@mui/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 from '@mui/material/Button';\nimport Dialog from '@mui/material/Dialog';\nimport DialogActions from '@mui/material/DialogActions';\nimport DialogContent from '@mui/material/DialogContent';\nimport DialogContentText from '@mui/material/DialogContentText';\nimport DialogTitle from '@mui/material/DialogTitle';\n\nimport {useStyles} from './styles';\n\nexport type Props = {\n open: boolean;\n title: React.ReactNode;\n content: React.ReactNode;\n cancelCaption?: string;\n discardCaption?: string;\n saveCaption?: string;\n disabledSave?: boolean;\n onCancel?: () => void;\n onDiscard?: () => void;\n onSave: () => void;\n};\n\nconst ConfirmationDialog = ({\n open,\n title,\n content,\n onCancel,\n cancelCaption = i18n.text('Cancel'),\n onDiscard,\n discardCaption = '',\n onSave,\n saveCaption = i18n.text('Save'),\n disabledSave = false\n}: Props) => {\n const styles = useStyles();\n\n return (\n <Dialog open={open} onClose={onCancel} classes={{paperScrollPaper: styles.paper}}>\n <DialogTitle classes={{root: styles.title}}>{title}</DialogTitle>\n <DialogContent classes={{root: styles.content}}>\n <DialogContentText classes={{root: styles.contentText}}>{content}</DialogContentText>\n </DialogContent>\n <DialogActions className={styles.actionButtons} disableSpacing>\n {onCancel && <Button onClick={onCancel}>{cancelCaption}</Button>}\n <div>\n {onDiscard && (\n <Button onClick={onDiscard} classes={{root: styles.discardButton}}>\n {discardCaption}\n </Button>\n )}\n <Button onClick={onSave} color=\"primary\" disabled={disabledSave} autoFocus>\n {saveCaption}\n </Button>\n </div>\n </DialogActions>\n </Dialog>\n );\n};\n\nexport default ConfirmationDialog;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n menuItem: {\n height: '32px'\n },\n menuText: {\n color: theme.palette.text.primary,\n fontSize: '13px',\n lineHeight: '15px'\n },\n checkbox: {\n padding: 0,\n marginRight: '15px'\n }\n}));\n","import React, {forwardRef} from 'react';\nimport {identity} from 'ramda';\nimport Checkbox from '@mui/material/Checkbox';\nimport MenuItem from '@mui/material/MenuItem';\nimport Typography from '@mui/material/Typography';\nimport {DropDownMenuItem} from '../../../types';\nimport {useStyles} from './styles';\n\ntype Props = {\n item: DropDownMenuItem;\n onMenuClose?: (e) => void;\n};\n\nconst SettingsMenuItemRenderer = forwardRef(({item, onMenuClose = identity}: Props, ref: React.Ref<HTMLLIElement>) => {\n const styles = useStyles();\n const {text, onClick, id, selected} = item;\n const handleClick = (e) => {\n onMenuClose(e);\n onClick(e);\n };\n\n return (\n <MenuItem\n classes={{root: styles.menuItem}}\n onClick={handleClick}\n ref={ref}\n data-modal\n data-reltio-id={`reltio-settings-menu-item${id}`}\n >\n <Checkbox checked={selected} className={styles.checkbox} color=\"primary\" />\n <Typography classes={{root: styles.menuText}}>{text}</Typography>\n </MenuItem>\n );\n});\n\nSettingsMenuItemRenderer.displayName = 'SettingsMenuItemRenderer';\n\nexport default SettingsMenuItemRenderer;\n","import React from 'react';\nimport SettingsIcon from '@mui/icons-material/Settings';\nimport i18n from 'ui-i18n';\nimport {DropDownMenuItem} from '../../types';\nimport {SmallIconButtonWithTooltip} from '../SmallIconButton';\nimport DropDownMenuButton from '../DropDownMenuButton/DropDownMenuButton';\nimport SettingsMenuItemRenderer from './SettingsMenuItemRender/SettingsMenuItemRender';\n\ntype Props = {\n items: Array<DropDownMenuItem>;\n menuId: string;\n};\n\nconst SettingsMenu = ({items, menuId}: Props) => {\n return (\n <DropDownMenuButton\n buttonComponent={SmallIconButtonWithTooltip}\n buttonProps={{\n icon: SettingsIcon,\n tooltipTitle: i18n.text('Settings'),\n size: 'L'\n }}\n menuId={menuId}\n menuItems={items}\n MenuItemRenderer={SettingsMenuItemRenderer}\n />\n );\n};\n\nexport default SettingsMenu;\n","import PropTypes from 'prop-types';\nimport React from 'react';\n\nconst VerticalDivider = ({height, margin}) => (\n <div\n style={{\n width: '1px',\n height: `${height}px`,\n borderLeft: '1px solid rgba(0,0,0,0.38)',\n margin: `0 ${margin}px`,\n flexShrink: '0'\n }}\n />\n);\n\nVerticalDivider.propTypes = {\n height: PropTypes.number,\n margin: PropTypes.number\n};\n\nexport default VerticalDivider;\n","import {useMemo} from 'react';\nimport {pipe} from 'ramda';\n\ntype UseActions = ({\n actions,\n dispatch\n}: {\n actions: {\n [key: string]: <T>(payload: T) => {type: string; payload: T};\n };\n dispatch: <T>({type, payload}: {type: string; payload: T}) => void;\n}) => {\n [key in keyof typeof actions]: <T>(payload: T) => void;\n};\n\nexport const useActions: UseActions = ({actions, dispatch}) =>\n useMemo(\n () =>\n Object.entries(actions).reduce((acc, [actionName, actionCreator]) => {\n return {...acc, [actionName]: pipe(actionCreator, dispatch)};\n }, {}),\n [dispatch, actions]\n );\n","import {useCallback, useEffect, useMemo, useRef, useState} from 'react';\nimport {useDispatch, useSelector} from 'react-redux';\nimport {cond, pipe, prop, T, evolve, filter as filterFn, when, identity, times, length, ifElse, always} from 'ramda';\nimport mdm, {profile} from '@reltio/mdm-module';\nimport {\n ActivityFilter,\n addGlobalFilterToQuery,\n Connection,\n Entity,\n getRelationsForDataTenantEntity,\n getRelationsForEntity,\n GlobalSearchRequestOptions,\n isAvailableEntityTypeUri,\n isAvailableRelationTypeUri,\n isDataTenantEntity,\n isObject,\n isTempUri,\n Metadata,\n Mode,\n RelationsContent,\n RelationsViewConfig,\n wrapInArrayIfNeeded\n} from '@reltio/mdm-sdk';\nimport {useSafePromise} from './useSafePromise';\nimport {usePrevious} from './usePrevious';\n\ntype Props = {\n sorting?: {\n field: string;\n order: string;\n };\n filter?: string;\n page: number;\n rowsPerPage: number;\n config: Pick<RelationsViewConfig, 'suggested' | 'content' | 'id'>;\n entity: Entity;\n relationActivityFilter?: ActivityFilter;\n mode: Mode;\n searchByOv?: boolean;\n};\n\nconst buildSuggestedIds = when(\n identity,\n pipe(\n wrapInArrayIfNeeded,\n length,\n times((n) => n + 1)\n )\n);\ntype ConnectionResponse = Array<{connections?: Connection[]; total: number}>;\n\nexport const useRelationsLoader = ({\n sorting,\n filter,\n page,\n rowsPerPage,\n config,\n entity,\n relationActivityFilter,\n mode,\n searchByOv = false\n}: Props) => {\n const [isLoading, setIsLoading] = useState(false);\n const dispatch = useDispatch();\n const tenant = useSelector(mdm.selectors.getTenant) as string;\n const metadata = useSelector(mdm.selectors.getMetadata) as Metadata;\n const dtssPath = useSelector(mdm.selectors.getDtssPath) as string;\n const {activityFilter, globalFilter}: GlobalSearchRequestOptions =\n useSelector(mdm.selectors.getGlobalSearchRequestOptions) || {};\n const lastLoadedTime = useSelector(mdm.selectors.getProfileLastLoadedTime);\n const safePromise = useSafePromise();\n\n const processContent = (content: RelationsContent) => {\n const getUri = when(isObject, prop('uri'));\n const filterRelation = pipe(getUri, isAvailableRelationTypeUri(metadata));\n\n return evolve({\n entityTypes: filterFn(isAvailableEntityTypeUri(metadata)),\n inRelations: filterFn(filterRelation),\n outRelations: filterFn(filterRelation),\n nextEntry: processContent\n })(content);\n };\n\n const suggested = config.suggested;\n const options = useMemo(\n () => ({\n searchByOv\n }),\n [searchByOv]\n );\n const loadRelations = useCallback(() => {\n if (entity?.uri) {\n const processedConfig = processContent(config.content);\n const requestConfig = {\n ...processedConfig,\n sortBy: sorting?.field,\n order: sorting?.order,\n returnDates: true,\n returnObjects: true,\n activeness: {\n relation: relationActivityFilter || ActivityFilter.ALL,\n entity: activityFilter\n },\n max: rowsPerPage,\n offset: page * rowsPerPage,\n filter: addGlobalFilterToQuery(globalFilter, filter) || undefined,\n suggested: buildSuggestedIds(suggested)\n };\n const configs = [requestConfig].concat(\n ifElse(\n identity,\n pipe(wrapInArrayIfNeeded, (suggested) =>\n suggested.map((config, i) => ({...config, id: requestConfig.suggested[i]}))\n ),\n always([])\n )(suggested)\n );\n\n const request: (entity: Entity) => Promise<ConnectionResponse> = cond([\n [pipe(prop('uri'), isTempUri), () => Promise.resolve([{total: 0}])],\n [\n isDataTenantEntity,\n (entity) =>\n getRelationsForDataTenantEntity({\n entityUri: entity.uri,\n configs: configs,\n customerTenant: tenant,\n dataTenant: entity.dataTenant,\n dtssPath,\n options\n })\n ],\n [T, (entity) => getRelationsForEntity(entity.uri, configs, options)]\n ]);\n setIsLoading(true);\n safePromise(request(entity))\n .then((result) => {\n if (!Array.isArray(result)) {\n throw Error(JSON.stringify(result));\n }\n const [{connections, total}] = result;\n dispatch(profile.relations.actions.relationsLoaded({id: config.id, connections, total}));\n })\n .catch((e) => {\n console.warn('Failed to load relations data', e);\n })\n .finally(() => {\n setIsLoading(false);\n });\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n activityFilter,\n metadata,\n config,\n dispatch,\n dtssPath,\n entity?.uri,\n entity?.dataTenant,\n filter,\n globalFilter,\n page,\n relationActivityFilter,\n rowsPerPage,\n safePromise,\n sorting,\n tenant,\n options,\n lastLoadedTime\n ]);\n const isRequestSentRef = useRef<boolean>(false);\n isRequestSentRef.current = false;\n useEffect(() => {\n isRequestSentRef.current = true;\n loadRelations();\n }, [loadRelations]);\n\n const prevMode = usePrevious(mode);\n useEffect(() => {\n if (mode === Mode.Viewing && !isRequestSentRef.current && prevMode !== mode) {\n isRequestSentRef.current = true;\n loadRelations();\n }\n }, [loadRelations, mode, prevMode]);\n return {isLoading, reload: loadRelations};\n};\n","import {useEffect, useState} from 'react';\nimport {useDidUpdateEffect} from '@reltio/components';\nimport {\n RelationshipsSavedState,\n RelationsTableSavedState,\n AttributesTableSavedState\n} from './../types/RelationshipsSavedState';\n\nconst DEFAULT_SAVED_STATE = {\n relationsTable: {},\n attributesTable: {}\n};\n\nconst useSavedState = ({getSavedState, saveState, entityTypeUri}) => {\n const [savedState, setSavedState] = useState<RelationshipsSavedState>(DEFAULT_SAVED_STATE);\n const [changedRelationsState, setRelationsChangedState] = useState<Record<string, RelationsTableSavedState>>(null);\n\n const saveChangesLocallyForPrevEntityType = () => {\n if (changedRelationsState) {\n setSavedState({...savedState, relationsTable: changedRelationsState});\n setRelationsChangedState(null);\n }\n };\n useDidUpdateEffect(saveChangesLocallyForPrevEntityType, [entityTypeUri]);\n\n const updateRelationsTableSavedState = (stateToSave: RelationsTableSavedState) => {\n const changedState: Record<string, RelationsTableSavedState> = {\n ...savedState.relationsTable,\n [entityTypeUri]: stateToSave\n };\n setRelationsChangedState(changedState);\n saveState({...savedState, relationsTable: changedState});\n };\n\n const updateAttributesTableSavedState = (stateToSave: AttributesTableSavedState) => {\n saveState({...savedState, attributesTable: stateToSave});\n };\n\n const [isLoading, setIsLoading] = useState(true);\n\n useEffect(() => {\n getSavedState()\n .then((savedState) => {\n setSavedState(savedState || DEFAULT_SAVED_STATE);\n })\n .then((_) => setIsLoading(false))\n .catch((_) => setIsLoading(false));\n }, []); // eslint-disable-line\n return {\n isLoading,\n relationsTableSavedState: savedState.relationsTable?.[entityTypeUri],\n attributesTableSavedState: savedState.attributesTable,\n updateRelationsTableSavedState,\n updateAttributesTableSavedState\n };\n};\n\nexport default useSavedState;\n","import {\n attributeUriToSearchUri,\n DataTypes,\n getAttrDataTypeDefinition,\n getReadableAttributesList,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {adjust, assoc, concat, find, map, pipe, pluck, prop, propEq, reject, uniqBy} from 'ramda';\nimport i18n from 'ui-i18n';\nimport {RelationshipsTableColumnData} from '../../../types';\n\nconst RELATION_TYPE_COLUMN_ID = 'relation.type';\nconst ATTRIBUTES_COLUMN_ID = 'relation.attributes';\n\nexport const DEFAULT_COLUMNS_DATA = [\n {\n id: 'entity.label',\n get label() {\n return i18n.text('Profile');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_STRING\n },\n hideable: false,\n filterable: false,\n initialWidth: 280,\n autoResize: false\n },\n {\n id: RELATION_TYPE_COLUMN_ID,\n get label() {\n return i18n.text('Type');\n }\n },\n {\n id: 'relation.label',\n get label() {\n return i18n.text('Directional Label');\n },\n filterable: false,\n dataTypeDefinition: {\n type: DataTypes.TYPE_STRING\n }\n },\n {\n id: 'relation.activeness.startDate',\n get label() {\n return i18n.text('Start Date');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_ACTIVENESS_DATE\n }\n },\n {\n id: 'relation.activeness.endDate',\n get label() {\n return i18n.text('End Date');\n },\n dataTypeDefinition: {\n type: DataTypes.TYPE_ACTIVENESS_DATE\n }\n },\n {\n id: ATTRIBUTES_COLUMN_ID,\n get label() {\n return i18n.text('Attributes');\n },\n sortable: false,\n filterable: false,\n maxAttrsToShow: 7\n }\n];\n\nexport const DEFAULT_COLUMNS = pluck('id', DEFAULT_COLUMNS_DATA);\nexport const ALL_TYPES_COLUMNS = [RELATION_TYPE_COLUMN_ID, ATTRIBUTES_COLUMN_ID];\n\nexport const ROWS_PER_PAGE_OPTIONS = [20, 50, 100];\n\nconst getColumnIdFromAttrUri = pipe(attributeUriToSearchUri, concat('relation.'));\n\nconst getColumnsDataFromRelationAttributes = pipe(\n map((attr) => ({\n id: getColumnIdFromAttrUri(attr.uri),\n label: attr.label,\n description: attr?.description,\n dataTypeDefinition: getAttrDataTypeDefinition(attr)\n })),\n uniqBy(prop('id'))\n);\n\nconst getRelationColumnDataType = (relationTypes: TRelationType[]) => ({\n type: DataTypes.TYPE_SELECT,\n options: relationTypes.map(({uri, label}) => ({value: uri, label}))\n});\n\nconst updateColumnData = (columnId: string, updateFn) => (columnsData: RelationshipsTableColumnData[]) =>\n adjust(columnsData.findIndex(propEq('id', columnId)), updateFn, columnsData);\n\nconst updateRelationTypeColumn = (relationTypes: TRelationType[]) =>\n updateColumnData(RELATION_TYPE_COLUMN_ID, assoc('dataTypeDefinition', getRelationColumnDataType(relationTypes)));\n\nexport const getColumnsData = (relationTypes: TRelationType[], currentRelationType: string) =>\n currentRelationType\n ? pipe(\n find((relationType: TRelationType) => relationType.uri === currentRelationType),\n getReadableAttributesList,\n getColumnsDataFromRelationAttributes,\n concat(DEFAULT_COLUMNS_DATA),\n reject(({id}) => ALL_TYPES_COLUMNS.includes(id))\n )(relationTypes)\n : updateRelationTypeColumn(relationTypes)(DEFAULT_COLUMNS_DATA);\n","import {\n assoc,\n pipe,\n evolve,\n either,\n path,\n prop,\n propOr,\n ifElse,\n always,\n without,\n concat,\n intersection,\n pick,\n unless,\n isNil,\n filter\n} from 'ramda';\nimport {useReducer} from 'react';\nimport {basicTableViewState, createStandardAction, Sorting, useActions} from '@reltio/components';\nimport {ALL_TYPES_COLUMNS, DEFAULT_COLUMNS} from '../components/RelationshipsView/helpers/tableHelpers';\nimport {validateFilterValue} from '@reltio/mdm-sdk';\n\ntype Props = {\n defaultColumns: string[];\n defaultSorting: Sorting;\n defaultRowsPerPage: number;\n};\n\nconst CHANGE_RELATION_TYPE = 'CHANGE_RELATION_TYPE';\nconst APPLY_SAVED_STATE = 'APPLY_SAVED_STATE';\nconst SAVE_CURRENT_STATE = 'SAVE_CURRENT_STATE';\n\nconst actions = {\n ...basicTableViewState.actions,\n changeRelationType: createStandardAction(CHANGE_RELATION_TYPE),\n applySavedState: createStandardAction(APPLY_SAVED_STATE),\n saveCurrentState: createStandardAction(SAVE_CURRENT_STATE)\n};\n\nconst resetPageNumber = assoc('page', 0);\n\nconst getDefaultVisibleColumnsForCurrentRelationType = (state) => {\n return pipe(\n prop('visibleColumns'),\n ifElse(always(state.currentRelationType), without(ALL_TYPES_COLUMNS), concat(ALL_TYPES_COLUMNS)),\n intersection(DEFAULT_COLUMNS)\n )(state);\n};\n\nconst getSavedVisibleColumnsForCurrentRelationType = (state) =>\n path(['visibleColumnsForRelationTypes', `${state.currentRelationType}`], state);\n\nconst changeVisibleColumnsForCurrentRelationType = (state) => {\n const nextVisibleColumns = either(\n getSavedVisibleColumnsForCurrentRelationType,\n getDefaultVisibleColumnsForCurrentRelationType\n )(state);\n return basicTableViewState.changeVisibleColumns(state, nextVisibleColumns);\n};\n\nconst getFiltersFromSavedState = pipe(\n propOr(null, 'filters'),\n unless(\n isNil,\n filter(({filter, value}) => validateFilterValue(filter, value))\n )\n);\n\nconst saveVisibleColumnsForCurrentRelationType = (state) => {\n const {currentRelationType, visibleColumns} = state;\n return evolve(\n {\n visibleColumnsForRelationTypes: assoc(`${currentRelationType}`, visibleColumns)\n },\n state\n );\n};\n\nconst getStateToSave = pipe(\n saveVisibleColumnsForCurrentRelationType,\n pick(['currentRelationType', 'visibleColumnsForRelationTypes', 'filters', 'sorting'])\n);\n\nexport const useRelationshipsTable = ({defaultColumns, defaultSorting, defaultRowsPerPage}: Props) => {\n const initState = {\n visibleColumns: defaultColumns,\n filters: null,\n sorting: defaultSorting,\n page: 0,\n rowsPerPage: defaultRowsPerPage,\n currentRelationType: null,\n stateToSave: null,\n visibleColumnsForRelationTypes: {},\n entityTypeOfAppliedSavedState: null\n };\n const [state, dispatch] = useReducer((state, action) => {\n switch (action.type) {\n case CHANGE_RELATION_TYPE: {\n const nextRelationType = action.payload;\n return pipe(\n saveVisibleColumnsForCurrentRelationType,\n assoc('currentRelationType', nextRelationType),\n changeVisibleColumnsForCurrentRelationType,\n resetPageNumber\n )(state);\n }\n case APPLY_SAVED_STATE: {\n const {savedState, entityTypeUri} = action.payload;\n const visibleColumns = savedState\n ? getSavedVisibleColumnsForCurrentRelationType(savedState)\n : state.visibleColumns;\n const filters = savedState ? getFiltersFromSavedState(savedState) : state.filters;\n return {\n ...state,\n ...savedState,\n filters,\n visibleColumns,\n entityTypeOfAppliedSavedState: entityTypeUri\n };\n }\n case SAVE_CURRENT_STATE: {\n return {\n ...state,\n stateToSave: getStateToSave(state)\n };\n }\n default:\n return basicTableViewState.reducer(state, action);\n }\n }, initState);\n const tableActions = useActions({actions, dispatch});\n return [state, tableActions];\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n select: {\n fontSize: '13px',\n color: 'rgba(0,0,0,.6)',\n paddingLeft: '15px'\n },\n selectMenu: {\n '& li': {\n fontSize: '13px',\n height: '32px'\n }\n },\n textField: {\n maxWidth: '100%'\n }\n});\n","import React, {useMemo} from 'react';\nimport i18n from 'ui-i18n';\nimport {map, concat, pipe} from 'ramda';\nimport {TRelationType} from '@reltio/mdm-sdk';\nimport {DropDownEditor} from '@reltio/components';\nimport {useStyles} from './styles';\n\ntype Props = {\n value: string;\n onChange: (value: string) => void;\n relationTypes: TRelationType[];\n className?: string;\n};\n\nconst RelationTypeSelector = ({value, onChange, relationTypes, className}: Props) => {\n const styles = useStyles();\n const entries = useMemo(\n () =>\n pipe(\n map(({label, uri}) => ({label, value: uri})),\n concat([{value: '', label: i18n.text('All types')}])\n )(relationTypes),\n [relationTypes]\n );\n\n return (\n <div className={className}>\n <DropDownEditor\n displayEmpty\n disableUnderline\n classes={{\n select: styles.select\n }}\n TextFieldProps={{\n classes: {\n root: styles.textField\n }\n }}\n MenuProps={{\n classes: {\n list: styles.selectMenu\n }\n }}\n value={value || ''}\n entries={entries}\n onChange={(value: string) => onChange(value || null)}\n />\n </div>\n );\n};\n\nexport default RelationTypeSelector;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n header: {\n height: '56px',\n boxSizing: 'border-box',\n paddingRight: '10px'\n },\n title: {\n fontSize: '16px'\n },\n total: {\n fontSize: '14px',\n color: theme.palette.text.secondary,\n flexShrink: 0,\n marginRight: '5px'\n },\n relationTypeSelector: {\n margin: '0px 10px 0 30px',\n overflow: 'hidden'\n }\n}));\n","import React, {memo, useMemo} from 'react';\nimport i18n from 'ui-i18n';\nimport {TRelationType} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport {\n BasicViewHeader,\n ColumnsSettings,\n DropDownMenuItem,\n FilterButton,\n SettingsMenu,\n Spacer,\n VerticalDivider\n} from '@reltio/components';\nimport RelationTypeSelector from '../RelationTypeSelector/RelationTypeSelector';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n total: number;\n filteringEnabled: boolean;\n onToggleFilters: () => void;\n columnsData: Record<string, unknown>[];\n selectedColumns: string[];\n currentRelationType: string;\n onRelationTypeChange: (value: string) => void;\n relationTypes: TRelationType[];\n onChangeColumns: (columns: string[]) => void;\n searchByOv: boolean;\n onToggleSearchByOv: () => void;\n showInactive: boolean;\n onToggleShowInactive: () => void;\n};\n\nconst RelationshipsTableHeader = ({\n total,\n filteringEnabled,\n onToggleFilters,\n columnsData,\n selectedColumns,\n currentRelationType,\n onRelationTypeChange,\n relationTypes,\n onChangeColumns,\n searchByOv,\n onToggleSearchByOv,\n showInactive,\n onToggleShowInactive\n}: Props) => {\n const styles = useStyles();\n\n const settingItems = useMemo<Array<DropDownMenuItem>>(() => {\n return [\n {\n selected: searchByOv,\n text: i18n.text('Search by OV only'),\n onClick: onToggleSearchByOv,\n id: 'showNonOv'\n },\n {\n selected: showInactive,\n text: i18n.text('Show inactive relationships'),\n onClick: onToggleShowInactive,\n id: 'showInactive'\n }\n ];\n }, [onToggleSearchByOv, searchByOv, onToggleShowInactive, showInactive]);\n\n return (\n <BasicViewHeader title={i18n.text('Relationships')} classes={{root: styles.header, title: styles.title}}>\n {relationTypes.length > 0 && (\n <RelationTypeSelector\n className={styles.relationTypeSelector}\n value={currentRelationType}\n onChange={onRelationTypeChange}\n relationTypes={relationTypes}\n />\n )}\n <VerticalDivider height={28} margin={20} />\n <Typography variant=\"caption\" className={styles.total}>\n {total === 1\n ? i18n.text('${count} record', {count: total})\n : i18n.text('${count} records', {count: total})}\n </Typography>\n <Spacer />\n <SettingsMenu items={settingItems} menuId=\"relationships-view-settings\" />\n <FilterButton enabled={filteringEnabled} onClick={onToggleFilters} />\n <VerticalDivider height={28} margin={8} />\n <ColumnsSettings\n columnsData={columnsData}\n selectedColumns={selectedColumns}\n onChangeColumns={onChangeColumns}\n />\n </BasicViewHeader>\n );\n};\n\nexport default memo(RelationshipsTableHeader);\n","import {Connection, isActiveObject} from '@reltio/mdm-sdk';\n\nexport const getIsInactiveRelation = (connection: Connection) =>\n !isActiveObject(connection?.relation) || !isActiveObject(connection?.entity);\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n headCell: {\n display: 'flex',\n alignItems: 'center',\n height: '100%',\n width: '100%',\n fontSize: '12px',\n color: theme.palette.text.secondary,\n background: 'linear-gradient(0deg, rgba(0, 0, 0, 0.06), rgba(0, 0, 0, 0.06)), #FFFFFF'\n },\n rowCell: {\n fontSize: '13px',\n overflow: 'hidden',\n overflowWrap: 'break-word'\n },\n inactiveRowCell: {\n opacity: 0.6\n },\n defaultWrapper: {\n padding: '15px 25px 0 25px',\n '&:last-child': {\n paddingBottom: '15px'\n }\n },\n entityCell: {\n display: 'flex',\n alignItems: 'flex-start',\n padding: '15px'\n },\n entityAvatar: {\n transform: 'scale(0.5)',\n margin: '-10px 0 -10px -10px'\n },\n inactiveEntityAvatar: {\n overflow: 'initial',\n '&:after': {\n content: '\"\"',\n position: 'absolute',\n backgroundColor: 'rgb(209, 206, 206)',\n border: '1px solid rgba(0, 0, 0, 1)',\n borderRadius: '2px',\n width: '12px',\n right: 0,\n bottom: 0,\n height: '12px'\n },\n '& > img': {\n borderRadius: '50%',\n overflow: 'hidden'\n }\n },\n entityLabel: {\n color: theme.palette.primary.main,\n textDecoration: 'none',\n fontWeight: 500\n },\n attributesWrapper: {\n padding: '15px 25px 10px 25px',\n color: 'rgba(0,0,0,0.87)'\n },\n commentsContainer: {\n marginLeft: 'auto'\n },\n description: {\n marginLeft: '-22px'\n }\n}));\n","import React from 'react';\nimport DefaultHeadCellRenderer from 'react-components/dist/Table/DefaultHeadCellRenderer/DefaultHeadCellRenderer';\nimport {DescriptionIcon, withFilterAtBottom} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\nconst HeadCellRenderer = (props) => {\n const styles = useStyles();\n const {description} = props?.headCellData;\n return (\n <div className={styles.headCell}>\n <DefaultHeadCellRenderer {...props} />\n <DescriptionIcon description={description} className={styles.description} />\n </div>\n );\n};\n\nexport default withFilterAtBottom(HeadCellRenderer);\n","import React from 'react';\nimport classnames from 'classnames';\nimport {useSelector} from 'react-redux';\nimport {CommentsContainer, COMMENTS_CONTAINER_VISIBILITY_AREA, EntityTypeIcon, EntityUriLink} from '@reltio/components';\nimport {\n CollaborationObjectTypes,\n ConnectionEntity,\n ConnectionRelation,\n createRelatedObjectUris,\n getEntityUriForLink,\n getLabel,\n TEntityType\n} from '@reltio/mdm-sdk';\nimport mdmModule from '@reltio/mdm-module';\nimport {useStyles} from './styles';\n\ntype Props = {\n value: {\n entity: ConnectionEntity;\n relation: ConnectionRelation;\n entityType: TEntityType;\n };\n isInactiveRelation?: boolean;\n};\n\nconst EntityProfileRenderer = ({value: {entity, entityType, relation}, isInactiveRelation}: Props) => {\n const styles = useStyles();\n const currentEntityUri = useSelector(mdmModule.selectors.getEntityUri);\n return (\n <div className={classnames(styles.entityCell, COMMENTS_CONTAINER_VISIBILITY_AREA)}>\n <EntityTypeIcon\n className={classnames(styles.entityAvatar, {[styles.inactiveEntityAvatar]: isInactiveRelation})}\n entityType={entityType}\n />\n <EntityUriLink\n value={getEntityUriForLink({uri: entity.entityUri, dataTenant: entity.dataTenant})}\n className={styles.entityLabel}\n >\n {getLabel(entity.entityLabel)}\n </EntityUriLink>\n <div className={styles.commentsContainer} onClick={(e) => e.stopPropagation()}>\n <CommentsContainer\n uri={relation.relationUri}\n relatedObjectUris={createRelatedObjectUris(CollaborationObjectTypes.RELATION, {\n entityUri: currentEntityUri,\n connection: {relation, entity}\n })}\n objectType={CollaborationObjectTypes.RELATION}\n allowOnlyOneComment\n />\n </div>\n </div>\n );\n};\n\nexport default EntityProfileRenderer;\n","import React from 'react';\nimport {ReadOnlyAttributesList} from '@reltio/components';\nimport {AttributeType, RecordAttributesType} from '@reltio/mdm-sdk';\nimport {RelationshipsTableColumnData} from '../../../types';\nimport {useStyles} from './styles';\n\ntype Props = {\n columnData: RelationshipsTableColumnData;\n value: {\n attributeTypes: AttributeType[];\n attributes: RecordAttributesType;\n };\n};\n\nconst AttributesRenderer = ({columnData, value: {attributes, attributeTypes}}: Props) => {\n const styles = useStyles();\n\n return (\n <div className={styles.attributesWrapper} onClick={(e) => e.stopPropagation()}>\n <ReadOnlyAttributesList\n max={columnData.maxAttrsToShow}\n entity={{attributes}}\n attrTypes={attributeTypes}\n drawLines={false}\n />\n </div>\n );\n};\n\nexport default AttributesRenderer;\n","import React from 'react';\nimport {DataTypeValue} from '@reltio/components';\nimport {useStyles} from './styles';\nimport {RelationshipsTableColumnData} from '../../../types';\n\ntype Props = {\n columnData: RelationshipsTableColumnData;\n value: unknown;\n};\n\nconst DefaultCellValueRenderer = ({value, columnData: {dataTypeDefinition}}: Props) => {\n const styles = useStyles();\n return (\n <div className={styles.defaultWrapper}>\n <DataTypeValue value={value} dataTypeDefinition={dataTypeDefinition} />\n </div>\n );\n};\n\nexport default DefaultCellValueRenderer;\n","import {assoc, split, slice, values, length, path, cond, map, pathEq, pipe, reduce, T} from 'ramda';\nimport {defaultGetRowCellHeight} from '@reltio/components';\nimport {Connection, getEntityType, getRelationType, getOvAttributeValuesByPath, Metadata} from '@reltio/mdm-sdk';\nimport HeadCellRenderer from './cell-renderers/HeadCellRenderer';\nimport EntityProfileRenderer from './cell-renderers/EntityProfileRenderer';\nimport AttributesRenderer from './cell-renderers/AttributesRenderer';\nimport DefaultCellValueRenderer from './cell-renderers/DefaultCellValueRenderer';\nimport {RelationshipsTableColumnData} from '../../types';\n\nconst getAttrPathFromColumnId = pipe(split('.'), slice(2, Infinity));\n\nconst getRelationAttributeValues = (attrPath, relation) =>\n pipe(path(['object', 'attributes']), getOvAttributeValuesByPath(attrPath))(relation);\n\nconst getRowValueByColumnId = (metadata: Metadata, {entity, relation}: Connection, columnId: string) => {\n switch (columnId) {\n case 'entity.label':\n return {entity, entityType: getEntityType(metadata, entity.entityType), relation};\n case 'relation.type':\n return relation.relationType;\n case 'relation.label':\n return relation.relationLabel;\n case 'relation.activeness.startDate':\n return relation.startDate;\n case 'relation.activeness.endDate':\n return relation.endDate;\n case 'relation.attributes':\n return {\n attributes: relation.object.attributes,\n attributeTypes: getRelationType(metadata, relation.relationType).attributes\n };\n default: {\n const attrPath = getAttrPathFromColumnId(columnId);\n return getRelationAttributeValues(attrPath, relation);\n }\n }\n};\n\nconst getBasicTableRowsData = (\n metadata: Metadata,\n columnsData: RelationshipsTableColumnData[],\n connections: Connection[]\n) => {\n return (connections || []).map((connection) =>\n pipe(\n reduce((acc, {id}) => assoc(id, getRowValueByColumnId(metadata, connection, id), acc), {}),\n assoc('rawValue', connection)\n )(columnsData)\n );\n};\n\nconst getNestedPathByColumnId = (columnId: string) => {\n if (columnId.startsWith('relation.attributes')) {\n const attrPath = getAttrPathFromColumnId(columnId);\n return attrPath.length > 1 ? attrPath.slice(0, -1) : null;\n } else {\n return null;\n }\n};\n\nconst getCellValueRenderer = (columnId: string) => {\n switch (columnId) {\n case 'entity.label':\n return EntityProfileRenderer;\n case 'relation.attributes':\n return AttributesRenderer;\n default:\n return DefaultCellValueRenderer;\n }\n};\n\nconst getColumnDataByColumnId = (columnData: RelationshipsTableColumnData) => ({\n sortable: true,\n resizable: true,\n ...columnData,\n headCellRenderer: HeadCellRenderer,\n nestedPath: getNestedPathByColumnId(columnData.id),\n rowCellValueRenderer: getCellValueRenderer(columnData.id)\n});\n\nconst getBasicTableColumnsData = map(getColumnDataByColumnId);\n\nconst calculateAttributesCellHeight = ({columnData, cell}) => {\n const attributesCount = pipe(path(['values', 0, 'attributes']), values, length)(cell);\n return attributesCount > columnData.maxAttrsToShow\n ? columnData.maxAttrsToShow * 26 + 49\n : attributesCount * 26 + 25;\n};\n\nconst getStaticRowCellHeight = cond([\n [pathEq(['columnData', 'id'], 'relation.attributes'), calculateAttributesCellHeight],\n [T, defaultGetRowCellHeight]\n]);\n\nexport {getBasicTableRowsData, getBasicTableColumnsData, getStaticRowCellHeight};\n","import React from 'react';\nimport classnames from 'classnames';\nimport {useStyles} from './styles';\n\ntype Props = {\n cell: {\n values: unknown[];\n };\n CellValueRenderer: React.ElementType;\n isInactiveRelation?: boolean;\n};\n\nconst RowCellRenderer = ({cell, CellValueRenderer, ...otherProps}: Props) => {\n const styles = useStyles();\n return (\n <div className={classnames(styles.rowCell, {[styles.inactiveRowCell]: otherProps.isInactiveRelation})}>\n {cell.values.map((value, index) => (\n <CellValueRenderer key={index} value={value} {...otherProps} />\n ))}\n </div>\n );\n};\n\nexport default RowCellRenderer;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n menuItem: {\n minHeight: '32px',\n color: theme.palette.text.secondary\n },\n menuText: {\n color: theme.palette.text.primary,\n fontSize: '13px',\n lineHeight: '15px',\n letterSpacing: 0,\n marginLeft: '16px'\n },\n buttons: {\n display: 'flex',\n alignItems: 'center',\n paddingRight: '5px'\n }\n}));\n","import React, {forwardRef, ReactNode} from 'react';\nimport MenuItem from '@mui/material/MenuItem';\nimport Typography from '@mui/material/Typography';\nimport {noop, withTooltip} from '@reltio/components';\nimport {useStyles} from './styles';\n\nconst MenuItemWithTooltip = withTooltip(MenuItem);\n\ntype Item = {\n text?: string;\n disabled?: boolean;\n icon: ReactNode;\n tooltip?: string;\n onClick?: (e) => void;\n};\n\ntype Props = {\n item: Item;\n onMenuClose?: () => void;\n};\n\nconst MenuItemRenderer = forwardRef(({item, onMenuClose = noop}: Props, ref: React.Ref<HTMLLIElement>) => {\n const styles = useStyles();\n const {icon, disabled, text, tooltip, onClick} = item;\n const handleClick = (e) => {\n onMenuClose();\n onClick(e);\n };\n\n return (\n <MenuItemWithTooltip\n tooltipTitle={tooltip}\n showForDisabled={true}\n classes={{root: styles.menuItem}}\n onClick={handleClick}\n disabled={disabled}\n ref={ref}\n >\n {icon}\n <Typography classes={{root: styles.menuText}}>{text}</Typography>\n </MenuItemWithTooltip>\n );\n});\nMenuItemRenderer.displayName = 'MenuItemRenderer';\n\nexport default MenuItemRenderer;\n","import React, {useCallback, useState} from 'react';\nimport {useSelector} from 'react-redux';\nimport mdmModule from '@reltio/mdm-module';\nimport i18n from 'ui-i18n';\nimport DeleteIcon from '@mui/icons-material/Delete';\nimport MoreVertIcon from '@mui/icons-material/MoreVert';\nimport {ConfirmationDialog, DropDownMenuButton, noop, SmallIconButton} from '@reltio/components';\nimport MenuItemRenderer from './MenuItemRenderer';\nimport {checkMetadataPermission, Connection, getLabel, getRelationType, MetadataPermissions} from '@reltio/mdm-sdk';\nimport {pipe, prop} from 'ramda';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n disableDelete?: boolean;\n connection: Connection;\n onMenuOpen?: () => void;\n onMenuClose?: () => void;\n onDelete: () => void;\n};\n\nexport const RelationshipMenuButton = ({\n disableDelete,\n connection: {entity, relation},\n onMenuOpen = noop,\n onMenuClose = noop,\n onDelete\n}: Props) => {\n const styles = useStyles();\n\n const metadata = useSelector(mdmModule.selectors.getMetadata);\n\n const hasDeletePermission = pipe(\n prop('relationType'),\n getRelationType(metadata),\n checkMetadataPermission(MetadataPermissions.DELETE)\n )(relation);\n\n const canDelete = !disableDelete && hasDeletePermission;\n\n const [pendingDeletion, setPendingDeletion] = useState(false);\n const showDeleteConfirmation = () => setPendingDeletion(true);\n const hideDeleteConfirmation = () => setPendingDeletion(false);\n\n const actions = [\n {\n disabled: !canDelete,\n text: i18n.text('Delete'),\n icon: <DeleteIcon />,\n tooltip: canDelete ? null : i18n.text(\"You don't have permissions to delete\"),\n onClick: showDeleteConfirmation\n }\n ];\n\n const handleMenuClose = useCallback(() => {\n if (!pendingDeletion) {\n onMenuClose();\n }\n }, [pendingDeletion, onMenuClose]);\n const truncateWithEllipsis = (text: string) => (text.length > 17 ? `${text.substring(0, 17)}...` : text);\n\n return (\n <div className={styles.buttons}>\n <DropDownMenuButton\n MenuItemRenderer={MenuItemRenderer}\n menuId={'relationships-table-actions'}\n buttonComponent={SmallIconButton}\n buttonProps={{\n icon: MoreVertIcon,\n size: 'S'\n }}\n menuItems={actions}\n onMenuOpen={onMenuOpen}\n onMenuClose={handleMenuClose}\n />\n <ConfirmationDialog\n open={pendingDeletion}\n title={i18n.text('Do you want to delete relationship \"${label}\"?', {\n label: truncateWithEllipsis(getLabel(entity.entityLabel))\n })}\n content={i18n.text(\n 'This relationship will be removed and all the values in the relationship will be permanently deleted. \\\nAre you sure you want to delete this relationship?'\n )}\n onSave={pipe(hideDeleteConfirmation, onMenuClose, onDelete)}\n onDiscard={pipe(hideDeleteConfirmation, onMenuClose)}\n saveCaption={i18n.text('Delete')}\n discardCaption={i18n.text('Cancel')}\n />\n </div>\n );\n};\n\nexport default RelationshipMenuButton;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n tableContainer: {\n flex: 1,\n overflow: 'hidden',\n display: 'flex',\n zIndex: 0\n },\n hoveredRowRightContentWrapper: {\n width: '100%',\n pointerEvents: 'none!important' as any\n },\n menuButtonContainer: {\n position: 'absolute',\n top: 'calc(50% - 12px)',\n right: 0,\n pointerEvents: 'all'\n },\n tooltipAnchor: {\n width: '100%',\n height: '1px'\n }\n});\n","import React, {ForwardedRef, memo, useCallback, useMemo, useState} from 'react';\nimport {Connection, Metadata} from '@reltio/mdm-sdk';\nimport {\n BasicTable,\n ColumnData,\n ColumnFilter,\n RowCellAutoSizer,\n Sorting,\n useDynamicRowCellHeight\n} from '@reltio/components';\nimport Tooltip from '@mui/material/Tooltip';\nimport i18n from 'ui-i18n';\nimport {either} from 'ramda';\nimport {getIsInactiveRelation} from '../../services/helpers';\nimport {getBasicTableColumnsData, getBasicTableRowsData, getStaticRowCellHeight} from './helpers';\nimport RowCellRenderer from './cell-renderers/RowCellRenderer';\nimport RelationshipMenuButton from '../RelationshipMenuButton/RelationshipMenuButton';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n metadata: Metadata;\n connections: Connection[];\n columnsData: ColumnData[];\n sorting: Sorting;\n onSort: (field: string) => void;\n filters?: Record<string, ColumnFilter>;\n onFilter: (event: {columnId: string; filter: ColumnFilter}) => void;\n onRowClick: (rowIndex: number) => void;\n onDelete: (relationUri: string) => void;\n tableRef: ForwardedRef<unknown>;\n readOnly?: boolean;\n};\n\nconst RelationshipsTable = ({\n metadata,\n connections,\n columnsData,\n sorting,\n onSort,\n filters,\n onFilter,\n onRowClick,\n tableRef,\n onDelete,\n readOnly\n}: Props) => {\n const styles = useStyles();\n\n const tableRowsData = useMemo(\n () => getBasicTableRowsData(metadata, columnsData, connections),\n [metadata, connections, columnsData]\n );\n const tableColumnsData = useMemo(() => getBasicTableColumnsData(columnsData), [columnsData]);\n\n const {getDynamicRowCellHeight, changeRowCellHeight} = useDynamicRowCellHeight();\n const getRowCellHeight = useCallback(either(getDynamicRowCellHeight, getStaticRowCellHeight), [\n getDynamicRowCellHeight,\n getStaticRowCellHeight\n ]);\n const [hoverRowIndex, setHoverRowIndex] = useState<number>(null);\n\n const renderRowCell = useCallback(\n (props) => {\n const isInactiveRelation = getIsInactiveRelation(props.rowValue.rawValue);\n return (\n <RowCellAutoSizer onChangeHeight={changeRowCellHeight} {...props}>\n <RowCellRenderer {...props} isInactiveRelation={isInactiveRelation} />\n </RowCellAutoSizer>\n );\n },\n [changeRowCellHeight]\n );\n\n const [isActionsMenuOpen, setIsActionsMenuOpen] = useState(false);\n\n const handleActionsMenuOpen = useCallback(() => setIsActionsMenuOpen(true), []);\n const handleActionsMenuClose = useCallback(() => {\n setHoverRowIndex(null);\n setIsActionsMenuOpen(false);\n }, []);\n\n const onRowHover = useCallback(\n (rowIndex) => setHoverRowIndex((prevHoverRowIndex) => (isActionsMenuOpen ? prevHoverRowIndex : rowIndex)),\n [isActionsMenuOpen]\n );\n\n const hoveredRowRightContent = useMemo(() => {\n const connection: Connection = hoverRowIndex != null ? tableRowsData[hoverRowIndex].rawValue : null;\n const isInactiveRelation = getIsInactiveRelation(connection);\n\n return (\n connection && (\n <>\n <Tooltip\n key={connection.relation.relationUri}\n open={!isActionsMenuOpen && isInactiveRelation}\n title={i18n.text('Inactive')}\n >\n <div className={styles.tooltipAnchor} />\n </Tooltip>\n <div className={styles.menuButtonContainer}>\n <RelationshipMenuButton\n disableDelete={readOnly}\n connection={connection}\n onMenuOpen={handleActionsMenuOpen}\n onMenuClose={handleActionsMenuClose}\n onDelete={() => onDelete(connection.relation.relationUri)}\n />\n </div>\n </>\n )\n );\n }, [isActionsMenuOpen, onDelete, tableRowsData, hoverRowIndex]);\n\n return (\n <div className={styles.tableContainer}>\n <BasicTable\n fixFirstColumn={true}\n columnsData={tableColumnsData}\n rowsData={tableRowsData}\n sorting={sorting}\n onSort={onSort}\n filters={filters}\n onFilter={onFilter}\n defaultColumnWidth={250}\n defaultColumnMinWidth={200}\n headRowHeight={48}\n getRowCellHeight={getRowCellHeight}\n renderRowCell={renderRowCell}\n onRowClick={onRowClick}\n ref={tableRef}\n hoverStateEnabled={true}\n hoverRowIndex={hoverRowIndex}\n onRowHover={onRowHover}\n hoveredRowRightContent={hoveredRowRightContent}\n classes={{\n hoveredRowRightContentWrapper: styles.hoveredRowRightContentWrapper\n }}\n />\n </div>\n );\n};\n\nexport default memo(RelationshipsTable);\n","import {AttributeType, Relation} from '@reltio/mdm-sdk';\nimport {CrosswalksByTypes, groupCrosswalksByTypesAndSources} from '@reltio/components';\nimport {assoc, map, pipe, propOr} from 'ramda';\n\ntype TableRow = {\n source: string;\n crosswalksByTypes: CrosswalksByTypes;\n};\n\nexport const buildTableRowsData = (relation: Relation, selectedAttributeTypes: AttributeType[] = []): TableRow[] => {\n return pipe(\n propOr([], 'crosswalks'),\n map(assoc('ownerType', 'entity')),\n groupCrosswalksByTypesAndSources(relation.type, selectedAttributeTypes)\n )(relation);\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles(() => ({\n tableRow: {\n '& + &': {\n marginTop: '4px'\n },\n margin: 'auto',\n maxWidth: '448px'\n }\n}));\n","import React, {memo, useCallback, useMemo, useState} from 'react';\nimport {\n AttributeType,\n checkCanDeleteCrosswalk,\n checkCanEditCrosswalk,\n getRelationType,\n Metadata,\n Relation,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {DeleteCrosswalkEvent, EditCrosswalkEvent, SourceCrosswalksRow} from '@reltio/components';\nimport {append, ifElse, includes, without} from 'ramda';\nimport {buildTableRowsData} from './helpers';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n readOnly?: boolean;\n relation: Relation;\n metadata: Metadata;\n selectedAttributeTypes?: AttributeType[];\n onDeleteCrosswalk: (event: DeleteCrosswalkEvent) => void;\n onEditCrosswalk: (event: EditCrosswalkEvent) => void;\n};\n\nconst LegendTable = ({\n readOnly,\n relation,\n metadata,\n selectedAttributeTypes,\n onDeleteCrosswalk,\n onEditCrosswalk\n}: Props) => {\n const styles = useStyles();\n\n const relationType: TRelationType = getRelationType(metadata, relation.type);\n\n const rowsData = useMemo(\n () => buildTableRowsData(relation, selectedAttributeTypes),\n [relation, selectedAttributeTypes]\n );\n const [expandedSources, setExpandedSources] = useState<string[]>([]);\n\n const handleDelete = useCallback(\n (crosswalkId: string) => {\n onDeleteCrosswalk({entityUri: relation.uri, crosswalkId});\n },\n [onDeleteCrosswalk, relation.uri]\n );\n\n const handleEdit = useCallback(\n (event: Omit<EditCrosswalkEvent, 'entityUri'>) => {\n onEditCrosswalk({entityUri: relation.uri, ...event});\n },\n [onEditCrosswalk, relation.uri]\n );\n\n return (\n <div>\n {rowsData.map(({source, crosswalksByTypes}) => {\n return (\n <div key={source} className={styles.tableRow}>\n <SourceCrosswalksRow\n source={source}\n crosswalksByTypes={crosswalksByTypes}\n expanded={expandedSources.includes(source)}\n disableEditCrosswalk={!checkCanEditCrosswalk(relationType) || readOnly}\n disableDeleteCrosswalk={!checkCanDeleteCrosswalk(relationType) || readOnly}\n onEdit={handleEdit}\n onDelete={handleDelete}\n onToggleExpanded={() => {\n setExpandedSources(ifElse(includes(source), without([source]), append(source)));\n }}\n />\n </div>\n );\n })}\n </div>\n );\n};\n\nexport default memo(LegendTable);\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n header: {\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n padding: '20px 12px',\n borderBottom: '1px solid rgba(0, 0, 0, 0.12)'\n },\n title: {\n fontWeight: 500,\n fontSize: '20px',\n lineHeight: '23px',\n letterSpacing: '0.25px',\n color: theme.palette.text.primary,\n marginLeft: '12px'\n },\n hint: {\n color: theme.palette.text.secondary,\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n alignSelf: 'flex-start',\n margin: '4px 14px 10px'\n },\n hintText: {\n marginLeft: '8px',\n fontSize: '12px',\n lineHeight: '16px'\n },\n buttons: {\n display: 'flex',\n padding: '8px 6px 4px'\n },\n buttonLabel: {\n fontSize: '14px',\n fontWeight: 500,\n lineHeight: '16px'\n },\n icon: {\n fontSize: '18px',\n marginRight: '8px'\n },\n editor: {\n paddingLeft: 25,\n margin: 'auto',\n maxWidth: '448px',\n boxSizing: 'border-box',\n marginBottom: '4px'\n },\n tableContainer: {\n overflowY: 'auto',\n overflowX: 'hidden',\n paddingLeft: '16px',\n paddingRight: '6px'\n }\n}));\n","import React, {memo, useState} from 'react';\nimport i18n from 'ui-i18n';\nimport {useSelector} from 'react-redux';\nimport mdmModule from '@reltio/mdm-module';\nimport InfoIcon from '@mui/icons-material/Info';\nimport AddIcon from '@mui/icons-material/Add';\nimport Button from '@mui/material/Button';\nimport LegendTable from '../LegendTable/LegendTable';\nimport {\n AttributeType,\n checkCanCreateCrosswalk,\n getRelationType,\n Metadata,\n Relation,\n TRelationType\n} from '@reltio/mdm-sdk';\nimport {\n AddCrosswalkEvent,\n CrosswalkEditor,\n DeleteCrosswalkEvent,\n EditCrosswalkEvent,\n withTooltip\n} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\nconst ButtonWithTooltip = withTooltip(Button);\n\ntype Props = {\n className?: string;\n readOnly?: boolean;\n relation: Relation;\n selectedAttributeTypes?: AttributeType[];\n onAddCrosswalk: (event: AddCrosswalkEvent) => void;\n onDeleteCrosswalk: (event: DeleteCrosswalkEvent) => void;\n onEditCrosswalk: (event: EditCrosswalkEvent) => void;\n};\n\nconst LegendPanel = ({\n className,\n readOnly,\n relation,\n selectedAttributeTypes,\n onAddCrosswalk,\n onDeleteCrosswalk,\n onEditCrosswalk\n}: Props) => {\n const styles = useStyles();\n\n const metadata: Metadata = useSelector(mdmModule.selectors.getMetadata);\n const relationType: TRelationType = getRelationType(metadata, relation.type);\n\n const [openEditor, setOpenEditor] = useState(false);\n const canAdd = checkCanCreateCrosswalk(relationType) && !readOnly;\n\n return (\n <div className={className}>\n <div className={styles.header}>\n <span className={styles.title}>{i18n.text('Legend')}</span>\n </div>\n <div className={styles.buttons}>\n <ButtonWithTooltip\n color=\"primary\"\n showForDisabled={true}\n disabled={!canAdd}\n tooltipTitle={canAdd ? null : i18n.text(\"You don't have permissions to add crosswalk\")}\n onClick={() => setOpenEditor(true)}\n >\n <AddIcon className={styles.icon} />\n <div className={styles.buttonLabel}>{i18n.text('Crosswalk')}</div>\n </ButtonWithTooltip>\n </div>\n <div className={styles.hint}>\n <InfoIcon className={styles.icon} />\n <span className={styles.hintText}>\n {i18n.text('You can drag a crosswalk to add values to attributes swimlanes')}\n </span>\n </div>\n <div className={styles.tableContainer}>\n {openEditor && (\n <CrosswalkEditor\n className={styles.editor}\n onAdd={(crosswalk) => onAddCrosswalk({entity: relation, crosswalk})}\n onClose={() => setOpenEditor(false)}\n />\n )}\n <LegendTable\n readOnly={readOnly}\n metadata={metadata}\n relation={relation}\n selectedAttributeTypes={selectedAttributeTypes}\n onDeleteCrosswalk={onDeleteCrosswalk}\n onEditCrosswalk={onEditCrosswalk}\n />\n </div>\n </div>\n );\n};\n\nexport default memo(LegendPanel);\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n entityInfo: {\n flex: '0 1 auto',\n overflow: 'hidden',\n minWidth: '100px'\n },\n entityLabelContainer: {\n display: 'flex',\n alignItems: 'center',\n overflow: 'hidden'\n },\n entityLabel: {\n lineHeight: '1.2',\n letterSpacing: '0.25px',\n color: theme.palette.text.primary\n },\n infoIcon: {\n fontSize: '16px',\n color: theme.palette.text.secondary,\n marginLeft: '5px'\n },\n profileBand: {\n margin: '-10px',\n maxWidth: '500px'\n },\n entityTypeBadge: {\n marginTop: '7px'\n }\n}));\n","import React from 'react';\nimport {Entity, getLabel} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport {ExpandedValueTooltip, LightArrowTooltip, ProfileBand, EntityTypeBadge} from '@reltio/components';\nimport InfoIcon from '@mui/icons-material/Info';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n entity: Entity;\n};\n\nconst EntityInfo = ({entity}: Props) => {\n const styles = useStyles();\n const label = getLabel(entity.label);\n return (\n <div className={styles.entityInfo}>\n <div className={styles.entityLabelContainer}>\n <ExpandedValueTooltip value={label}>\n <Typography variant=\"h6\" className={styles.entityLabel} noWrap>\n {label}\n </Typography>\n </ExpandedValueTooltip>\n <LightArrowTooltip\n title={<ProfileBand className={styles.profileBand} entity={entity} />}\n placement={'right'}\n >\n <InfoIcon className={styles.infoIcon} />\n </LightArrowTooltip>\n </div>\n <EntityTypeBadge className={styles.entityTypeBadge} entity={entity} size={'medium'} />\n </div>\n );\n};\n\nexport default EntityInfo;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n root: {\n flexShrink: 0,\n overflow: 'hidden',\n width: '110px'\n },\n label: {\n color: theme.palette.text.secondary,\n fontSize: '13px'\n }\n}));\n","import React from 'react';\nimport {ConnectionRelation} from '@reltio/mdm-sdk';\nimport Typography from '@mui/material/Typography';\nimport {ExpandedValueTooltip} from '@reltio/components';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n relation: ConnectionRelation;\n};\n\nconst RelationDirection = ({relation}: Props) => {\n const styles = useStyles();\n const {direction, relationLabel} = relation;\n return (\n <div className={styles.root}>\n <ExpandedValueTooltip value={relationLabel}>\n <Typography variant={'subtitle2'} className={styles.label} align={'center'} noWrap>\n {relationLabel}\n </Typography>\n </ExpandedValueTooltip>\n <svg width=\"110\" height=\"12\" fill=\"black\" fillOpacity=\"0.3\">\n {direction === 'out' && <polygon points=\"94 0, 110 6, 94 12, 94 9, 0 9, 0 3, 94 3\" />}\n {direction === 'bidirectional' && (\n <polygon points=\"94 0, 110 6, 94 12, 94 9, 16 9, 16 12, 0 6, 16 0, 16 3, 94 3\" />\n )}\n {direction === 'in' && <polygon points=\"16 12, 0 6, 16 0, 16 3, 110 3, 110 9, 16 9\" />}\n </svg>\n </div>\n );\n};\n\nexport default RelationDirection;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles(() => ({\n root: {\n '&:hover $editButton': {\n visibility: 'visible'\n }\n },\n editButton: {\n visibility: 'hidden',\n marginLeft: '4px',\n marginBottom: '4px'\n },\n paper: {\n width: '150px',\n border: '3px solid rgba(0, 0, 0, 0.3)',\n borderRadius: '4px',\n boxSizing: 'border-box',\n overflow: 'hidden'\n }\n}));\n","import React, {KeyboardEvent, useRef, useState} from 'react';\nimport {formatDate} from '@reltio/mdm-sdk';\nimport {DateEditor, SmallIconButton} from '@reltio/components';\nimport EditIcon from '@mui/icons-material/Edit';\nimport Popover from '@mui/material/Popover';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n value: number;\n onChange: (value: number) => void;\n readOnly?: boolean;\n};\n\nconst RelationDate = ({value = null, onChange, readOnly}: Props) => {\n const styles = useStyles();\n const ref = useRef<HTMLSpanElement>();\n\n const [showEditor, setShowEditor] = useState(false);\n const openEditor = () => setShowEditor(true);\n const closeEditor = () => setShowEditor(false);\n\n const [editedValue, setEditedValue] = useState(value);\n\n const applyChangesAndClose = () => {\n if (editedValue !== value) {\n onChange(editedValue);\n }\n closeEditor();\n };\n\n const onKeyUp = (event: KeyboardEvent<HTMLDivElement>) => {\n if (event.key === 'Enter') applyChangesAndClose();\n else if (event.key === 'Escape') closeEditor();\n };\n\n return (\n <span ref={ref} className={styles.root}>\n {value && formatDate(value)}\n <SmallIconButton\n disabled={readOnly}\n icon={EditIcon}\n size={'XXS'}\n className={styles.editButton}\n onClick={openEditor}\n />\n <Popover\n classes={{paper: styles.paper}}\n open={showEditor}\n anchorEl={ref.current}\n anchorOrigin={{vertical: 'top', horizontal: 'left'}}\n transformOrigin={{vertical: 14, horizontal: 20}}\n onKeyUp={onKeyUp}\n onBackdropClick={applyChangesAndClose}\n >\n <DateEditor\n label={undefined}\n value={editedValue && new Date(editedValue)}\n onChange={(value) => setEditedValue(value && value.valueOf())}\n slotProps={{\n textField: {\n size: 'small',\n hiddenLabel: true,\n InputProps: {\n autoFocus: true,\n disableUnderline: true,\n fullWidth: true\n }\n }\n }}\n />\n </Popover>\n </span>\n );\n};\n\nexport default RelationDate;\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles((theme) => ({\n relationBand: {\n flexShrink: 0,\n boxShadow: 'inset 0px -1px 0px rgba(0,0,0,0.06)',\n padding: '16px 19px'\n },\n inactiveRelationBand: {\n opacity: 0.6,\n background: 'rgba(185, 188, 197, 0.18)'\n },\n toolbar: {\n display: 'flex',\n alignItems: 'center',\n gap: '16px',\n marginBottom: '10px'\n },\n mainInfo: {\n display: 'flex',\n gap: '16px',\n marginLeft: '40px'\n },\n detailsInfo: {\n display: 'flex',\n gap: '34px',\n marginLeft: '40px',\n marginTop: '17px',\n color: theme.palette.text.secondary,\n fontSize: '13px'\n },\n detailTitle: {\n color: theme.palette.text.primary,\n flexShrink: 0,\n marginRight: '4px'\n },\n directionalLabel: {\n display: 'flex',\n overflow: 'hidden',\n '& span': {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap'\n }\n },\n relationDate: {\n flexShrink: 0\n },\n commentsContainer: {\n marginRight: '18px'\n }\n}));\n","import React, {memo} from 'react';\nimport {CollaborationObjectTypes, Connection, createRelatedObjectUris, Entity} from '@reltio/mdm-sdk';\nimport {\n CommentsContainer,\n COMMENTS_CONTAINER_VISIBILITY_AREA,\n ExpandedValueTooltip,\n SmallIconButton,\n Spacer\n} from '@reltio/components';\nimport classnames from 'classnames';\nimport ArrowBackIcon from '@mui/icons-material/ArrowBack';\nimport Typography from '@mui/material/Typography';\nimport i18n from 'ui-i18n';\nimport EntityInfo from './EntityInfo/EntityInfo';\nimport RelationDirection from './RelationDirection/RelationDirection';\nimport RelationDate from './RelationDate/RelationDate';\nimport {getIsInactiveRelation} from '../../services/helpers';\nimport RelationshipMenuButton from '../RelationshipMenuButton/RelationshipMenuButton';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n readOnly?: boolean;\n entity: Entity;\n connection: Connection;\n onNavigateBack: () => void;\n onDelete: () => void;\n onChangeActivenessDate: (attributeName: string, value: number) => void;\n};\n\nconst RelationshipBand = ({readOnly, entity, connection, onNavigateBack, onDelete, onChangeActivenessDate}: Props) => {\n const isInactiveRelation = getIsInactiveRelation(connection);\n const styles = useStyles();\n return (\n <div\n className={classnames(styles.relationBand, COMMENTS_CONTAINER_VISIBILITY_AREA, {\n [styles.inactiveRelationBand]: isInactiveRelation\n })}\n data-reltio-id=\"relationship-band-wrapper\"\n >\n <div className={styles.toolbar}>\n <SmallIconButton icon={ArrowBackIcon} size={'S'} onClick={() => onNavigateBack()} />\n <Typography variant={'subtitle2'} display={'inline'}>\n {i18n.text('Back to relationships')}\n </Typography>\n <Spacer />\n <div className={styles.commentsContainer}>\n <CommentsContainer\n uri={connection.relation.relationUri}\n relatedObjectUris={createRelatedObjectUris(CollaborationObjectTypes.RELATION, {\n entityUri: entity?.uri,\n connection\n })}\n objectType={CollaborationObjectTypes.RELATION}\n allowOnlyOneComment\n />\n </div>\n <RelationshipMenuButton connection={connection} onDelete={onDelete} disableDelete={readOnly} />\n </div>\n <div className={styles.mainInfo}>\n <EntityInfo entity={entity} />\n <RelationDirection relation={connection.relation} />\n <EntityInfo entity={{...connection.entity.object, dataTenant: connection.entity.dataTenant}} />\n </div>\n <div className={styles.detailsInfo}>\n <div className={styles.directionalLabel}>\n <span className={styles.detailTitle}>{i18n.text('Directional label:')}</span>\n <ExpandedValueTooltip value={connection.relation.relationLabel}>\n <span>{connection.relation.relationLabel}</span>\n </ExpandedValueTooltip>\n </div>\n <div className={styles.relationDate}>\n <span className={styles.detailTitle}>{i18n.text('Start date:')}</span>\n <RelationDate\n value={connection.relation.startDate}\n onChange={(value) => onChangeActivenessDate('startDate', value)}\n readOnly={readOnly}\n />\n </div>\n <div className={styles.relationDate}>\n <span className={styles.detailTitle}>{i18n.text('End date:')}</span>\n <RelationDate\n value={connection.relation.endDate}\n onChange={(value) => onChangeActivenessDate('endDate', value)}\n readOnly={readOnly}\n />\n </div>\n </div>\n </div>\n );\n};\n\nexport default memo(RelationshipBand);\n","import {ErrorPopup} from '@reltio/components';\nimport i18n from 'ui-i18n';\nimport {getRequestErrorMessage} from '@reltio/mdm-sdk';\n\nexport const showErrorMessage = (error: unknown) => {\n console.error(error); // eslint-disable-line\n ErrorPopup.addError({\n title: i18n.text('Error'),\n message: getRequestErrorMessage(error, i18n.text('Something went wrong'))\n });\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n detailsView: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n overflow: 'hidden'\n },\n locked: {\n pointerEvents: 'none'\n },\n resizablePanesWrapper: {\n flexGrow: 1\n },\n pane: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n display: 'flex',\n flexDirection: 'column',\n overflow: 'hidden'\n }\n});\n","import React, {memo, useCallback, useMemo, useState} from 'react';\nimport classnames from 'classnames';\nimport {\n ApiError,\n ApiErrorCode,\n AttributeType,\n Connection,\n deleteActivenessAttribute,\n Entity,\n getRelation,\n Relation,\n updateActivenessAttribute\n} from '@reltio/mdm-sdk';\nimport {\n AttributesTable,\n BasicView,\n CrosswalkDragLayer,\n CrosswalksDisplayProvider,\n ExpandedAttributesProvider,\n ResizablePanes,\n useCrosswalkActions,\n useModifiedEntity,\n useSafePromise\n} from '@reltio/components';\nimport LegendPanel from '../LegendPanel/LegendPanel';\nimport RelationshipBand from '../RelationshipBand/RelationshipBand';\nimport {assocPath, dissocPath, pipe} from 'ramda';\nimport {showErrorMessage} from '../../services/errors';\nimport {useCrosswalksDisplay} from '../../hooks/useCrosswalksDisplay';\nimport HTML5Backend from 'react-dnd-html5-backend';\nimport {DndProvider} from 'react-dnd';\n\nimport {useStyles} from './styles';\n\nconst MIN_PANE1_SIZE = 600;\nconst MIN_PANE2_SIZE = 480;\nconst MAX_PANE1_SIZE = -MIN_PANE2_SIZE;\n\ntype Props = {\n entity: Entity;\n connection: Connection;\n visibleColumns?: string[];\n onClose: (error?: ApiError) => void;\n onDeleteConnection: () => void;\n onChangeConnection: (connection: Connection) => void;\n onChangeVisibleColumns: (visibleColumns: string[]) => void;\n readOnly?: boolean;\n};\n\nconst RelationshipDetails = ({\n entity,\n connection,\n visibleColumns,\n onClose,\n onDeleteConnection,\n onChangeConnection,\n onChangeVisibleColumns,\n readOnly\n}: Props) => {\n const styles = useStyles();\n const displayProps = useCrosswalksDisplay();\n const [paneSize, setPaneSize] = useState(MAX_PANE1_SIZE);\n const handlePaneSizeChange = useCallback(({percentageSize}) => setPaneSize(percentageSize), []);\n\n const [selectedAttrTypes, setSelectedAttrTypes] = useState<AttributeType[]>();\n const [isLoading, setIsLoading] = useState(false);\n const relationUri = connection.relation.relationUri;\n\n const safePromise = useSafePromise();\n const onLoad = useCallback(() => setIsLoading(true), []);\n const onLoaded = useCallback(() => setIsLoading(false), []);\n const onDeleteRelation = useCallback(pipe(onDeleteConnection, onLoad), []);\n const [onError, reloadRelation] = useMemo(() => {\n const onError = (error: ApiError) => {\n if (error.errorCode === ApiErrorCode.CROSSWALK_NOT_FOUND) {\n showErrorMessage(error);\n reloadRelation();\n } else if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n onClose(error);\n } else {\n showErrorMessage(error);\n onLoaded();\n }\n };\n const reloadRelation = () => {\n safePromise(getRelation(relationUri))\n .then((newRelation: Relation) => {\n onChangeConnection(assocPath(['relation', 'object'], newRelation, connection));\n onLoaded();\n })\n .catch(onError);\n };\n return [onError, reloadRelation];\n }, [connection, onLoaded, onChangeConnection, onClose]);\n\n const {\n modifiedEntity,\n crosswalksMap,\n newlyCreatedAttributes,\n onPinAttribute,\n onIgnoreAttribute,\n onAddAttribute,\n onEditAttribute,\n onDeleteAttribute,\n emptyTempAttributeUris\n } = useModifiedEntity({\n entity: connection.relation.object,\n onModify: reloadRelation,\n onError,\n onLoad\n });\n\n const {addCrosswalk, deleteCrosswalk, editCrosswalk} = useCrosswalkActions({\n onSuccess: reloadRelation,\n onError,\n onLoad\n });\n\n const onChangeActivenessDate = useCallback(\n (attributeName: string, value: number) => {\n onLoad();\n const request = value\n ? updateActivenessAttribute({entityUri: relationUri, attributeName, value}).then(() =>\n onChangeConnection(assocPath(['relation', attributeName], value, connection))\n )\n : deleteActivenessAttribute({entityUri: relationUri, attributeName}).then(() =>\n onChangeConnection(dissocPath(['relation', attributeName], connection))\n );\n request.then(onLoaded).catch(onError);\n },\n [connection, onLoad, onLoaded, onError]\n );\n\n return (\n <BasicView className={styles.detailsView}>\n <CrosswalksDisplayProvider {...displayProps}>\n <DndProvider backend={HTML5Backend}>\n <CrosswalkDragLayer />\n <ResizablePanes\n className={classnames(styles.resizablePanesWrapper, {[styles.locked]: isLoading})}\n orientation={'vertical'}\n size={paneSize}\n minSize={MIN_PANE1_SIZE}\n maxSize={MAX_PANE1_SIZE}\n allowResize={true}\n onChange={handlePaneSizeChange}\n >\n <div className={styles.pane}>\n <RelationshipBand\n readOnly={readOnly}\n entity={entity}\n connection={connection}\n onNavigateBack={onClose}\n onDelete={onDeleteRelation}\n onChangeActivenessDate={onChangeActivenessDate}\n />\n <ExpandedAttributesProvider attributeUris={newlyCreatedAttributes}>\n <AttributesTable\n readOnly={readOnly}\n entity={modifiedEntity}\n crosswalksMap={crosswalksMap}\n isLoading={isLoading}\n onPin={onPinAttribute}\n onIgnore={onIgnoreAttribute}\n onEdit={onEditAttribute}\n onAdd={onAddAttribute}\n onDelete={onDeleteAttribute}\n emptyTempAttributeUris={emptyTempAttributeUris}\n selectedAttributeTypes={selectedAttrTypes}\n onSelectAttributeTypes={setSelectedAttrTypes}\n visibleColumns={visibleColumns}\n onChangeVisibleColumns={onChangeVisibleColumns}\n />\n </ExpandedAttributesProvider>\n </div>\n <LegendPanel\n readOnly={readOnly}\n className={styles.pane}\n relation={connection.relation.object}\n selectedAttributeTypes={selectedAttrTypes}\n onAddCrosswalk={addCrosswalk}\n onDeleteCrosswalk={deleteCrosswalk}\n onEditCrosswalk={editCrosswalk}\n />\n </ResizablePanes>\n </DndProvider>\n </CrosswalksDisplayProvider>\n </BasicView>\n );\n};\n\nexport default memo(RelationshipDetails);\n","import {useCallback, useMemo, useState, useRef} from 'react';\nimport {CrosswalkBase, debounce, eqCrosswalks} from '@reltio/mdm-sdk';\nimport {any, concat} from 'ramda';\n\nexport const useCrosswalksDisplay = () => {\n const [highlightedCrosswalks, setHighlightedCrosswalks] = useState<CrosswalkBase[]>([]);\n const highlightedCrosswalksCache = useRef([]);\n const applyHighlightedCrosswalks = useCallback(\n debounce(() => {\n setHighlightedCrosswalks([...highlightedCrosswalksCache.current]);\n }, 50),\n []\n );\n const cacheHighlightedCrosswalks = useCallback(\n (arr) => {\n highlightedCrosswalksCache.current = arr;\n applyHighlightedCrosswalks(arr);\n },\n [applyHighlightedCrosswalks]\n );\n\n const setCrosswalkHighlighted = useCallback(\n (crosswalk: CrosswalkBase, highlighted: boolean) => {\n if (!crosswalk) return;\n if (highlighted) {\n cacheHighlightedCrosswalks([crosswalk]);\n } else {\n cacheHighlightedCrosswalks([]);\n }\n },\n [cacheHighlightedCrosswalks]\n );\n\n const [focusedCrosswalks, setFocusedCrosswalks] = useState<CrosswalkBase[]>([]);\n const calculateFocusedCrosswalks = (prev: CrosswalkBase[], next: CrosswalkBase[]) =>\n concat(\n prev.filter((prevCrosswalk) => !any(eqCrosswalks(prevCrosswalk), next)),\n next.filter((nextCrosswalk) => !any(eqCrosswalks(nextCrosswalk), prev))\n );\n\n const toggleCrosswalkFocus = useCallback((crosswalk: CrosswalkBase) => {\n if (!crosswalk) return;\n setFocusedCrosswalks((prevValue) => calculateFocusedCrosswalks([crosswalk], prevValue));\n }, []);\n\n return {\n highlightedCrosswalks: useMemo(\n () => [...highlightedCrosswalks, ...focusedCrosswalks],\n [highlightedCrosswalks, focusedCrosswalks]\n ),\n focusedCrosswalks,\n toggleCrosswalkFocus,\n setCrosswalkHighlighted\n };\n};\n","import {makeStyles} from '@mui/styles';\n\nexport const useStyles = makeStyles({\n relationshipsView: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n overflowX: 'hidden',\n overflowY: 'auto',\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif',\n display: 'flex',\n flexDirection: 'column'\n },\n '@global div[role=tooltip]': {\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif'\n },\n '@global div[role=presentation]': {\n fontFamily: 'Roboto, Helvetica, Arial, sans-serif'\n },\n pane: {\n display: 'flex',\n flexDirection: 'column',\n flex: 1,\n overflow: 'hidden',\n position: 'relative'\n }\n});\n","import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react';\nimport {Dispatch} from 'redux';\nimport {connect} from 'react-redux';\nimport {\n always,\n andThen,\n both,\n either,\n equals,\n filter,\n identity,\n map,\n otherwise,\n pipe,\n prop,\n propEq,\n update,\n when,\n not\n} from 'ramda';\nimport mdmModule, {profile} from '@reltio/mdm-module';\nimport {\n ApiError,\n ApiErrorCode,\n checkMetadataPermission,\n CollaborationObjectTypes,\n Connection,\n Entity,\n getEntitiesMapForConnections,\n getInheritancePath,\n getRelationshipsObjectIdsForCollaboration,\n isDataTenantEntity,\n Metadata,\n MetadataPermissions,\n Mode,\n RelationshipsPerspectiveConfig,\n removeRelation,\n TRelationType,\n ActivityFilter\n} from '@reltio/mdm-sdk';\nimport {\n BasicTablePagination,\n CollaborationContextProvider,\n EntitiesMapContext,\n LinearLoadIndicator,\n ScreenProfileBand,\n useCollaboration,\n useDidUpdateEffect,\n useRelationsLoader\n} from '@reltio/components';\nimport useSavedState from '../../hooks/useSavedState';\nimport {useRelationshipsTable} from '../../hooks/useRelationshipsTable';\nimport {RelationshipsSavedState} from '../../types';\nimport {DEFAULT_COLUMNS, getColumnsData, ROWS_PER_PAGE_OPTIONS} from './helpers/tableHelpers';\nimport {buildRelationshipsFilter} from './helpers/filtersHelpers';\nimport RelationshipsTableHeader from '../RelationshipsTableHeader/RelationshipsTableHeader';\nimport RelationshipsTable from '../RelationshipsTable/RelationshipsTable';\nimport RelationshipDetails from '../RelationshipDetails/RelationshipDetails';\nimport {showErrorMessage} from '../../services/errors';\n\nimport {useStyles} from './styles';\n\ntype Props = {\n config: RelationshipsPerspectiveConfig;\n entity: Entity;\n metadata: Metadata;\n connections: Connection[];\n total: number;\n saveState: (state: RelationshipsSavedState) => void;\n getSavedState: () => Promise<RelationshipsSavedState>;\n dispatch: Dispatch;\n};\n\nconst RelationshipsView = ({\n config,\n entity,\n metadata,\n connections,\n total,\n saveState,\n getSavedState,\n dispatch\n}: Props) => {\n const styles = useStyles();\n const tableRef = useRef();\n\n const isDTEntity = isDataTenantEntity(entity);\n\n const [searchByOv, setSearchByOv] = useState(false);\n const [showInactive, setShowInactive] = useState(false);\n\n const {type: entityTypeUri} = entity || {};\n const [\n {\n visibleColumns,\n filters,\n page,\n rowsPerPage,\n sorting,\n currentRelationType,\n stateToSave,\n entityTypeOfAppliedSavedState\n },\n {\n changeColumns,\n toggleFilters,\n changeFilter,\n changePage,\n changeRowsPerPage,\n toggleSort,\n changeRelationType,\n saveCurrentState,\n applySavedState\n }\n ] = useRelationshipsTable({\n defaultColumns: DEFAULT_COLUMNS,\n defaultRowsPerPage: ROWS_PER_PAGE_OPTIONS[0],\n defaultSorting: {\n field: DEFAULT_COLUMNS[0],\n order: 'asc'\n }\n });\n\n const isSavedStateApplied = entityTypeOfAppliedSavedState === entityTypeUri;\n\n const {\n isLoading: isSavedStateLoading,\n relationsTableSavedState,\n attributesTableSavedState,\n updateRelationsTableSavedState,\n updateAttributesTableSavedState\n } = useSavedState({\n getSavedState,\n saveState,\n entityTypeUri\n });\n\n const [attributesTableVisibleColumns, setAttributesTableVisibleColumns] = useState<string[]>();\n\n useEffect(() => {\n if (!isSavedStateLoading) {\n applySavedState({savedState: relationsTableSavedState, entityTypeUri});\n }\n }, [isSavedStateLoading, entityTypeUri]); // eslint-disable-line\n\n useEffect(() => {\n if (!isSavedStateLoading) {\n setAttributesTableVisibleColumns(attributesTableSavedState?.visibleColumns);\n }\n }, [isSavedStateLoading]); // eslint-disable-line\n\n useDidUpdateEffect(() => {\n if (isSavedStateApplied) {\n updateRelationsTableSavedState(stateToSave);\n }\n }, [stateToSave]);\n\n const resetPage = () => {\n changePage(0);\n };\n useDidUpdateEffect(resetPage, [entity]);\n\n const [detailedConnectionIndex, setDetailedConnectionIndex] = useState<number>();\n const hideConnectionDetails = useCallback(() => {\n setDetailedConnectionIndex(null);\n }, []);\n\n const relationTypes: TRelationType[] = useMemo(() => {\n const inheritancePath = getInheritancePath(metadata, entityTypeUri);\n const isRelatedToEntityType = ({startObject, endObject}) =>\n inheritancePath.some(either(equals(startObject.objectTypeURI), equals(endObject.objectTypeURI)));\n return metadata.relationTypes.filter(\n both(checkMetadataPermission(MetadataPermissions.READ), isRelatedToEntityType)\n );\n }, [metadata, entityTypeUri]);\n\n const columnsData = useMemo(\n () => getColumnsData(relationTypes, currentRelationType),\n [relationTypes, currentRelationType]\n );\n const visibleColumnsData = useMemo(\n () => visibleColumns.map((id) => columnsData.find(propEq('id', id))).filter(identity),\n [visibleColumns, columnsData]\n );\n\n const relationsConfig = useMemo(() => {\n const relations = pipe(\n when(always(currentRelationType), filter(propEq('uri', currentRelationType))),\n map(prop('uri'))\n )(relationTypes);\n return {\n id: config.id,\n content: {\n inRelations: relations,\n outRelations: relations\n }\n };\n }, [config.id, currentRelationType, relationTypes]);\n\n const relationFilter = useMemo(\n () => buildRelationshipsFilter(filters, visibleColumnsData),\n [filters, visibleColumnsData]\n );\n\n const {isLoading: isRelationsLoading, reload: reloadRelations} = useRelationsLoader({\n page,\n rowsPerPage,\n config: relationsConfig,\n entity: isSavedStateApplied ? entity : null,\n filter: relationFilter,\n mode: Mode.Viewing,\n sorting,\n searchByOv,\n relationActivityFilter: showInactive ? ActivityFilter.ALL : ActivityFilter.ACTIVE_ONLY\n });\n\n const isLoading = !isSavedStateApplied || isRelationsLoading;\n\n const onSort = useCallback(pipe(toggleSort, saveCurrentState), [toggleSort, saveCurrentState]);\n const onFilter = useCallback(pipe(changeFilter, saveCurrentState), [changeFilter, saveCurrentState]);\n const onToggleFilters = useCallback(pipe(toggleFilters, saveCurrentState), [toggleFilters, saveCurrentState]);\n const onChangeColumns = useCallback(pipe(changeColumns, saveCurrentState), [changeColumns, saveCurrentState]);\n const onRelationTypeChange = useCallback(pipe(changeRelationType, saveCurrentState), [\n changeRelationType,\n saveCurrentState\n ]);\n const onChangeDetailedColumns = useCallback(\n (visibleColumns: string[]) => {\n setAttributesTableVisibleColumns(visibleColumns);\n updateAttributesTableSavedState({visibleColumns});\n },\n [updateAttributesTableSavedState]\n );\n\n const detailedConnection = connections?.[detailedConnectionIndex];\n const onChangeDetailedConnection = useCallback(\n (newConnection: Connection) => {\n dispatch(\n profile.relations.actions.relationsLoaded({\n id: config.id,\n connections: update(detailedConnectionIndex, newConnection, connections),\n total\n })\n );\n },\n [detailedConnection]\n );\n const [objectIds, objectTypes] = useMemo(() => {\n return [getRelationshipsObjectIdsForCollaboration(connections), [CollaborationObjectTypes.RELATION]];\n }, [connections]);\n\n const collaboration = useCollaboration({objectIds, objectTypes, enabled: !isDTEntity});\n const entitiesMap = useMemo(() => getEntitiesMapForConnections(connections), [connections]);\n\n const handleError = useCallback(\n (error: ApiError) => {\n showErrorMessage(error);\n if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n reloadRelations();\n }\n },\n [reloadRelations]\n );\n\n const deleteRelation = useCallback(\n (relationUri: string) => {\n pipe(removeRelation, andThen(reloadRelations), otherwise(handleError))(relationUri);\n },\n [reloadRelations, handleError]\n );\n\n const deleteRelationAndCloseDetails = useCallback(() => {\n pipe(\n removeRelation,\n andThen(pipe(hideConnectionDetails, reloadRelations)),\n otherwise((error: ApiError) => {\n if (error.errorCode === ApiErrorCode.OBJECT_NOT_FOUND) {\n hideConnectionDetails();\n }\n handleError(error);\n })\n )(detailedConnection.relation.relationUri);\n }, [detailedConnection, reloadRelations, hideConnectionDetails, handleError]);\n\n const onCloseConnectionDetails = useCallback(\n (error?: ApiError) => {\n if (error) handleError(error);\n hideConnectionDetails();\n },\n [handleError, hideConnectionDetails]\n );\n\n const onToggleSearchByOv = useCallback(() => {\n setSearchByOv(not);\n }, []);\n\n const onToggleShowInactive = useCallback(() => {\n setShowInactive(not);\n }, []);\n\n return (\n <CollaborationContextProvider collaboration={collaboration}>\n <EntitiesMapContext.Provider value={entitiesMap}>\n <div className={styles.relationshipsView}>\n <ScreenProfileBand entity={entity} />\n <RelationshipsTableHeader\n total={total}\n filteringEnabled={!!filters}\n onToggleFilters={onToggleFilters}\n columnsData={columnsData}\n selectedColumns={visibleColumns}\n onChangeColumns={onChangeColumns}\n relationTypes={relationTypes}\n currentRelationType={currentRelationType}\n onRelationTypeChange={onRelationTypeChange}\n searchByOv={searchByOv}\n onToggleSearchByOv={onToggleSearchByOv}\n showInactive={showInactive}\n onToggleShowInactive={onToggleShowInactive}\n />\n <div className={styles.pane}>\n {isLoading && <LinearLoadIndicator />}\n <RelationshipsTable\n readOnly={isDTEntity}\n metadata={metadata}\n connections={connections}\n columnsData={visibleColumnsData}\n sorting={sorting}\n onSort={onSort}\n filters={filters}\n onFilter={onFilter}\n onRowClick={setDetailedConnectionIndex}\n tableRef={tableRef}\n onDelete={deleteRelation}\n />\n <BasicTablePagination\n count={total}\n rowsPerPageOptions={ROWS_PER_PAGE_OPTIONS}\n page={page}\n onChangePage={changePage}\n rowsPerPage={rowsPerPage}\n onChangeRowsPerPage={changeRowsPerPage}\n basicTableRef={tableRef}\n />\n </div>\n {detailedConnection && (\n <RelationshipDetails\n readOnly={isDTEntity}\n entity={entity}\n visibleColumns={attributesTableVisibleColumns}\n onChangeVisibleColumns={onChangeDetailedColumns}\n connection={detailedConnection}\n onClose={onCloseConnectionDetails}\n onDeleteConnection={deleteRelationAndCloseDetails}\n onChangeConnection={onChangeDetailedConnection}\n />\n )}\n </div>\n </EntitiesMapContext.Provider>\n </CollaborationContextProvider>\n );\n};\n\nconst mapStateToProps = (state, {config: {id}}) => {\n return {\n entity: mdmModule.selectors.getEntity(state),\n metadata: mdmModule.selectors.getMetadata(state),\n connections: mdmModule.selectors.getConnectionsByViewId(state, id),\n total: mdmModule.selectors.getTotalByViewId(state, id)\n };\n};\n\nexport default connect(mapStateToProps)(RelationshipsView);\n","import {buildColumnsFilter, ColumnFilter} from '@reltio/components';\nimport {FilterBuilder} from '@reltio/mdm-sdk';\nimport {RelationshipsTableColumnData} from '../../../types';\n\nexport const buildRelationshipsFilter = (\n filters: Record<string, ColumnFilter>,\n columnsData: RelationshipsTableColumnData[]\n) => {\n const filtersClause = buildColumnsFilter(columnsData, filters);\n\n return new FilterBuilder().addClause(filtersClause).build();\n};\n","import React, {useCallback, useContext, useMemo} from 'react';\nimport {Provider} from 'react-redux';\nimport {Store} from 'redux';\n\nimport createGenerateClassName from '@mui/styles/createGenerateClassName';\nimport StylesProvider from '@mui/styles/StylesProvider';\nimport ReactResizeDetector from 'react-resize-detector';\nimport {LocalizationProvider} from '@mui/x-date-pickers/LocalizationProvider';\nimport {AdapterMoment} from '@mui/x-date-pickers/AdapterMoment';\nimport {ErrorPopup, ViewIdContext, FeaturesContext} from '@reltio/components';\nimport mdmModule from '@reltio/mdm-module';\nimport {RelationshipsSavedState} from '../../types';\nimport RelationshipsView from './RelationshipsView';\nimport {promisifyCallback, RelationshipsPerspectiveConfig} from '@reltio/mdm-sdk';\n\nconst generateClassName = createGenerateClassName({\n productionPrefix: 'relationshipsPerspective',\n disableGlobal: true,\n seed: 'relP'\n});\n\ntype Props = {\n config: RelationshipsPerspectiveConfig;\n store: Store<unknown>;\n onResize?: (width: number, height: number) => void;\n saveState: (state: RelationshipsSavedState) => void;\n getSavedState: (clb: (state: RelationshipsSavedState) => void) => void;\n};\n\nconst RelationshipsPerspective = ({config, store, onResize, saveState, getSavedState}: Props) => {\n const getSavedStatePromisified: () => Promise<RelationshipsSavedState> = useCallback(\n promisifyCallback(getSavedState),\n [getSavedState]\n );\n const featuresContext = useContext(FeaturesContext);\n const showDescription = mdmModule.selectors.getShowAttributeDescription(store.getState());\n const features = useMemo(() => ({...featuresContext, showDescription}), [featuresContext, showDescription]);\n\n return (\n <Provider store={store}>\n <ViewIdContext.Provider value={config.id}>\n <FeaturesContext.Provider value={features}>\n <StylesProvider generateClassName={generateClassName}>\n <LocalizationProvider dateAdapter={AdapterMoment}>\n <ReactResizeDetector\n handleHeight\n onResize={(width, height) => onResize?.(Math.floor(width), Math.floor(height))}\n />\n {config && (\n <RelationshipsView\n config={config}\n saveState={saveState}\n getSavedState={getSavedStatePromisified}\n />\n )}\n <ErrorPopup />\n </LocalizationProvider>\n </StylesProvider>\n </FeaturesContext.Provider>\n </ViewIdContext.Provider>\n </Provider>\n );\n};\n\nexport default RelationshipsPerspective;\n","import {RelationshipsView} from '@reltio/relationships';\n\nexport default RelationshipsView;\n"],"names":["props","width","height","viewBox","xmlns","d","fill","fillRule","stroke","strokeWidth","useStyles","makeStyles","theme","color","palette","primary","main","closeIcon","position","right","bottom","transform","button","padding","FilterButton","enabled","onClick","styles","Tooltip","title","i18n","IconButton","classes","root","size","Filter","className","Close","propTypes","PropTypes","pagination","display","alignItems","justifyContent","flexShrink","borderTop","boxShadow","boxSizing","overflowY","containerType","caption","fontSize","lineHeight","displayedRows","selectRoot","marginLeft","marginRight","select","textAlign","actions","BasicTablePagination","count","rowsPerPageOptions","page","onChangePage","rowsPerPage","onChangeRowsPerPage","basicTableRef","labelRowsPerPage","resetScrollbarPosition","useCallback","pathOr","identity","handleChangePage","value","handleChangeRowsPerPage","TablePagination","classnames","selectLabel","input","backIconButtonProps","nextIconButtonProps","component","labelDisplayedRows","from","to","fromRow","toRow","countRows","onPageChange","pipe","nthArg","onRowsPerPageChange","getValue","displayName","memo","CHANGE_COLUMNS","TOGGLE_FILTERS","CHANGE_FILTER","TOGGLE_SORT","CHANGE_PAGE","CHANGE_ROWS_PER_PAGE","changeColumns","createStandardAction","toggleFilters","changeFilter","toggleSort","changePage","changeRowsPerPage","changeVisibleColumns","state","nextVisibleColumns","removedColumns","difference","visibleColumns","isRemovedColumn","columnId","includes","evolve","always","sorting","when","field","nextSortField","order","filters","keys","reduce","acc","dissoc","reducer","action","type","columnIds","payload","enableFilters","filter","assoc","prevSortField","path","prevSortOrder","toggleSortOrder","basicViewPaper","flexDirection","basicView","BasicView","forwardRef","ref","children","otherProps","Paper","paper","minHeight","fontWeight","letterSpacing","content","contentText","marginBottom","actionButtons","paddingTop","discardButton","open","onCancel","cancelCaption","onDiscard","discardCaption","onSave","saveCaption","disabledSave","Dialog","onClose","paperScrollPaper","DialogTitle","DialogContent","DialogContentText","DialogActions","disableSpacing","Button","disabled","autoFocus","menuItem","menuText","text","checkbox","SettingsMenuItemRenderer","item","onMenuClose","id","selected","MenuItem","e","Checkbox","checked","Typography","items","menuId","DropDownMenuButton","buttonComponent","SmallIconButtonWithTooltip","buttonProps","icon","SettingsIcon","tooltipTitle","menuItems","MenuItemRenderer","VerticalDivider","margin","style","borderLeft","useActions","dispatch","useMemo","Object","entries","actionName","actionCreator","buildSuggestedIds","wrapInArrayIfNeeded","length","times","n","useRelationsLoader","config","entity","relationActivityFilter","mode","searchByOv","isLoading","setIsLoading","useState","useDispatch","tenant","useSelector","mdm","metadata","dtssPath","activityFilter","globalFilter","lastLoadedTime","safePromise","useSafePromise","processContent","getUri","isObject","prop","filterRelation","isAvailableRelationTypeUri","entityTypes","filterFn","isAvailableEntityTypeUri","inRelations","outRelations","nextEntry","suggested","options","loadRelations","uri","requestConfig","sortBy","returnDates","returnObjects","activeness","relation","ActivityFilter","max","offset","addGlobalFilterToQuery","undefined","configs","concat","ifElse","map","i","request","cond","isTempUri","Promise","resolve","total","isDataTenantEntity","getRelationsForDataTenantEntity","entityUri","customerTenant","dataTenant","T","getRelationsForEntity","then","result","Array","isArray","Error","JSON","stringify","connections","profile","catch","console","warn","finally","isRequestSentRef","useRef","current","useEffect","prevMode","usePrevious","Mode","reload","DEFAULT_SAVED_STATE","relationsTable","attributesTable","RELATION_TYPE_COLUMN_ID","ATTRIBUTES_COLUMN_ID","DEFAULT_COLUMNS_DATA","label","dataTypeDefinition","DataTypes","hideable","filterable","initialWidth","autoResize","sortable","maxAttrsToShow","DEFAULT_COLUMNS","pluck","ALL_TYPES_COLUMNS","ROWS_PER_PAGE_OPTIONS","getColumnIdFromAttrUri","attributeUriToSearchUri","getColumnsDataFromRelationAttributes","attr","description","getAttrDataTypeDefinition","uniqBy","CHANGE_RELATION_TYPE","APPLY_SAVED_STATE","SAVE_CURRENT_STATE","basicTableViewState","changeRelationType","applySavedState","saveCurrentState","resetPageNumber","getDefaultVisibleColumnsForCurrentRelationType","currentRelationType","without","intersection","getSavedVisibleColumnsForCurrentRelationType","changeVisibleColumnsForCurrentRelationType","either","getFiltersFromSavedState","propOr","unless","isNil","validateFilterValue","saveVisibleColumnsForCurrentRelationType","visibleColumnsForRelationTypes","getStateToSave","pick","paddingLeft","selectMenu","textField","maxWidth","onChange","relationTypes","DropDownEditor","displayEmpty","disableUnderline","TextFieldProps","MenuProps","list","header","paddingRight","secondary","relationTypeSelector","overflow","filteringEnabled","onToggleFilters","columnsData","selectedColumns","onRelationTypeChange","onChangeColumns","onToggleSearchByOv","showInactive","onToggleShowInactive","settingItems","BasicViewHeader","variant","Spacer","SettingsMenu","ColumnsSettings","getIsInactiveRelation","connection","isActiveObject","headCell","background","rowCell","overflowWrap","inactiveRowCell","opacity","defaultWrapper","paddingBottom","entityCell","entityAvatar","inactiveEntityAvatar","backgroundColor","border","borderRadius","entityLabel","textDecoration","attributesWrapper","commentsContainer","withFilterAtBottom","headCellData","DefaultHeadCellRenderer","DescriptionIcon","entityType","isInactiveRelation","currentEntityUri","mdmModule","COMMENTS_CONTAINER_VISIBILITY_AREA","EntityTypeIcon","EntityUriLink","getEntityUriForLink","getLabel","stopPropagation","CommentsContainer","relationUri","relatedObjectUris","createRelatedObjectUris","CollaborationObjectTypes","objectType","allowOnlyOneComment","columnData","attributes","attributeTypes","attrTypes","drawLines","DataTypeValue","getAttrPathFromColumnId","split","slice","Infinity","getNestedPathByColumnId","startsWith","attrPath","getCellValueRenderer","EntityProfileRenderer","AttributesRenderer","DefaultCellValueRenderer","getBasicTableColumnsData","resizable","headCellRenderer","HeadCellRenderer","nestedPath","rowCellValueRenderer","getStaticRowCellHeight","pathEq","cell","attributesCount","values","defaultGetRowCellHeight","CellValueRenderer","index","key","buttons","MenuItemWithTooltip","withTooltip","noop","tooltip","showForDisabled","disableDelete","onMenuOpen","onDelete","hasDeletePermission","getRelationType","checkMetadataPermission","MetadataPermissions","canDelete","pendingDeletion","setPendingDeletion","hideDeleteConfirmation","Delete","handleMenuClose","SmallIconButton","MoreVertIcon","ConfirmationDialog","substring","tableContainer","flex","zIndex","hoveredRowRightContentWrapper","pointerEvents","menuButtonContainer","top","tooltipAnchor","onSort","onFilter","onRowClick","tableRef","readOnly","tableRowsData","getEntityType","relationType","relationLabel","startDate","endDate","object","getOvAttributeValuesByPath","getRelationAttributeValues","getRowValueByColumnId","getBasicTableRowsData","tableColumnsData","getDynamicRowCellHeight","changeRowCellHeight","useDynamicRowCellHeight","getRowCellHeight","hoverRowIndex","setHoverRowIndex","renderRowCell","rowValue","rawValue","RowCellAutoSizer","onChangeHeight","isActionsMenuOpen","setIsActionsMenuOpen","handleActionsMenuOpen","handleActionsMenuClose","onRowHover","rowIndex","prevHoverRowIndex","hoveredRowRightContent","BasicTable","fixFirstColumn","rowsData","defaultColumnWidth","defaultColumnMinWidth","headRowHeight","hoverStateEnabled","tableRow","marginTop","selectedAttributeTypes","onDeleteCrosswalk","onEditCrosswalk","groupCrosswalksByTypesAndSources","buildTableRowsData","expandedSources","setExpandedSources","handleDelete","crosswalkId","handleEdit","event","source","crosswalksByTypes","SourceCrosswalksRow","expanded","disableEditCrosswalk","checkCanEditCrosswalk","disableDeleteCrosswalk","checkCanDeleteCrosswalk","onEdit","onToggleExpanded","append","borderBottom","hint","alignSelf","hintText","buttonLabel","editor","overflowX","ButtonWithTooltip","onAddCrosswalk","openEditor","setOpenEditor","canAdd","checkCanCreateCrosswalk","Add","Info","CrosswalkEditor","onAdd","crosswalk","entityInfo","minWidth","entityLabelContainer","infoIcon","profileBand","entityTypeBadge","ExpandedValueTooltip","noWrap","LightArrowTooltip","ProfileBand","placement","EntityTypeBadge","direction","align","fillOpacity","points","visibility","editButton","showEditor","setShowEditor","closeEditor","editedValue","setEditedValue","applyChangesAndClose","formatDate","EditIcon","Popover","anchorEl","anchorOrigin","vertical","horizontal","transformOrigin","onKeyUp","onBackdropClick","DateEditor","Date","valueOf","slotProps","hiddenLabel","InputProps","fullWidth","relationBand","inactiveRelationBand","toolbar","gap","mainInfo","detailsInfo","detailTitle","directionalLabel","textOverflow","whiteSpace","relationDate","onNavigateBack","onChangeActivenessDate","ArrowBackIcon","showErrorMessage","error","ErrorPopup","message","getRequestErrorMessage","detailsView","left","locked","resizablePanesWrapper","flexGrow","pane","onDeleteConnection","onChangeConnection","onChangeVisibleColumns","displayProps","highlightedCrosswalks","setHighlightedCrosswalks","highlightedCrosswalksCache","applyHighlightedCrosswalks","debounce","cacheHighlightedCrosswalks","arr","setCrosswalkHighlighted","highlighted","focusedCrosswalks","setFocusedCrosswalks","toggleCrosswalkFocus","prevValue","calculateFocusedCrosswalks","prev","next","prevCrosswalk","any","eqCrosswalks","nextCrosswalk","useCrosswalksDisplay","paneSize","setPaneSize","handlePaneSizeChange","percentageSize","selectedAttrTypes","setSelectedAttrTypes","onLoad","onLoaded","onDeleteRelation","onError","reloadRelation","errorCode","ApiErrorCode","getRelation","newRelation","assocPath","modifiedEntity","crosswalksMap","newlyCreatedAttributes","onPinAttribute","onIgnoreAttribute","onAddAttribute","onEditAttribute","onDeleteAttribute","emptyTempAttributeUris","useModifiedEntity","onModify","addCrosswalk","deleteCrosswalk","editCrosswalk","useCrosswalkActions","onSuccess","attributeName","updateActivenessAttribute","deleteActivenessAttribute","dissocPath","DndProvider","backend","HTML5Backend","CrosswalkDragLayer","ResizablePanes","orientation","minSize","maxSize","allowResize","attributeUris","AttributesTable","onPin","onIgnore","onSelectAttributeTypes","relationshipsView","fontFamily","connect","saveState","getSavedState","isDTEntity","setSearchByOv","setShowInactive","entityTypeUri","stateToSave","entityTypeOfAppliedSavedState","defaultColumns","defaultSorting","defaultRowsPerPage","initState","useReducer","nextRelationType","savedState","useRelationshipsTable","isSavedStateApplied","isSavedStateLoading","relationsTableSavedState","attributesTableSavedState","updateRelationsTableSavedState","updateAttributesTableSavedState","setSavedState","changedRelationsState","setRelationsChangedState","useDidUpdateEffect","_","changedState","useSavedState","attributesTableVisibleColumns","setAttributesTableVisibleColumns","detailedConnectionIndex","setDetailedConnectionIndex","hideConnectionDetails","inheritancePath","getInheritancePath","both","startObject","endObject","some","equals","objectTypeURI","find","getReadableAttributesList","reject","updateColumnData","updateFn","getRelationColumnDataType","adjust","findIndex","propEq","updateRelationTypeColumn","getColumnsData","visibleColumnsData","relationsConfig","relations","relationFilter","filtersClause","buildColumnsFilter","FilterBuilder","addClause","build","buildRelationshipsFilter","isRelationsLoading","reloadRelations","onChangeDetailedColumns","detailedConnection","onChangeDetailedConnection","newConnection","update","objectIds","objectTypes","getRelationshipsObjectIdsForCollaboration","collaboration","useCollaboration","entitiesMap","getEntitiesMapForConnections","handleError","deleteRelation","removeRelation","andThen","otherwise","deleteRelationAndCloseDetails","onCloseConnectionDetails","not","CollaborationContext","EntitiesMapContext","ScreenProfileBand","LinearLoadIndicator","generateClassName","createGenerateClassName","productionPrefix","disableGlobal","seed","store","onResize","getSavedStatePromisified","promisifyCallback","featuresContext","useContext","FeaturesContext","showDescription","getState","features","Provider","ViewIdContext","StylesProvider","LocalizationProvider","dateAdapter","AdapterMoment","handleHeight","Math","floor"],"sourceRoot":""}
|