{"version":3,"file":"static/js/6a7ab0ea362163ed5012.bundle.js","mappings":";k/BAkLA,SAASA,EAAyBC,EAA2BC,GAAiC,IAAAC,EAAAC,EAC1F,IAAKF,IAAgBA,EAAYG,gBAC7B,OAAO,KAGX,MACMC,EADcL,EACkCM,IAAIC,OAAOF,kCAE3DG,EAEL,QAFsBN,EAAGD,EAAYG,gBAAgBK,MAClDC,IAAc,IAAAC,EAAA,OAA0B,QAAtBA,EAAAD,EAAeE,eAAO,IAAAD,OAAA,EAAtBA,EAAwBE,uBAAwBR,YACrE,IAAAH,OAAA,EAFyBA,EAEvBY,SAEH,IAAKC,EAAAA,gBAAgBC,YAAYR,GAC7B,OAAO,KAIX,OAD6E,QAA1DL,EAAGK,EAAkBC,MAAKQ,IAA2B,IAAnBA,EAAKC,mBAAmB,IAAAf,EAAAA,EAAIK,EAAkB,GA2BvG,SAASW,EAAiBC,EAA+BpB,EAA2BqB,GAChF,MAAMC,EAAY,IAAIC,IAAIH,EAAuBpB,EAAYwB,QAAQC,YAAYC,SAC7EJ,EAAUK,OACVL,EAAUK,QAAU,IAAIN,IAExBC,EAAUK,QAAUN,EAIxB,OADmB,IAAIE,IAAID,EAAUM,MACnBC,SAAWP,EAAUK,OA0G3C,SAASG,EAAyCC,GAC9C,MAAO,CACHC,0BAA0BD,MAAAA,OAAS,EAATA,EAAWE,4BAA6B,4BAClEC,yBAAyBH,MAAAA,OAAS,EAATA,EAAWI,qBAAsB,qBAC1DC,4BAA4BL,MAAAA,OAAS,EAATA,EAAWK,6BAA8B,6BACrEC,0BAA0BN,MAAAA,OAAS,EAATA,EAAWO,iCAAkC,iCAEvEC,0BAA0BR,MAAAA,OAAS,EAATA,EAAWQ,2BAA4B,2BAEjEC,0BAA0BT,MAAAA,OAAS,EAATA,EAAWU,gCAAiC,gCACtEC,gCAAgCX,MAAAA,OAAS,EAATA,EAAWY,2CAA4C,4CAI/F,SAASC,EAAgDb,GACrD,MAAO,CACHc,6BAA6Bd,MAAAA,OAAS,EAATA,EAAWc,8BAA+B,8BACvEC,4BAA4Bf,MAAAA,OAAS,EAATA,EAAWe,6BAA8B,6BACrEC,2CAA2ChB,MAAAA,OAAS,EAATA,EAAWgB,4CAA6C,4CACnGC,8CAA8CjB,MAAAA,OAAS,EAATA,EAAWiB,+CAAgD,+CACzGC,2CAA2ClB,MAAAA,OAAS,EAATA,EAAWkB,4CAA6C,4CACnGC,eAAenB,MAAAA,OAAS,EAATA,EAAWoB,YAAa,YACvCC,mBAAmBrB,MAAAA,OAAS,EAATA,EAAWqB,oBAAqB,oBACnDC,kBAAkBtB,MAAAA,OAAS,EAATA,EAAWsB,mBAAoB,oBAIzD,SAASC,EAA+DvB,GACpE,MAAO,CACHwB,0BAA0BxB,MAAAA,OAAS,EAATA,EAAWwB,2BAA4B,2BACjEC,+BAA+BzB,MAAAA,OAAS,EAATA,EAAWyB,gCAAiC,gCAC3EC,0BAA0B1B,MAAAA,OAAS,EAATA,EAAW0B,2BAA4B,2BACjEC,gCAAgC3B,MAAAA,OAAS,EAATA,EAAW2B,iCAAkC,kCA8lBrF,SAASC,EACLC,EACAC,EACAC,EACAC,EACAC,EACAC,GAEA,MAAMC,EAA2BC,EAAmBH,EAAaC,MAAAA,EAAAA,EAA4B,IAC7F,MAAO,GAAGL,MAAAA,EAAAA,EAAQ,MAAMC,MAAAA,EAAAA,EAAS,MAAMO,EAAmBN,EAAQC,KAC9DG,EAA2B,IAAIA,IAA6B,KAQpE,SAASE,EAAmBN,EAAiBO,GACzC,GAAIP,GAAUO,EAAiB,CAC3B,MAAMC,EAAgBR,EAAOS,QAAQ,GACrC,OAAOC,EAAAA,EAAAA,QAAOH,GAAmB,GAAIC,EAAe,KAExD,MAAO,GAGX,SAASH,EAAmBH,EAAsBC,GAC9C,OAAID,GAAeC,GACRO,EAAAA,EAAAA,QAAOP,GAA4B,GAAID,GAE3C,GAmCX,SAASS,EACLC,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,EACA9B,EACAE,EACAC,EACA4B,EACAC,EACAC,EACAC,EACAC,GAEA,MAAMxB,EAAsB,CACxByB,UAAWR,EACXS,cAAeR,EACfS,wBAAyBT,GAG7B,OAAII,EAEIM,IAAAA,cAAA,QAAMC,UAAU,aACZD,IAAAA,cAAA,QAAMC,UAAU,2BACXN,GAAkB,aAM9BP,EAWDY,IAAAA,cAACE,EAAAA,eAAc,CACXjB,QAASA,EACTE,GAAIA,EACJD,SAAUA,EACViB,KAAM,CAAE/B,MAAOwB,GAAgBxB,GAC/BmB,YAAaA,EACb9B,cAAeA,EACfE,kBAAmBA,EACnB6B,qBAAsBA,EACtBC,eAAgBA,IAlBhBO,IAAAA,cAAA,QAAMC,UAAU,aACZD,IAAAA,cAAA,QAAMC,UAAU,gCAA8B,QAsB9D,SAASG,EACLC,EACAC,EACAC,EACAC,EACAC,EACAxB,GAAsC,IAAAyB,EAEtC,IAAKH,IAAaD,IAAiBD,EAC/B,OAAO,KAGX,MAAMM,EAAgB1B,MAAAA,GAAmB,QAAZyB,EAAPzB,EAASpE,IAAIC,cAAM,IAAA4F,OAAA,EAAnBA,EAAqBE,qBAE3C,IAAIC,EAAsBL,EADIG,GAEDH,IACzBK,EAAsB,GAAGL,KAHCG,KAK9B,MAAMG,EAAkB,CACpBC,IAAKR,EACLE,QAASA,GAAoB,GAC7BO,YAAaH,GAEXI,EAAa,CACfX,aAAAA,EACAD,cAAAA,GAYJ,OAVAY,EAAWZ,cAAca,iBAAkB,EAC3CD,EAAWZ,cAAcc,KAAO,EAChCF,EAAWZ,cAAce,UAAY,CACjCC,GAAI,CAAEC,EAAG,IAAKC,EAAG,IAAKC,EAAG,8BAA+BC,GAAI,kBAC5DC,GAAI,CAAEJ,EAAG,IAAKC,EAAG,IAAKC,EAAG,8BAA+BC,GAAI,kBAC5DE,GAAI,CAAEL,EAAG,IAAKC,EAAG,IAAKC,EAAG,8BAA+BC,GAAI,kBAC5DG,GAAI,CAAEN,EAAG,IAAKC,EAAG,IAAKC,EAAG,8BAA+BC,GAAI,kBAC5DI,GAAI,CAAEP,EAAG,IAAKC,EAAG,IAAKC,EAAG,8BAA+BC,GAAI,mBAI5DzB,IAAAA,cAAC8B,EAAAA,GAAKC,OAAAC,OAAA,CACFC,eAAgBhD,MAAAA,OAAO,EAAPA,EAASiD,cAAcD,gBACnCnB,EACAG,EAAU,CACdkB,oBAAoB,QACpBC,qBAAmB,KAKxB,MAAMC,EAAoEC,EAAAA,GAAiBC,wBAA2C,UAASC,EAAA,CAAIC,UArwBpGC,IA0CjD,IAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAA,IA1CkD,KACnD7C,EAAI,QACJlB,EAAO,cACPoB,EAAa,YACbd,EAAW,cACX9B,EAAa,kBACbE,EAAiB,iBACjBC,EAAgB,gBAChBgB,EAAe,qBACfqE,EAAoB,UACpBC,EAAS,UACTC,EAAS,SACTjE,EAAQ,GACRC,EAAE,iBACFiE,EAAgB,gBAChBC,EAAe,wBACfC,EAAuB,eACvBC,EAAc,4BACdC,EAA2B,qBAC3BhE,EAAoB,iBACpBiE,GAAgB,UAChBC,IAAY,EAAI,qBAChBC,GAAoB,aACpBC,GAAY,eACZnE,GAAc,eACdoE,GAAc,gBACdC,GAAe,wBACfC,GAAuB,oBACvBC,GAAmB,cACnBC,GAAa,eACbC,GAAc,mBACdC,GAAkB,eAClBC,GAAc,eACdzE,GAAc,aACd0E,GAAY,kBACZC,GAAiB,eACjBC,GAAc,wBACdC,GAAuB,4BACvBC,GAA2B,uBAC3BC,GAAsB,uBACtBC,GAAsB,cACtBC,IACHlC,EACG,MAAMmC,IAASC,EAAAA,EAAAA,GAAU7F,IACnB,QAAE8F,GAAO,cAAEC,IAAkB7E,GAC5B8E,GAAOC,KAAYC,EAAAA,EAAAA,UAAS,CAC/BC,gBAAgB,EAChBC,yBAAyB,IAEvBC,GAAe1B,GACf,EACkF,QADjFjB,EACQ,QADRC,EACDzC,EAAKoF,YAAI,IAAA3C,GAAM,QAANA,EAATA,EAAW2C,YAAI,IAAA3C,GAAW,QAAXA,EAAfA,EAAiB4C,iBAAS,IAAA5C,GAA8C,QAA9CA,EAA1BA,EAA4B5H,MAAKyK,GAAKA,EAAEC,aAAcX,MAAAA,QAAO,EAAPA,GAASY,mBAAS,IAAA/C,OAAA,EAAxEA,EAA0EgD,gBAAQ,IAAAjD,EAAAA,EAAI,GACrFkD,GAAeC,KAAoBX,EAAAA,EAAAA,UAASG,KAC5CS,GAAUC,KAAeb,EAAAA,EAAAA,WAAS,GAEzC,IAAIc,IAAaC,EAAAA,EAAAA,uBAAmC,QAAdrD,EAACkC,MAAAA,QAAO,EAAPA,GAASoB,YAAI,IAAAtD,EAAAA,EAAI,GAAqB,QAAnBC,EAAEiC,MAAAA,QAAO,EAAPA,GAASY,gBAAQ,IAAA7C,EAAAA,EAAIsD,OAAOC,UAAWpH,EAAQiD,mBAAeoE,GACtHnD,IACA8C,GAAavK,EAAiBuK,GAAYhH,EAAS,cAEvD,MAAMsH,GAAiF,QAAxDxD,EAnOnC,SAA6CxI,EAA2BC,GACpE,MAAMgM,EAAgBlM,EAAyBC,EAAaC,GACtDiM,EAAyBD,MAAAA,OAAa,EAAbA,EAAeE,iBAC9C,OAAKpL,EAAAA,gBAAgBC,YAAYkL,IAI1BE,EAAAA,EAAAA,kBAAiBF,EAAuB,GAAIlM,EAAYwB,QAAQC,aAH5DxB,MAAAA,OAAW,EAAXA,EAAaoM,gBA+NUC,CAAoC5H,EAAS8F,WAAQ,IAAAhC,EAAAA,EAAIgC,MAAAA,QAAO,EAAPA,GAAS6B,gBAC9FE,GAA2F,QAAnE9D,EAnIlC,SACIzI,EACA0L,EACAzL,GAEA,MAAMgM,EAAgBlM,EAAyBC,EAAaC,GAC5D,OAAKgM,MAAAA,GAAAA,EAAeO,YASbrL,EAAiBuK,EAAY1L,EADhB,GAJAA,EACkCM,IAAIC,OAAOF,qCAEtCoM,mBAAmBR,EAAcO,gBANjDd,EA4HsBgB,CAAmChI,EAASgH,GAAYlB,WAAQ,IAAA/B,EAAAA,EAAIiD,IAC9FiB,GAAgBC,KAAqBhC,EAAAA,EAAAA,UAAiB2B,KACtDM,GAAiBC,KAAsBlC,EAAAA,EAAAA,UAA6BoB,KACpEe,GAAiBC,KAAsBpC,EAAAA,EAAAA,WAAkB,IACzDqC,GAAsBC,KAA2BtC,EAAAA,EAAAA,WAAkB,GACpEuC,GAAuB1H,IAAAA,YACvB2H,GAAsB3H,IAAAA,SAAc,IAAM+E,MAAAA,IAAAA,GAAS6C,iBAAkBC,EAAAA,EAAAA,GAAuB5I,EAAS8F,GAAQ6C,sBAAmBtB,GAAW,CAACvB,MAG3I+C,GAAaC,KAAkB5C,EAAAA,EAAAA,UAAiB,GAEvDnF,IAAAA,WAAgB,KACZ,GAAI4D,GACA,OAYJ,OATiBoE,EAAAA,EAAAA,KACb,SAAAC,EAAA,OAAe,QAAfA,EAAM9H,EAAKoF,YAAI,IAAA0C,OAAA,EAATA,EAAW1C,KAAKC,aACtB,KAAK,IAAA0C,EACG5C,GAAe,IAAe,QAAV4C,EAAC/H,EAAKoF,YAAI,IAAA2C,GAAgB,QAAhBA,EAATA,EAAW3C,KAAKC,iBAAS,IAAA0C,IAAzBA,EAA2BlN,MAAKyK,GAAKA,EAAEC,aAAcX,MAAAA,QAAO,EAAPA,GAASY,cAEnFG,GAAiB,QAK9B,IAEH9F,IAAAA,WAAgB,KACZmH,GAAkBL,IAClBO,GAAmBd,MACpB,CAACN,GAAYa,GAA0BP,KAE1CvG,IAAAA,WAAgB,KAEZmI,SAASC,iBAAiB,0BAA0BC,SAAQC,IACxDA,EAAQC,aAAa,QAASD,EAAQE,aAAa,eAAiB,SAEzE,IACH,MAAOC,KAAuBtD,EAAAA,EAAAA,UAAS,IAAIuD,EAAAA,YAErCC,GAAmB1J,EAAQpE,IAAIC,OAAO6N,iBAGtC/N,GADcqE,EACkCpE,IAAIC,OAAOF,kCAO3DgO,GAAwB5I,IAAAA,aAC1B,CAACzF,EAA2BsO,KACxB,MAAMC,EAAgBD,EAAWC,cAEjC,GADAL,GAAoBM,SAASD,EAAeD,GACxCG,EAAAA,iBAAiBC,mBAAmBJ,EAAWK,OAC/C,OAEJ,MAAMtN,EAAc,GAAGkN,KAAiBD,EAAWK,QACnD,IAAIC,EAA2B,GAC/B,GAAIjC,GAAekC,SAASN,GAAgB,CACxC,MAAMO,EAAS,IAAIvN,IAAIoL,GAAgB3M,EAAYwB,QAAQC,YAAYC,SACvEoN,EAAOC,aAAaC,OAAOT,GAC3BK,EAA2BzN,EAAiB2N,EAAOG,WAAYvK,EAASrD,QAExEuN,EAA2BzN,EAAiBwL,GAAgBjI,EAASrD,GAGzE,GADAuL,GAAkBgC,GACdL,IAAkBlO,GAAmC,CACrD,MAAM6O,EAAwBnO,EAAAA,gBAAgBC,YAAYsN,EAAWa,kBAC/Db,EAAWa,iBAAiB,QAC5BpD,EACAqD,GAAchD,EAAAA,EAAAA,kBAAiB8C,EAAuBlP,EAAYwB,QAAQC,aAChFqL,GAAmBsC,MAG3B,CAAClB,GAAqBxJ,EAASiI,KAGnC,IAAKnC,GACD,OAAO,KAwJX,MAAM6E,IAAUC,EAAAA,EAAAA,kBAAiB,QAASzG,EAAmB,GAAI2B,GAAQY,SAAS6D,YAE5EM,IAAYC,EAAAA,EAAAA,wBAAuB3G,EAAmBwG,IA6FtDI,IAzFyB/K,EAAQpE,IAAIC,QAAUmE,EAAQpE,IAAIC,OAAOmP,yBAyFlD,yBAEtB,OACIjK,IAAAA,cAAA,OAAKC,UAAW+J,IACXxG,EACGxD,IAAAA,cAAA,IAAA+B,OAAAC,OAAA,CACI7F,KAAM+K,GACNgD,SAASC,EAAAA,EAAAA,kBAAiB/G,EAAmBwG,GAAS7E,GAAQoB,MAAM,aACxDjI,EACR6G,GAAQoB,KACRlH,EAAQmL,iBAAiBC,eAAetF,GAAQuF,OAChDvF,GAAQwF,cACR3L,EACAmG,GAAQyF,aACRvH,GAEJhD,UAAU,eACN6J,IAEJ9J,IAAAA,cAAA,OAAKC,UAAU,mCACXD,IAAAA,cAAA,OAAKC,UAAU,sBACVG,EACGC,EACApB,EAAQlD,QAAQuE,aAChB8G,GACArC,GAAQ6B,gBACR7B,GAAQoB,KACRlH,IAGRe,IAAAA,cAAA,OAAKC,UAAU,kCACXD,IAAAA,cAAA,MAAIC,UAAU,4BAA4B8E,GAAQoB,MACjDlH,EAAQlD,QAAQ0O,KAAKC,iBAAmB1L,EACrCC,EACAC,EACAC,EACAuE,GACAqB,GAAQlF,UACRkF,GAAQuF,MACR/K,EACA9B,EACAE,EACAC,EACA4B,EACAC,GACAsF,GAAQ4F,YACRhL,GACAoF,GAAQ6F,eAsLbC,GApLoB9F,GAAQ+F,YAqL5C9K,IAAAA,cAAA,KAAGC,UAAU,qBAAqB4K,QAhL7B7K,IAAAA,cAAA,IAAA+B,OAAAC,OAAA,CACI7F,KAAM+K,GACNgD,SAASC,EAAAA,EAAAA,kBAAiB/G,EAAmBwG,GAAS7E,GAAQoB,MAAM,aACxDjI,EACR6G,GAAQoB,KACRlH,EAAQmL,iBAAiBC,eAAetF,GAAQuF,OAChDvF,GAAQwF,cACR3L,GAEJqB,UAAU,eACN6J,IAEJ9J,IAAAA,cAAA,OAAKC,UAAU,sBACVG,EACGC,EACApB,EAAQlD,QAAQuE,aAChB8G,GACArC,GAAQ6B,gBACR7B,GAAQoB,KACRlH,IAGRe,IAAAA,cAAA,OAAKC,UAAU,wBACXD,IAAAA,cAAA,OAAKC,UAAU,oBAAoB8E,GAAQgG,QAC3C/K,IAAAA,cAAA,MAAIC,UAAW+K,GAAAA,CAAW,qBAAsB,CAAE,YAAa/L,EAAQlD,QAAQ0O,KAAKC,kBAAoBO,MAAOlG,GAAQoB,MACnHnG,IAAAA,cAAA,OAAKC,UAAU,4BACV8E,GAAQmG,SACLlL,IAAAA,cAAA,OAAKC,UAAW,GAAG+J,mBAA+BiB,MAAO1G,IAAkB,gBAAc,KAE5FZ,IAAwBoB,GAAQoG,oBAC7BnL,IAAAA,cAAA,OAAKC,UAAW,GAAG+J,wBAAoCiB,MAAOzG,IAA2B,cAAY,KAExGmD,IACG3H,IAAAA,cAAA,QACIC,UAAW,GAAG+J,wBAAmCrC,KACjDsD,MAAOlG,GAAQ6C,kBAEtB7C,GAAQoB,MAEZpB,GAAQqG,OAASpL,IAAAA,cAAA,OAAKC,UAAU,6BAA6B8E,GAAQqG,OACrErG,GAAQsG,cAAgBrL,IAAAA,cAAA,OAAKC,UAAU,oCAAoC8E,GAAQsG,eAEvFpM,EAAQlD,QAAQ0O,KAAKC,iBAAmB1L,EACrCC,EACAC,EACAC,EACAuE,GACAqB,GAAQlF,UACRkF,GAAQuF,MACR/K,EACA9B,EACAE,EACAC,OACA0I,OACAA,EACAvB,GAAQ4F,YACRhL,GACAoF,GAAQ6F,cAEX3L,EAAQlD,QAAQ0O,KAAKC,iBA3mB9C,SAAmCY,EAAgDxH,GAC/E,IAAIyH,EAAwB,aAExBzH,MAAAA,GAAAA,EAAiB0H,mBACjBD,EAAwB,aACuB,KAAxCzH,MAAAA,OAAe,EAAfA,EAAiB0H,sBACxBD,EAAwB,iBAGY,SAApCzH,MAAAA,OAAe,EAAfA,EAAiB2H,kBACjBF,EAAwB,SAG5B,MAAMG,EAA0D,SAApC5H,MAAAA,OAAe,EAAfA,EAAiB2H,iBACvC3H,MAAAA,OAAe,EAAfA,EAAiB6H,kBAAmB,QACpC7H,EAAkBwH,EAA6BtL,IAAAA,cAAAA,IAAAA,SAAA,UAErD,OACIA,IAAAA,cAAA,OAAKC,UAAU,6BACXD,IAAAA,cAAA,QAAMC,UAAWsL,EAAuBN,MAAOnH,EAAkBwH,OAA6BhF,GACzFoF,IAulBgDE,CAA0B/H,GAAgBC,OAjVtE+H,GAqVA9G,GAAQpK,iBA/UjCqF,IAAAA,cAAA,OAAKC,UAAU,2BACV4L,GAAgBC,KAAKtQ,IAAwB,IAAAuQ,EAAAC,EAAAC,EAAAC,EAC1C,MAAMC,EAAsD,QAApCJ,EAAe,QAAfC,EAAGxQ,EAAKL,eAAO,IAAA6Q,OAAA,EAAZA,EAAc5Q,2BAAmB,IAAA2Q,EAAAA,EAAI,GAChE,IAxBhB,SAAgCjD,GAC5B,MACMsD,EADoBnN,EACiCpE,IAAIC,OAAOuR,wBACtE,OACI/Q,EAAAA,gBAAgBC,YAAY6Q,KAC3BA,EAAiChD,SAASkD,EAAAA,eAAeC,OAC1DH,EAAiChD,SAASN,EAAc1N,qBAkB3CoR,CAAuBL,GACxB,OAAO,KAGX,MACMvR,EADcqE,EACkCpE,IAAIC,OAAOF,kCAC3DkO,EAAgBqD,EAChBM,EAiBA,QAjBQR,EACG,QADHC,EACV1Q,EAAKH,gBAAQ,IAAA6Q,OAAA,EAAbA,EAAeJ,KAAiBjD,IAAa,IAAA6D,EAAAC,EAAAC,EAAAC,EACzC,MAAO,CACHC,OAAQ,GAAgB,QAAhBJ,EAAGlR,EAAKmK,gBAAQ,IAAA+G,EAAAA,EAAI,MAAMP,KAA4C,QAA1BQ,EAAI9D,EAAW9B,mBAAW,IAAA4F,EAAAA,EAAI,KAClFzD,MAA6B,QAAxB0D,EAAE/D,EAAW9B,mBAAW,IAAA6F,EAAAA,EAAI,GACjC9D,cAAAA,EACAiE,aAAclE,EAAWmE,mBACzBzM,SAAUsI,EAAWoE,eACrBvD,iBAAkBb,EAAWnC,iBAC7BwG,UAAWrE,EAAWpN,UACtBuI,oBAAqBA,IAAsBjF,EAAAA,EAAAA,QAAOiF,GAAqB8E,GAAiB,GACxFqE,WACIxE,KACA5E,MAAAA,IAEC,QAFsB8I,EAAvB9I,GAAyB/I,MACrBoS,IAAqB,IAAAC,EAAA,OAAID,EAAsBlE,SAAiC,QAA5BmE,EAAMxE,EAAW9B,mBAAW,IAAAsG,EAAAA,EAAI,cACvF,IAAAR,OAAA,EAFDA,EAEGM,uBAEb,IAAAlB,EAAAA,EAAI,GAQV,OANInD,IAAkBlO,GAClBU,EAAAA,gBAAgBC,YAAYkR,KAC3BA,EAASa,MAAKC,GAAUA,EAAOL,cAEhCT,EAAS,GAAGS,WAAY,GAGxBlN,IAAAA,cAACwN,EAAAA,gCAA+B,CAC5BvO,QAASA,EACTwN,SAAUA,EACVgB,kBAAmB7E,GACnB8E,IAAKlS,EAAKmK,eA5CnB,KAoVN1G,EAAQlD,QAAQ0O,KAAKC,iBAClB1K,IAAAA,cAAA,OAAKC,UAAU,4BACXD,IAAAA,cAAA,OAAKC,UAAW,wBACZD,IAAAA,cAAC2N,EAAAA,EAAwB,CACrB1O,QAASA,EACT8F,QAASC,GACT4I,gBAAiBzN,EAAKyN,gBACtB/I,OAAQ5F,EAAQlD,QAAQ8I,OACxBgJ,aAAchI,GACdiI,SAAWC,GAAajI,GAAiBiI,GACzCC,uBAAuB,GACvBC,yBAAyB,GACzBC,yBAAyB,GACzBC,SAAU1K,GACV2K,iBAAmBL,GAAa/H,GAAY+H,QAK1D9O,EAAQpE,IAAIC,OAAOuT,YA+GjC,SACI9T,EACA+T,EACAC,EACAC,EACAC,EACAC,EACAzL,GAEA,IAAKuL,EACD,OAAO,KAGX,MAAMG,GAAgBF,MAAAA,OAAY,EAAZA,EAAcjF,kBAAclD,EAC5ChI,EAAsBK,EAAmB6P,EAAWE,GACpDlQ,EAA2BE,EAAmB0H,OAAOuI,GAAgB1L,GAE3E,OACIjD,IAAAA,cAAC4O,EAAAA,gBAAe,CACZ3P,QAAS1E,EACT4E,GAAIoP,EACJrP,SAAUoP,EACVE,UAAWA,EACXK,YAAaF,EACbG,UAAQ,EACRJ,UAAWpQ,EACX2E,qBAAsBzE,EACtB2B,KAAM,KAzIN4O,CAAa9P,EAASC,EAAUC,EAAI4F,GAAQwF,cAAexF,GAAQyF,aAAc5L,EAAiBqE,GACjGhE,EAAQlD,QAAQ0O,KAAKC,iBAnOJsE,MAAkB,IAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EAAAC,EACxC,MAAMC,EAA0B,CAC5BnK,SAAsB,QAAdsJ,EAAE9O,EAAK4E,eAAO,IAAAkK,OAAA,EAAZA,EAActJ,SACxBoF,OAAoB,QAAdmE,EAAE/O,EAAK4E,eAAO,IAAAmK,OAAA,EAAZA,EAAcnE,OACtB5E,KAAkB,QAAdgJ,EAAEhP,EAAK4E,eAAO,IAAAoK,OAAA,EAAZA,EAAchJ,KACpB2E,YAAyB,QAAdsE,EAAEjP,EAAK4E,eAAO,IAAAqK,OAAA,EAAZA,EAActE,YAC3BiF,iBAA8B,QAAdV,EAAElP,EAAK4E,eAAO,IAAAsK,OAAA,EAAZA,EAAc1J,SAChCqK,qBAAkC,QAAdV,EAAEnP,EAAK4E,eAAO,IAAAuK,OAAA,EAAZA,EAAcU,qBACpCnQ,UAAuB,QAAd0P,EAAEpP,EAAK4E,eAAO,IAAAwK,OAAA,EAAZA,EAAc1P,UACzByK,MAAmB,QAAdkF,EAAErP,EAAK4E,eAAO,IAAAyK,OAAA,EAAZA,EAAclF,MACrBxK,cAA2B,QAAd2P,EAAEtP,EAAK4E,eAAO,IAAA0K,OAAA,EAAZA,EAAcnF,MAC7B2F,gBAA6B,QAAdP,EAAEvP,EAAK4E,eAAO,IAAA2K,OAAA,EAAZA,EAAcO,gBAC/BrJ,gBAA6B,QAAd+I,EAAExP,EAAK4E,eAAO,IAAA4K,OAAA,EAAZA,EAAc/I,gBAC/BsJ,oBAAiC,QAAdN,EAAEzP,EAAK4E,eAAO,IAAA6K,OAAA,EAAZA,EAAcM,qBAEjCC,EACFpM,KACAA,MAAAA,QAAuB,EAAvBA,GAAyB/I,MACrBoS,GACI9R,EAAAA,gBAAgBC,YAAYwI,KAC5BqJ,EAAsBgD,iBACtBhD,EAAsBgD,kBAAoBrL,GAAQkL,mBAM9D,IAAII,EAEJ,MAAM/K,EAAwB,QAAZuK,EAAG1P,EAAKoF,YAAI,IAAAsK,GAAgB,QAAhBA,EAATA,EAAWtK,KAAKC,iBAAS,IAAAqK,OAAA,EAAzBA,EAA2BS,QAAO7K,GAAKA,EAAEC,YAAcX,GAAQY,WAAU4K,QAAO,CAACC,EAAKC,IAAQD,GAAOC,EAAI7K,UAAY,IAAI,GAE9I,GAAIN,EAAc,CACd,MAAMoL,EAAc,gCAAgC3L,GAAQY,WACtDgL,EAAgBrM,IAAqB,qBACrCsM,GAAc7R,EAAAA,EAAAA,QAAO4R,EAAerL,GAE1C+K,EACIrQ,IAAAA,cAAA,QACIb,GAAIuR,EACJzQ,UAAW,GAAG+J,iBACd6G,YAAaA,IAAMpJ,IAAwB,GAC3CqJ,WAAYA,IAAMrJ,IAAwB,GAC1CsJ,aAAcA,IAAMtJ,IAAwB,IAE3CnC,EACDtF,IAAAA,cAACgR,EAAAA,QAAO,CACJC,OAAQzJ,GACR0J,OAAQ,IAAIR,IACZzQ,UAAU,0BAET2Q,IAMjB,OACI5Q,IAAAA,cAACmR,EAAAA,KAAI,CAAClR,UAAU,qDACZD,IAAAA,cAACoR,EAAAA,mBAAkB,CACfnN,cAAeA,IAAgC,cAC/CC,eAAgBA,IAAkC,WAClDC,mBAAoBA,IAA0C,iBAC9DC,eAAgBA,IAAkC,gBAClDiN,qBAAsBlB,MAAAA,OAA8B,EAA9BA,EAAgChD,WACtDmE,oBAzC0B,CAClCC,kBAAmB,KAyCXpR,KAAM,CAAEoF,KAAMpF,EAAKoF,KAAMR,QAAS5E,EAAK6E,eAAiB8K,EAAU0B,cAAerR,EAAK4E,SACtF7B,UAAWA,EACXjE,QAASA,EACTE,GAAIA,EACJgP,SAAU1K,GACVvE,SAAUA,EACVuS,SAAU5L,GACVE,SAAUA,GACVnC,aAAcA,GACdS,aAAcA,GACdqN,iBAAmBD,IACf3L,GAAiB2L,IAErB7M,cAAeA,GACf+M,MAAOC,IACH7J,IAAgB8J,GAASA,EAAO,OAGvCxB,IAgJoCrB,GACzChP,IAAAA,cAAA,OACIC,UAAW+K,GAAAA,CAAW,uBAAwB,CAAE8G,KAAMxK,KACtDyK,SAAU,EACV7H,QAAU0H,IACFA,EAAEV,SAAWxJ,GAAqBsK,SAClCzK,IAAoBD,KAG5B2K,OAASL,IAAK,IAAAM,EACuB,QAA7BA,EAACxK,GAAqBsK,eAAO,IAAAE,GAA5BA,EAA8BC,SAASP,EAAEQ,gBAC1C7K,IAAmB,IAG3B8K,IAAK3K,IAEL1H,IAAAA,cAAA,OAAKC,UAAU,gBACVoD,GAtUjB,SAAyBiP,EAA4B9W,GACjD,GAAkB,OAAd8W,EACA,OAEJ,MAAMC,EAAyC9J,GAAoB+J,YAAY1G,KAAsBW,IAC1F,CACHgG,oBAAoBC,EAAAA,EAAAA,4CAA2CjG,EAAS3D,eACxE6J,eAAgB,CACZhN,SAAU,EACViN,MAAOnG,EAASvD,WAI5B,OAAOlJ,IAAAA,aAAmBsS,EAAiC,CAAEO,kBAAmBrX,EAAM+W,mBAAAA,IAyTtDO,CAAgBzP,EAAiB0B,GAAQY,UAC5DrC,GAtnBrB,SACIA,EACAyB,EACAgO,GAEA,OAAO/S,IAAAA,aAAmBsD,EAA+C,CAAEyB,QAAAA,EAASgO,UAAAA,IAinBxCC,CAA8B1P,EAAyByB,IAASkO,EAAAA,EAAAA,IAAahU,EAAQlD,UAChHkD,EAAQlD,QAAQ0O,KAAKC,iBAClB1K,IAAAA,cAAAA,IAAAA,SAAA,KACIA,IAAAA,cAAA,WACKiF,GAAMG,gBACHpF,IAAAA,cAACkT,EAAAA,EAAc,CACXjT,UAAU,kBACVkT,QAASA,IAAMjO,GAAQ1C,EAAAA,EAAC,GAAKyC,IAAK,IAAEG,gBAAgB,KACpDnG,QAASA,EACT8F,QAASA,KAEjB/E,IAAAA,cAAA,UACIC,UAAU,mBACVgL,MAAOpG,GAAOuO,UAAS,aACXvO,GAAOuO,UACnBlJ,QAASmJ,UACLnO,GAAQ1C,EAAAA,EAAC,GAAKyC,IAAK,IAAEG,gBAAgB,OAGzCpF,IAAAA,cAAA,KAAGC,UAAU,yCAzUZ,QAAzBqT,GAACnT,EAAKoT,2BAAmB,IAAAD,IAAxBA,GAA0BE,MAK3BxT,IAAAA,cAAA,WACIA,IAAAA,cAACyT,EAAAA,QAA2B,CACxBxT,UAAU,wBACVyT,8BAA8BjP,MAAAA,QAA2B,EAA3BA,GAA6BiP,+BAAgC,+BAC3FC,iCAAiClP,MAAAA,QAA2B,EAA3BA,GAA6BkP,kCAAmC,kCACjGC,mCAzS+BtX,GAyS8CmI,GAxStF,CACHoP,0BAA0BvX,MAAAA,QAAS,EAATA,GAAWuX,2BAA4B,2BAEjEC,yBAAyBxX,MAAAA,QAAS,EAATA,GAAWwX,0BAA2B,0BAC/DC,6BAA6BzX,MAAAA,QAAS,EAATA,GAAWyX,8BAA+B,8BAEvEC,iCAAiC1X,MAAAA,QAAS,EAATA,GAAW0X,kCAAmC,kCAC/EC,kCAAkC3X,MAAAA,QAAS,EAATA,GAAW2X,mCAAoC,mCACjFC,uCAAuC5X,MAAAA,QAAS,EAATA,GAAW4X,wCAAyC,wCAE3FC,qBAAqB7X,MAAAA,QAAS,EAATA,GAAW6X,sBAAuB,sBACvDC,yBAAyB9X,MAAAA,QAAS,EAATA,GAAW8X,0BAA2B,0BAC/DC,eAAe/X,MAAAA,QAAS,EAATA,GAAW+X,gBAAiB,kBA6R/BC,mCAAoCjY,EAAyCoI,IAC7E8P,wCAAyCpX,EAAgDsH,IACzF+P,uDAAwD3W,EAA+D4G,IACvHxF,QAASA,EACTE,GAAIA,EACJD,SAAUA,EACViB,KAAM,CACF4E,QAAS,CACLY,SAAsB,QAAd8O,GAAEtU,EAAK4E,eAAO,IAAA0P,QAAA,EAAZA,GAAc9O,SACxBoF,OAAoB,QAAd2J,GAAEvU,EAAK4E,eAAO,IAAA2P,QAAA,EAAZA,GAAc3J,OACtB5E,KAAkB,QAAdwO,GAAExU,EAAK4E,eAAO,IAAA4P,QAAA,EAAZA,GAAcxO,KACpB2E,YAAyB,QAAd8J,GAAEzU,EAAK4E,eAAO,IAAA6P,QAAA,EAAZA,GAAc9J,YAC3BiF,iBAA8B,QAAd8E,GAAE1U,EAAK4E,eAAO,IAAA8P,QAAA,EAAZA,GAAclP,SAChCqK,qBAAkC,QAAd8E,GAAE3U,EAAK4E,eAAO,IAAA+P,QAAA,EAAZA,GAAc9E,qBACpCnQ,UAAuB,QAAdkV,GAAE5U,EAAK4E,eAAO,IAAAgQ,QAAA,EAAZA,GAAclV,UACzByK,MAAmB,QAAd0K,GAAE7U,EAAK4E,eAAO,IAAAiQ,QAAA,EAAZA,GAAc1K,MACrBxK,cAA2B,QAAdmV,GAAE9U,EAAK4E,eAAO,IAAAkQ,QAAA,EAAZA,GAAc3K,MAC7B2F,gBAA6B,QAAdiF,GAAE/U,EAAK4E,eAAO,IAAAmQ,QAAA,EAAZA,GAAcjF,gBAC/BrJ,gBAA6B,QAAduO,GAAEhV,EAAK4E,eAAO,IAAAoQ,QAAA,EAAZA,GAAcvO,gBAC/BsJ,oBAAiC,QAAdkF,GAAEjV,EAAK4E,eAAO,IAAAqQ,QAAA,EAAZA,GAAclF,qBAEvCuB,SAAU5L,IAAiB,EAC3B0N,oBAAqBpT,EAAKoT,qBAE9B8B,mBAAmB,EACnBC,UAAWjC,MAAAA,IAAwB,IAAAkC,QACzB7Q,MAAAA,QAAsB,EAAtBA,GAAyB8Q,KAC/BC,EAAAA,EAAAA,GAAM,CACFC,KAAM,GAAe,QAAfH,EAAGpV,EAAK4E,eAAO,IAAAwQ,OAAA,EAAZA,EAAcpP,OAAO1B,MAAAA,QAA2B,EAA3BA,GAA6BjH,4CAC3DmY,UAAW,IACXC,UAAU,EACVC,SAAU,eACVC,KAAM,UACNC,cAAc,KAGtBpR,uBAAwBA,MA9CzB,KA4US3E,IAAAA,cAAA,WACKiF,GAAMI,yBACHrF,IAAAA,cAACgW,EAAAA,EAAuB,CACpB/V,UAAU,4BACVkT,QAASA,IAAMjO,GAAQ1C,EAAAA,EAAC,GAAKyC,IAAK,IAAEI,yBAAyB,KAC7DpG,QAASA,EACT8F,QAASA,KAEjB/E,IAAAA,cAAA,UACIC,UAAU,6BACVgL,MAAOpG,GAAOoR,wBAAuB,aACzBpR,GAAOoR,wBACnB/L,QAASA,KACLhF,GAAQ1C,EAAAA,EAAC,GAAKyC,IAAK,IAAEI,yBAAyB,OAGlDrF,IAAAA,cAAA,KAAGC,UAAU,gCAGpBsD,GAAuCA,KAMvDwB,GAAQmR,OACLlW,IAAAA,cAACmW,EAAAA,EAAa,CACVlX,QAASA,EACTmX,MAAOrR,GAAQmR,MACfG,KAAK,WA3WrB,IAAkC/C,GAAAmB,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GAAAC,GA9Ra9Y,GAwNduP,GAqcVhB,KAjzBG,KAg9B9B","sources":["webpack://Msdyn365.Commerce.Online/./src/themes/dlvry-adventureworks/views/components/product.component.tsx?81ba"],"sourcesContent":["/*!\r\n * Copyright (c) Microsoft Corporation.\r\n * All rights reserved. See LICENSE in the project root for license information.\r\n */\r\n\r\nimport React, { useState } from 'react';\r\nimport classnames from 'classnames';\r\nimport { reaction } from 'mobx';\r\nimport { IProductsDimensionsAvailabilities } from '@msdyn365-commerce/commerce-entities';\r\nimport {\r\n //AddToCartComponent,\r\n //AddToOrderTemplateComponent,\r\n IPriceComponentResources,\r\n ISwatchItem,\r\n //PriceComponent,\r\n ProductComponentSwatchComponent,\r\n RatingComponent,\r\n IOrderTemplateNameDialogResources,\r\n IAddToOrderTemplateDialogResources,\r\n IItemAddedToOrderTemplateDialogResources,\r\n IDuplicateItemsWhenAddingToOrderTemplateDialogResources\r\n} from '@msdyn365-commerce/components';\r\nimport { PriceComponent } from './price.component';\r\nimport {\r\n getCatalogId,\r\n IAny,\r\n IComponent,\r\n IComponentProps,\r\n ICoreContext,\r\n IGeneric,\r\n IGridSettings,\r\n IImageData,\r\n IImageSettings,\r\n Image,\r\n msdyn365Commerce\r\n} from '@msdyn365-commerce/core';\r\nimport {\r\n AttributeSwatch,\r\n AttributeValue,\r\n Customer,\r\n ProductDimension,\r\n ProductList,\r\n ProductPrice,\r\n ProductSearchResult,\r\n SimpleProduct,\r\n UnitOfMeasureConversion\r\n} from '@msdyn365-commerce/retail-proxy';\r\nimport {\r\n ArrayExtensions,\r\n convertDimensionTypeToProductDimensionType,\r\n Dictionary,\r\n DimensionTypes,\r\n generateImageUrl,\r\n getProductPageUrlSync,\r\n IDimensionsApp,\r\n StringExtensions,\r\n OrderTemplate\r\n} from '@msdyn365-commerce-modules/retail-actions';\r\nimport {\r\n format,\r\n Tooltip,\r\n getPayloadObject,\r\n getTelemetryAttributes,\r\n ITelemetryContent, Node,\r\n onTelemetryClick\r\n} from '@msdyn365-commerce-modules/utilities';\r\nimport { ICartState } from '@msdyn365-commerce/global-state';\r\nimport { AllergensModal } from '../../../../components/product-list-component/components/allergens-modal';\r\nimport { ProductInformationModal } from '../../../../components/product-list-component/components/product-information-modal';\r\nimport ProductListOrderQuantity from '../../../../components/common/product-list-order-quantity';\r\nimport { getLocale } from '../../../../components/product-list-component/locale';\r\nimport { AddToCartComponent, IAddToCartToastResources } from '../../../../modules/dlvry-buybox/common/add-to-cart.component';\r\nimport { toast } from '../../../../components/toast/toast';\r\nimport AddToOrderTemplateComponent from './addtoordertemplate.component';\r\nimport PQueue from 'p-queue';\r\nimport { IProductInventoryInformation } from '../../../../components/common/product-inventory-utils';\r\nimport { ProductSearchResultExt } from '../../../../modules/dlvry-search-result-container/components';\r\nimport { UnitOfMeasure } from '../../../../components/unit-of-measure';\r\nimport DiscountBadge from '../../../../components/discount-badge/discount-badge';\r\nimport { getTemperatureZoneIcon } from '../../../../shared-utils/attributes/get-temperature-zone';\r\n\r\nexport interface IProductComponentProps extends IComponentProps<{\r\n cart?: ICartState,\r\n product?: ProductSearchResultExt,\r\n simpleProduct?: SimpleProduct,\r\n orderTemplates?: OrderTemplate[],\r\n customerInformation?: Customer,\r\n unitConversions?: UnitOfMeasureConversion[]\r\n}> {\r\n className?: string;\r\n imageSettings?: IImageSettings;\r\n savingsText?: string;\r\n freePriceText?: string;\r\n originalPriceText?: string;\r\n currentPriceText?: string;\r\n ratingAriaLabel?: string;\r\n ratingCountAriaLabel?: string;\r\n cartQueue?: PQueue;\r\n allowBack?: boolean;\r\n telemetryContent?: ITelemetryContent;\r\n quickViewButton?: React.ReactNode;\r\n productComparisonButton?: React.ReactNode;\r\n wishlistButton?: React.ReactNode;\r\n isEnabledProductDescription?: boolean;\r\n isPriceMinMaxEnabled?: boolean;\r\n disableBuyButton?: boolean;\r\n showPrice?: boolean;\r\n showAgreementProduct?: boolean;\r\n userHasAccess?: boolean;\r\n buyAlwaysAdd?: boolean;\r\n priceResources?: IPriceComponentResources;\r\n inventoryLabel?: string;\r\n inventoryStatus?: IProductInventoryInformation;\r\n dimensionAvailabilities?: IProductsDimensionsAvailabilities[];\r\n swatchItemAriaLabel?: string;\r\n addToCartText?: string;\r\n updateCartText?: string,\r\n removeFromCartText?: string;\r\n outOfStockText?: string;\r\n priceErrorText?: string;\r\n toastStrings?: IAddToCartToastResources;\r\n inCartTooltipText?: string;\r\n transitTooltip?: string;\r\n agreementProductTooltip?: string\r\n addToOrderTemplateResources?: IAddToOrderTemplateResources;\r\n onUpdateOrderTemplates?: (orderTemplate?: ProductList) => Promise;\r\n retrieveOrderTemplates?(): Promise;\r\n onBuyValidate?: (product: ProductSearchResultExt, quantity: number) => Promise;\r\n}\r\n\r\nexport interface IProductComponent extends IComponent {\r\n}\r\n\r\nexport interface IAddToOrderTemplateResources {\r\n addToOrderTemplateHeader: string;\r\n noOrderTemplatesMessage: string;\r\n noOrderTemplatesDescription: string;\r\n createAnOrderTemplateButtonText: string;\r\n createNewOrderTemplateButtonText: string;\r\n cancelOrderTemplateCreationButtonText: string;\r\n selectTemplatesText: string;\r\n addToTemplateButtonText: string;\r\n lineItemsText: string;\r\n createOrderTemplateHeader: string;\r\n orderTemplateTitle: string;\r\n orderTemplateNameAriaLabel: string;\r\n createOrderTemplateDescription: string;\r\n defaultOrderTemplateName: string;\r\n createOrderTemplateButtonText: string;\r\n cancelNewOrderTemplateCreationButtonText: string;\r\n viewOrderTemplateButtonText: string;\r\n continueShoppingButtonText: string;\r\n itemAddedToOrderTemplateHeaderItemOneText: string;\r\n itemAddedToOrderTemplateHeaderItemFormatText: string;\r\n itemAddedToOrderTemplateHeaderMessageText: string;\r\n priceFree: string;\r\n originalPriceText: string;\r\n currentPriceText: string;\r\n duplicatedProductsHeader: string;\r\n duplicatedProductsDescription: string;\r\n updateQuantityButtonText: string;\r\n cancelDuplicateItemsButtonText: string;\r\n addToOrderTemplateButtonText: string;\r\n addToOrderTemplateButtonTooltip: string;\r\n}\r\n\r\nexport interface BuyValidationResult {\r\n isValid: boolean;\r\n message?: string;\r\n}\r\n\r\nconst PriceComponentActions = {};\r\n\r\n/**\r\n * Gets the product page url from the default swatch selected.\r\n * @param productData - Product card to be rendered.\r\n * @returns The default color swatch selected if any.\r\n */\r\nfunction getDefaultSwatchSelected(coreContext: ICoreContext, productData?: ProductSearchResult): AttributeSwatch | null {\r\n if (!productData || !productData.AttributeValues) {\r\n return null;\r\n }\r\n\r\n const siteContext = coreContext as ICoreContext;\r\n const dimensionToPreSelectInProductCard = siteContext.app.config.dimensionToPreSelectInProductCard;\r\n\r\n const attributeSwatches = productData.AttributeValues.find(\r\n attributeValue => attributeValue.KeyName?.toLocaleLowerCase() === dimensionToPreSelectInProductCard\r\n )?.Swatches;\r\n\r\n if (!ArrayExtensions.hasElements(attributeSwatches)) {\r\n return null;\r\n }\r\n\r\n const defaultSwatch = attributeSwatches.find(item => item.IsDefault === true) ?? attributeSwatches[0];\r\n return defaultSwatch;\r\n}\r\n\r\n/**\r\n * Gets the product image from the default swatch selected.\r\n * @param coreContext - Context of the module using the component.\r\n * @param productData - Product card to be rendered.\r\n * @returns The product card image url.\r\n */\r\nfunction getProductImageUrlFromDefaultSwatch(coreContext: ICoreContext, productData?: ProductSearchResult): string | undefined {\r\n const defaultSwatch = getDefaultSwatchSelected(coreContext, productData);\r\n const swatchProductImageUrls = defaultSwatch?.ProductImageUrls;\r\n if (!ArrayExtensions.hasElements(swatchProductImageUrls)) {\r\n return productData?.PrimaryImageUrl;\r\n }\r\n\r\n return generateImageUrl(swatchProductImageUrls[0], coreContext.request.apiSettings);\r\n}\r\n\r\n/**\r\n * Updates the product url link to product details page.\r\n * @param productDetailsPageUrl - Product page url.\r\n * @param coreContext - Context of the module using the component.\r\n * @param queryString - Querystring to be added to the URL.\r\n * @returns The update product page url.\r\n */\r\nfunction updateProductUrl(productDetailsPageUrl: string, coreContext: ICoreContext, queryString: string): string {\r\n const sourceUrl = new URL(productDetailsPageUrl, coreContext.request.apiSettings.baseUrl);\r\n if (sourceUrl.search) {\r\n sourceUrl.search += `&${queryString}`;\r\n } else {\r\n sourceUrl.search += queryString;\r\n }\r\n\r\n const updatedUrl = new URL(sourceUrl.href);\r\n return updatedUrl.pathname + sourceUrl.search;\r\n}\r\n\r\n/**\r\n * Gets the react node for product unit of measure display.\r\n * @param unitOfMeasure - DefaultUnitOfMeasure property from product.\r\n * @returns The node representing markup for unit of measure component.\r\n */\r\n// @ts-expect-error\r\nfunction renderProductUnitOfMeasure(context: ICoreContext, unitOfMeasure?: string): JSX.Element | null {\r\n if (!unitOfMeasure) {\r\n return null;\r\n }\r\n return (\r\n \r\n );\r\n}\r\n\r\n/**\r\n * Gets the react node for product availability.\r\n * @param inventoryAvailabilityLabel - The product information.\r\n * @returns The node representing markup for product availability.\r\n */\r\nfunction renderProductAvailability(inventoryAvailabilityLabel: string | undefined, inventoryStatus?: IProductInventoryInformation): JSX.Element | null {\r\n let availabilityClassName = 'retrieving';\r\n\r\n if (inventoryStatus?.IsProductAvailable) {\r\n availabilityClassName = 'available';\r\n } else if (inventoryStatus?.IsProductAvailable === false) {\r\n availabilityClassName = 'not-available';\r\n }\r\n\r\n if (inventoryStatus?.StockLevelCode === 'ERR') {\r\n availabilityClassName = 'error';\r\n }\r\n\r\n const inventoryStatusText = inventoryStatus?.StockLevelCode === 'ERR'\r\n ? inventoryStatus?.StockLevelLabel || 'ERROR'\r\n : inventoryStatus ? inventoryAvailabilityLabel : <> ;\r\n\r\n return (\r\n
\r\n \r\n {inventoryStatusText}\r\n \r\n
\r\n );\r\n}\r\n\r\n/**\r\n * Renders product comparison button similar to the quick view button.\r\n * @param productComparisonButton - React element of the button.\r\n * @param product - Current product info.\r\n * @param catalogId - Current catalog.\r\n * @returns React element for the specific product.\r\n */\r\nfunction renderProductComparisonButton(\r\n productComparisonButton: React.ReactNode,\r\n product: ProductSearchResult,\r\n catalogId: number\r\n): JSX.Element | undefined {\r\n return React.cloneElement(productComparisonButton as React.ReactElement, { product, catalogId });\r\n}\r\n\r\n/**\r\n * Gets the product page url from the default swatch selected.\r\n * @param coreContext - Context of the module using the component.\r\n * @param productUrl - Product page url for the product card.\r\n * @param productData - Product card to be rendered.\r\n * @returns The product card image url.\r\n */\r\nfunction getProductPageUrlFromDefaultSwatch(\r\n coreContext: ICoreContext,\r\n productUrl: string,\r\n productData?: ProductSearchResult\r\n): string | undefined {\r\n const defaultSwatch = getDefaultSwatchSelected(coreContext, productData);\r\n if (!defaultSwatch?.SwatchValue) {\r\n return productUrl;\r\n }\r\n\r\n const siteContext = coreContext as ICoreContext;\r\n const dimensionToPreSelectInProductCard = siteContext.app.config.dimensionToPreSelectInProductCard;\r\n\r\n const queryStringEncoded = encodeURIComponent(defaultSwatch.SwatchValue);\r\n const queryString = `${dimensionToPreSelectInProductCard}=${queryStringEncoded}`;\r\n return updateProductUrl(productUrl, coreContext, queryString);\r\n}\r\n\r\nfunction generateAddToOrderTemplateDialogResources(resources: IAddToOrderTemplateResources | undefined): IAddToOrderTemplateDialogResources {\r\n return {\r\n addToOrderTemplateHeader: resources?.addToOrderTemplateHeader || 'addToOrderTemplateHeader',\r\n\r\n noOrderTemplatesMessage: resources?.noOrderTemplatesMessage || 'noOrderTemplatesMessage',\r\n noOrderTemplatesDescription: resources?.noOrderTemplatesDescription || 'noOrderTemplatesDescription',\r\n\r\n createAnOrderTemplateButtonText: resources?.createAnOrderTemplateButtonText || 'createAnOrderTemplateButtonText',\r\n createNewOrderTemplateButtonText: resources?.createNewOrderTemplateButtonText || 'createNewOrderTemplateButtonText',\r\n cancelOrderTemplateCreationButtonText: resources?.cancelOrderTemplateCreationButtonText || 'cancelOrderTemplateCreationButtonText',\r\n\r\n selectTemplatesText: resources?.selectTemplatesText || 'selectTemplatesText',\r\n addToTemplateButtonText: resources?.addToTemplateButtonText || 'addToTemplateButtonText',\r\n lineItemsText: resources?.lineItemsText || 'lineItemsText',\r\n };\r\n}\r\n\r\nfunction generateOrderTemplateNameDialogResources(resources: IAddToOrderTemplateResources | undefined): IOrderTemplateNameDialogResources {\r\n return {\r\n orderTemplateHeaderLabel: resources?.createOrderTemplateHeader || 'createOrderTemplateHeader',\r\n orderTemplateTitleLabel: resources?.orderTemplateTitle || 'orderTemplateTitle',\r\n orderTemplateNameAriaLabel: resources?.orderTemplateNameAriaLabel || 'orderTemplateNameAriaLabel',\r\n orderTemplateDescription: resources?.createOrderTemplateDescription || 'createOrderTemplateDescription',\r\n\r\n defaultOrderTemplateName: resources?.defaultOrderTemplateName || 'defaultOrderTemplateName',\r\n\r\n orderTemplateButtonLabel: resources?.createOrderTemplateButtonText || 'createOrderTemplateButtonText',\r\n orderTemplateCancelButtonLabel: resources?.cancelNewOrderTemplateCreationButtonText || 'cancelNewOrderTemplateCreationButtonText',\r\n };\r\n}\r\n\r\nfunction generateItemAddedToOrderTemplateDialogResources(resources: IAddToOrderTemplateResources | undefined): IItemAddedToOrderTemplateDialogResources {\r\n return {\r\n viewOrderTemplateButtonText: resources?.viewOrderTemplateButtonText || 'viewOrderTemplateButtonText',\r\n continueShoppingButtonText: resources?.continueShoppingButtonText || 'continueShoppingButtonText',\r\n itemAddedToOrderTemplateHeaderItemOneText: resources?.itemAddedToOrderTemplateHeaderItemOneText || 'itemAddedToOrderTemplateHeaderItemOneText',\r\n itemAddedToOrderTemplateHeaderItemFormatText: resources?.itemAddedToOrderTemplateHeaderItemFormatText || 'itemAddedToOrderTemplateHeaderItemFormatText',\r\n itemAddedToOrderTemplateHeaderMessageText: resources?.itemAddedToOrderTemplateHeaderMessageText || 'itemAddedToOrderTemplateHeaderMessageText',\r\n freePriceText: resources?.priceFree || 'priceFree',\r\n originalPriceText: resources?.originalPriceText || 'originalPriceText',\r\n currentPriceText: resources?.currentPriceText || 'currentPriceText',\r\n };\r\n}\r\n\r\nfunction generateDuplicateItemsWhenAddingToOrderTemplateDialogResources(resources: IAddToOrderTemplateResources | undefined): IDuplicateItemsWhenAddingToOrderTemplateDialogResources {\r\n return {\r\n duplicatedProductsHeader: resources?.duplicatedProductsHeader || 'duplicatedProductsHeader',\r\n duplicatedProductsDescription: resources?.duplicatedProductsDescription || 'duplicatedProductsDescription',\r\n updateQuantityButtonText: resources?.updateQuantityButtonText || 'updateQuantityButtonText',\r\n cancelDuplicateItemsButtonText: resources?.cancelDuplicateItemsButtonText || 'cancelDuplicateItemsButtonText',\r\n };\r\n}\r\n\r\nconst ProductCard: React.FC = ({\r\n data,\r\n context,\r\n imageSettings,\r\n savingsText,\r\n freePriceText,\r\n originalPriceText,\r\n currentPriceText,\r\n ratingAriaLabel,\r\n ratingCountAriaLabel,\r\n cartQueue,\r\n allowBack,\r\n typeName,\r\n id,\r\n telemetryContent,\r\n quickViewButton,\r\n productComparisonButton,\r\n wishlistButton,\r\n isEnabledProductDescription,\r\n isPriceMinMaxEnabled,\r\n disableBuyButton,\r\n showPrice = true,\r\n showAgreementProduct,\r\n buyAlwaysAdd,\r\n priceResources,\r\n inventoryLabel,\r\n inventoryStatus,\r\n dimensionAvailabilities,\r\n swatchItemAriaLabel,\r\n addToCartText,\r\n updateCartText,\r\n removeFromCartText,\r\n outOfStockText,\r\n priceErrorText,\r\n toastStrings,\r\n inCartTooltipText,\r\n transitTooltip,\r\n agreementProductTooltip,\r\n addToOrderTemplateResources,\r\n onUpdateOrderTemplates,\r\n retrieveOrderTemplates,\r\n onBuyValidate\r\n}) => {\r\n const locale = getLocale(context);\r\n const { product, simpleProduct } = data;\r\n const [modal, setModal] = useState({\r\n allergensModal: false,\r\n productInformationModal: false\r\n });\r\n const cartQuantity = buyAlwaysAdd\r\n ? 0\r\n : data.cart?.cart?.CartLines?.find(x => x.ProductId === product?.RecordId)?.Quantity ?? 0;\r\n const [orderQuantity, setOrderQuantity] = useState(cartQuantity);\r\n const [breakoff, setBreakoff] = useState(false);\r\n\r\n let productUrl = getProductPageUrlSync(product?.Name ?? '', product?.RecordId ?? Number.MIN_VALUE, context.actionContext, undefined);\r\n if (allowBack) {\r\n productUrl = updateProductUrl(productUrl, context, 'back=true');\r\n }\r\n const productImageUrlFromSwatch = getProductImageUrlFromDefaultSwatch(context, product) ?? product?.PrimaryImageUrl;\r\n const productPageUrlFromSwatch = getProductPageUrlFromDefaultSwatch(context, productUrl, product) ?? productUrl;\r\n const [productPageUrl, setProductPageUrl] = useState(productPageUrlFromSwatch);\r\n const [productImageUrl, setProductImageUrl] = useState(productImageUrlFromSwatch);\r\n const [cardActionsOpen, setCardActionsOpen] = useState(false);\r\n const [showCartCountTooltip, setShowCartCountTooltip] = useState(false);\r\n const cardActionWrapperRef = React.createRef();\r\n const temperatureZoneIcon = React.useMemo(() => product?.TemperatureZone ? getTemperatureZoneIcon(context, product.TemperatureZone) : undefined, [product]);\r\n\r\n // @ts-expect-error -- Variable is declared but its value is never read.\r\n const [forceUpdate, setForceUpdate] = useState(0);\r\n\r\n React.useEffect(() => {\r\n if (buyAlwaysAdd) {\r\n return;\r\n }\r\n\r\n const disposer = reaction(\r\n () => data.cart?.cart.CartLines,\r\n () => {\r\n if (cartQuantity > 0 && !data.cart?.cart.CartLines?.find(x => x.ProductId === product?.RecordId)) {\r\n // This product was removed from cart, reset quantity\r\n setOrderQuantity(0);\r\n }\r\n });\r\n\r\n return disposer;\r\n }, []);\r\n\r\n React.useEffect(() => {\r\n setProductPageUrl(productPageUrlFromSwatch);\r\n setProductImageUrl(productImageUrlFromSwatch);\r\n }, [productUrl, productPageUrlFromSwatch, productImageUrlFromSwatch]);\r\n\r\n React.useEffect(() => {\r\n // Set 'title' attribute on AddToOrderTemplate buttons\r\n document.querySelectorAll('.order-template-button').forEach(element => {\r\n element.setAttribute('title', element.getAttribute('aria-label') || '');\r\n });\r\n }, []);\r\n const [selectedSwatchItems] = useState(new Dictionary());\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-member-access -- app context is generic\r\n const enableStockCheck = context.app.config.enableStockCheck;\r\n\r\n const siteContext = context as ICoreContext;\r\n const dimensionToPreSelectInProductCard = siteContext.app.config.dimensionToPreSelectInProductCard;\r\n\r\n /**\r\n * Updates the product page and Image url based on swatch selected.\r\n * @param coreContext - Context of the caller.\r\n * @param swatchItem - Dimension swatch selected.\r\n */\r\n const updatePageAndImageUrl = React.useCallback(\r\n (coreContext: ICoreContext, swatchItem: ISwatchItem) => {\r\n const dimensionType = swatchItem.dimensionType;\r\n selectedSwatchItems.setValue(dimensionType, swatchItem);\r\n if (StringExtensions.isNullOrWhitespace(swatchItem.value)) {\r\n return;\r\n }\r\n const queryString = `${dimensionType}=${swatchItem.value}`;\r\n let productPageUrlWithSwatch = '';\r\n if (productPageUrl.includes(dimensionType)) {\r\n const newUrl = new URL(productPageUrl, coreContext.request.apiSettings.baseUrl);\r\n newUrl.searchParams.delete(dimensionType);\r\n productPageUrlWithSwatch = updateProductUrl(newUrl.toString(), context, queryString);\r\n } else {\r\n productPageUrlWithSwatch = updateProductUrl(productPageUrl, context, queryString);\r\n }\r\n setProductPageUrl(productPageUrlWithSwatch);\r\n if (dimensionType === dimensionToPreSelectInProductCard) {\r\n const swatchProductImageUrl = ArrayExtensions.hasElements(swatchItem.productImageUrls)\r\n ? swatchItem.productImageUrls[0]\r\n : undefined;\r\n const newImageUrl = generateImageUrl(swatchProductImageUrl, coreContext.request.apiSettings);\r\n setProductImageUrl(newImageUrl);\r\n }\r\n },\r\n [selectedSwatchItems, context, productPageUrl]\r\n );\r\n\r\n if (!product) {\r\n return null;\r\n }\r\n\r\n /**\r\n * Checks if rendering the particular dimensions is allowed for product card.\r\n * @param dimensionType - Dimension to be displayed.\r\n * @returns Updates the state with new product page url.\r\n */\r\n function shouldDisplayDimension(dimensionType: string): boolean {\r\n const dimensionsContext = context as ICoreContext;\r\n const dimensionsToDisplayOnProductCard = dimensionsContext.app.config.dimensionsInProductCard;\r\n return (\r\n ArrayExtensions.hasElements(dimensionsToDisplayOnProductCard) &&\r\n !dimensionsToDisplayOnProductCard.includes(DimensionTypes.none) &&\r\n dimensionsToDisplayOnProductCard.includes(dimensionType.toLocaleLowerCase() as DimensionTypes)\r\n );\r\n }\r\n\r\n /**\r\n * Gets the react node for product dimension as swatch.\r\n * @param attributeValues - Attribute value property from product.\r\n * @returns The node representing markup for unit of measure component.\r\n */\r\n function renderProductDimensions(attributeValues?: AttributeValue[]): JSX.Element | null {\r\n if (!attributeValues) {\r\n return null;\r\n }\r\n\r\n return (\r\n
\r\n {attributeValues.map((item: AttributeValue) => {\r\n const dimensionTypeValue = item.KeyName?.toLocaleLowerCase() ?? '';\r\n if (!shouldDisplayDimension(dimensionTypeValue)) {\r\n return null;\r\n }\r\n\r\n const siteContext = context as ICoreContext;\r\n const dimensionToPreSelectInProductCard = siteContext.app.config.dimensionToPreSelectInProductCard;\r\n const dimensionType = dimensionTypeValue as DimensionTypes;\r\n const swatches =\r\n item.Swatches?.map(swatchItem => {\r\n return {\r\n itemId: `${item.RecordId ?? ''}-${dimensionTypeValue}-${swatchItem.SwatchValue ?? ''}`,\r\n value: swatchItem.SwatchValue ?? '',\r\n dimensionType,\r\n colorHexCode: swatchItem.SwatchColorHexCode,\r\n imageUrl: swatchItem.SwatchImageUrl,\r\n productImageUrls: swatchItem.ProductImageUrls,\r\n isDefault: swatchItem.IsDefault,\r\n swatchItemAriaLabel: swatchItemAriaLabel ? format(swatchItemAriaLabel, dimensionType) : '',\r\n isDisabled:\r\n enableStockCheck &&\r\n dimensionAvailabilities?.find(\r\n dimensionAvailability => dimensionAvailability.value === (swatchItem.SwatchValue ?? '')\r\n )?.isDisabled\r\n };\r\n }) ?? [];\r\n if (\r\n dimensionType === dimensionToPreSelectInProductCard &&\r\n ArrayExtensions.hasElements(swatches) &&\r\n !swatches.some(swatch => swatch.isDefault)\r\n ) {\r\n swatches[0].isDefault = true;\r\n }\r\n return (\r\n \r\n );\r\n })}\r\n
\r\n );\r\n }\r\n\r\n function renderQuickView(quickview: React.ReactNode, item?: number): JSX.Element | undefined {\r\n if (quickview === null) {\r\n return undefined;\r\n }\r\n const selectedDimensions: ProductDimension[] = selectedSwatchItems.getValues().map(swatches => {\r\n return {\r\n DimensionTypeValue: convertDimensionTypeToProductDimensionType(swatches.dimensionType),\r\n DimensionValue: {\r\n RecordId: 0,\r\n Value: swatches.value\r\n }\r\n };\r\n });\r\n return React.cloneElement(quickview as React.ReactElement, { selectedProductId: item, selectedDimensions });\r\n }\r\n\r\n function renderOrderTemplateButton() {\r\n if (!data.customerInformation?.IsB2b) {\r\n return null;\r\n }\r\n\r\n return (\r\n
\r\n {\r\n await onUpdateOrderTemplates?.(orderTemplate);\r\n toast({\r\n text: `${data.product?.Name}${addToOrderTemplateResources?.itemAddedToOrderTemplateHeaderMessageText}`,\r\n autoClose: 3000,\r\n canClose: true,\r\n position: 'bottom-right',\r\n type: 'success',\r\n showProgress: true\r\n });\r\n }}\r\n retrieveOrderTemplates={retrieveOrderTemplates}\r\n />\r\n
\r\n );\r\n }\r\n\r\n function renderWishlistButton(wishlistButton: React.ReactNode): React.ReactNode | undefined {\r\n return wishlistButton;\r\n }\r\n\r\n // Construct telemetry attribute to render\r\n const payLoad = getPayloadObject('click', telemetryContent!, '', product.RecordId.toString());\r\n\r\n const attribute = getTelemetryAttributes(telemetryContent!, payLoad);\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access -- -- Do not need type check for appsettings\r\n // @ts-expect-error\r\n const isUnitOfMeasureEnabled = context.app.config && context.app.config.unitOfMeasureDisplayType === 'buyboxAndBrowse';\r\n const _renderCartButton = (): JSX.Element => {\r\n const product1: SimpleProduct = {\r\n RecordId: data.product?.RecordId!,\r\n ItemId: data.product?.ItemId,\r\n Name: data.product?.Name,\r\n Description: data.product?.Description,\r\n ProductTypeValue: data.product?.RecordId!,\r\n DefaultUnitOfMeasure: data.product?.DefaultUnitOfMeasure,\r\n BasePrice: data.product?.BasePrice!,\r\n Price: data.product?.Price!,\r\n AdjustedPrice: data.product?.Price!,\r\n MasterProductId: data.product?.MasterProductId,\r\n PrimaryImageUrl: data.product?.PrimaryImageUrl,\r\n ExtensionProperties: data.product?.ExtensionProperties\r\n };\r\n const productDimensionAvailabilities =\r\n dimensionAvailabilities &&\r\n dimensionAvailabilities?.find(\r\n dimensionAvailability =>\r\n ArrayExtensions.hasElements(dimensionAvailabilities) &&\r\n dimensionAvailability.masterProductId &&\r\n dimensionAvailability.masterProductId === product.MasterProductId\r\n );\r\n const ProductAvailableQuantity: any = {\r\n AvailableQuantity: 1000\r\n };\r\n\r\n let cartCount: JSX.Element | undefined = undefined;\r\n // const cartQuantity = data.cart?.cart.CartLines?.find(x => x.ProductId === product.RecordId)?.Quantity;\r\n const cartQuantity = data.cart?.cart.CartLines?.filter(x => x.ProductId === product.RecordId).reduce((acc, val) => acc + (val.Quantity || 0), 0);\r\n\r\n if (cartQuantity) {\r\n const cartCountId = `product-component-cart-count-${product.RecordId}`;\r\n const tooltipString = inCartTooltipText || '{0} i handlekurven';\r\n const tooltipText = format(tooltipString, cartQuantity);\r\n\r\n cartCount = (\r\n setShowCartCountTooltip(true)}\r\n onMouseOut={() => setShowCartCountTooltip(false)}\r\n onTouchStart={() => setShowCartCountTooltip(true)}\r\n >\r\n {cartQuantity}\r\n \r\n {tooltipText}\r\n \r\n \r\n );\r\n }\r\n\r\n return (\r\n \r\n {\r\n setOrderQuantity(quantity);\r\n }}\r\n onBuyValidate={onBuyValidate}\r\n onAdd={e => {\r\n setForceUpdate((prev) => prev + 1);\r\n }}\r\n />\r\n {cartCount}\r\n \r\n );\r\n };\r\n\r\n const baseClassName = 'msc-product-component';\r\n\r\n return (\r\n
\r\n {isEnabledProductDescription ? (\r\n \r\n
\r\n
\r\n {renderProductPlacementImage(\r\n imageSettings,\r\n context.request.gridSettings,\r\n productImageUrl,\r\n product.PrimaryImageUrl,\r\n product.Name,\r\n context\r\n )}\r\n
\r\n
\r\n
{product.Name}
\r\n {context.request.user.isAuthenticated && renderPrice(\r\n context,\r\n typeName,\r\n id,\r\n showPrice,\r\n product.BasePrice,\r\n product.Price,\r\n savingsText,\r\n freePriceText,\r\n originalPriceText,\r\n currentPriceText,\r\n isPriceMinMaxEnabled,\r\n priceResources,\r\n product.PriceFailed,\r\n priceErrorText,\r\n product.ProductPrice\r\n )}\r\n {renderDescription(product.Description)}\r\n
\r\n
\r\n \r\n ) : (\r\n \r\n
\r\n {renderProductPlacementImage(\r\n imageSettings,\r\n context.request.gridSettings,\r\n productImageUrl,\r\n product.PrimaryImageUrl,\r\n product.Name,\r\n context\r\n )}\r\n
\r\n
\r\n
{product.ItemId}
\r\n
\r\n
\r\n {product.Transit && (\r\n
T
\r\n )}\r\n {showAgreementProduct && product.IsAgreementProduct && (\r\n
A
\r\n )}\r\n {temperatureZoneIcon && (\r\n \r\n )}\r\n {product.Name}\r\n
\r\n {product.Brand &&
{product.Brand}
}\r\n {product.Manufacturer &&
{product.Manufacturer}
}\r\n
\r\n {context.request.user.isAuthenticated && renderPrice(\r\n context,\r\n typeName,\r\n id,\r\n showPrice,\r\n product.BasePrice,\r\n product.Price,\r\n savingsText,\r\n freePriceText,\r\n originalPriceText,\r\n currentPriceText,\r\n undefined,\r\n undefined,\r\n product.PriceFailed,\r\n priceErrorText,\r\n product.ProductPrice\r\n )}\r\n {context.request.user.isAuthenticated && renderProductAvailability(inventoryLabel, inventoryStatus)}\r\n
\r\n \r\n )}\r\n {renderProductDimensions(product.AttributeValues)}\r\n {context.request.user.isAuthenticated && (\r\n
\r\n
\r\n setOrderQuantity(newValue)}\r\n inputQuantityAriaLabel=''\r\n incrementButtonAriaLabel=''\r\n decrementButtonAriaLabel=''\r\n disabled={disableBuyButton}\r\n onBreakoffChange={(newValue) => setBreakoff(newValue)}\r\n />\r\n
\r\n
\r\n )}\r\n {!context.app.config.hideRating &&\r\n renderRating(context, typeName, id, product.AverageRating, product.TotalRatings, ratingAriaLabel, ratingCountAriaLabel)}\r\n {context.request.user.isAuthenticated && _renderCartButton()}\r\n {\r\n if (e.target === cardActionWrapperRef.current) {\r\n setCardActionsOpen(!cardActionsOpen);\r\n }\r\n }}\r\n onBlur={(e) => {\r\n if (!cardActionWrapperRef.current?.contains(e.relatedTarget as Node)) {\r\n setCardActionsOpen(false);\r\n }\r\n }}\r\n ref={cardActionWrapperRef}\r\n >\r\n
\r\n {quickViewButton && renderQuickView(quickViewButton, product.RecordId)}\r\n {productComparisonButton && renderProductComparisonButton(productComparisonButton, product, getCatalogId(context.request))}\r\n {context.request.user.isAuthenticated && (\r\n <>\r\n
\r\n {modal.allergensModal && (\r\n setModal({ ...modal, allergensModal: false })}\r\n context={context}\r\n product={product}/>\r\n )}\r\n {\r\n setModal({ ...modal, allergensModal: true });\r\n }\r\n }>\r\n \r\n \r\n
\r\n {renderOrderTemplateButton()}\r\n
\r\n {modal.productInformationModal && (\r\n setModal({ ...modal, productInformationModal: false })}\r\n context={context}\r\n product={product}/>\r\n )}\r\n {\r\n setModal({ ...modal, productInformationModal: true });\r\n }\r\n }>\r\n \r\n \r\n
\r\n {wishlistButton && renderWishlistButton(wishlistButton)}\r\n \r\n )}\r\n
\r\n
\r\n\r\n {product.Badge && (\r\n \r\n )}\r\n \r\n );\r\n};\r\n\r\nfunction renderLabel(\r\n name?: string,\r\n price?: string,\r\n rating?: number,\r\n ratingAriaLabelText?: string,\r\n reviewCount?: number,\r\n ratingCountAriaLabelText?: string\r\n): string {\r\n const reviewCountArialableText = getReviewAriaLabel(reviewCount, ratingCountAriaLabelText ?? '');\r\n return `${name ?? ''} ${price ?? ''} ${getRatingAriaLabel(rating, ratingAriaLabelText)}${\r\n reviewCountArialableText ? ` ${reviewCountArialableText}` : ''\r\n }`;\r\n}\r\n\r\nfunction renderDescription(description?: string): JSX.Element | null {\r\n return

{description}

;\r\n}\r\n\r\nfunction getRatingAriaLabel(rating?: number, ratingAriaLabel?: string): string {\r\n if (rating && ratingAriaLabel) {\r\n const roundedRating = rating.toFixed(2);\r\n return format(ratingAriaLabel || '', roundedRating, '5');\r\n }\r\n return '';\r\n}\r\n\r\nfunction getReviewAriaLabel(reviewCount?: number, ratingCountAriaLabelText?: string): string {\r\n if (reviewCount && ratingCountAriaLabelText) {\r\n return format(ratingCountAriaLabelText || '', reviewCount);\r\n }\r\n return '';\r\n}\r\n\r\nfunction renderRating(\r\n coreContext: ICoreContext,\r\n moduleTypeName: string,\r\n moduleId: string,\r\n avgRating?: number,\r\n totalRatings?: number,\r\n ariaLabel?: string,\r\n ratingCountAriaLabel?: string\r\n): JSX.Element | null {\r\n if (!avgRating) {\r\n return null;\r\n }\r\n\r\n const numberRatings = totalRatings?.toString() || undefined;\r\n const ratingAriaLabelText = getRatingAriaLabel(avgRating, ariaLabel);\r\n const ratingCountAriaLabelText = getReviewAriaLabel(Number(numberRatings), ratingCountAriaLabel);\r\n\r\n return (\r\n \r\n );\r\n}\r\n\r\nfunction renderPrice(\r\n context: ICoreContext,\r\n typeName: string,\r\n id: string,\r\n show: boolean,\r\n basePrice?: number,\r\n adjustedPrice?: number,\r\n savingsText?: string,\r\n freePriceText?: string,\r\n originalPriceText?: string,\r\n currentPriceText?: string,\r\n isPriceMinMaxEnabled?: boolean,\r\n priceResources?: IPriceComponentResources,\r\n priceFailed?: boolean,\r\n priceErrorText?: string,\r\n productPrice?: ProductPrice\r\n): JSX.Element | null {\r\n const price: ProductPrice = {\r\n BasePrice: basePrice,\r\n AdjustedPrice: adjustedPrice,\r\n CustomerContextualPrice: adjustedPrice\r\n };\r\n\r\n if (priceFailed) {\r\n return (\r\n \r\n \r\n {priceErrorText || 'Pris n/a'}\r\n \r\n \r\n )\r\n }\r\n\r\n if (!show) {\r\n return (\r\n \r\n \r\n ...\r\n \r\n \r\n )\r\n }\r\n\r\n return (\r\n \r\n );\r\n}\r\n\r\nfunction renderProductPlacementImage(\r\n imageSettings?: IImageSettings,\r\n gridSettings?: IGridSettings,\r\n imageUrl?: string,\r\n fallbackImageUrl?: string,\r\n altText?: string,\r\n context?: ICoreContext>\r\n): JSX.Element | null {\r\n if (!imageUrl || !gridSettings || !imageSettings) {\r\n return null;\r\n }\r\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-assignment -- Site level config can be of any type.\r\n const contextConfig = context?.app.config?.placeholderImageName;\r\n const emptyPlaceHolderImage = contextConfig as string;\r\n let fallbackImageSource = fallbackImageUrl;\r\n if (emptyPlaceHolderImage && fallbackImageUrl) {\r\n fallbackImageSource = `${fallbackImageUrl},${emptyPlaceHolderImage}`;\r\n }\r\n const img: IImageData = {\r\n src: imageUrl,\r\n altText: altText ? altText : '',\r\n fallBackSrc: fallbackImageSource\r\n };\r\n const imageProps = {\r\n gridSettings,\r\n imageSettings\r\n };\r\n imageProps.imageSettings.cropFocalRegion = true;\r\n imageProps.imageSettings.mode = 0;\r\n imageProps.imageSettings.viewports = {\r\n xs: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' },\r\n lg: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' },\r\n md: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' },\r\n sm: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' },\r\n xl: { h: 200, w: 200, q: 'w=200&h=200&q=80&m=0&f=webp', qe: 't=200h200qhigh' }\r\n };\r\n\r\n return (\r\n \r\n );\r\n}\r\n\r\nexport const ProductComponent: React.FunctionComponent = msdyn365Commerce.createComponentOverride('Product', { component: ProductCard, ...PriceComponentActions });\r\n\r\nexport default ProductComponent;\r\n"],"names":["getDefaultSwatchSelected","coreContext","productData","_productData$Attribut","_attributeSwatches$fi","AttributeValues","dimensionToPreSelectInProductCard","app","config","attributeSwatches","find","attributeValue","_attributeValue$KeyNa","KeyName","toLocaleLowerCase","Swatches","ArrayExtensions","hasElements","item","IsDefault","updateProductUrl","productDetailsPageUrl","queryString","sourceUrl","URL","request","apiSettings","baseUrl","search","href","pathname","generateOrderTemplateNameDialogResources","resources","orderTemplateHeaderLabel","createOrderTemplateHeader","orderTemplateTitleLabel","orderTemplateTitle","orderTemplateNameAriaLabel","orderTemplateDescription","createOrderTemplateDescription","defaultOrderTemplateName","orderTemplateButtonLabel","createOrderTemplateButtonText","orderTemplateCancelButtonLabel","cancelNewOrderTemplateCreationButtonText","generateItemAddedToOrderTemplateDialogResources","viewOrderTemplateButtonText","continueShoppingButtonText","itemAddedToOrderTemplateHeaderItemOneText","itemAddedToOrderTemplateHeaderItemFormatText","itemAddedToOrderTemplateHeaderMessageText","freePriceText","priceFree","originalPriceText","currentPriceText","generateDuplicateItemsWhenAddingToOrderTemplateDialogResources","duplicatedProductsHeader","duplicatedProductsDescription","updateQuantityButtonText","cancelDuplicateItemsButtonText","renderLabel","name","price","rating","ratingAriaLabelText","reviewCount","ratingCountAriaLabelText","reviewCountArialableText","getReviewAriaLabel","getRatingAriaLabel","ratingAriaLabel","roundedRating","toFixed","format","renderPrice","context","typeName","id","show","basePrice","adjustedPrice","savingsText","isPriceMinMaxEnabled","priceResources","priceFailed","priceErrorText","productPrice","BasePrice","AdjustedPrice","CustomerContextualPrice","React","className","PriceComponent","data","renderProductPlacementImage","imageSettings","gridSettings","imageUrl","fallbackImageUrl","altText","_context$app$config","contextConfig","placeholderImageName","fallbackImageSource","img","src","fallBackSrc","imageProps","cropFocalRegion","mode","viewports","xs","h","w","q","qe","lg","md","sm","xl","Image","Object","assign","requestContext","actionContext","loadFailureBehavior","bypassHideOnFailure","ProductComponent","msdyn365Commerce","createComponentOverride","_objectSpread","component","_ref","_data$cart$cart$CartL","_data$cart","_product$Name","_product$RecordId","_getProductImageUrlFr","_getProductPageUrlFro","ratingCountAriaLabel","cartQueue","allowBack","telemetryContent","quickViewButton","productComparisonButton","wishlistButton","isEnabledProductDescription","disableBuyButton","showPrice","showAgreementProduct","buyAlwaysAdd","inventoryLabel","inventoryStatus","dimensionAvailabilities","swatchItemAriaLabel","addToCartText","updateCartText","removeFromCartText","outOfStockText","toastStrings","inCartTooltipText","transitTooltip","agreementProductTooltip","addToOrderTemplateResources","onUpdateOrderTemplates","retrieveOrderTemplates","onBuyValidate","locale","getLocale","product","simpleProduct","modal","setModal","useState","allergensModal","productInformationModal","cartQuantity","cart","CartLines","x","ProductId","RecordId","Quantity","orderQuantity","setOrderQuantity","breakoff","setBreakoff","productUrl","getProductPageUrlSync","Name","Number","MIN_VALUE","undefined","productImageUrlFromSwatch","defaultSwatch","swatchProductImageUrls","ProductImageUrls","generateImageUrl","PrimaryImageUrl","getProductImageUrlFromDefaultSwatch","productPageUrlFromSwatch","SwatchValue","encodeURIComponent","getProductPageUrlFromDefaultSwatch","productPageUrl","setProductPageUrl","productImageUrl","setProductImageUrl","cardActionsOpen","setCardActionsOpen","showCartCountTooltip","setShowCartCountTooltip","cardActionWrapperRef","temperatureZoneIcon","TemperatureZone","getTemperatureZoneIcon","forceUpdate","setForceUpdate","reaction","_data$cart2","_data$cart3","document","querySelectorAll","forEach","element","setAttribute","getAttribute","selectedSwatchItems","Dictionary","enableStockCheck","updatePageAndImageUrl","swatchItem","dimensionType","setValue","StringExtensions","isNullOrWhitespace","value","productPageUrlWithSwatch","includes","newUrl","searchParams","delete","toString","swatchProductImageUrl","productImageUrls","newImageUrl","payLoad","getPayloadObject","attribute","getTelemetryAttributes","baseClassName","unitOfMeasureDisplayType","onClick","onTelemetryClick","cultureFormatter","formatCurrency","Price","AverageRating","TotalRatings","user","isAuthenticated","PriceFailed","ProductPrice","description","Description","ItemId","classnames","title","Transit","IsAgreementProduct","Brand","Manufacturer","inventoryAvailabilityLabel","availabilityClassName","IsProductAvailable","StockLevelCode","inventoryStatusText","StockLevelLabel","renderProductAvailability","attributeValues","map","_item$KeyName$toLocal","_item$KeyName","_item$Swatches$map","_item$Swatches","dimensionTypeValue","dimensionsToDisplayOnProductCard","dimensionsInProductCard","DimensionTypes","none","shouldDisplayDimension","swatches","_item$RecordId","_swatchItem$SwatchVal","_swatchItem$SwatchVal2","_dimensionAvailabilit","itemId","colorHexCode","SwatchColorHexCode","SwatchImageUrl","isDefault","isDisabled","dimensionAvailability","_swatchItem$SwatchVal3","some","swatch","ProductComponentSwatchComponent","onSelectDimension","key","ProductListOrderQuantity","unitConversions","currentCount","onChange","newValue","inputQuantityAriaLabel","incrementButtonAriaLabel","decrementButtonAriaLabel","disabled","onBreakoffChange","hideRating","moduleTypeName","moduleId","avgRating","totalRatings","ariaLabel","numberRatings","RatingComponent","ratingCount","readOnly","renderRating","_renderCartButton","_data$product14","_data$product15","_data$product16","_data$product17","_data$product18","_data$product19","_data$product20","_data$product21","_data$product22","_data$product23","_data$product24","_data$product25","_data$cart4","product1","ProductTypeValue","DefaultUnitOfMeasure","MasterProductId","ExtensionProperties","productDimensionAvailabilities","masterProductId","cartCount","filter","reduce","acc","val","cartCountId","tooltipString","tooltipText","onMouseOver","onMouseOut","onTouchStart","Tooltip","isOpen","target","Node","AddToCartComponent","hasAvailableProducts","productAvailability","AvailableQuantity","productSearch","quantity","onUpdateQuantity","onAdd","e","prev","open","tabIndex","current","onBlur","_cardActionWrapperRef","contains","relatedTarget","ref","quickview","selectedDimensions","getValues","DimensionTypeValue","convertDimensionTypeToProductDimensionType","DimensionValue","Value","selectedProductId","renderQuickView","catalogId","renderProductComparisonButton","getCatalogId","AllergensModal","onClose","allergens","async","_data$customerInforma","customerInformation","IsB2b","AddToOrderTemplateComponent","addToOrderTemplateButtonText","addToOrderTemplateButtonTooltip","addToOrderTemplateDialogResources","addToOrderTemplateHeader","noOrderTemplatesMessage","noOrderTemplatesDescription","createAnOrderTemplateButtonText","createNewOrderTemplateButtonText","cancelOrderTemplateCreationButtonText","selectTemplatesText","addToTemplateButtonText","lineItemsText","createOrderTemplateDialogResources","itemAddedToOrderTemplateDialogResources","duplicateItemsWhenAddingToOrderTemplateDialogResources","_data$product","_data$product2","_data$product3","_data$product4","_data$product5","_data$product6","_data$product7","_data$product8","_data$product9","_data$product10","_data$product11","_data$product12","showButtonTooltip","onSuccess","_data$product13","orderTemplate","toast","text","autoClose","canClose","position","type","showProgress","ProductInformationModal","productInformationTitle","Badge","DiscountBadge","badge","size"],"sourceRoot":""}