@next-bricks/ai-portal 0.60.3 → 0.61.0

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.
Files changed (53) hide show
  1. package/dist/bricks.json +28 -27
  2. package/dist/chunks/{1480.0de951a3.js → 1480.a7ffdf61.js} +2 -2
  3. package/dist/chunks/1480.a7ffdf61.js.map +1 -0
  4. package/dist/chunks/{2232.085b8abd.js → 2232.06e10f13.js} +2 -2
  5. package/dist/chunks/2232.06e10f13.js.map +1 -0
  6. package/dist/chunks/{5712.f692e3f5.js → 5712.6b8e0a77.js} +2 -2
  7. package/dist/chunks/5712.6b8e0a77.js.map +1 -0
  8. package/dist/chunks/9164.34a6f72c.js +2 -0
  9. package/dist/chunks/9164.34a6f72c.js.map +1 -0
  10. package/dist/chunks/9271.24992b40.js +2 -0
  11. package/dist/chunks/9271.24992b40.js.map +1 -0
  12. package/dist/chunks/chat-box.3a31adcd.js +3 -0
  13. package/dist/chunks/chat-box.3a31adcd.js.map +1 -0
  14. package/dist/chunks/chat-input.8d663f4e.js +3 -0
  15. package/dist/chunks/chat-input.8d663f4e.js.LICENSE.txt +1 -0
  16. package/dist/chunks/chat-input.8d663f4e.js.map +1 -0
  17. package/dist/chunks/chat-stream.d3cde350.js +2 -0
  18. package/dist/chunks/chat-stream.d3cde350.js.map +1 -0
  19. package/dist/chunks/cruise-canvas.c1a7bc9f.js +2 -0
  20. package/dist/chunks/cruise-canvas.c1a7bc9f.js.map +1 -0
  21. package/dist/chunks/{main.fc9fd5d4.js → main.08d6c690.js} +2 -2
  22. package/dist/chunks/{main.fc9fd5d4.js.map → main.08d6c690.js.map} +1 -1
  23. package/dist/examples.json +17 -17
  24. package/dist/{index.f2850973.js → index.5a41efb9.js} +2 -2
  25. package/dist/{index.f2850973.js.map → index.5a41efb9.js.map} +1 -1
  26. package/dist/manifest.json +256 -220
  27. package/dist/types.json +844 -868
  28. package/dist-types/chat-box/index.d.ts +3 -10
  29. package/dist-types/chat-input/i18n.d.ts +3 -1
  30. package/dist-types/chat-input/index.d.ts +16 -1
  31. package/dist-types/chat-stream/ChatStream.d.ts +1 -1
  32. package/dist-types/chat-stream/index.d.ts +5 -0
  33. package/dist-types/cruise-canvas/CruiseCanvas.d.ts +1 -1
  34. package/dist-types/cruise-canvas/index.d.ts +5 -0
  35. package/dist-types/shared/ChatCompletions/useChatCompletions.d.ts +65 -0
  36. package/dist-types/shared/TaskContext.d.ts +3 -0
  37. package/package.json +2 -2
  38. package/dist/chunks/1480.0de951a3.js.map +0 -1
  39. package/dist/chunks/2232.085b8abd.js.map +0 -1
  40. package/dist/chunks/2324.a4a90c77.js +0 -2
  41. package/dist/chunks/2324.a4a90c77.js.map +0 -1
  42. package/dist/chunks/5712.f692e3f5.js.map +0 -1
  43. package/dist/chunks/6792.03e66697.js +0 -2
  44. package/dist/chunks/6792.03e66697.js.map +0 -1
  45. package/dist/chunks/chat-box.a8e58e50.js +0 -3
  46. package/dist/chunks/chat-box.a8e58e50.js.map +0 -1
  47. package/dist/chunks/chat-input.e999f79c.js +0 -2
  48. package/dist/chunks/chat-input.e999f79c.js.map +0 -1
  49. package/dist/chunks/chat-stream.8d8dc5a0.js +0 -2
  50. package/dist/chunks/chat-stream.8d8dc5a0.js.map +0 -1
  51. package/dist/chunks/cruise-canvas.4a0692fb.js +0 -2
  52. package/dist/chunks/cruise-canvas.4a0692fb.js.map +0 -1
  53. /package/dist/chunks/{chat-box.a8e58e50.js.LICENSE.txt → chat-box.3a31adcd.js.LICENSE.txt} +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"file":"chunks/2232.085b8abd.js","mappings":"2IAGO,SAASA,EACdC,GAEA,OAAQA,GACN,IAAK,iBACH,MAAO,CAAEC,IAAK,OAAQC,MAAO,SAAUC,KAAM,gBAC/C,IAAK,YACH,MAAO,CAAEF,IAAK,OAAQC,MAAO,SAAUC,KAAM,gBAC/C,IAAK,SACH,MAAO,CAAEF,IAAK,OAAQC,MAAO,SAAUC,KAAM,gBAC/C,IAAK,aACH,MAAO,CAAEF,IAAK,OAAQC,MAAO,SAAUC,KAAM,QAC/C,IAAK,UACH,MAAO,CAAEF,IAAK,OAAQE,KAAM,qBAAsBC,UAAU,GAC9D,QACE,MAAO,CAAEH,IAAK,OAAQC,MAAO,SAAUC,KAAM,gBAEnD,C,sFCjBIE,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,6WACoH,KAE7JH,EAAwBI,OAAS,CAChC,IAAO,gBACP,QAAW,oBACX,QAAW,qBAEZ,S,sECVIJ,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,oyEAGs0B,KAE/2BH,EAAwBI,OAAS,CAChC,SAAY,qBACZ,IAAO,gBACP,QAAW,oBACX,KAAQ,iBACR,UAAa,sBACb,OAAU,mBACV,QAAW,oBACX,iBAAkB,2BAClB,SAAY,qBACZ,KAAQ,iBACR,KAAQ,iBACR,KAAQ,iBACR,OAAU,mBACV,KAAQ,iBACR,MAAS,kBACT,KAAQ,kBAET,S,sECzBIJ,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,gPAAiP,KAE1RH,EAAwBI,OAAS,CAChC,KAAQ,kBAET,S,2HCPIJ,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,0aAA2a,KAEpdH,EAAwBI,OAAS,CAChC,UAAa,sBACb,KAAQ,iBACR,QAAW,oBACX,OAAU,oBAEX,S,2ECXO,IAAKC,EAAC,SAADA,GAAC,OAADA,EAAC,oCAADA,EAAC,kDAADA,EAAC,gEAADA,EAAC,oBAADA,CAAC,MAOb,MAcaC,EAAK,+BAELC,EAAU,CAAEC,GAhBN,CACjBC,iBAAkB,mBAClBC,wBAAyB,sCACzBC,+BAAgC,6CAChCC,SAAU,0DAYiBC,GATV,CACjBJ,iBAAkB,QAClBC,wBAAyB,mBACzBC,+BAAgC,qBAChCC,SAAU,gCAOCE,EAAIC,EAAAA,KAAKC,UAAU,KAAMV,E,sECxBlCN,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,m/DAAo/D,KAE7hEH,EAAwBI,OAAS,CAChC,QAAW,oBACX,KAAQ,iBACR,MAAS,kBACT,KAAQ,iBACR,MAAS,kBACT,KAAQ,iBACR,KAAQ,iBACR,UAAa,sBACb,QAAW,oBACX,SAAY,qBACZ,QAAW,oBACX,eAAgB,yBAChB,UAAa,sBACb,OAAU,mBACV,QAAW,oBACX,iBAAkB,2BAClB,SAAY,qBACZ,MAAS,mBAEV,S,uICbO,SAASa,EACdC,EACAvB,EACAwB,EACAC,EACAC,EACAC,EACAC,GAKA,MAAMC,EAAmBD,aAAO,EAAPA,EAASC,iBAC5BC,EAAuBF,aAAO,EAAPA,EAASE,qBAEtC,OAAOC,EAAAA,EAAAA,UAAQ,KACb,IAAKR,EACH,MAAO,CACLS,SAAU,GACVC,WAAY,MAIhB,MAAM,OAAEC,EAAM,OAAEC,IAAWC,EAAAA,EAAAA,GACzBZ,EACAC,EACAC,EACAC,EACAG,GAEIE,EAA0B,GAEhC,IAAIK,EAA6C,CAC/CC,KAAM,YACNJ,OAAQ,IAEND,EAAkC,KACtC,IAAK,MAAMM,KAASL,EAClB,GAAmB,QAAfK,EAAMC,KAAgB,KAAAC,EACxB,MAAMC,EAAMH,EAAMG,IAYhB,IAAAC,EAXED,EAAIE,WAAaF,EAAIG,gBACvBZ,EAAa,CACXO,KAAM,MACNhC,GAAIkC,EAAIlC,KAKI,cAAdkC,EAAI1C,OACQ,QADayC,EACzBC,EAAIV,gBAAQ,IAAAS,GAAZA,EAAcK,QACdJ,EAAIV,SAASe,OAAOC,GAAqB,SAAbA,EAAIV,QAE5BD,EAAqBH,OAAOY,OAAS,GACvCd,EAAS1B,KAAK+B,GAEhBL,EAAS1B,KAAK,CACZgC,KAAM,OACNW,QAASP,EAAIV,SACVkB,SAASF,GACRA,EAAIG,MAAMC,KAAKC,GAAwB,SAAdA,EAAKb,KAAkBa,EAAKC,KAAO,OAE7DC,KAAK,IACRC,IAAKd,EAAIc,IACTC,sBAAuBf,EAAIe,sBAC3BC,mBAAoBnB,EAAMmB,mBAC1BC,MAAmB,QAAdhB,EAAED,EAAIV,gBAAQ,IAAAW,OAAA,EAAZA,EACHiB,QAAQZ,GAAqB,SAAbA,EAAIV,OACrBY,SAASF,GAAQA,EAAIG,QACrBS,QAAQP,GAAuB,SAAdA,EAAKb,OACtBY,KAAKC,GAASA,EAAKQ,SAExBxB,EAAuB,CACrBC,KAAM,YACNJ,OAAQ,KAGVG,EAAqBH,OAAO5B,KAAKiC,GAG/BG,EAAIoB,cACFzB,EAAqBH,OAAOY,OAAS,GACvCd,EAAS1B,KAAK+B,GAEZR,GACFG,EAAS1B,KAAK,CACZgC,KAAM,OACNW,QAASP,EAAIoB,cAGjBzB,EAAuB,CACrBC,KAAM,YACNJ,OAAQ,IAGd,MACEG,EAAqBH,OAAO5B,KAAKiC,GACd,UAAfA,EAAMC,OACRP,EAAa,CACXO,KAAMD,EAAMC,KACZhC,GAAI+B,EAAMwB,KAAKvD,KAMvB,IAAIwD,EACFhC,EAASc,OAAS,IAAMmB,EAAAA,GAAYC,SAASlE,GAC/C,GACEgE,GAC8B,cAA9B3B,EAAqBC,MACkB,IAAvCD,EAAqBH,OAAOY,OAC5B,CACA,MAAMqB,EAAcnC,EAASA,EAASc,OAAS,GACtB,SAArBqB,EAAY7B,MAAmB6B,EAAYT,qBAC7CM,GAA2B,EAE/B,CAMA,OAJI3B,EAAqBH,OAAOY,OAAS,GAAKkB,IAC5ChC,EAAS1B,KAAK+B,GAGT,CAAEL,WAAUG,SAAQF,aAAY,GACtC,CACDV,EACAvB,EACAwB,EACAE,EACAC,EACAF,EACAI,EACAC,GAEJ,C,iJCxIIF,EAAU,CAAC,EAEfA,EAAQwC,kBAAoB,IAC5BxC,EAAQyC,cAAgB,IACxBzC,EAAQ0C,OAAS,SAAc,KAAM,QACrC1C,EAAQ2C,OAAS,IACjB3C,EAAQ4C,mBAAqB,IAEhB,IAAI,IAAS5C,GAKnB,QAAe,KAAW,IAAQnB,OAAS,IAAQA,YAASgE,E,0BCX5D,SAASC,EAAWC,GAKN,IALO,QAC1B1B,EAAO,IACPO,EAAG,sBACHC,EAAqB,MACrBE,GACiBgB,EACjB,OACEC,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,OAAKC,UAAWC,EAAOC,OACnBvB,GAAOC,IACPmB,IAAAA,cAACI,EAAAA,EAAe,CACdxB,IAAKA,EACLC,sBAAuBA,IAG1BR,GAEFU,SAAAA,EAAOb,OAAS8B,IAAAA,cAACK,EAAAA,EAAQ,CAACtB,MAAOA,EAAOuB,GAAG,SAAY,KAG9D,C,eCtBI,EAAU,CAAC,EAEf,EAAQd,kBAAoB,IAC5B,EAAQC,cAAgB,IACxB,EAAQC,OAAS,SAAc,KAAM,QACrC,EAAQC,OAAS,IACjB,EAAQC,mBAAqB,IAEhB,IAAI,IAAS,GAKnB,QAAe,KAAW,IAAQ/D,OAAS,IAAQA,YAASgE,E,gDCb/D,EAAU,CAAC,EAEf,EAAQL,kBAAoB,IAC5B,EAAQC,cAAgB,IACxB,EAAQC,OAAS,SAAc,KAAM,QACrC,EAAQC,OAAS,IACjB,EAAQC,mBAAqB,IAEhB,IAAI,IAAS,GAKnB,QAAe,KAAW,IAAQ/D,OAAS,IAAQA,YAASgE,E,2DCb/D,EAAU,CAAC,EAEf,EAAQL,kBAAoB,IAC5B,EAAQC,cAAgB,IACxB,EAAQC,OAAS,SAAc,KAAM,QACrC,EAAQC,OAAS,IACjB,EAAQC,mBAAqB,IAEhB,IAAI,IAAS,GAKnB,QAAe,KAAW,IAAQ/D,OAAS,IAAQA,YAASgE,ECb5D,SAASU,EAAQR,GAAsC,IAArC,IAAEjC,GAAoBiC,EAC7C,MAAOS,EAAMC,IAAWC,EAAAA,EAAAA,UAA6B,UAE/CC,GAAmBC,EAAAA,EAAAA,cAAaC,IACpCJ,EAAQI,EAAM,GACb,IAEH,OACEb,IAAAA,cAAA,OACEC,UAAWa,IAAWZ,EAAOa,KAAM,CACjC,CAACb,EAAOc,OAAiB,UAATR,KAGlBR,IAAAA,cAACiB,EAAAA,EAAW,CAACnD,IAAKA,EAAKoD,aAAcP,IAG3C,C,eCnBO,MAAMQ,GAAgBC,EAAAA,EAAAA,eAAkC,CAC7D/D,WAAY,KACZgE,mBAAoBA,SCFf,SAASC,EACdlG,EACAmG,GAKA,OAAQnG,GACN,IAAK,YACH,MAAO,CACL6E,UAAWC,EAAOsB,UAClBjG,KAAM,CACJF,IAAK,OACLC,MAAO,SACPC,KAAM,iBAGZ,IAAK,YACL,IAAK,UACH,MAA0B,eAAtBgG,EACK,CACLhG,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,gBAIL,CACL0E,UAAWC,EAAOwB,QAClBnG,KAAM,CACJF,IAAK,OACLC,MAAO,WACPC,KAAM,qBACNC,UAAU,IAGhB,IAAK,iBACH,MAAO,CACLyE,UAAWC,EAAO,kBAClB3E,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,gBAGZ,IAAK,SACH,MAAO,CACL0E,UAAWC,EAAOyB,OAClBpG,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,UAGZ,IAAK,WACL,IAAK,aACH,MAAO,CACL0E,UAAWC,EAAO0B,SAClBrG,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,gBAGZ,IAAK,UACH,MAAO,CACLA,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,QAGZ,QACE,MAAO,CACLA,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,UAIhB,CCpEO,SAASsG,EAAO9B,GAAmC,IAAA+B,EAAA/D,EAAA,IAAlC,IAAED,EAAG,UAAEiE,GAAyBhC,EACtD,MAAM/B,EAAWF,EAAIE,SACfgE,GAAYhE,SAAqB,QAAb8D,EAAR9D,EAAUiE,mBAAW,IAAAH,OAAA,EAArBA,EAAuBI,SAASlE,aAAQ,EAARA,EAAUmE,MACtDC,EAAWpE,aAAQ,EAARA,EAAUmE,KACrBE,IAAiBrE,GACjB,kBAAEuD,EAAiB,gBAAEe,EAAe,mBAAEC,IAC1CC,EAAAA,EAAAA,YAAWC,EAAAA,IACP,WAAEpF,EAAU,mBAAEgE,IAAuBmB,EAAAA,EAAAA,YAAWrB,IAEhD,UAAElB,EAAS,KAAE1E,IAAS4B,EAAAA,EAAAA,UAAQ,IAC3BmE,EAAgBxD,EAAI1C,MAAOmG,IACjC,CAACzD,EAAI1C,MAAOmG,KAERmB,EAAqBC,EAAqB5D,IAAS5B,EAAAA,EAAAA,UAAQ,KAAM,IAAAU,EACtE,MAAM+E,EAAqB,GACrBC,EAA4C,GAC5C9D,EAAoB,GAC1B,IAAIiC,EAAqB,eAAboB,EA8BZ,OA7BY,QAAZvE,EAAAC,EAAIV,gBAAQ,IAAAS,GAAZA,EAAciF,SAASC,IACrB,GAAqB,SAAjBA,EAAQrF,KACV,IAAK,MAAMe,KAAQsE,EAAQxE,MAAO,CACN,IAAAyE,EAA1B,GAAkB,SAAdvE,EAAKb,KACP,OAAiB,QAAjBoF,EAAQvE,EAAKwE,YAAI,IAAAD,OAAA,EAATA,EAAWpF,MACjB,IAAK,WACHgF,EAASlH,KAAK+C,EAAKwE,KAAK5E,SACxB,MACF,IAAK,uBAES,IAAA6E,EADZL,EAAgBnH,KAAK+C,EAAKwE,MACrBjC,IACHA,EACEmC,OAAOC,KAC6B,YAAzB,QAATF,EAAAzE,EAAKwE,YAAI,IAAAC,GAAc,QAAdA,EAATA,EAAWG,oBAAY,IAAAH,OAAA,EAAvBA,EAAyBtF,MACrBa,EAAKwE,KAAKI,aAAaC,WACvB7E,EAAKwE,KAAKM,QACdrF,OAAS,OAII,SAAdO,EAAKb,MACdmB,EAAMrD,KAAK+C,EAAKQ,KAEpB,CACF,IAKK,CAFiB2D,EAASjE,KAAK,IAEbkE,EAAiB9D,EAAM,GAC/C,CAACjB,EAAIV,SAAUgF,KAEXoB,EAAWC,IAAgB/C,EAAAA,EAAAA,WAAS,GACrCgD,EAAcrB,KAAkBvE,EAAI6F,YAE1C,OACE3D,IAAAA,cAAA,OAAKC,UAAWa,IAAW,CAAE,CAACZ,EAAOsD,WAAYA,KAC9CE,GACC1D,IAAAA,cAAA,OACEC,UAAWa,IAAWZ,EAAO0D,QAAS3D,GACtC4D,QAASA,IAAMJ,GAAcK,IAAUA,KAEvC9D,IAAAA,cAAA,OAAKC,UAAWC,EAAO3E,MACrByE,IAAAA,cAAC+D,EAAAA,GAAgBxI,IAEnByE,IAAAA,cAAA,OAAKC,UAAWC,EAAOgC,OAAQpE,EAAI6F,aAAe3B,GAClDhC,IAAAA,cAAC+D,EAAAA,IAAWC,EAAAA,EAAAA,GAAA,CAAC/D,UAAWC,EAAO+D,OAAWC,EAAAA,MAG9ClE,IAAAA,cAAA,OAAKC,UAAWC,EAAOiE,MACpB9B,GACCrC,IAAAA,cAAA,OACEC,UAAWC,EAAOkE,KAClBP,QAASA,KACP,MAAMN,EAAuB,CAC3B3F,KAAM,MACNhC,GAAIkC,EAAIlC,KAETmG,EAAYQ,EAAqBD,IAAkBwB,IAClDO,EAAAA,EAAAA,SAAQP,EAAMP,GAAUO,EAAOP,KAE7Bc,EAAAA,EAAAA,SAAQd,EAAQlG,IAClBgE,GAAmB,EACrB,GAGFrB,IAAAA,cAAC+D,EAAAA,GAAW,CAAC1I,IAAI,SAASE,KAAK,yBAC9ByG,GAGLhC,IAAAA,cAAA,OAAKC,UAAWC,EAAOoE,MACR,QADavG,EACzBD,EAAIV,gBAAQ,IAAAW,OAAA,EAAZA,EAAcS,KAAI,CAACuE,EAASwB,KAAK,IAAAC,EAAA,MACf,SAAjBzB,EAAQrF,KAAkB,KACxBsC,IAAAA,cAAA,OACEyE,IAAKF,EACLtE,UAAWa,IAAWZ,EAAO6C,QAAS2B,EAAAA,EAAaC,WAErC,QAF+CH,EAE5DzB,EAAQxE,aAAK,IAAAiG,OAAA,EAAbA,EAAehG,KAAI,CAACC,EAAMmG,IACzB5E,IAAAA,cAACA,IAAAA,SAAc,CAACyE,IAAKG,GACJ,SAAdnG,EAAKb,MACJoC,IAAAA,cAAC6E,EAAAA,EAAgB,CACf5E,UAAWa,IACTZ,EAAO,gBACPwE,EAAAA,EAAa,qBAEfrG,QAASI,EAAKC,UAMzB,KAGLsB,IAAAA,cAAA,OAAKC,UAAWC,EAAO7B,SACpBqE,GACC1C,IAAAA,cAAA,OAAKC,UAAWa,IAAWZ,EAAOyE,SAAUD,EAAAA,EAAaC,WACvD3E,IAAAA,cAAC6E,EAAAA,EAAgB,CACf5E,UAAWyE,EAAAA,EAAa,oBACxBrG,QAASqE,KAIdC,EAAoBnE,KAAI,CAAC+E,EAAQgB,IAChCvE,IAAAA,cAAA,OAAKyE,IAAKF,EAAOtE,UAAWC,EAAO4E,KACjC9E,IAAAA,cAAC+E,EAAAA,EAAuBxB,MAG3BzF,EAAIkH,cAAgBhF,IAAAA,cAACO,EAAQ,CAACzC,IAAKA,IAAU,KAC7CiB,EAAMb,OAAS,GAAK8B,IAAAA,cAACK,EAAAA,EAAQ,CAACtB,MAAOA,MAKhD,C,eCpIO,SAASkG,GAASlF,GAAuC,IAAtC,MAAEpC,EAAK,UAAEoE,GAA2BhC,EAC5D,MAAmB,QAAfpC,EAAMC,KACDoC,IAAAA,cAAC6B,EAAO,CAAC/D,IAAKH,EAAMG,IAAKiE,UAAWA,IAG1B,UAAfpE,EAAMC,KACDoC,IAAAA,cAAA,OAAKC,UAAWC,EAAOgF,OAAQvH,EAAMuH,OAGvClF,IAAAA,cAACmF,GAAQ,CAACxH,MAAOA,EAAOoE,UAAWA,GAC5C,CAOA,SAASoD,GAAQC,GAAsC,IAArC,MAAEzH,EAAK,UAAEoE,GAA0BqD,EACnD,MAAM,kBAAE7D,EAAiB,gBAAEe,EAAe,mBAAEC,IAC1CC,EAAAA,EAAAA,YAAWC,EAAAA,IACP,mBAAEpB,EAAkB,WAAEhE,IAAemF,EAAAA,EAAAA,YAAWrB,IAC/CqC,EAAWC,IAAgB/C,EAAAA,EAAAA,WAAS,IACrC,KAAE9C,EAAI,KAAEuB,GAASxB,GAEjB,UAAEsC,EAAS,KAAE1E,IAAS4B,EAAAA,EAAAA,UAAQ,IAC3BmE,EACU,SAAf3D,EAAMC,KAAkB,YAAcuB,EAAK/D,MAC3CmG,IAED,CAAC5D,EAAMC,KAAM2D,EAAmBpC,EAAK/D,QAExC,OACE4E,IAAAA,cAAA,OAAKC,UAAWa,IAAW,CAAE,CAACZ,EAAOsD,WAAYA,KAC/CxD,IAAAA,cAAA,OACEC,UAAWa,IAAWZ,EAAO0D,QAAS3D,GACtC4D,QAASA,IAAMJ,GAAcK,IAAUA,KAEvC9D,IAAAA,cAAA,OAAKC,UAAWC,EAAO3E,MACrByE,IAAAA,cAAC+D,EAAAA,GAAgBxI,IAEnByE,IAAAA,cAAA,OAAKC,UAAWC,EAAOgC,OACX,SAATtE,GACGrB,EAAAA,EAAAA,GAAET,EAAAA,EAAEK,wBAAyB,CAAEgG,KAAMxE,EAAM0H,KAAKlD,QAChD5F,EAAAA,EAAAA,GAAET,EAAAA,EAAEM,+BAAgC,CAClC+F,KAAMxE,EAAM2H,SAASnD,QAG7BnC,IAAAA,cAAC+D,EAAAA,IAAWC,EAAAA,EAAAA,GAAA,CAAC/D,UAAWC,EAAO+D,OAAWC,EAAAA,MAE5ClE,IAAAA,cAAA,OAAKC,UAAWC,EAAOiE,MACrBnE,IAAAA,cAAA,OACEC,UAAWC,EAAOkE,KAClBP,QAASA,KACP,MAAMN,EAAS,CACb3F,KAAMD,EAAMC,KACZhC,GAAI+B,EAAMwB,KAAKvD,KAEhBmG,EAAYQ,EAAqBD,IAAkBwB,IAClDO,EAAAA,EAAAA,SAAQP,EAAMP,GAAUO,EAAOP,KAE7Bc,EAAAA,EAAAA,SAAQd,EAAQlG,IAClBgE,GAAmB,EACrB,GAGFrB,IAAAA,cAAC+D,EAAAA,GAAW,CAAC1I,IAAI,SAASE,KAAK,UACrB,SAATqC,GACGrB,EAAAA,EAAAA,GAAET,EAAAA,EAAEK,wBAAyB,CAAEgG,KAAMxE,EAAM0H,KAAKlD,QAChD5F,EAAAA,EAAAA,GAAET,EAAAA,EAAEM,+BAAgC,CAClC+F,KAAMxE,EAAM2H,SAASnD,SAMrC,C,gBCtFI,GAAU,CAAC,EAEf,GAAQ3C,kBAAoB,IAC5B,GAAQC,cAAgB,IACxB,GAAQC,OAAS,SAAc,KAAM,QACrC,GAAQC,OAAS,IACjB,GAAQC,mBAAqB,IAEhB,IAAI,KAAS,IAKnB,SAAe,MAAW,KAAQ/D,OAAS,KAAQA,YAASgE,ECb5D,SAAS0F,GAAcxF,GAA+B,IAA9B,IAAEjC,GAA0BiC,EACzD,OACEC,IAAAA,cAAA,OAAKC,UAAWC,GAAOsF,KACrBxF,IAAAA,cAAA,OAAKC,UAAWC,GAAO7B,SACrB2B,IAAAA,cAAC+D,EAAAA,GAAW,CAAC1I,IAAI,OAAOE,KAAK,wBAC5BgB,EAAAA,EAAAA,GAAET,EAAAA,EAAEO,SAAU,CAAE8F,KAAMrE,EAAI0H,IAAKC,YAEjC3H,EAAI4H,oBACH1F,IAAAA,cAAA,OAAKC,UAAWC,GAAOyF,SACrB3F,IAAAA,cAAC4F,EAAAA,EAAkB,CAACC,OAAQ/H,EAAI4H,mBAAoBpF,GAAG,UAKjE,CCAO,SAASwF,GAAgB/F,GAKN,IALO,OAC/BzC,EAAM,WACNyI,EAAU,SACVC,EAAQ,UACRjE,GACsBhC,EACtB,MAAO2B,EAASuE,IAAW9I,EAAAA,EAAAA,UAAQ,KACjC,MAAM+I,EAAY5I,EAAOA,EAAOY,OAAS,GACzC,IAAI+H,EACJ,GAAIC,EACF,OAAQA,EAAUtI,MAChB,IAAK,OACL,IAAK,WACHqI,EAAUC,EAAU/G,KAAKgH,KAAKD,EAAU/G,KAAKgH,KAAKjI,OAAS,GAC3D,MACF,IAAK,MACH+H,EAAUC,EAAUpI,IACpB,MACF,QACE,MAAO,EAAC,OAAO+B,GAIrB,IAAKmG,GAAYI,EAAAA,GAAmB9G,SAASyG,GAC3C,MAAO,EAAC,EAAOE,GAEjB,IAAK,MAAMtI,KAASL,EAClB,OAAQK,EAAMC,MACZ,IAAK,OACL,IAAK,WACH,GAAID,EAAMwB,KAAKgH,KAAKE,MAAMvI,GAAsB,mBAAdA,EAAI1C,QACpC,MAAO,EAAC,EAAO6K,GAEjB,MACF,IAAK,MACH,GAAwB,mBAApBtI,EAAMG,IAAI1C,MACZ,MAAO,EAAC,EAAO6K,GAIvB,OAAIA,GAA6B,YAAlBA,EAAQ7K,OAAuB6K,EAAQjI,SAC7C,EAAC,EAAOiI,GAGV,EAAC,EAAMA,EAAQ,GACrB,CAACD,EAAU1I,EAAQyI,IAEtB,OACE/F,IAAAA,cAAA,OAAKC,UAAWC,EAAOoG,WACrBtG,IAAAA,cAAC+D,EAAAA,GAAW,CACV1I,IAAI,UACJkL,SAAS,QACThL,KAAK,mBACL0E,UAAWC,EAAOsG,SAEpBxG,IAAAA,cAAA,OAAKC,UAAWC,EAAOiE,MACpB7G,EAAOkB,KAAI,CAACb,EAAO4G,IAClBvE,IAAAA,cAACiF,GAAS,CAACR,IAAKF,EAAO5G,MAAOA,EAAOoE,UAAWA,MAEjDL,GAAW1B,IAAAA,cAAA,OAAKC,UAAWC,EAAOuG,UAClCT,GACCC,IACCS,EAAAA,GAAoBpH,SAASyG,KACX,YAAlBE,EAAQ7K,OAAyC,mBAAlB6K,EAAQ7K,SACvC6K,EAAQ/G,cACR+G,EAAQT,IACPxF,IAAAA,cAACuF,GAAc,CAACzH,IAAKmI,IAErBA,EAAQP,oBACN1F,IAAAA,cAAC4F,EAAAA,EAAkB,CACjBC,OAAQI,EAAQP,mBAChBpF,GAAG,WAOnB,C,wCC5FI,GAAU,CAAC,EAEf,GAAQd,kBAAoB,IAC5B,GAAQC,cAAgB,IACxB,GAAQC,OAAS,SAAc,KAAM,QACrC,GAAQC,OAAS,IACjB,GAAQC,mBAAqB,IAEhB,IAAI,KAAS,IAKnB,SAAe,MAAW,KAAQ/D,OAAS,KAAQA,YAASgE,E,wCCb/D,GAAU,CAAC,EAEf,GAAQL,kBAAoB,IAC5B,GAAQC,cAAgB,IACxB,GAAQC,OAAS,SAAc,KAAM,QACrC,GAAQC,OAAS,IACjB,GAAQC,mBAAqB,IAEhB,IAAI,KAAS,IAKnB,SAAe,MAAW,KAAQ/D,OAAS,KAAQA,YAASgE,E,cCtB5D,IAAK/D,GAAC,SAADA,GAAC,OAADA,EAAC,kBAADA,EAAC,sBAADA,EAAC,gBAADA,EAAC,sBAADA,EAAC,gBAADA,EAAC,wBAADA,CAAC,MASb,MAkBaC,GAAK,2BAILQ,GAAIC,GAAAA,KAAKC,UAAU,KAAMV,I,gBCxB/B,SAAS4K,GACdhK,EACAiK,EACAC,GAEA,MAAMC,GAAsBC,EAAAA,EAAAA,SAAO,GAC7BC,GAAoBD,EAAAA,EAAAA,SAAO,IAC1BE,EAAYC,IAAiBxG,EAAAA,EAAAA,WAAS,GAyD7C,OAvDAyG,EAAAA,EAAAA,YAAU,KACR,MAAMC,EAAkBR,EAAmBS,QACrCC,EAAmBT,EAAiBQ,QAC1C,GAAIL,EAAkBK,UAAYD,IAAoBE,EACpD,OAGF,MAAMC,EAAeA,KACnBL,EACEE,EAAgBI,UAAYJ,EAAgBK,aAAgB,GAC1DL,EAAgBM,cAEfZ,EAAoBO,UAGzBL,EAAkBK,QAChBD,EAAgBI,UAAYJ,EAAgBK,aAAgB,EAC5DL,EAAgBM,aAAY,EAIhC,IAAIC,EAFJP,EAAgBQ,iBAAiB,SAAUL,GAG3C,MAAMM,EAAW,IAAIC,GAAAA,GAAe,KAC9Bd,EAAkBK,UAGtBP,EAAoBO,SAAU,EAE9BD,EAAgBW,SAAS,CACvBC,IAAKV,EAAiBI,aACtBO,SAAU,YAEZC,aAAaP,GACbA,EAAQQ,YAAW,KACjBrB,EAAoBO,SAAU,CAAI,GACjC,KAAI,IAIT,OAFAQ,EAASO,QAAQd,GAEV,KACLO,EAASQ,aACTjB,EAAgBkB,oBAAoB,SAAUf,EAAa,CAC5D,GAGA,CAAC5K,IAUG,CAAEsK,aAAYsB,gBARE3H,EAAAA,EAAAA,cAAY,KACjC,MAAMwG,EAAkBR,EAAmBS,QAC3CD,SAAAA,EAAiBW,SAAS,CACxBC,IAAKZ,aAAe,EAAfA,EAAiBM,aACtBO,SAAU,WACV,GACD,CAACrB,IAGN,C,eC/DI,GAAU,CAAC,EAEf,GAAQpH,kBAAoB,IAC5B,GAAQC,cAAgB,IACxB,GAAQC,OAAS,SAAc,KAAM,QACrC,GAAQC,OAAS,IACjB,GAAQC,mBAAqB,IAEhB,IAAI,KAAS,IAKnB,SAAe,MAAW,KAAQ/D,OAAS,KAAQA,YAASgE,E,gBCS5D,SAAS2I,GAAOzI,GAAmC,IAAA0I,EAAA,IAAlC,KAAEpD,EAAI,SAAEC,GAAwBvF,EACtD,MAAM,MAAEnD,EAAK,gBAAE0F,IAAoBE,EAAAA,EAAAA,YAAWC,EAAAA,GACxCiG,GAAWvL,EAAAA,EAAAA,UAAQ,IAChBP,EAAM+L,MAAMpM,GAAMA,EAAEX,KAAOyJ,EAAKuD,UACtC,CAAChM,EAAOyI,EAAKuD,SAEVC,GAAc1L,EAAAA,EAAAA,UAAQ,IACnBkI,EAAKyD,KAAKtK,KAAKuK,IAAK,IAAAC,EAAA,MAAM,IAC5BD,EACHE,sBAAkD,QAA7BD,EAAED,EAAME,6BAAqB,IAAAD,OAAA,EAA3BA,EAA6BxK,KAAK8G,IACvD,MAAMnG,EAAOvC,EAAM+L,MAAMpM,GAAMA,EAAEX,KAAO0J,EAASsD,SACjD,MAAO,CACLzG,KAAMmD,EAASnD,KACfyG,OAAQtD,EAASsD,OACjBxN,MAAO+D,aAAI,EAAJA,EAAM/D,MACb8N,UAAW/J,aAAI,EAAJA,EAAM+J,UACjBC,QAAShK,aAAI,EAAJA,EAAMgK,QAChB,IAEJ,KACA,CAAC9D,EAAKyD,KAAMlM,IAETwM,GAAajM,EAAAA,EAAAA,UACjB,IAAMkM,GAAqBX,EAAStN,QACpC,CAACsN,EAAStN,QAGZ,OACE4E,IAAAA,cAAA,OAAKC,UAAWC,GAAOoJ,KACrBtJ,IAAAA,cAAA,OAAKC,UAAWC,GAAO0D,SACrB5D,IAAAA,cAAA,OAAKC,UAAWC,GAAOqJ,QACrBvJ,IAAAA,cAAA,OAAKC,UAAWa,IAAWZ,GAAOsJ,OAAQJ,EAAWnJ,YACnDD,IAAAA,cAAC+D,EAAAA,GAAgBqF,EAAW7N,MAC3B6N,EAAW1K,MAEdsB,IAAAA,cAAA,OAAKC,UAAWC,GAAOgC,OACpB,GAAa,QAAVuG,EAAApD,EAAKoE,aAAK,IAAAhB,GAAVA,EAAYtG,KAAO,GAAGkD,EAAKoE,MAAMtH,UAAY,KAAKkD,EAAKlD,SAG/DnC,IAAAA,cAAA,OAAKC,UAAWC,GAAOwJ,OACrB1J,IAAAA,cAAC2J,EAAAA,GAAkB,CACjBb,KAAMD,EACNe,iBAAkBtE,aAAQ,EAARA,EAAUsD,OAC5BiB,eAAiBC,IACXA,EAAEvG,QACJjB,EAAgB,CAAE1E,KAAM,WAAYhC,GAAIkO,EAAEvG,QAC5C,MAKRvD,IAAAA,cAAA,OAAKC,UAAWC,GAAOiE,MACpBmB,EACCtF,IAAAA,cAAC+J,GAAc,CAACzE,SAAUA,IAE1BtF,IAAAA,cAACgK,EAAAA,GAAiB,CAChB/J,UAAWC,GAAO+J,MAClBC,YAAY,UACZC,aAAa,kBAMzB,CAMA,SAASJ,GAAc3E,GAAoC,IAAnC,SAAEE,GAA+BF,EACvD,MAAM,MAAExI,EAAK,OAAEC,IAAW2F,EAAAA,EAAAA,YAAWC,EAAAA,GAC/B2H,GAAejN,EAAAA,EAAAA,UAAQ,IACpBP,EAAM+L,MAAMpM,GAAMA,EAAEX,KAAO0J,EAASsD,UAC1C,CAAChM,EAAO0I,EAASsD,SACdyB,EAAgBD,EAAahP,OAE7B,KAAEG,EAAI,UAAE0E,IAAc9C,EAAAA,EAAAA,UAC1B,IAAMkM,GAAqBgB,IAC3B,CAACA,IAGGC,GAAanN,EAAAA,EAAAA,UAAQ,IAClB,CACL,IACKiN,EACHG,YAAQ1K,KAGX,CAACuK,KAEE,SAAEhN,GAAaV,GACnB,EACA0N,EAAahP,MACbkP,EACAzN,GAGI+J,GAAqBG,EAAAA,EAAAA,QAAuB,MAC5CF,GAAmBE,EAAAA,EAAAA,QAAuB,OAE1C,WAAEE,EAAU,eAAEsB,GAAmB5B,IACrC,EACAC,EACAC,GAGF,OACE7G,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,OAAKC,UAAWC,GAAO,mBACrBF,IAAAA,cAAC+D,EAAAA,IAAWC,EAAAA,EAAAA,GAAA,GAAKzI,EAAI,CAAE0E,UAAWA,KACjCqF,EAASnD,MAEZnC,IAAAA,cAAA,OAAKC,UAAWC,GAAOsK,KAAMC,IAAK7D,GAChC5G,IAAAA,cAAA,OAAKC,UAAWC,GAAO9C,SAAUqN,IAAK5D,GACnCzJ,EAASoB,KAAI,CAACJ,EAAKmG,EAAOmG,IACzB1K,IAAAA,cAAA,OAAKC,UAAWC,GAAO6C,QAAS0B,IAAKF,GACrB,SAAbnG,EAAIV,KACHsC,IAAAA,cAACF,EAAW,CACVzB,QAASD,EAAIC,QACbO,IAAKR,EAAIQ,IACTG,MAAOX,EAAIW,QAGbiB,IAAAA,cAAC8F,GAAgB,CACfxI,OAAQc,EAAId,OACZyI,WAAYqE,EAAahP,MACzB4K,SAAUzB,IAAUmG,EAAKxM,OAAS,EAClC6D,WAAS,SAOrB/B,IAAAA,cAAA,UACEC,UAAW,GAAG0K,GAAa,kBAAkBC,GAAAA,EAAe,qBAC5DC,MAAO,CAAEC,OAAQ,QACjBC,QAAS9D,EACTpD,QAAS0E,GAETvI,IAAAA,cAAC+D,EAAAA,GAAW,CAAC1I,IAAI,OAAOE,KAAK,UAIrC,CAEA,SAAS8N,GAAqBjO,GAC5B,MAAMG,GAAOJ,EAAAA,GAAAA,GAAsBC,GACnC,IAAIsD,EACAuB,EAEJ,OAAQ7E,GACN,IAAK,UACHsD,EAAOnC,GAAET,GAAEkP,WACX/K,EAAYC,GAAOwB,QACnB,MACF,IAAK,YACHhD,EAAOnC,GAAET,GAAEmP,WACXhL,EAAYC,GAAOsB,UACnB,MACF,IAAK,SACH9C,EAAOnC,GAAET,GAAEoP,QACXjL,EAAYC,GAAOyB,OACnB,MACF,IAAK,iBACHjD,EAAOnC,GAAET,GAAEqP,QACXlL,EAAYC,GAAOkL,OACnB,MACF,IAAK,aACH1M,EAAOnC,GAAET,GAAEuP,YACX,MACF,QACE3M,EAAenC,GAARnB,EAAUU,GAAEkP,UAAelP,GAAEwP,SAGxC,MAAO,CAAE/P,OAAMmD,OAAMuB,YACvB,EAxLAsL,EAAAA,GAAAA,gBAAexP,GHKQ,CAAEE,GApBN,CACjBqP,QAAS,UACTN,UAAW,YACXG,OAAQ,SACRF,UAAW,YACXC,OAAQ,SACRG,WAAY,cAce/O,GAXV,CACjBgP,QAAS,MACTN,UAAW,MACXG,OAAQ,KACRF,UAAW,KACXC,OAAQ,KACRG,WAAY,SITd,MAAMG,GAAgC,CACpCnQ,IAAK,UACLE,KAAM,UASD,SAASkQ,GAAK1L,GAA2C,IAA1C,OAAEwD,EAAM,UAAExB,EAAS,MAAE2J,GAAmB3L,EAC5D,MAAM,gBAAEuC,EAAe,mBAAEC,IAAuBC,EAAAA,EAAAA,YAAWC,EAAAA,IACrD,mBAAEpB,IAAuBmB,EAAAA,EAAAA,YAAWrB,IAEnCuB,EAAqBC,IAC1BxF,EAAAA,EAAAA,UAAQ,KACN,MAAMyF,EAAqB,GACrBC,EAA4C,GAC5C9D,EAAoB,GAEC,IAAA4M,EAuB3B,MAvBoB,QAAhBpI,EAAO3F,OACU,QAAnB+N,EAAApI,EAAOzF,IAAIV,gBAAQ,IAAAuO,GAAnBA,EAAqB7I,SAASC,IAC5B,GAAqB,SAAjBA,EAAQrF,KACV,IAAK,MAAMe,KAAQsE,EAAQxE,MAAO,CACN,IAAAyE,EAA1B,GAAkB,SAAdvE,EAAKb,KACP,OAAiB,QAAjBoF,EAAQvE,EAAKwE,YAAI,IAAAD,OAAA,EAATA,EAAWpF,MACjB,IAAK,WACHgF,EAASlH,KAAK+C,EAAKwE,KAAK5E,SACxB,MACF,IAAK,uBACHwE,EAAgBnH,KAAK+C,EAAKwE,UAGP,SAAdxE,EAAKb,MACdmB,EAAMrD,KAAK+C,EAAKQ,KAEpB,CACF,KAMG,CAFiB2D,EAASjE,KAAK,IAEbkE,EAAiB9D,EAAM,GAC/C,CAACwE,IAEN,OACEvD,IAAAA,cAAA,OACEC,UAAWa,IAAWZ,GAAO0L,MAAO,CAClC,CAAC1L,GAAO2L,KAAM9J,EACd,CAAC7B,GAAOwL,OAAQA,KAGlB1L,IAAAA,cAAA,OAAKC,UAAWC,GAAO4E,KACrB9E,IAAAA,cAAA,OAAKC,UAAWC,GAAOqJ,QACrBvJ,IAAAA,cAAA,OAAKC,UAAWC,GAAOgC,OAAO,oBAC9BlC,IAAAA,cAAC8L,EAAAA,GAAiB,CAChBvQ,KAAMiQ,GACNO,QAAQ,OACRlI,QAASA,KACH9B,EACFQ,EAAmB,OAEnBD,EAAgB,MAChBjB,GAAmB,GACrB,KAINrB,IAAAA,cAAA,OAAKC,UAAWC,GAAOiE,MACJ,QAAhBZ,EAAO3F,KACNoC,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAACgM,GAAAA,EAAc,CAAClO,IAAKyF,EAAOzF,IAAKiO,QAAQ,cACxCxI,EAAOzF,IAAIkH,cACVhF,IAAAA,cAACiM,GAAS,CACR9J,KAAK,OACL+J,OAAQ3I,EAAOzF,IAAIkH,cAAcmH,KACjCC,SAAS,QAET1J,EACF1C,IAAAA,cAACiM,GAAS,CACR9J,KAAK,UACL+J,OAAQxJ,EACR0J,SAAS,OAETzJ,EAAoBzE,OAAS,EAC/B8B,IAAAA,cAACiM,GAAS,CACR9J,KAAK,OACL+J,OAAQG,KAAKC,UAAU3J,EAAqB,KAAM,GAClDyJ,SAAS,SAET,MAGNpM,IAAAA,cAACwI,GAAO,CACNnD,KAAM9B,EAAO8B,KACbC,SAAW/B,EAAkC+B,aAO3D,CAQA,SAAS2G,GAAS7G,GAA6C,IAA5C,KAAEjD,EAAI,OAAE+J,EAAM,SAAEE,GAA0BhH,EAC3D,OACEpF,IAAAA,cAAA,OAAKC,UAAWa,IAAWZ,GAAOoJ,IAAKpJ,GAAOqM,SAC5CvM,IAAAA,cAAA,OAAKC,UAAWC,GAAO0D,SAAU,GAAGzB,KAAQiK,KAC5CpM,IAAAA,cAAA,OAAKC,UAAWa,IAAWZ,GAAO7B,QAASqG,EAAAA,EAAaC,WACtD3E,IAAAA,cAAA,OAAKC,UAAWC,GAAOsM,UACrBxM,IAAAA,cAACyM,EAAAA,GAAgB,CACfxM,UAAWC,GAAO,cAClBgM,OAAQA,EACRE,SAAUA,EACVM,aAAa,YAMzB,C,4BCtII,GAAU,CAAC,EAEf,GAAQlN,kBAAoB,IAC5B,GAAQC,cAAgB,IACxB,GAAQC,OAAS,SAAc,KAAM,QACrC,GAAQC,OAAS,IACjB,GAAQC,mBAAqB,IAEhB,IAAI,KAAS,IAKnB,SAAe,MAAW,KAAQ/D,OAAS,KAAQA,YAASgE,E,+DCb/D,GAAU,CAAC,EAEf,GAAQL,kBAAoB,IAC5B,GAAQC,cAAgB,IACxB,GAAQC,OAAS,SAAc,KAAM,QACrC,GAAQC,OAAS,IACjB,GAAQC,mBAAqB,IAEhB,IAAI,KAAS,IAKnB,SAAe,MAAW,KAAQ/D,OAAS,KAAQA,YAASgE,ECtB5D,IAAK/D,GAAC,SAADA,GAAC,OAADA,EAAC,gCAADA,CAAC,MAIb,MAQaC,GAAK,gCAILQ,GAAIC,GAAAA,KAAKC,UAAU,KAAMV,ICW/B,SAAS4Q,GAAY5M,GAIc,IAJb,KAC3B6M,EAAI,kBACJrL,EAAiB,MACjBsJ,GACkB9K,EAClB,MAAO8M,EAAUC,IAAepM,EAAAA,EAAAA,WAAS,IAEnC,UAAEqM,EAAS,MAAE3R,EAAK,KAAE+G,IAAShF,EAAAA,EAAAA,UAAQ,IAClCyP,EAAKI,QACV,CAACC,EAAKC,IACe,cAAfA,EAAK9R,MACA,IACF6R,EACH7R,MAAO8R,EAAK9R,MACZ+G,KAAM+K,EAAK/K,KACX4K,UAAWE,EAAIF,UAAY,IAEnBE,EAAI9K,MAAQ+K,EAAK9R,MACpB,IACF6R,EACH7R,MAAO8R,EAAK9R,MACZ+G,KAAM+K,EAAK/K,MAGR8K,GAET,CACEF,UAAW,EACX5K,KAAM,GACN/G,WAAOyE,KAGV,CAAC+M,KAEE,UAAE3M,EAAS,KAAE1E,IAAS4B,EAAAA,EAAAA,UAAQ,IAC3BgQ,GAAyB/R,EAAOmG,IACtC,CAACnG,EAAOmG,IAEL6L,GAASxM,EAAAA,EAAAA,cAAY,KACzBkM,GAAahJ,IAAUA,GAAK,GAC3B,IAEH,GAAK8I,UAAAA,EAAM1O,OACT,OAAO,KAGT,MAAMmP,EACJN,IAAcH,EAAK1O,QAAgC,cAAtBqD,EAE/B,OACEvB,IAAAA,cAAAA,IAAAA,SAAA,KACG6M,GAAY7M,IAAAA,cAAA,OAAKC,UAAWC,GAAOoN,KAAMzJ,QAASuJ,IACnDpN,IAAAA,cAAA,OAAKC,UAAWa,IAAWZ,GAAOqN,SAAUtN,GAAY4K,MAAOA,GAC7D7K,IAAAA,cAAA,OAAKC,UAAWC,GAAOsN,IAAK3J,QAASuJ,GACnCpN,IAAAA,cAAA,OAAKC,UAAWC,GAAO3E,MACrByE,IAAAA,cAAC+D,EAAAA,GAAgBxI,IAEnByE,IAAAA,cAAA,QAAMC,UAAWC,GAAOxB,KAAMwD,MAAOmL,EAAU,GAAKlL,GACjDkL,EAAU9Q,GAAET,GAAE2R,gBAAkBtL,GAEnCnC,IAAAA,cAAA,QAAMC,UAAWC,GAAOwN,MACrBX,EAAU,IAAEH,EAAK1O,QAEpB8B,IAAAA,cAAC+D,EAAAA,GAAW,CACV9D,UAAWC,GAAOyN,OAClBtS,IAAI,OACJC,MAAM,WACNC,KAAMsR,EAAW,OAAS,QAG7BA,GACC7M,IAAAA,cAAA,MAAIC,UAAWC,GAAO0N,SACnBhB,EAAKpO,KAAI,CAAC0O,EAAM3I,IACfvE,IAAAA,cAAC6N,GAAgB,CACfpJ,IAAKF,EACLnJ,MAAO8R,EAAK9R,MACZmG,kBAAmBA,EACnBY,KAAM+K,EAAK/K,WAQ3B,CAQA,SAAS0L,GAAgBzI,GAAoD,IAAnD,MAAEhK,EAAK,kBAAEmG,EAAiB,KAAEY,GAAqBiD,EACzE,MAAM,UAAEnF,EAAS,KAAE1E,IAAS4B,EAAAA,EAAAA,UAAQ,IAC3BgQ,GAAyB/R,EAAOmG,IACtC,CAACnG,EAAOmG,IAEX,OACEvB,IAAAA,cAAA,MAAIC,UAAWa,IAAWZ,GAAOgN,KAAMjN,IACrCD,IAAAA,cAAC+D,EAAAA,IAAWC,EAAAA,EAAAA,GAAA,GAAKzI,EAAI,CAAE0E,UAAWC,GAAO9E,SACzC4E,IAAAA,cAAA,QAAMC,UAAWC,GAAOiC,KAAMD,MAAOC,GAClCA,GAIT,CAEA,SAASgL,GACP/R,EACAmG,GAEA,OAAQnG,GACN,IAAK,YACH,MAAO,CACL6E,UAAWC,GAAOsB,UAClBjG,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,UAGZ,IAAK,YACL,IAAK,UACH,MAA0B,eAAtBgG,EACK,CACLtB,eAAWJ,EACXtE,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,gBAIL,CACL0E,UAAWC,GAAOwB,QAClBnG,KAAM,CACJF,IAAK,OACLC,MAAO,WACPC,KAAM,qBACNC,UAAU,IAGhB,IAAK,iBACH,MAAO,CACLyE,UAAWC,GAAO,kBAClB3E,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,gBAGZ,IAAK,SACH,MAAO,CACL0E,UAAWC,GAAOyB,OAClBpG,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,UAGZ,IAAK,WACH,MAAO,CACL0E,UAAWC,GAAO0B,SAClBrG,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,gBAGZ,QACE,MAAO,CACLA,KAAM,CACJF,IAAK,KACLoG,OAAQ,MACRlG,KAAM,UAIhB,EAlMAgQ,EAAAA,GAAAA,gBAAexP,GDEQ,CAAEE,GAVN,CACjBwR,eAAgB,2BASWnR,GANV,CACjBmR,eAAgB,e,uCE+CX,SAASK,GAAmB/N,EAyBjC0K,GACA,IAAAsD,EAAA,IAzBA,eACEC,EAAc,eACdC,EAAc,OACdC,EAAM,YACNC,EAAW,SACXC,EAAQ,iBACRnR,EACAoR,aAAcC,EAAgB,wBAC9BC,EAAuB,mBACvBC,EAAkB,aAClBC,EAAY,mBACZC,EAAkB,UAClBC,EAAS,gBACTC,EAAe,YACfC,EAAW,cACXC,EAAa,QACbC,EAAO,YACPC,EAAW,iBACXC,EAAgB,iBAChBC,EAAgB,iBAChBC,EAAgB,eAChBC,EAAc,cACdC,GACyBtP,EAG3B,MAAM,aACJuP,EAAY,MACZ1S,EAAK,aACL2S,EAAY,OACZ1S,EAAM,cACN2S,EAAa,cACbC,EAAa,WACbC,IACEC,EAAAA,EAAAA,GACF3B,EACAC,EACAC,EACAC,GAEIyB,EAA+B,QAAtB7B,EAAGuB,aAAY,EAAZA,EAAcpN,aAAK,IAAA6L,EAAAA,EAAI,GACnCxM,EAAoB+N,aAAY,EAAZA,EAAclU,MAElCyU,EADmBxQ,EAAAA,GAAYC,SAASiC,IACY,mBAAtBA,EAC9BqL,ECpGD,SACL2C,EACA3S,GAEA,OAAOO,EAAAA,EAAAA,UAAQ,KACb,MAAM2S,EAA4B,GAElC,IAAK,MAAMzK,KAAQkK,EACjB,IAAK,MAAMxG,KAAS1D,EAAKyD,KACvB,IAAK,MAAMxD,KAAYyD,EAAME,sBAC3B,GAAI3D,EAASsD,OAAQ,CACnB,MAAMzJ,EAAOvC,EAAM+L,MAAMpM,GAAMA,EAAEX,KAAO0J,EAASsD,SACjDkH,EAAMpU,KAAK,CACTyG,KAAMmD,EAASnD,KACfyG,OAAQtD,EAASsD,OACjBxN,MAAO+D,aAAI,EAAJA,EAAM/D,OAEjB,MACE0U,EAAMpU,KAAK,CACTyG,KAAMmD,EAASnD,OAOzB,OAAO2N,CAAK,GACX,CAACP,EAAc3S,GACpB,CDwEemT,CAAmBR,EAAc3S,IACxC,QAAEE,EAAO,YAAEC,IAAgBiT,EAAAA,GAAAA,GAAsBT,IACjD,SAAEnS,EAAQ,OAAEG,EAAM,WAAEF,GAAeX,IACrC4S,EACFA,aAAY,EAAZA,EAAclU,MACdwB,EACAC,EACAC,EACAC,EACA,CAAEE,mBAAkBC,sBAAsB,KAG5CiK,EAAAA,EAAAA,YAAU,KACRiI,EAAe,CACba,UAAWX,aAAY,EAAZA,EAAcW,WACzB,GACD,CAACb,EAAgBE,aAAY,EAAZA,EAAcW,YAElC,MAAMC,IAAQ/S,EAAAA,EAAAA,UAAQ,IACfI,EAGE,IAAIA,EAAO4S,UAAU7R,SAASR,GACnCA,EAAIkH,cACA,CACEpJ,GAAIkC,EAAIlC,GACRmF,KAAMjD,EAAIkH,eAEZ,KARG,IAUR,CAACzH,KAEG6S,GAAoBC,KAAyB3P,EAAAA,EAAAA,WAAS,IACtD4P,GAAmBC,KAAwB7P,EAAAA,EAAAA,WAAS,IACpD2N,GAAcmC,KAAmB9P,EAAAA,EAAAA,YAAoB4N,IAC5DnH,EAAAA,EAAAA,YAAU,KACRqJ,KAAkBlC,EAAiB,GAClC,CAACA,IACJ,MAAOmC,GAAmBC,KAAwBhQ,EAAAA,EAAAA,YAI5CiQ,IAAuB/P,EAAAA,EAAAA,cAC1B2C,IACC8M,IAAsB,GACtBpB,EAAiB1L,EAAO,GAE1B,CAAC0L,KAGH2B,EAAAA,EAAAA,qBACEnG,GACA,KAAM,CACJoG,mBAAoBA,KAClBN,IAAqB,GACrBpI,YAAW,KACTqI,IAAgB,EAAM,GACrB,IAAK,EAEVM,qBAAsBA,KACpBT,IAAsB,EAAM,EAE9BU,mBAAqBC,IACnBN,IAAsB5M,IACpB,MAAMmN,EAAS,IAAIC,IAAIpN,GAEvB,OADAmN,EAAOE,IAAIH,GACJC,CAAM,GACb,KAGN,IAGF,MAAOG,GAAyBC,KAA8B3Q,EAAAA,EAAAA,UAE5D,OAEK4Q,GAAchP,KAAmB5B,EAAAA,EAAAA,UAA8B,OAC/D6Q,GAAiBhP,KAAsB7B,EAAAA,EAAAA,UAC5C,OAEK8Q,GAAiBnQ,KAAsBX,EAAAA,EAAAA,WAAS,GACjD/D,KAA0B2S,EAG1BmC,IAAW1K,EAAAA,EAAAA,SAAO,IACxBI,EAAAA,EAAAA,YAAU,KACR,GAAIxK,GAAuB,CACzB,MAAMgL,EAAQQ,YAAW,KACvBsJ,GAASpK,SAAU,CAAI,GACtB,KACH,MAAO,KACLa,aAAaP,EAAM,CAEvB,IACC,CAAChL,KAEJ,MAAM+U,KAAsBzD,GAC5B9G,EAAAA,EAAAA,YAAU,MAELsK,GAASpK,SAAWqK,KACrBrU,IACCmU,IAEDlP,GAAgBjF,EAClB,GACC,CAACA,EAAYmU,GAAiBE,MAEjCvK,EAAAA,EAAAA,YAAU,MACRwK,EAAAA,EAAAA,cAAaC,eAAehC,EAAU,GACrC,CAACA,IAEJ,MAAMiC,IAAajR,EAAAA,EAAAA,cACjB,CAACkR,EAAsBjM,EAAiBkM,KAA6B,IAAAC,EAC9C,QAArBA,EAAAxC,EAAcnI,eAAO,IAAA2K,GAArBA,EAAAC,KAAAzC,EAAwBsC,EAAOjM,EAAQkM,EAAM,GAE/C,CAACvC,IAGG0C,GAAe9U,EAAS,GACxB+U,GAAqC,UAAvBD,cAAY,EAAZA,GAAcxU,MAAkBwU,GAAe,MAE5DE,GAAcC,KAAmB3R,EAAAA,EAAAA,UAA8B,MAEhE4R,GAAYtE,GACXuE,GAAYC,KAAiB9R,EAAAA,EAAAA,UAA0B,MACxD+R,IAAmBtV,EAAAA,EAAAA,UACvB,KAAM,CACJ6Q,iBACAzM,oBACA3E,QACAC,SACAyV,aACA5D,qBACAR,SACAS,YACAC,kBACAE,gBAEA+C,cACA9C,UACAC,cACAZ,WAEAgD,2BACAC,8BACAC,gBACAhP,mBACAiP,mBACAhP,sBAEA6N,sBACAE,qBACArB,iBAAkB0B,GAClBH,mBACAhC,qBACAW,mBACAsB,qBAEAhB,gBACAC,aACAgD,QAAAA,GACE,MAAMC,EAAMC,OAAOC,KACjB,IAAGC,EAAAA,EAAAA,eAAcC,MAAM,GAAI,KAAKlE,QAAAA,EAAe,WAC/C,UAEE8D,IACFA,EAAIK,mBAAqBb,GACrB,CACE9T,QAAS8T,GAAY9T,QACrBO,IAAKuT,GAAYvT,IACjBC,sBAAuBsT,GAAYtT,uBAErC,CAAC,EAET,EACA0T,cACAC,iBACAJ,gBACAC,sBAEF,CACErE,EACAzM,EACA3E,EACAC,EACAyV,GACA5D,EACAR,EACAS,EACAC,EACAE,EAEA+C,GACA9C,EACAC,EACAZ,EAEAgD,GACAE,GACAC,GAEAnB,GACAE,GACAK,GACAnC,EACAW,EACAsB,GAEAhB,EACAC,EACAyC,GACAtD,EACA0D,GACAH,KAIEa,IAAqB9V,EAAAA,EAAAA,UACzB,KAAM,CACJE,aACAgE,yBAEF,CAAChE,IAGGuJ,IAAqBG,EAAAA,EAAAA,QAAuB,MAC5CF,IAAmBE,EAAAA,EAAAA,QAAuB,OAE1C,WAAEE,GAAU,eAAEsB,IAAmB5B,GACrChK,GACAiK,GACAC,IAGIqM,IAAwBC,EAAAA,GAAAA,GAC5B7B,GACA/T,EACAT,EACAC,GAGIqW,IAA2BD,EAAAA,GAAAA,GAC/B5B,GACAhU,EACAT,EACAC,IAGKsW,GAAWC,KAAgB5S,EAAAA,EAAAA,WAAS,IAC3CyG,EAAAA,EAAAA,YAAU,KACR,IAAIoM,GAAS,EAUb,OATAC,QAAQC,KAAK,EACXC,EAAAA,EAAAA,GAAmB,cAEnB,IAAIF,SAASG,GAAYxL,WAAWwL,EAAS,SAC5CC,SAAQ,KACJL,GACHD,IAAa,EACf,IAEK,KACLC,GAAS,CAAI,CACd,GACA,KAEHM,EAAAA,GAAAA,GAAgBpB,IAEhB,MAAMqB,MAAWxC,KAAgBC,IASjC,OARApK,EAAAA,EAAAA,YAAU,KACRkI,EAAcyE,GAAM,GACnB,CAACzE,EAAeyE,MAEnB3M,EAAAA,EAAAA,YAAU,KAAM,IAAA4M,EACY,QAA1BA,EAAAnN,GAAmBS,eAAO,IAAA0M,GAA1BA,EAA4BC,OAAO,GAClC,CAACrX,GAAuB0W,KAGzBrT,IAAAA,cAACyC,EAAAA,EAAYwR,SAAQ,CAACpT,MAAO4R,IAC3BzS,IAAAA,cAACmB,EAAc8S,SAAQ,CAACpT,MAAOoS,IAC7BjT,IAAAA,cAAA,OAAKC,UAAWC,GAAOgU,WACrBlU,IAAAA,cAAA,OAAKC,UAAWC,GAAOqJ,QACrBvJ,IAAAA,cAAA,UAAK4P,IAENjT,IAAyB0W,GACxBrT,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAA,OACEC,UAAWC,GAAOoE,KAClB6P,UAAW,EACX1J,IAAK7D,IAEL5G,IAAAA,cAAA,OAAKC,UAAWC,GAAOkU,OAAQ3J,IAAK5D,IACjCzJ,EAASoB,KAAI,CAACJ,EAAKmG,EAAOmG,IACzB1K,IAAAA,cAAA,OAAKC,UAAWC,GAAO6C,QAAS0B,IAAKF,GACrB,SAAbnG,EAAIV,KACHsC,IAAAA,cAACF,EAAW,CACVzB,QAASD,EAAIC,QACbO,IAAKR,EAAIQ,IACTC,sBAAuBT,EAAIS,sBAC3BE,MAAOX,EAAIW,QAGbiB,IAAAA,cAAC8F,GAAgB,CACfxI,OAAQc,EAAId,OACZyI,WAAYxE,EACZyE,SAAUzB,IAAUmG,EAAKxM,OAAS,OAKzCgQ,GACGoB,aAAY,EAAZA,EAAc+E,WACZrU,IAAAA,cAAAA,IAAAA,SAAA,KACEA,IAAAA,cAAC2M,GAAY,CACXC,KAAMA,EACNrL,kBAAmBA,EACnBsJ,MAAO,CAAEyJ,UAAW,MAEtBtU,IAAAA,cAACuU,GAAAA,EAAU,CAACF,UAAQ,EAAC/T,GAAG,UAG5B+N,KACuB,cAAtB9M,GACwB,WAAtBA,GACCgN,IACJ3R,EAAMsB,OAAS,GACb8B,IAAAA,cAACwU,GAAAA,EAAY,CAACvU,UAAWC,GAAOuU,aAI1CzU,IAAAA,cAAA,UACEC,UAAW,GAAG0K,GAAa,kBAAkBC,GAAAA,EAAe,qBAC5DG,QAAS9D,GACTpD,QAAS0E,IAETvI,IAAAA,cAAC+D,EAAAA,GAAW,CAAC1I,IAAI,OAAOE,KAAK,WAE7B2S,EAAUoB,UAAAA,EAAc+E,SAAWjG,aAAQ,EAARA,EAAU5D,MAC7CxK,IAAAA,cAAA,OAAKC,UAAWC,GAAOwU,QACrB1U,IAAAA,cAAA,OAAKC,UAAWC,GAAOkU,QACrBpU,IAAAA,cAAC2M,GAAY,CACXC,KAAMA,EACNrL,kBAAmBA,IAEpB2M,EACClO,IAAAA,cAACuU,GAAAA,EAAU,MAEXvU,IAAAA,cAAC2U,GAAAA,EAAO,CAACvZ,MAAOmG,EAAmBsO,QAASA,MAIhD,MAGN7P,IAAAA,cAAA,OAAKC,UAAWC,GAAO,iBACrBF,IAAAA,cAAC+D,EAAAA,GAAW,CACV1I,IAAI,OACJC,MAAM,WACNC,KAAK,qBACLC,UAAQ,MAMdwE,IAAAA,cAAA,OACEC,UAAWa,IAAWZ,GAAO0L,MAAO,CAClC,CAAC1L,GAAO2M,YAAaqG,MAGtBA,IACClT,IAAAA,cAACyL,GAAK,CACJlI,OAAQ2P,GACRxH,QAAS0H,KAGZA,IACCpT,IAAAA,cAACyL,GAAK,CAAClI,OAAQ6P,GAA0BrR,WAAS,KAIvDqP,IAA2BpR,IAAAA,cAAC4U,GAAAA,EAAY,CAAC1E,MAAOA,KAChDzB,GACCzO,IAAAA,cAAA,OAAKC,UAAWa,IAAW+T,GAAAA,EAAcC,QAAS5U,GAAO4U,UACvD9U,IAAAA,cAAC8L,EAAAA,GAAiB,CAChBvQ,KAAMwZ,EAAAA,GACNhJ,QAAQ,OACR7J,OAAO3F,EAAAA,EAAAA,GAAET,EAAAA,EAAEI,kBACX2H,QAASqL,KAIdqD,IAAcvS,IAAAA,cAACgV,GAAAA,EAAW,CAAC/V,KAAMsT,KACjCH,IAAgBpS,IAAAA,cAACiV,GAAAA,EAAa,CAACC,OAAQ9C,MAIhD,C,sEEjfI3W,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,gUAAiU,KAE1WH,EAAwBI,OAAS,CAChC,KAAQ,iBACR,MAAS,mBAEV,S,mGCPIsZ,EAAgC,IAAIC,IAAI,cACxC3Z,EAA0B,IAA4B,KACtD4Z,EAAqC,IAAgCF,GAEzE1Z,EAAwBC,KAAK,CAACC,EAAOC,GAAI,+IAA+IyZ,82CAAg5C,KAExkD5Z,EAAwBI,OAAS,CAChC,UAAa,sBACb,OAAU,mBACV,KAAQ,iBACR,OAAU,mBACV,QAAW,oBACX,eAAgB,yBAChB,OAAU,mBACV,MAAS,kBACT,SAAY,qBACZ,SAAY,qBACZ,QAAW,qBAEZ,S,sECpBIJ,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,+zCAAg0C,KAEz2CH,EAAwBI,OAAS,CAChC,MAAS,kBACT,MAAS,kBACT,IAAO,gBACP,IAAO,gBACP,OAAU,mBACV,MAAS,kBACT,KAAQ,iBACR,IAAO,gBACP,QAAW,oBACX,QAAW,oBACX,SAAY,qBACZ,QAAW,oBACX,OAAU,mBACV,aAAc,wBAEf,S,sECpBIJ,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,20DAA40D,KAEr3DH,EAAwBI,OAAS,CAChC,IAAO,gBACP,QAAW,oBACX,OAAU,mBACV,OAAU,mBACV,OAAU,mBACV,QAAW,oBACX,UAAa,sBACb,OAAU,mBACV,MAAS,kBACT,MAAS,kBACT,KAAQ,iBACR,iBAAkB,2BAClB,KAAQ,iBACR,SAAY,qBACZ,QAAW,qBAEZ,S,qECrBIJ,E,MAA0B,GAA4B,KAE1DA,EAAwBC,KAAK,CAACC,EAAOC,GAAI,mIAAoI,KAE7KH,EAAwBI,OAAS,CAChC,cAAe,yBAEhB,S","sources":["webpack:///./src/shared/getFlowOrActivityIcon.ts","webpack:///./src/chat-stream/HumanInTheLoop/HumanInTheLoop.module.css","webpack:///./src/shared/PlanProgress/PlanProgress.module.css","webpack:///./src/chat-stream/UserMessage/UserMessage.module.css","webpack:///./src/chat-stream/AssistantMessage/AssistantMessage.module.css","webpack:///./src/chat-stream/i18n.ts","webpack:///./src/chat-stream/NodeChunk/NodeChunk.module.css","webpack:///./src/chat-stream/useConversationStream.ts","webpack:///./src/chat-stream/UserMessage/UserMessage.module.css?84b2","webpack:///./src/chat-stream/UserMessage/UserMessage.tsx","webpack:///./src/chat-stream/AssistantMessage/AssistantMessage.module.css?a84b","webpack:///./src/chat-stream/NodeChunk/NodeChunk.module.css?1c0e","webpack:///./src/chat-stream/NodeView/NodeView.module.css?3001","webpack:///./src/chat-stream/NodeView/NodeView.tsx","webpack:///./src/chat-stream/StreamContext.ts","webpack:///./src/chat-stream/NodeChunk/getStateDisplay.ts","webpack:///./src/chat-stream/NodeChunk/NodeJob.tsx","webpack:///./src/chat-stream/NodeChunk/NodeChunk.tsx","webpack:///./src/chat-stream/HumanInTheLoop/HumanInTheLoop.module.css?e637","webpack:///./src/chat-stream/HumanInTheLoop/HumanInTheLoop.tsx","webpack:///./src/chat-stream/AssistantMessage/AssistantMessage.tsx","webpack:///./src/chat-stream/Aside/Aside.module.css?0aa1","webpack:///./src/chat-stream/Aside/FlowApp/FlowApp.module.css?5832","webpack:///./src/chat-stream/Aside/FlowApp/i18n.ts","webpack:///./src/chat-stream/useAutoScroll.ts","webpack:///./src/chat-stream/ScrollDownButton.module.css?e644","webpack:///./src/chat-stream/Aside/FlowApp/FlowApp.tsx","webpack:///./src/chat-stream/Aside/Aside.tsx","webpack:///./src/chat-stream/styles.module.css?c00e","webpack:///./src/shared/PlanProgress/PlanProgress.module.css?ebff","webpack:///./src/shared/PlanProgress/i18n.ts","webpack:///./src/shared/PlanProgress/PlanProgress.tsx","webpack:///./src/chat-stream/ChatStream.tsx","webpack:///./src/shared/useServiceFlowPlan.ts","webpack:///./src/chat-stream/NodeView/NodeView.module.css","webpack:///./src/chat-stream/styles.module.css","webpack:///./src/chat-stream/Aside/Aside.module.css","webpack:///./src/chat-stream/Aside/FlowApp/FlowApp.module.css","webpack:///./src/chat-stream/ScrollDownButton.module.css"],"sourcesContent":["import type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport type { ConversationState, JobState, TaskState } from \"./interfaces\";\n\nexport function getFlowOrActivityIcon(\n state: TaskState | JobState | ConversationState | undefined\n): GeneralIconProps {\n switch (state) {\n case \"input-required\":\n return { lib: \"antd\", theme: \"filled\", icon: \"pause-circle\" };\n case \"completed\":\n return { lib: \"antd\", theme: \"filled\", icon: \"check-circle\" };\n case \"failed\":\n return { lib: \"antd\", theme: \"filled\", icon: \"close-circle\" };\n case \"terminated\":\n return { lib: \"antd\", theme: \"filled\", icon: \"stop\" };\n case \"working\":\n return { lib: \"antd\", icon: \"loading-3-quarters\", spinning: true };\n default:\n return { lib: \"antd\", theme: \"filled\", icon: \"clock-circle\" };\n }\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.hil--e3zZFYQc{background:rgba(255,255,255,0.5);border-radius:8px;border:1px solid #ffffff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:13px 16px;margin-top:12px}.content--tmVj790o,\n.actions--wbNFKF3J{display:flex;align-items:center}.content--tmVj790o{gap:10px;flex-wrap:wrap}.actions--wbNFKF3J{justify-content:flex-end;margin-top:-3px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"hil\": `hil--e3zZFYQc`,\n\t\"content\": `content--tmVj790o`,\n\t\"actions\": `actions--wbNFKF3J`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.progress--lx8TY1CA{margin-bottom:10px;position:relative}.bar--ApxcfDGj,\n.details--YLrChHBK{background:rgba(255,255,255,0.6);border:1px solid rgba(255,255,255,0.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.bar--ApxcfDGj{cursor:pointer;display:flex;align-items:center;height:32px;box-shadow:0px 2px 6px 0px rgba(0,0,0,0.04);border-radius:16px;font-size:12px;padding:0 14px}.icon--tQcIUG1N{margin-right:6px;width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:linear-gradient(222deg,#abaab7 25%,#fff 75%);color:#4e4d56;font-size:10px;text-shadow:0px 1px 1px #fff}.progress--lx8TY1CA.completed--CRSVMXSS .icon--tQcIUG1N{background:linear-gradient(222deg,#16c661 25%,#fff 75%);color:#055527}.progress--lx8TY1CA.failed--uYq638ML .icon--tQcIUG1N{background:linear-gradient(222deg,#f24c25 25%,#fff 75%);color:#5b1504}.progress--lx8TY1CA.working--vSiJEm6I .icon--tQcIUG1N{background:linear-gradient(222deg,#3e56ff 25%,#fff 75%);color:#0c165d}.progress--lx8TY1CA.input-required--fub8PAf3 .icon--tQcIUG1N{background:linear-gradient(222deg,#12aacc 25%,#fff 75%);color:#0c353e}.progress--lx8TY1CA.canceled--Ew8Xed4m .icon--tQcIUG1N{background:linear-gradient(222deg,#fcaa07 25%,#fff 75%);color:#302206}.text--xtCVQl6G,\n.name--GCO4oNl4{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0;flex:1}.stat--vXcz2KIB{margin-left:6px}.expand--euAPifdF{margin-left:6px}.stat--vXcz2KIB,\n.expand--euAPifdF{color:rgba(0,0,0,0.45)}.details--YLrChHBK{position:absolute;left:0;right:0;bottom:40px;box-shadow:0px 3px 6px -4px rgba(0,0,0,0.12);border-radius:12px;list-style:none;margin:0;padding:20px;cursor:auto}.step--WdWDE_I7{--state-color:initial;display:flex;align-items:center;color:var(--state-color,var(--text-color-secondary))}.name--GCO4oNl4{color:var(--state-color,#262626)}.step--WdWDE_I7:not(:last-child){margin-bottom:16px}.step--WdWDE_I7.completed--CRSVMXSS{--state-color:var(--color-success)}.step--WdWDE_I7.failed--uYq638ML{--state-color:var(--color-error)}.step--WdWDE_I7.working--vSiJEm6I{--state-color:var(--color-info)}.step--WdWDE_I7.input-required--fub8PAf3{--state-color:var(--palette-cyan-7)}.step--WdWDE_I7.canceled--Ew8Xed4m{--state-color:#fcaa07}.state--Flb6ddfB{margin-right:10px}.mask--nL2DoW2Q{position:fixed;top:0;right:0;bottom:0;left:0}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"progress\": `progress--lx8TY1CA`,\n\t\"bar\": `bar--ApxcfDGj`,\n\t\"details\": `details--YLrChHBK`,\n\t\"icon\": `icon--tQcIUG1N`,\n\t\"completed\": `completed--CRSVMXSS`,\n\t\"failed\": `failed--uYq638ML`,\n\t\"working\": `working--vSiJEm6I`,\n\t\"input-required\": `input-required--fub8PAf3`,\n\t\"canceled\": `canceled--Ew8Xed4m`,\n\t\"text\": `text--xtCVQl6G`,\n\t\"name\": `name--GCO4oNl4`,\n\t\"stat\": `stat--vXcz2KIB`,\n\t\"expand\": `expand--euAPifdF`,\n\t\"step\": `step--WdWDE_I7`,\n\t\"state\": `state--Flb6ddfB`,\n\t\"mask\": `mask--nL2DoW2Q`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.user--HjXM9OHW{background:rgba(255,255,255,0.6);border-radius:24px;padding:8px 16px;width:-moz-fit-content;width:fit-content;max-width:500px;margin-left:auto;overflow-wrap:break-word;white-space:pre-wrap;font-size:16px;line-height:26px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"user\": `user--HjXM9OHW`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.assistant--CrlgPgYL{display:flex}.body--sAIo2dhL{flex:1;min-width:0;padding:3px 0 3px 16px}.texting--Rpmsbpca{position:relative}.texting--Rpmsbpca::after{content:\" \";animation:texting--Rpmsbpca 2s infinite;white-space:pre}.avatar--jaJhEiSV{font-size:32px}@keyframes texting--Rpmsbpca{0%{content:\"\\\\00a0\\\\00a0\\\\00a0\"}25%{content:\".\\\\00a0\\\\00a0\"}50%{content:\"..\\\\00a0\"}75%{content:\"...\"}100%{content:\"\\\\00a0\\\\00a0\\\\00a0\"}}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"assistant\": `assistant--CrlgPgYL`,\n\t\"body\": `body--sAIo2dhL`,\n\t\"texting\": `texting--Rpmsbpca`,\n\t\"avatar\": `avatar--jaJhEiSV`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n SWITCH_TO_CANVAS = \"SWITCH_TO_CANVAS\",\n INITIATING_SERVICE_FLOW = \"INITIATING_SERVICE_FLOW\",\n STARTING_SERVICE_FLOW_ACTIVITY = \"STARTING_SERVICE_FLOW_ACTIVITY\",\n HIL_TIPS = \"HIL_TIPS\",\n}\n\nconst en: Locale = {\n SWITCH_TO_CANVAS: \"Switch to canvas\",\n INITIATING_SERVICE_FLOW: \"Initiating service flow: {{ name }}\",\n STARTING_SERVICE_FLOW_ACTIVITY: \"Starting service flow activity: {{ name }}\",\n HIL_TIPS: \"Triggered HIL rule, waiting for {{ name }} to process.\",\n};\n\nconst zh: Locale = {\n SWITCH_TO_CANVAS: \"切换为画布\",\n INITIATING_SERVICE_FLOW: \"发起业务流:{{ name }}\",\n STARTING_SERVICE_FLOW_ACTIVITY: \"开始业务流活动:{{ name }}\",\n HIL_TIPS: \"触发 HIL 规则,等待 {{ name }} 处理。\",\n};\n\nexport const NS = \"bricks/ai-portal/chat-stream\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.heading--lj5kJ2fg{display:flex;align-items:center;padding:5px 8px;margin:0 -8px 12px;cursor:pointer}.main--P8894aNV{font-size:16px;line-height:26px}.caret--XqX6mjyf{opacity:0;transition:transform 0.2s ease-in-out}.heading--lj5kJ2fg:hover{background:rgba(184,187,205,0.15);border-radius:8px}.heading--lj5kJ2fg:hover .caret--XqX6mjyf{opacity:1}.icon--l8SzaFlV{display:flex;align-items:center;margin-right:12px}.title--FZPCnJbE{color:#262626;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool--ugqSpeIM{background:#e2e5ef;border:1px solid #d4d4de;border-radius:13px;line-height:24px;padding:0 12px;width:-moz-fit-content;width:fit-content;font-size:12px;color:rgba(0,0,0,0.65);cursor:pointer;display:flex;align-items:center;gap:7px;margin-bottom:12px}.tool--ugqSpeIM eo-icon{font-size:14px;color:#8c8c8c}.body--p3Zt_jA4{margin-bottom:20px}.heading--lj5kJ2fg + .body--p3Zt_jA4{padding-left:26px}.collapsed--cGSG2zk_ .body--p3Zt_jA4{display:none}.collapsed--cGSG2zk_ .caret--XqX6mjyf{transform:rotate(180deg);opacity:1}.content--pBkkWQ5e{margin-top:14px}.content--pBkkWQ5e .markdown--Ky2J85cs [class*=\"code-wrapper--\"]::part(mermaid){background:rgba(255,255,255,0.6);border-radius:8px;border:1px solid rgba(0,0,0,0.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px;min-width:var(--cruise-canvas-node-width-medium);width:auto;max-width:100%}.content--pBkkWQ5e:empty{display:none}.message--okEUzWzg:first-child > .message-part--kxjYnHz0:first-child > :first-child{margin-top:0}.icon--l8SzaFlV{color:#abaab7}.completed--JWq7E1Jw .icon--l8SzaFlV{color:#0fbe59}.failed--uk7jDD7K .icon--l8SzaFlV{color:#f24c25}.working--dZiN0y04 .icon--l8SzaFlV{color:var(--elevo-color-brand)}.input-required--JSuPr8br .icon--l8SzaFlV{color:#12aacc}.canceled--LyMjPJQd .icon--l8SzaFlV{color:#fcaa07}ai-portal\\\\.chat-stream[hide-mermaid] .content--pBkkWQ5e .markdown--Ky2J85cs .mermaid{display:none}.error--n_Of3DwP{color:var(--color-error);white-space:pre-wrap;word-break:break-word}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"heading\": `heading--lj5kJ2fg`,\n\t\"main\": `main--P8894aNV`,\n\t\"caret\": `caret--XqX6mjyf`,\n\t\"icon\": `icon--l8SzaFlV`,\n\t\"title\": `title--FZPCnJbE`,\n\t\"tool\": `tool--ugqSpeIM`,\n\t\"body\": `body--p3Zt_jA4`,\n\t\"collapsed\": `collapsed--cGSG2zk_`,\n\t\"content\": `content--pBkkWQ5e`,\n\t\"markdown\": `markdown--Ky2J85cs`,\n\t\"message\": `message--okEUzWzg`,\n\t\"message-part\": `message-part--kxjYnHz0`,\n\t\"completed\": `completed--JWq7E1Jw`,\n\t\"failed\": `failed--uk7jDD7K`,\n\t\"working\": `working--dZiN0y04`,\n\t\"input-required\": `input-required--JSuPr8br`,\n\t\"canceled\": `canceled--LyMjPJQd`,\n\t\"error\": `error--n_Of3DwP`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","import { useMemo } from \"react\";\nimport type { ChatMessage, MessageFromAssistant } from \"./interfaces.js\";\nimport type {\n ActiveDetail,\n ActivityWithFlow,\n ConversationError,\n ConversationState,\n ServiceFlowRun,\n Task,\n TaskState,\n} from \"../shared/interfaces.js\";\nimport { getFlatChunks } from \"../shared/getFlatChunks.js\";\nimport { DONE_STATES } from \"../shared/constants.js\";\n\nexport function useConversationStream(\n conversationAvailable: boolean,\n state: ConversationState | TaskState | undefined,\n tasks: Task[],\n errors: ConversationError[],\n flowMap?: Map<string, ServiceFlowRun>,\n activityMap?: Map<string, ActivityWithFlow>,\n options?: {\n showHumanActions?: boolean;\n skipActivitySubTasks?: boolean;\n }\n) {\n const showHumanActions = options?.showHumanActions;\n const skipActivitySubTasks = options?.skipActivitySubTasks;\n\n return useMemo(() => {\n if (!conversationAvailable) {\n return {\n messages: [],\n lastDetail: null,\n };\n }\n\n const { chunks, jobMap } = getFlatChunks(\n tasks,\n errors,\n flowMap,\n activityMap,\n skipActivitySubTasks\n );\n const messages: ChatMessage[] = [];\n\n let prevAssistantMessage: MessageFromAssistant = {\n role: \"assistant\",\n chunks: [],\n };\n let lastDetail: ActiveDetail | null = null;\n for (const chunk of chunks) {\n if (chunk.type === \"job\") {\n const job = chunk.job;\n if (job.toolCall && !job.ignoreDetails) {\n lastDetail = {\n type: \"job\",\n id: job.id,\n };\n }\n\n if (\n job.state === \"completed\" &&\n job.messages?.length &&\n job.messages.every((msg) => msg.role === \"user\")\n ) {\n if (prevAssistantMessage.chunks.length > 0) {\n messages.push(prevAssistantMessage);\n }\n messages.push({\n role: \"user\",\n content: job.messages\n .flatMap((msg) =>\n msg.parts.map((part) => (part.type === \"text\" ? part.text : \"\"))\n )\n .join(\"\"),\n cmd: job.cmd,\n mentionedAiEmployeeId: job.mentionedAiEmployeeId,\n fromSkippedSubTask: chunk.fromSkippedSubTask,\n files: job.messages\n ?.filter((msg) => msg.role === \"user\")\n .flatMap((msg) => msg.parts)\n .filter((part) => part.type === \"file\")\n .map((part) => part.file),\n });\n prevAssistantMessage = {\n role: \"assistant\",\n chunks: [],\n };\n } else {\n prevAssistantMessage.chunks.push(chunk);\n }\n\n if (job.humanAction) {\n if (prevAssistantMessage.chunks.length > 0) {\n messages.push(prevAssistantMessage);\n }\n if (showHumanActions) {\n messages.push({\n role: \"user\",\n content: job.humanAction,\n });\n }\n prevAssistantMessage = {\n role: \"assistant\",\n chunks: [],\n };\n }\n } else {\n prevAssistantMessage.chunks.push(chunk);\n if (chunk.type !== \"error\") {\n lastDetail = {\n type: chunk.type,\n id: chunk.task.id,\n };\n }\n }\n }\n\n let shouldAppendEmptyMessage =\n messages.length > 0 && !DONE_STATES.includes(state);\n if (\n shouldAppendEmptyMessage &&\n prevAssistantMessage.role === \"assistant\" &&\n prevAssistantMessage.chunks.length === 0\n ) {\n const lastMessage = messages[messages.length - 1];\n if (lastMessage.role === \"user\" && lastMessage.fromSkippedSubTask) {\n shouldAppendEmptyMessage = false;\n }\n }\n\n if (prevAssistantMessage.chunks.length > 0 || shouldAppendEmptyMessage) {\n messages.push(prevAssistantMessage);\n }\n\n return { messages, jobMap, lastDetail };\n }, [\n conversationAvailable,\n state,\n tasks,\n flowMap,\n activityMap,\n errors,\n showHumanActions,\n skipActivitySubTasks,\n ]);\n}\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./UserMessage.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./UserMessage.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React from \"react\";\nimport styles from \"./UserMessage.module.css\";\nimport type { CommandPayload, FileInfo } from \"../../shared/interfaces\";\nimport { ReadableCommand } from \"../../shared/ReadableCommand/ReadableCommand\";\nimport { FileList } from \"../../shared/FilePreview/FileList\";\n\nexport interface UserMessageProps {\n content: string;\n cmd?: CommandPayload;\n mentionedAiEmployeeId?: string;\n files?: FileInfo[];\n}\n\nexport function UserMessage({\n content,\n cmd,\n mentionedAiEmployeeId,\n files,\n}: UserMessageProps) {\n return (\n <>\n <div className={styles.user}>\n {(cmd || mentionedAiEmployeeId) && (\n <ReadableCommand\n cmd={cmd}\n mentionedAiEmployeeId={mentionedAiEmployeeId}\n />\n )}\n {content}\n </div>\n {files?.length ? <FileList files={files} ui=\"chat\" /> : null}\n </>\n );\n}\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./AssistantMessage.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./AssistantMessage.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./NodeChunk.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./NodeChunk.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./NodeView.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./NodeView.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","// istanbul ignore file: experimental\nimport React, { useCallback, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { CreatedView } from \"../../shared/CreatedView/CreatedView\";\nimport type { Job } from \"../../shared/interfaces\";\nimport styles from \"./NodeView.module.css\";\n\nexport interface NodeViewProps {\n job: Job;\n}\n\nexport function NodeView({ job }: NodeViewProps): JSX.Element {\n const [size, setSize] = useState<\"medium\" | \"large\">(\"medium\");\n\n const handleSizeChange = useCallback((value: \"medium\" | \"large\") => {\n setSize(value);\n }, []);\n\n return (\n <div\n className={classNames(styles.view, {\n [styles.large]: size === \"large\",\n })}\n >\n <CreatedView job={job} onSizeChange={handleSizeChange} />\n </div>\n );\n}\n","import { createContext, type Dispatch } from \"react\";\nimport type { ActiveDetail } from \"../shared/interfaces\";\n\nexport interface StreamContextValue {\n lastDetail: ActiveDetail | null;\n setUserClosedAside: Dispatch<React.SetStateAction<boolean>>;\n}\n\nexport const StreamContext = createContext<StreamContextValue>({\n lastDetail: null,\n setUserClosedAside: () => {},\n});\n","import type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport type {\n ConversationState,\n JobState,\n TaskState,\n} from \"../../shared/interfaces\";\nimport styles from \"./NodeChunk.module.css\";\n\nexport function getStateDisplay(\n state: JobState | TaskState | undefined,\n conversationState: ConversationState | undefined\n): {\n className?: string;\n icon: GeneralIconProps;\n} {\n switch (state) {\n case \"completed\":\n return {\n className: styles.completed,\n icon: {\n lib: \"antd\",\n theme: \"filled\",\n icon: \"check-circle\",\n },\n };\n case \"submitted\":\n case \"working\":\n if (conversationState === \"terminated\") {\n return {\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-stop\",\n },\n };\n }\n return {\n className: styles.working,\n icon: {\n lib: \"antd\",\n theme: \"outlined\",\n icon: \"loading-3-quarters\",\n spinning: true,\n },\n };\n case \"input-required\":\n return {\n className: styles[\"input-required\"],\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-user\",\n },\n };\n case \"failed\":\n return {\n className: styles.failed,\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"xmark\",\n },\n };\n case \"canceled\":\n case \"terminated\" as JobState:\n return {\n className: styles.canceled,\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-stop\",\n },\n };\n case \"skipped\":\n return {\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"ban\",\n },\n };\n default:\n return {\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"clock\",\n },\n };\n }\n}\n","import React, { useContext, useMemo, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { isEqual } from \"lodash\";\nimport type { CmdbInstanceDetailData } from \"../../cruise-canvas/interfaces.js\";\nimport styles from \"./NodeChunk.module.css\";\nimport sharedStyles from \"../../cruise-canvas/shared.module.css\";\nimport { WrappedIcon } from \"../../shared/bricks.js\";\nimport { EnhancedMarkdown } from \"../../cruise-canvas/EnhancedMarkdown/EnhancedMarkdown.js\";\nimport { CmdbInstanceDetail } from \"../../cruise-canvas/CmdbInstanceDetail/CmdbInstanceDetail.js\";\nimport { NodeView } from \"../NodeView/NodeView.js\";\nimport { TaskContext } from \"../../shared/TaskContext.js\";\nimport { StreamContext } from \"../StreamContext.js\";\nimport type { ActiveDetail, FileInfo, Job } from \"../../shared/interfaces.js\";\nimport { getStateDisplay } from \"./getStateDisplay.js\";\nimport { ICON_UP } from \"../../shared/constants.js\";\nimport { FileList } from \"../../shared/FilePreview/FileList.js\";\n\nexport interface NodeJobProps {\n job: Job;\n isSubTask?: boolean;\n}\n\nexport function NodeJob({ job, isSubTask }: NodeJobProps) {\n const toolCall = job.toolCall;\n const toolTitle = toolCall?.annotations?.title || toolCall?.name;\n const toolName = toolCall?.name;\n const showToolCall = !!toolCall;\n const { conversationState, setActiveDetail, setSubActiveDetail } =\n useContext(TaskContext);\n const { lastDetail, setUserClosedAside } = useContext(StreamContext);\n\n const { className, icon } = useMemo(() => {\n return getStateDisplay(job.state, conversationState);\n }, [job.state, conversationState]);\n\n const [toolMarkdownContent, cmdbInstanceDetails, files] = useMemo(() => {\n const contents: string[] = [];\n const instanceDetails: CmdbInstanceDetailData[] = [];\n const files: FileInfo[] = [];\n let large = toolName === \"llm_answer\";\n job.messages?.forEach((message) => {\n if (message.role === \"tool\") {\n for (const part of message.parts) {\n if (part.type === \"data\") {\n switch (part.data?.type) {\n case \"markdown\":\n contents.push(part.data.content);\n break;\n case \"cmdb_instance_detail\":\n instanceDetails.push(part.data as CmdbInstanceDetailData);\n if (!large) {\n large =\n Object.keys(\n part.data?.outputSchema?.type === \"object\"\n ? part.data.outputSchema.properties\n : part.data.detail\n ).length > 6;\n }\n break;\n }\n } else if (part.type === \"file\") {\n files.push(part.file);\n }\n }\n }\n });\n\n const markdownContent = contents.join(\"\");\n\n return [markdownContent, instanceDetails, files] as const;\n }, [job.messages, toolName]);\n\n const [collapsed, setCollapsed] = useState(false);\n const showHeading = showToolCall || !!job.instruction;\n\n return (\n <div className={classNames({ [styles.collapsed]: collapsed })}>\n {showHeading && (\n <div\n className={classNames(styles.heading, className)}\n onClick={() => setCollapsed((prev) => !prev)}\n >\n <div className={styles.icon}>\n <WrappedIcon {...icon} />\n </div>\n <div className={styles.title}>{job.instruction || toolTitle}</div>\n <WrappedIcon className={styles.caret} {...ICON_UP} />\n </div>\n )}\n <div className={styles.body}>\n {showToolCall && (\n <div\n className={styles.tool}\n onClick={() => {\n const detail: ActiveDetail = {\n type: \"job\",\n id: job.id,\n };\n (isSubTask ? setSubActiveDetail : setActiveDetail)((prev) =>\n isEqual(prev, detail) ? prev : detail\n );\n if (isEqual(detail, lastDetail)) {\n setUserClosedAside(false);\n }\n }}\n >\n <WrappedIcon lib=\"lucide\" icon=\"square-chevron-right\" />\n {toolTitle}\n </div>\n )}\n <div className={styles.main}>\n {job.messages?.map((message, index) =>\n message.role === \"tool\" ? null : (\n <div\n key={index}\n className={classNames(styles.message, sharedStyles.markdown)}\n >\n {message.parts?.map((part, partIndex) => (\n <React.Fragment key={partIndex}>\n {part.type === \"text\" && (\n <EnhancedMarkdown\n className={classNames(\n styles[\"message-part\"],\n sharedStyles[\"markdown-wrapper\"]\n )}\n content={part.text}\n />\n )}\n </React.Fragment>\n ))}\n </div>\n )\n )}\n </div>\n <div className={styles.content}>\n {toolMarkdownContent && (\n <div className={classNames(styles.markdown, sharedStyles.markdown)}>\n <EnhancedMarkdown\n className={sharedStyles[\"markdown-wrapper\"]}\n content={toolMarkdownContent}\n />\n </div>\n )}\n {cmdbInstanceDetails.map((detail, index) => (\n <div key={index} className={styles.box}>\n <CmdbInstanceDetail {...detail} />\n </div>\n ))}\n {job.generatedView ? <NodeView job={job} /> : null}\n {files.length > 0 && <FileList files={files} />}\n </div>\n </div>\n </div>\n );\n}\n","import React, { useContext, useMemo, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { isEqual } from \"lodash\";\nimport styles from \"./NodeChunk.module.css\";\nimport type {\n MessageChunk,\n MessageChunkOfActivity,\n MessageChunkOfFlow,\n} from \"../interfaces.js\";\nimport { NodeJob } from \"./NodeJob.js\";\nimport { WrappedIcon } from \"../../shared/bricks\";\nimport { getStateDisplay } from \"./getStateDisplay.js\";\nimport { TaskContext } from \"../../shared/TaskContext\";\nimport { ICON_UP } from \"../../shared/constants\";\nimport { StreamContext } from \"../StreamContext\";\nimport { K, t } from \"../i18n\";\n\nexport interface NodeChunkProps {\n chunk: MessageChunk;\n isSubTask?: boolean;\n}\n\nexport function NodeChunk({ chunk, isSubTask }: NodeChunkProps) {\n if (chunk.type === \"job\") {\n return <NodeJob job={chunk.job} isSubTask={isSubTask} />;\n }\n\n if (chunk.type === \"error\") {\n return <div className={styles.error}>{chunk.error}</div>;\n }\n\n return <NodeTask chunk={chunk} isSubTask={isSubTask} />;\n}\n\ninterface NodeTaskProps {\n chunk: MessageChunkOfFlow | MessageChunkOfActivity;\n isSubTask?: boolean;\n}\n\nfunction NodeTask({ chunk, isSubTask }: NodeTaskProps) {\n const { conversationState, setActiveDetail, setSubActiveDetail } =\n useContext(TaskContext);\n const { setUserClosedAside, lastDetail } = useContext(StreamContext);\n const [collapsed, setCollapsed] = useState(false);\n const { type, task } = chunk;\n\n const { className, icon } = useMemo(() => {\n return getStateDisplay(\n chunk.type === \"flow\" ? \"completed\" : task.state,\n conversationState\n );\n }, [chunk.type, conversationState, task.state]);\n\n return (\n <div className={classNames({ [styles.collapsed]: collapsed })}>\n <div\n className={classNames(styles.heading, className)}\n onClick={() => setCollapsed((prev) => !prev)}\n >\n <div className={styles.icon}>\n <WrappedIcon {...icon} />\n </div>\n <div className={styles.title}>\n {type === \"flow\"\n ? t(K.INITIATING_SERVICE_FLOW, { name: chunk.flow.name })\n : t(K.STARTING_SERVICE_FLOW_ACTIVITY, {\n name: chunk.activity.name,\n })}\n </div>\n <WrappedIcon className={styles.caret} {...ICON_UP} />\n </div>\n <div className={styles.body}>\n <div\n className={styles.tool}\n onClick={() => {\n const detail = {\n type: chunk.type,\n id: chunk.task.id,\n };\n (isSubTask ? setSubActiveDetail : setActiveDetail)((prev) =>\n isEqual(prev, detail) ? prev : detail\n );\n if (isEqual(detail, lastDetail)) {\n setUserClosedAside(false);\n }\n }}\n >\n <WrappedIcon lib=\"lucide\" icon=\"route\" />\n {type === \"flow\"\n ? t(K.INITIATING_SERVICE_FLOW, { name: chunk.flow.name })\n : t(K.STARTING_SERVICE_FLOW_ACTIVITY, {\n name: chunk.activity.name,\n })}\n </div>\n </div>\n </div>\n );\n}\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./HumanInTheLoop.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./HumanInTheLoop.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React from \"react\";\nimport { WrappedIcon } from \"../../shared/bricks\";\nimport type { Job } from \"../../shared/interfaces\";\nimport styles from \"./HumanInTheLoop.module.css\";\nimport { RequestHumanAction } from \"../../shared/RequestHumanAction/RequestHumanAction\";\nimport { K, t } from \"../i18n\";\n\nexport interface HumanInTheLoopProps {\n job: Job;\n}\n\nexport function HumanInTheLoop({ job }: HumanInTheLoopProps) {\n return (\n <div className={styles.hil}>\n <div className={styles.content}>\n <WrappedIcon lib=\"antd\" icon=\"exclamation-circle\" />\n {t(K.HIL_TIPS, { name: job.hil!.username })}\n </div>\n {job.requestHumanAction && (\n <div className={styles.actions}>\n <RequestHumanAction action={job.requestHumanAction} ui=\"chat\" />\n </div>\n )}\n </div>\n );\n}\n","import React, { useMemo } from \"react\";\nimport styles from \"./AssistantMessage.module.css\";\nimport {\n GENERAL_DONE_STATES,\n NON_WORKING_STATES,\n} from \"../../shared/constants.js\";\nimport type {\n ConversationState,\n Job,\n JobState,\n TaskState,\n} from \"../../shared/interfaces.js\";\nimport { WrappedIcon } from \"../../shared/bricks.js\";\nimport type { MessageChunk } from \"../interfaces\";\nimport { RequestHumanAction } from \"../../shared/RequestHumanAction/RequestHumanAction\";\nimport { NodeChunk } from \"../NodeChunk/NodeChunk\";\nimport { HumanInTheLoop } from \"../HumanInTheLoop/HumanInTheLoop\";\n\nexport interface AssistantMessageProps {\n chunks: MessageChunk[];\n scopeState: ConversationState | TaskState | JobState | undefined;\n isLatest?: boolean;\n isSubTask?: boolean;\n}\n\nexport function AssistantMessage({\n chunks,\n scopeState,\n isLatest,\n isSubTask,\n}: AssistantMessageProps) {\n const [working, lastJob] = useMemo(() => {\n const lastChunk = chunks[chunks.length - 1];\n let lastJob: Job | undefined;\n if (lastChunk) {\n switch (lastChunk.type) {\n case \"flow\":\n case \"activity\":\n lastJob = lastChunk.task.jobs[lastChunk.task.jobs.length - 1];\n break;\n case \"job\":\n lastJob = lastChunk.job;\n break;\n default:\n return [false, undefined];\n }\n }\n\n if (!isLatest || NON_WORKING_STATES.includes(scopeState!)) {\n return [false, lastJob];\n }\n for (const chunk of chunks) {\n switch (chunk.type) {\n case \"flow\":\n case \"activity\":\n if (chunk.task.jobs.some((job) => job.state === \"input-required\")) {\n return [false, lastJob];\n }\n break;\n case \"job\":\n if (chunk.job.state === \"input-required\") {\n return [false, lastJob];\n }\n }\n }\n if (lastJob && lastJob.state === \"working\" && lastJob.toolCall) {\n return [false, lastJob];\n }\n\n return [true, lastJob];\n }, [isLatest, chunks, scopeState]);\n\n return (\n <div className={styles.assistant}>\n <WrappedIcon\n lib=\"easyops\"\n category=\"image\"\n icon=\"elevo-avatar-png\"\n className={styles.avatar}\n />\n <div className={styles.body}>\n {chunks.map((chunk, index) => (\n <NodeChunk key={index} chunk={chunk} isSubTask={isSubTask} />\n ))}\n {working && <div className={styles.texting}></div>}\n {isLatest &&\n lastJob &&\n !GENERAL_DONE_STATES.includes(scopeState) &&\n (lastJob.state === \"working\" || lastJob.state === \"input-required\") &&\n !lastJob.humanAction &&\n (lastJob.hil ? (\n <HumanInTheLoop job={lastJob} />\n ) : (\n lastJob.requestHumanAction && (\n <RequestHumanAction\n action={lastJob.requestHumanAction}\n ui=\"chat\"\n />\n )\n ))}\n </div>\n </div>\n );\n}\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./Aside.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./Aside.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./FlowApp.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./FlowApp.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n WAITING = \"WAITING\",\n EXECUTING = \"EXECUTING\",\n PAUSED = \"PAUSED\",\n SUCCEEDED = \"SUCCEEDED\",\n FAILED = \"FAILED\",\n TERMINATED = \"TERMINATED\",\n}\n\nconst en: Locale = {\n WAITING: \"Waiting\",\n EXECUTING: \"Executing\",\n PAUSED: \"Paused\",\n SUCCEEDED: \"Succeeded\",\n FAILED: \"Failed\",\n TERMINATED: \"Terminated\",\n};\n\nconst zh: Locale = {\n WAITING: \"等待中\",\n EXECUTING: \"执行中\",\n PAUSED: \"暂停\",\n SUCCEEDED: \"成功\",\n FAILED: \"失败\",\n TERMINATED: \"已终止\",\n};\n\nexport const NS = \"bricks/ai-portal/FlowApp\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","import {\n useCallback,\n useEffect,\n useRef,\n useState,\n type RefObject,\n} from \"react\";\nimport ResizeObserver from \"resize-observer-polyfill\";\n\nexport function useAutoScroll(\n conversationAvailable: boolean,\n scrollContainerRef: RefObject<HTMLDivElement>,\n scrollContentRef: RefObject<HTMLDivElement>\n) {\n const detectScrolledUpRef = useRef(false);\n const manualScrolledRef = useRef(false);\n const [scrollable, setScrollable] = useState(false);\n\n useEffect(() => {\n const scrollContainer = scrollContainerRef.current;\n const contentContainer = scrollContentRef.current;\n if (manualScrolledRef.current || !scrollContainer || !contentContainer) {\n return;\n }\n\n const handleScroll = () => {\n setScrollable(\n scrollContainer.scrollTop + scrollContainer.clientHeight! + 24 <\n scrollContainer.scrollHeight\n );\n if (!detectScrolledUpRef.current) {\n return;\n }\n manualScrolledRef.current =\n scrollContainer.scrollTop + scrollContainer.clientHeight! + 6 <\n scrollContainer.scrollHeight;\n };\n scrollContainer.addEventListener(\"scroll\", handleScroll);\n\n let timer: ReturnType<typeof setTimeout>;\n const observer = new ResizeObserver(() => {\n if (manualScrolledRef.current) {\n return;\n }\n detectScrolledUpRef.current = false;\n // Scroll to the bottom of the content container\n scrollContainer.scrollTo({\n top: contentContainer.scrollHeight,\n behavior: \"instant\",\n });\n clearTimeout(timer);\n timer = setTimeout(() => {\n detectScrolledUpRef.current = true;\n }, 100);\n });\n observer.observe(contentContainer);\n\n return () => {\n observer.disconnect();\n scrollContainer.removeEventListener(\"scroll\", handleScroll);\n };\n // Auto scroll after the conversation becomes available\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [conversationAvailable]);\n\n const scrollToBottom = useCallback(() => {\n const scrollContainer = scrollContainerRef.current;\n scrollContainer?.scrollTo({\n top: scrollContainer?.scrollHeight,\n behavior: \"instant\",\n });\n }, [scrollContainerRef]);\n\n return { scrollable, scrollToBottom };\n}\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./ScrollDownButton.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./ScrollDownButton.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useContext, useMemo, useRef } from \"react\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport classNames from \"classnames\";\nimport styles from \"./FlowApp.module.css\";\nimport {\n WrappedBlankState,\n WrappedIcon,\n WrappedRunningFlow,\n} from \"../../../shared/bricks\";\nimport { getFlowOrActivityIcon } from \"../../../shared/getFlowOrActivityIcon\";\nimport type {\n ActivityRun,\n ConversationState,\n JobState,\n ServiceFlowRun,\n TaskState,\n} from \"../../../shared/interfaces\";\nimport { TaskContext } from \"../../../shared/TaskContext\";\nimport { K, locales, NS, t } from \"./i18n\";\nimport { useConversationStream } from \"../../useConversationStream\";\nimport { UserMessage } from \"../../UserMessage/UserMessage\";\nimport { AssistantMessage } from \"../../AssistantMessage/AssistantMessage\";\nimport { useAutoScroll } from \"../../useAutoScroll\";\nimport scrollStyles from \"../../ScrollDownButton.module.css\";\nimport floatingStyles from \"../../../shared/FloatingButton.module.css\";\n\ninitializeI18n(NS, locales);\n\nexport interface FlowAppProps {\n flow: ServiceFlowRun;\n activity?: ActivityRun;\n}\n\nexport function FlowApp({ flow, activity }: FlowAppProps) {\n const { tasks, setActiveDetail } = useContext(TaskContext);\n const flowTask = useMemo(() => {\n return tasks.find((t) => t.id === flow.taskId)!;\n }, [tasks, flow.taskId]);\n\n const runningSpec = useMemo(() => {\n return flow.spec.map((stage) => ({\n ...stage,\n serviceFlowActivities: stage.serviceFlowActivities?.map((activity) => {\n const task = tasks.find((t) => t.id === activity.taskId);\n return {\n name: activity.name,\n taskId: activity.taskId,\n state: task?.state,\n startTime: task?.startTime,\n endTime: task?.endTime,\n };\n }),\n }));\n }, [flow.spec, tasks]);\n\n const flowStatus = useMemo(\n () => getFlowStatusDisplay(flowTask.state),\n [flowTask.state]\n );\n\n return (\n <div className={styles.app}>\n <div className={styles.heading}>\n <div className={styles.header}>\n <div className={classNames(styles.status, flowStatus.className)}>\n <WrappedIcon {...flowStatus.icon} />\n {flowStatus.text}\n </div>\n <div className={styles.title}>\n {`${flow.space?.name ? `${flow.space.name} / ` : \"\"}${flow.name}`}\n </div>\n </div>\n <div className={styles.chart}>\n <WrappedRunningFlow\n spec={runningSpec}\n activeActivityId={activity?.taskId}\n onActiveChange={(e) => {\n if (e.detail) {\n setActiveDetail({ type: \"activity\", id: e.detail });\n }\n }}\n />\n </div>\n </div>\n <div className={styles.body}>\n {activity ? (\n <ActivityDetail activity={activity} />\n ) : (\n <WrappedBlankState\n className={styles.blank}\n description=\"您还未选择活动\"\n illustration=\"serviceflows\"\n />\n )}\n </div>\n </div>\n );\n}\n\ninterface ActivityDetailProps {\n activity: ActivityRun;\n}\n\nfunction ActivityDetail({ activity }: ActivityDetailProps) {\n const { tasks, errors } = useContext(TaskContext);\n const activityTask = useMemo(() => {\n return tasks.find((t) => t.id === activity.taskId)!;\n }, [tasks, activity.taskId]);\n const activityState = activityTask.state;\n\n const { icon, className } = useMemo(\n () => getFlowStatusDisplay(activityState),\n [activityState]\n );\n\n const fixedTasks = useMemo(() => {\n return [\n {\n ...activityTask,\n parent: undefined,\n },\n ];\n }, [activityTask]);\n\n const { messages } = useConversationStream(\n true,\n activityTask.state,\n fixedTasks,\n errors\n );\n\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const scrollContentRef = useRef<HTMLDivElement>(null);\n\n const { scrollable, scrollToBottom } = useAutoScroll(\n true,\n scrollContainerRef,\n scrollContentRef\n );\n\n return (\n <>\n <div className={styles[\"activity-title\"]}>\n <WrappedIcon {...icon} className={className} />\n {activity.name}\n </div>\n <div className={styles.chat} ref={scrollContainerRef}>\n <div className={styles.messages} ref={scrollContentRef}>\n {messages.map((msg, index, list) => (\n <div className={styles.message} key={index}>\n {msg.role === \"user\" ? (\n <UserMessage\n content={msg.content}\n cmd={msg.cmd}\n files={msg.files}\n />\n ) : (\n <AssistantMessage\n chunks={msg.chunks}\n scopeState={activityTask.state}\n isLatest={index === list.length - 1}\n isSubTask\n />\n )}\n </div>\n ))}\n </div>\n </div>\n <button\n className={`${scrollStyles[\"scroll-down\"]} ${floatingStyles[\"floating-button\"]}`}\n style={{ bottom: \"30px\" }}\n hidden={!scrollable}\n onClick={scrollToBottom}\n >\n <WrappedIcon lib=\"antd\" icon=\"down\" />\n </button>\n </>\n );\n}\n\nfunction getFlowStatusDisplay(state: TaskState | JobState | ConversationState) {\n const icon = getFlowOrActivityIcon(state);\n let text: string;\n let className: string | undefined;\n\n switch (state) {\n case \"working\":\n text = t(K.EXECUTING);\n className = styles.working;\n break;\n case \"completed\":\n text = t(K.SUCCEEDED);\n className = styles.completed;\n break;\n case \"failed\":\n text = t(K.FAILED);\n className = styles.failed;\n break;\n case \"input-required\":\n text = t(K.PAUSED);\n className = styles.paused;\n break;\n case \"terminated\":\n text = t(K.TERMINATED);\n break;\n default:\n text = state ? t(K.EXECUTING) : t(K.WAITING);\n }\n\n return { icon, text, className };\n}\n","import React, { useContext, useMemo } from \"react\";\nimport classNames from \"classnames\";\nimport type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport styles from \"./Aside.module.css\";\nimport sharedStyles from \"../../cruise-canvas/shared.module.css\";\nimport { WrappedCodeBlock, WrappedIconButton } from \"../../shared/bricks\";\nimport type { CmdbInstanceDetailData } from \"../../cruise-canvas/interfaces\";\nimport { ToolCallStatus } from \"../../cruise-canvas/ToolCallStatus/ToolCallStatus\";\nimport { TaskContext } from \"../../shared/TaskContext\";\nimport { StreamContext } from \"../StreamContext\";\nimport type {\n ActiveDetailOfActivity,\n FileInfo,\n FulfilledActiveDetail,\n} from \"../../shared/interfaces\";\nimport { FlowApp } from \"./FlowApp/FlowApp\";\n\nconst ICON_SHRINK: GeneralIconProps = {\n lib: \"easyops\",\n icon: \"shrink\",\n};\n\nexport interface AsideProps {\n detail: FulfilledActiveDetail;\n isSubTask?: boolean;\n faded?: boolean;\n}\n\nexport function Aside({ detail, isSubTask, faded }: AsideProps) {\n const { setActiveDetail, setSubActiveDetail } = useContext(TaskContext);\n const { setUserClosedAside } = useContext(StreamContext);\n\n const [toolMarkdownContent, cmdbInstanceDetails /* , files */] =\n useMemo(() => {\n const contents: string[] = [];\n const instanceDetails: CmdbInstanceDetailData[] = [];\n const files: FileInfo[] = [];\n\n if (detail.type === \"job\") {\n detail.job.messages?.forEach((message) => {\n if (message.role === \"tool\") {\n for (const part of message.parts) {\n if (part.type === \"data\") {\n switch (part.data?.type) {\n case \"markdown\":\n contents.push(part.data.content);\n break;\n case \"cmdb_instance_detail\":\n instanceDetails.push(part.data as CmdbInstanceDetailData);\n break;\n }\n } else if (part.type === \"file\") {\n files.push(part.file);\n }\n }\n }\n });\n }\n\n const markdownContent = contents.join(\"\");\n\n return [markdownContent, instanceDetails, files] as const;\n }, [detail]);\n\n return (\n <div\n className={classNames(styles.aside, {\n [styles.sub]: isSubTask,\n [styles.faded]: faded,\n })}\n >\n <div className={styles.box}>\n <div className={styles.header}>\n <div className={styles.title}>Elevo&#39;s Computer</div>\n <WrappedIconButton\n icon={ICON_SHRINK}\n variant=\"mini\"\n onClick={() => {\n if (isSubTask) {\n setSubActiveDetail(null);\n } else {\n setActiveDetail(null);\n setUserClosedAside(true);\n }\n }}\n />\n </div>\n <div className={styles.body}>\n {detail.type === \"job\" ? (\n <>\n <ToolCallStatus job={detail.job} variant=\"read-only\" />\n {detail.job.generatedView ? (\n <EditorApp\n name=\"View\"\n source={detail.job.generatedView.code}\n language=\"jsx\"\n />\n ) : toolMarkdownContent ? (\n <EditorApp\n name=\"Content\"\n source={toolMarkdownContent}\n language=\"md\"\n />\n ) : cmdbInstanceDetails.length > 0 ? (\n <EditorApp\n name=\"CMDB\"\n source={JSON.stringify(cmdbInstanceDetails, null, 2)}\n language=\"json\"\n />\n ) : null}\n </>\n ) : (\n <FlowApp\n flow={detail.flow}\n activity={(detail as ActiveDetailOfActivity).activity}\n />\n )}\n </div>\n </div>\n </div>\n );\n}\n\ninterface EditorAppProps {\n name: string;\n source: string;\n language: string;\n}\n\nfunction EditorApp({ name, source, language }: EditorAppProps) {\n return (\n <div className={classNames(styles.app, styles.editor)}>\n <div className={styles.heading}>{`${name}.${language}`}</div>\n <div className={classNames(styles.content, sharedStyles.markdown)}>\n <div className={styles.scroller}>\n <WrappedCodeBlock\n className={styles[\"code-block\"]}\n source={source}\n language={language}\n themeVariant=\"elevo\"\n />\n </div>\n </div>\n </div>\n );\n}\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./styles.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./styles.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./PlanProgress.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./PlanProgress.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n PLAN_COMPLETED = \"PLAN_COMPLETED\",\n}\n\nconst en: Locale = {\n PLAN_COMPLETED: \"All tasks are completed\",\n};\n\nconst zh: Locale = {\n PLAN_COMPLETED: \"所有任务已全部完成\",\n};\n\nexport const NS = \"bricks/ai-portal/PlanProgress\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","// istanbul ignore file: experimental\nimport React, { useCallback, useMemo, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport styles from \"./PlanProgress.module.css\";\nimport type {\n ConversationState,\n JobState,\n PlanProgressStep,\n TaskState,\n} from \"../interfaces\";\nimport { WrappedIcon } from \"../../shared/bricks\";\nimport { K, locales, NS, t } from \"./i18n\";\n\ninitializeI18n(NS, locales);\n\nexport interface PlanProgressProps {\n plan: PlanProgressStep[];\n conversationState?: ConversationState;\n style?: React.CSSProperties;\n}\n\ninterface PlanProgressStat {\n doneCount: number;\n name: string;\n // `state` is undefined when it is not started.\n state: TaskState | undefined;\n}\n\nexport function PlanProgress({\n plan,\n conversationState,\n style,\n}: PlanProgressProps): JSX.Element | null {\n const [expanded, setExpanded] = useState(false);\n\n const { doneCount, state, name } = useMemo(() => {\n return plan.reduce<PlanProgressStat>(\n (acc, step) => {\n if (step.state === \"completed\") {\n return {\n ...acc,\n state: step.state,\n name: step.name,\n doneCount: acc.doneCount + 1,\n };\n } else if (!acc.name || step.state) {\n return {\n ...acc,\n state: step.state,\n name: step.name,\n };\n }\n return acc;\n },\n {\n doneCount: 0,\n name: \"\",\n state: undefined,\n }\n );\n }, [plan]);\n\n const { className, icon } = useMemo(() => {\n return getClassNameAndIconProps(state, conversationState);\n }, [state, conversationState]);\n\n const toggle = useCallback(() => {\n setExpanded((prev) => !prev);\n }, []);\n\n if (!plan?.length) {\n return null;\n }\n\n const allDone =\n doneCount === plan.length && conversationState === \"completed\";\n\n return (\n <>\n {expanded && <div className={styles.mask} onClick={toggle} />}\n <div className={classNames(styles.progress, className)} style={style}>\n <div className={styles.bar} onClick={toggle}>\n <div className={styles.icon}>\n <WrappedIcon {...icon} />\n </div>\n <span className={styles.text} title={allDone ? \"\" : name}>\n {allDone ? t(K.PLAN_COMPLETED) : name}\n </span>\n <span className={styles.stat}>\n {doneCount}/{plan.length}\n </span>\n <WrappedIcon\n className={styles.expand}\n lib=\"antd\"\n theme=\"outlined\"\n icon={expanded ? \"down\" : \"up\"}\n />\n </div>\n {expanded && (\n <ul className={styles.details}>\n {plan.map((step, index) => (\n <PlanProgressStep\n key={index}\n state={step.state}\n conversationState={conversationState}\n name={step.name}\n />\n ))}\n </ul>\n )}\n </div>\n </>\n );\n}\n\ninterface PlanStepProps {\n state?: TaskState;\n conversationState?: ConversationState;\n name: string;\n}\n\nfunction PlanProgressStep({ state, conversationState, name }: PlanStepProps) {\n const { className, icon } = useMemo(() => {\n return getClassNameAndIconProps(state, conversationState);\n }, [state, conversationState]);\n\n return (\n <li className={classNames(styles.step, className)}>\n <WrappedIcon {...icon} className={styles.state} />\n <span className={styles.name} title={name}>\n {name}\n </span>\n </li>\n );\n}\n\nfunction getClassNameAndIconProps(\n state: JobState | TaskState | ConversationState | undefined,\n conversationState?: JobState | TaskState | ConversationState\n) {\n switch (state) {\n case \"completed\":\n return {\n className: styles.completed,\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"check\",\n },\n };\n case \"submitted\":\n case \"working\":\n if (conversationState === \"terminated\") {\n return {\n className: undefined,\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-stop\",\n },\n };\n }\n return {\n className: styles.working,\n icon: {\n lib: \"antd\",\n theme: \"outlined\",\n icon: \"loading-3-quarters\",\n spinning: true,\n },\n };\n case \"input-required\":\n return {\n className: styles[\"input-required\"],\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-user\",\n },\n };\n case \"failed\":\n return {\n className: styles.failed,\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"xmark\",\n },\n };\n case \"canceled\":\n return {\n className: styles.canceled,\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-stop\",\n },\n };\n default:\n return {\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"clock\",\n },\n };\n }\n}\n","// istanbul ignore file: experimental\nimport React, {\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { getBasePath, getRuntime } from \"@next-core/runtime\";\nimport classNames from \"classnames\";\nimport { preloadHighlighter } from \"@next-shared/markdown\";\nimport { useConversationDetail } from \"../cruise-canvas/useConversationDetail.js\";\nimport { useConversationStream } from \"./useConversationStream.js\";\nimport { WrappedIcon, WrappedIconButton } from \"../shared/bricks.js\";\nimport { UserMessage } from \"./UserMessage/UserMessage.js\";\nimport { AssistantMessage } from \"./AssistantMessage/AssistantMessage.js\";\nimport { TaskContext } from \"../shared/TaskContext.js\";\nimport { ChatBox } from \"../shared/ChatBox/ChatBox.js\";\nimport { DONE_STATES, ICON_CANVAS } from \"../shared/constants.js\";\nimport { ExpandedView } from \"../shared/ExpandedView/ExpandedView.js\";\nimport { Aside } from \"./Aside/Aside.js\";\nimport { StreamContext } from \"./StreamContext.js\";\nimport type { FeedbackDetail } from \"../cruise-canvas/interfaces.js\";\nimport { NodeFeedback } from \"../shared/NodeFeedback/NodeFeedback.js\";\nimport type { ChatStreamProps, ChatStreamRef, ConversationDetail } from \".\";\nimport styles from \"./styles.module.css\";\nimport toolbarStyles from \"../cruise-canvas/toolbar.module.css\";\nimport { K, t } from \"./i18n.js\";\nimport { NodeReplay } from \"../cruise-canvas/NodeReplay/NodeReplay.js\";\nimport type {\n ActiveDetail,\n ActiveImages,\n ExtraChatPayload,\n FileInfo,\n} from \"../shared/interfaces.js\";\nimport { useFlowAndActivityMap } from \"../shared/useFlowAndActivityMap.js\";\nimport { useFulfilledActiveDetail } from \"../shared/useFulfilledActiveDetail.js\";\nimport { useAutoScroll } from \"./useAutoScroll.js\";\nimport scrollStyles from \"./ScrollDownButton.module.css\";\nimport floatingStyles from \"../shared/FloatingButton.module.css\";\nimport { PlanProgress } from \"../shared/PlanProgress/PlanProgress.js\";\nimport { useServiceFlowPlan } from \"../shared/useServiceFlowPlan.js\";\nimport { FilePreview } from \"../shared/FilePreview/FilePreview.js\";\nimport { ImagesPreview } from \"../shared/FilePreview/ImagesPreview.js\";\nimport { useHandleEscape } from \"../shared/useHandleEscape.js\";\n\ninterface ChatStreamComponentProps extends ChatStreamProps {\n conversationId: string;\n onShare: () => void;\n onTerminate: () => void;\n onSubmitFeedback: (detail: FeedbackDetail) => void;\n onSwitchToCanvas: () => void;\n onFeedbackOnView: (viewId: string) => void;\n onDetailChange: (detail: ConversationDetail) => void;\n onSplitChange: (split: boolean) => void;\n}\n\nexport function ChatStreamComponent(\n {\n conversationId,\n initialRequest,\n replay,\n replayDelay,\n supports,\n showHumanActions,\n showFeedback: propShowFeedback,\n showFeedbackAfterFailed,\n showFeedbackOnView,\n showUiSwitch,\n previewUrlTemplate,\n showCases,\n exampleProjects,\n tryItOutUrl,\n uploadOptions,\n onShare,\n onTerminate,\n onSubmitFeedback,\n onSwitchToCanvas,\n onFeedbackOnView,\n onDetailChange,\n onSplitChange,\n }: ChatStreamComponentProps,\n ref: React.Ref<ChatStreamRef>\n) {\n const {\n conversation,\n tasks,\n serviceFlows,\n errors,\n humanInputRef,\n skipToResults,\n watchAgain,\n } = useConversationDetail(\n conversationId,\n initialRequest,\n replay,\n replayDelay\n );\n const pageTitle = conversation?.title ?? \"\";\n const conversationState = conversation?.state;\n const conversationDone = DONE_STATES.includes(conversationState!);\n const canChat = conversationDone || conversationState === \"input-required\";\n const plan = useServiceFlowPlan(serviceFlows, tasks);\n const { flowMap, activityMap } = useFlowAndActivityMap(serviceFlows);\n const { messages, jobMap, lastDetail } = useConversationStream(\n !!conversation,\n conversation?.state,\n tasks,\n errors,\n flowMap,\n activityMap,\n { showHumanActions, skipActivitySubTasks: true }\n );\n\n useEffect(() => {\n onDetailChange({\n projectId: conversation?.projectId,\n });\n }, [onDetailChange, conversation?.projectId]);\n\n const views = useMemo(() => {\n if (!jobMap) {\n return [];\n }\n return [...jobMap.values()].flatMap((job) =>\n job.generatedView\n ? {\n id: job.id,\n view: job.generatedView,\n }\n : []\n );\n }, [jobMap]);\n\n const [submittingFeedback, setSubmittingFeedback] = useState(false);\n const [submittedFeedback, setSubmittedFeedback] = useState(false);\n const [showFeedback, setShowFeedback] = useState<boolean>(!!propShowFeedback);\n useEffect(() => {\n setShowFeedback(!!propShowFeedback);\n }, [propShowFeedback]);\n const [feedbackDoneViews, setFeedbackDoneViews] = useState<\n Set<string> | undefined\n >();\n\n const handleSubmitFeedback = useCallback(\n (detail: FeedbackDetail) => {\n setSubmittingFeedback(true);\n onSubmitFeedback(detail);\n },\n [onSubmitFeedback]\n );\n\n useImperativeHandle(\n ref,\n () => ({\n feedbackSubmitDone: () => {\n setSubmittedFeedback(true);\n setTimeout(() => {\n setShowFeedback(false);\n }, 3000);\n },\n feedbackSubmitFailed: () => {\n setSubmittingFeedback(false);\n },\n feedbackOnViewDone: (viewId: string) => {\n setFeedbackDoneViews((prev) => {\n const newSet = new Set(prev);\n newSet.add(viewId);\n return newSet;\n });\n },\n }),\n []\n );\n\n const [activeExpandedViewJobId, setActiveExpandedViewJobId] = useState<\n string | null\n >(null);\n\n const [activeDetail, setActiveDetail] = useState<ActiveDetail | null>(null);\n const [subActiveDetail, setSubActiveDetail] = useState<ActiveDetail | null>(\n null\n );\n const [userClosedAside, setUserClosedAside] = useState(false);\n const conversationAvailable = !!conversation;\n\n // Delay flag to prevent the aside from being auto-opened for a completed task\n const delayRef = useRef(false);\n useEffect(() => {\n if (conversationAvailable) {\n const timer = setTimeout(() => {\n delayRef.current = true;\n }, 1000);\n return () => {\n clearTimeout(timer);\n };\n }\n }, [conversationAvailable]);\n\n const hasInitialRequest = !!initialRequest;\n useEffect(() => {\n if (\n (delayRef.current || hasInitialRequest) &&\n lastDetail &&\n !userClosedAside\n ) {\n setActiveDetail(lastDetail);\n }\n }, [lastDetail, userClosedAside, hasInitialRequest]);\n\n useEffect(() => {\n getRuntime().applyPageTitle(pageTitle);\n }, [pageTitle]);\n\n const humanInput = useCallback(\n (input: string | null, action?: string, extra?: ExtraChatPayload) => {\n humanInputRef.current?.(input, action, extra);\n },\n [humanInputRef]\n );\n\n const firstMessage = messages[0];\n const userMessage = firstMessage?.role === \"user\" ? firstMessage : null;\n\n const [activeImages, setActiveImages] = useState<ActiveImages | null>(null);\n\n const workspace = conversationId;\n const [activeFile, setActiveFile] = useState<FileInfo | null>(null);\n const taskContextValue = useMemo(\n () => ({\n conversationId,\n conversationState,\n tasks,\n errors,\n workspace,\n previewUrlTemplate,\n replay,\n showCases,\n exampleProjects,\n uploadOptions,\n\n humanInput,\n onShare,\n onTerminate,\n supports,\n\n activeExpandedViewJobId,\n setActiveExpandedViewJobId,\n activeDetail,\n setActiveDetail,\n subActiveDetail,\n setSubActiveDetail,\n\n submittingFeedback,\n submittedFeedback,\n onSubmitFeedback: handleSubmitFeedback,\n setShowFeedback,\n showFeedbackOnView,\n onFeedbackOnView,\n feedbackDoneViews,\n\n skipToResults,\n watchAgain,\n tryItOut() {\n const win = window.open(\n `${getBasePath().slice(0, -1)}${tryItOutUrl ?? \"/elevo\"}`,\n \"_blank\"\n );\n if (win) {\n win.__elevo_try_it_out = userMessage\n ? {\n content: userMessage.content,\n cmd: userMessage.cmd,\n mentionedAiEmployeeId: userMessage.mentionedAiEmployeeId,\n }\n : {};\n }\n },\n activeFile,\n setActiveFile,\n activeImages,\n setActiveImages,\n }),\n [\n conversationId,\n conversationState,\n tasks,\n errors,\n workspace,\n previewUrlTemplate,\n replay,\n showCases,\n exampleProjects,\n uploadOptions,\n\n humanInput,\n onShare,\n onTerminate,\n supports,\n\n activeExpandedViewJobId,\n activeDetail,\n subActiveDetail,\n\n submittingFeedback,\n submittedFeedback,\n handleSubmitFeedback,\n showFeedbackOnView,\n onFeedbackOnView,\n feedbackDoneViews,\n\n skipToResults,\n watchAgain,\n userMessage,\n tryItOutUrl,\n activeFile,\n activeImages,\n ]\n );\n\n const streamContextValue = useMemo(\n () => ({\n lastDetail,\n setUserClosedAside,\n }),\n [lastDetail]\n );\n\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const scrollContentRef = useRef<HTMLDivElement>(null);\n\n const { scrollable, scrollToBottom } = useAutoScroll(\n conversationAvailable,\n scrollContainerRef,\n scrollContentRef\n );\n\n const fulfilledActiveDetail = useFulfilledActiveDetail(\n activeDetail,\n jobMap,\n flowMap,\n activityMap\n );\n\n const fulfilledSubActiveDetail = useFulfilledActiveDetail(\n subActiveDetail,\n jobMap,\n flowMap,\n activityMap\n );\n\n const [depsReady, setDepsReady] = useState(false);\n useEffect(() => {\n let ignore = false;\n Promise.race([\n preloadHighlighter(\"light-plus\"),\n // Wait at most 5s\n new Promise((resolve) => setTimeout(resolve, 5000)),\n ]).finally(() => {\n if (!ignore) {\n setDepsReady(true);\n }\n });\n return () => {\n ignore = true;\n };\n }, []);\n\n useHandleEscape(taskContextValue);\n\n const split = !!(activeDetail || subActiveDetail);\n useEffect(() => {\n onSplitChange(split);\n }, [onSplitChange, split]);\n\n useEffect(() => {\n scrollContainerRef.current?.focus();\n }, [conversationAvailable, depsReady]);\n\n return (\n <TaskContext.Provider value={taskContextValue}>\n <StreamContext.Provider value={streamContextValue}>\n <div className={styles.container}>\n <div className={styles.header}>\n <h1>{pageTitle}</h1>\n </div>\n {conversationAvailable && depsReady ? (\n <>\n <div\n className={styles.main}\n tabIndex={-1}\n ref={scrollContainerRef}\n >\n <div className={styles.narrow} ref={scrollContentRef}>\n {messages.map((msg, index, list) => (\n <div className={styles.message} key={index}>\n {msg.role === \"user\" ? (\n <UserMessage\n content={msg.content}\n cmd={msg.cmd}\n mentionedAiEmployeeId={msg.mentionedAiEmployeeId}\n files={msg.files}\n />\n ) : (\n <AssistantMessage\n chunks={msg.chunks}\n scopeState={conversationState}\n isLatest={index === list.length - 1}\n />\n )}\n </div>\n ))}\n {replay\n ? conversation?.finished && (\n <>\n <PlanProgress\n plan={plan}\n conversationState={conversationState}\n style={{ marginTop: 14 }}\n />\n <NodeReplay finished ui=\"chat\" />\n </>\n )\n : showFeedback &&\n (conversationState === \"completed\" ||\n (conversationState === \"failed\" &&\n showFeedbackAfterFailed)) &&\n tasks.length > 0 && (\n <NodeFeedback className={styles.feedback} />\n )}\n </div>\n </div>\n <button\n className={`${scrollStyles[\"scroll-down\"]} ${floatingStyles[\"floating-button\"]}`}\n hidden={!scrollable}\n onClick={scrollToBottom}\n >\n <WrappedIcon lib=\"antd\" icon=\"down\" />\n </button>\n {(replay ? !conversation?.finished : supports?.chat) ? (\n <div className={styles.footer}>\n <div className={styles.narrow}>\n <PlanProgress\n plan={plan}\n conversationState={conversationState}\n />\n {replay ? (\n <NodeReplay />\n ) : (\n <ChatBox state={conversationState} canChat={canChat} />\n )}\n </div>\n </div>\n ) : null}\n </>\n ) : (\n <div className={styles[\"loading-icon\"]}>\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"loading-3-quarters\"\n spinning\n />\n </div>\n )}\n </div>\n {\n <div\n className={classNames(styles.aside, {\n [styles.expanded]: !!fulfilledActiveDetail,\n })}\n >\n {fulfilledActiveDetail && (\n <Aside\n detail={fulfilledActiveDetail}\n faded={!!fulfilledSubActiveDetail}\n />\n )}\n {fulfilledSubActiveDetail && (\n <Aside detail={fulfilledSubActiveDetail} isSubTask />\n )}\n </div>\n }\n {activeExpandedViewJobId && <ExpandedView views={views!} />}\n {showUiSwitch && (\n <div className={classNames(toolbarStyles.toolbar, styles.toolbar)}>\n <WrappedIconButton\n icon={ICON_CANVAS}\n variant=\"mini\"\n title={t(K.SWITCH_TO_CANVAS)}\n onClick={onSwitchToCanvas}\n />\n </div>\n )}\n {activeFile && <FilePreview file={activeFile} />}\n {activeImages && <ImagesPreview images={activeImages} />}\n </StreamContext.Provider>\n </TaskContext.Provider>\n );\n}\n","import { useMemo } from \"react\";\nimport type { PlanProgressStep, ServiceFlowRun, Task } from \"./interfaces\";\n\nexport function useServiceFlowPlan(\n serviceFlows: ServiceFlowRun[],\n tasks: Task[]\n): PlanProgressStep[] {\n return useMemo(() => {\n const steps: PlanProgressStep[] = [];\n\n for (const flow of serviceFlows) {\n for (const stage of flow.spec) {\n for (const activity of stage.serviceFlowActivities) {\n if (activity.taskId) {\n const task = tasks.find((t) => t.id === activity.taskId);\n steps.push({\n name: activity.name,\n taskId: activity.taskId,\n state: task?.state,\n });\n } else {\n steps.push({\n name: activity.name,\n });\n }\n }\n }\n }\n\n return steps;\n }, [serviceFlows, tasks]);\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.view--O8CNDdS_{background:rgba(255,255,255,0.6);border-radius:8px;border:1px solid rgba(0,0,0,0.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 20px;width:var(--cruise-canvas-node-width-medium);max-width:100%;margin-top:14px}.large--jT3IWlRf{width:var(--cruise-canvas-node-width-large)}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"view\": `view--O8CNDdS_`,\n\t\"large\": `large--jT3IWlRf`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"../home-container/images/background.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `ai-portal\\\\.chat-stream{display:flex;position:relative;width:100%;height:100%;overflow:hidden;background-color:#f3f3f4;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-size:cover;background-repeat:no-repeat;background-position:center;background-attachment:fixed;color:rgba(0,0,0,0.88);--cruise-canvas-node-width-small:330px;--cruise-canvas-node-width-medium:453px;--cruise-canvas-node-width-large:800px;--cruise-canvas-primary-color:var(--elevo-color-brand);--cruise-canvas-input-background:rgba(255,255,255,0.8);--cruise-canvas-input-box-shadow:0px 1px 0px 0px #ffffff,inset 0px 2px 4px 0px #b3bcf9}.container--IOwk4fR1{display:flex;flex-direction:column;position:relative;flex:1;min-width:0}.header--O9c4lNA3{height:54px;padding:0 72px;display:flex;align-items:center;justify-content:space-between}.header--O9c4lNA3 h1{font-weight:500;font-size:14px;margin:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.main--KDIjetJs{overflow-y:auto;flex:1;padding:20px 24px}.narrow--xWih9UIb{width:100%;max-width:800px;margin:0 auto}.message--YIXGDQNi + .message--YIXGDQNi{margin-top:40px}.loading-icon--lagcmORP{flex:1;display:flex;align-items:center;justify-content:center;font-size:48px;color:#fff}.footer--aLZ8UWjM{padding:0 20px 24px}.aside--Xjd6To2A{width:0%;height:100%;transition:width 0.2s ease-in-out;position:relative}.expanded--xZgk3uBF{width:50%}.feedback--YbYylTcK{margin:24px auto 0}.toolbar--uiLshJmw{left:20px;bottom:20px}@media (max-width: 1123px){div.toolbar--uiLshJmw{display:none}}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"container\": `container--IOwk4fR1`,\n\t\"header\": `header--O9c4lNA3`,\n\t\"main\": `main--KDIjetJs`,\n\t\"narrow\": `narrow--xWih9UIb`,\n\t\"message\": `message--YIXGDQNi`,\n\t\"loading-icon\": `loading-icon--lagcmORP`,\n\t\"footer\": `footer--aLZ8UWjM`,\n\t\"aside\": `aside--Xjd6To2A`,\n\t\"expanded\": `expanded--xZgk3uBF`,\n\t\"feedback\": `feedback--YbYylTcK`,\n\t\"toolbar\": `toolbar--uiLshJmw`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.aside--DDIdDtkt{padding:12px 12px 12px 0;height:100%}.faded--AsNxuT2v{opacity:0.4}.sub--d8EpebQt{position:absolute;top:16px;right:16px;left:-16px;height:calc(100% - 16px)}.box--niuFBiiQ{background:#ffffff;box-shadow:1px 1px 10px 0px rgba(0,10,26,0.1);border-radius:12px;height:100%;display:flex;flex-direction:column}.header--DPl_hrTp{height:52px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,0.15);padding:0 20px}.title--HlE9yRcJ{font-weight:500;font-size:16px;color:#262626}.body--OLKz1zeC{flex:1;min-height:0;padding:20px;display:flex;flex-direction:column}.app--UanK0TGf{flex:1;min-height:0;background:#ffffff;border-radius:9px;border:1px solid #ccd1de;margin-top:16px;overflow:hidden;display:flex;flex-direction:column}.heading--ngRi_rQ4{background:#e6e9f3;color:#5e6472;padding:5px 14px}.content--I2i0y65v{font-size:12px;flex:1;min-height:0;position:relative}.scroller--mLfznC_I{height:100%;overflow-x:hidden;overflow-y:auto;overflow:hidden auto;padding:10px}.scroller--mLfznC_I.loading--U1GWHEp9{display:flex;align-items:center;justify-content:center}.editor--p_Sqs1os .content--I2i0y65v .code-block--XiUVX7st::part(wrapper){position:static;margin:0}.editor--p_Sqs1os .content--I2i0y65v .code-block--XiUVX7st::part(pre){background:none!important;padding:0;border-radius:0;border:0}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"aside\": `aside--DDIdDtkt`,\n\t\"faded\": `faded--AsNxuT2v`,\n\t\"sub\": `sub--d8EpebQt`,\n\t\"box\": `box--niuFBiiQ`,\n\t\"header\": `header--DPl_hrTp`,\n\t\"title\": `title--HlE9yRcJ`,\n\t\"body\": `body--OLKz1zeC`,\n\t\"app\": `app--UanK0TGf`,\n\t\"heading\": `heading--ngRi_rQ4`,\n\t\"content\": `content--I2i0y65v`,\n\t\"scroller\": `scroller--mLfznC_I`,\n\t\"loading\": `loading--U1GWHEp9`,\n\t\"editor\": `editor--p_Sqs1os`,\n\t\"code-block\": `code-block--XiUVX7st`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.app--qxnx6yuG{border-radius:9px;border:1px solid #ccd1de;flex:1;min-height:0;display:flex;flex-direction:column}.heading--SbCRupnn{border-bottom:1px solid #ccd1de;border-radius:9px 9px 0 0;background-image:radial-gradient(circle at 1px 1px,#ddd 1px,transparent 0px);background-size:25px 25px;background-position:12px;max-height:30%;display:flex;flex-direction:column}.header--LGXNxV5J{display:flex;align-items:center;padding:16px 30px}.status--aqbJGBcl{background:#aeb3bc;border-radius:100px;height:40px;padding:9px 16px;display:flex;align-items:center;gap:8px;font-size:18px;color:#ffffff}.status--aqbJGBcl eo-icon{font-size:22px}.status--aqbJGBcl.paused--U1cc3Ksn{background:#f0a22e}.status--aqbJGBcl.working--f2PYqFo7{background:#4f69ff}.status--aqbJGBcl.completed--Ihiekkve{background:#08bf33}.status--aqbJGBcl.failed--kB8wxIZ0{background:var(--color-error)}.title--IRvB2t7z{font-weight:500;font-size:16px;margin-left:40px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart--mypbn8pI{padding:8px 22px 18px;overflow:auto;min-height:0}.body--jnk1EIz0{padding:16px 12px 12px;display:flex;flex:1;min-height:0;flex-direction:column;position:relative}.activity-title--hF6stwmT{font-weight:500;font-size:16px;display:flex;align-items:center;gap:6px;margin-bottom:16px}.activity-title--hF6stwmT eo-icon{font-size:20px;color:#8c8c8c}.activity-title--hF6stwmT .paused--U1cc3Ksn{color:#f0a22e}.activity-title--hF6stwmT .working--f2PYqFo7{color:#4f69ff}.activity-title--hF6stwmT .completed--Ihiekkve{color:#08bf33}.activity-title--hF6stwmT .failed--kB8wxIZ0{color:var(--color-error)}.chat--nEzTEXbV{background:rgba(227,228,229,0.4);border:1px solid rgba(0,0,0,0.1);border-radius:8px;padding:16px 20px;flex:1;min-height:0;overflow-y:auto}.messages--vLiwUYSP{width:100%;margin:0 auto}.message--Okzj6NDx + .message--Okzj6NDx{margin-top:40px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"app\": `app--qxnx6yuG`,\n\t\"heading\": `heading--SbCRupnn`,\n\t\"header\": `header--LGXNxV5J`,\n\t\"status\": `status--aqbJGBcl`,\n\t\"paused\": `paused--U1cc3Ksn`,\n\t\"working\": `working--f2PYqFo7`,\n\t\"completed\": `completed--Ihiekkve`,\n\t\"failed\": `failed--kB8wxIZ0`,\n\t\"title\": `title--IRvB2t7z`,\n\t\"chart\": `chart--mypbn8pI`,\n\t\"body\": `body--jnk1EIz0`,\n\t\"activity-title\": `activity-title--hF6stwmT`,\n\t\"chat\": `chat--nEzTEXbV`,\n\t\"messages\": `messages--vLiwUYSP`,\n\t\"message\": `message--Okzj6NDx`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.scroll-down--st4A5sQ4{position:absolute;left:50%;bottom:136px;transform:translateX(-50%);width:32px;height:32px;font-size:12px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"scroll-down\": `scroll-down--st4A5sQ4`\n};\nexport default ___CSS_LOADER_EXPORT___;\n"],"names":["getFlowOrActivityIcon","state","lib","theme","icon","spinning","___CSS_LOADER_EXPORT___","push","module","id","locals","K","NS","locales","en","SWITCH_TO_CANVAS","INITIATING_SERVICE_FLOW","STARTING_SERVICE_FLOW_ACTIVITY","HIL_TIPS","zh","t","i18n","getFixedT","useConversationStream","conversationAvailable","tasks","errors","flowMap","activityMap","options","showHumanActions","skipActivitySubTasks","useMemo","messages","lastDetail","chunks","jobMap","getFlatChunks","prevAssistantMessage","role","chunk","type","_job$messages","job","_job$messages2","toolCall","ignoreDetails","length","every","msg","content","flatMap","parts","map","part","text","join","cmd","mentionedAiEmployeeId","fromSkippedSubTask","files","filter","file","humanAction","task","shouldAppendEmptyMessage","DONE_STATES","includes","lastMessage","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","undefined","UserMessage","_ref","React","className","styles","user","ReadableCommand","FileList","ui","NodeView","size","setSize","useState","handleSizeChange","useCallback","value","classNames","view","large","CreatedView","onSizeChange","StreamContext","createContext","setUserClosedAside","getStateDisplay","conversationState","completed","prefix","working","failed","canceled","NodeJob","_toolCall$annotations","isSubTask","toolTitle","annotations","title","name","toolName","showToolCall","setActiveDetail","setSubActiveDetail","useContext","TaskContext","toolMarkdownContent","cmdbInstanceDetails","contents","instanceDetails","forEach","message","_part$data","data","_part$data2","Object","keys","outputSchema","properties","detail","collapsed","setCollapsed","showHeading","instruction","heading","onClick","prev","WrappedIcon","_extends","caret","ICON_UP","body","tool","isEqual","main","index","_message$parts","key","sharedStyles","markdown","partIndex","EnhancedMarkdown","box","CmdbInstanceDetail","generatedView","NodeChunk","error","NodeTask","_ref2","flow","activity","HumanInTheLoop","hil","username","requestHumanAction","actions","RequestHumanAction","action","AssistantMessage","scopeState","isLatest","lastJob","lastChunk","jobs","NON_WORKING_STATES","some","assistant","category","avatar","texting","GENERAL_DONE_STATES","useAutoScroll","scrollContainerRef","scrollContentRef","detectScrolledUpRef","useRef","manualScrolledRef","scrollable","setScrollable","useEffect","scrollContainer","current","contentContainer","handleScroll","scrollTop","clientHeight","scrollHeight","timer","addEventListener","observer","ResizeObserver","scrollTo","top","behavior","clearTimeout","setTimeout","observe","disconnect","removeEventListener","scrollToBottom","FlowApp","_flow$space","flowTask","find","taskId","runningSpec","spec","stage","_stage$serviceFlowAct","serviceFlowActivities","startTime","endTime","flowStatus","getFlowStatusDisplay","app","header","status","space","chart","WrappedRunningFlow","activeActivityId","onActiveChange","e","ActivityDetail","WrappedBlankState","blank","description","illustration","activityTask","activityState","fixedTasks","parent","chat","ref","list","scrollStyles","floatingStyles","style","bottom","hidden","EXECUTING","SUCCEEDED","FAILED","PAUSED","paused","TERMINATED","WAITING","initializeI18n","ICON_SHRINK","Aside","faded","_detail$job$messages","aside","sub","WrappedIconButton","variant","ToolCallStatus","EditorApp","source","code","language","JSON","stringify","editor","scroller","WrappedCodeBlock","themeVariant","PlanProgress","plan","expanded","setExpanded","doneCount","reduce","acc","step","getClassNameAndIconProps","toggle","allDone","mask","progress","bar","PLAN_COMPLETED","stat","expand","details","PlanProgressStep","ChatStreamComponent","_conversation$title","conversationId","initialRequest","replay","replayDelay","supports","showFeedback","propShowFeedback","showFeedbackAfterFailed","showFeedbackOnView","showUiSwitch","previewUrlTemplate","showCases","exampleProjects","tryItOutUrl","uploadOptions","onShare","onTerminate","onSubmitFeedback","onSwitchToCanvas","onFeedbackOnView","onDetailChange","onSplitChange","conversation","serviceFlows","humanInputRef","skipToResults","watchAgain","useConversationDetail","pageTitle","canChat","steps","useServiceFlowPlan","useFlowAndActivityMap","projectId","views","values","submittingFeedback","setSubmittingFeedback","submittedFeedback","setSubmittedFeedback","setShowFeedback","feedbackDoneViews","setFeedbackDoneViews","handleSubmitFeedback","useImperativeHandle","feedbackSubmitDone","feedbackSubmitFailed","feedbackOnViewDone","viewId","newSet","Set","add","activeExpandedViewJobId","setActiveExpandedViewJobId","activeDetail","subActiveDetail","userClosedAside","delayRef","hasInitialRequest","getRuntime","applyPageTitle","humanInput","input","extra","_humanInputRef$curren","call","firstMessage","userMessage","activeImages","setActiveImages","workspace","activeFile","setActiveFile","taskContextValue","tryItOut","win","window","open","getBasePath","slice","__elevo_try_it_out","streamContextValue","fulfilledActiveDetail","useFulfilledActiveDetail","fulfilledSubActiveDetail","depsReady","setDepsReady","ignore","Promise","race","preloadHighlighter","resolve","finally","useHandleEscape","split","_scrollContainerRef$c","focus","Provider","container","tabIndex","narrow","finished","marginTop","NodeReplay","NodeFeedback","feedback","footer","ChatBox","ExpandedView","toolbarStyles","toolbar","ICON_CANVAS","FilePreview","ImagesPreview","images","___CSS_LOADER_URL_IMPORT_0___","URL","___CSS_LOADER_URL_REPLACEMENT_0___"],"sourceRoot":""}
@@ -1,2 +0,0 @@
1
- "use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[2324],{17632:(e,t,n)=>{n.d(t,{K:()=>a,t:()=>r});var i=n(67177);let a=function(e){return e.UPLOAD_FILES="UPLOAD_FILES",e.UPLOADING="UPLOADING",e.UPLOAD_FAILED="UPLOAD_FAILED",e.DROP_FILES_HERE="DROP_FILES_HERE",e.SUPPORTED_FILE_TYPES="SUPPORTED_FILE_TYPES",e.UNSUPPORTED_FILE_TYPE="UNSUPPORTED_FILE_TYPE",e.MAX_SIZE_EXCEEDED="MAX_SIZE_EXCEEDED",e.MAX_SIZE_EXCEEDED_UNKNOWN="MAX_SIZE_EXCEEDED_UNKNOWN",e.MAX_FILES_EXCEEDED="MAX_FILES_EXCEEDED",e}({});const o="bricks/ai-portal/FileUpload",r=i.i18n.getFixedT(null,o);(0,i.initializeI18n)(o,{en:{UPLOAD_FILES:"Upload files",UPLOADING:"Uploading...",UPLOAD_FAILED:"Upload failed",DROP_FILES_HERE:"Drop files here",SUPPORTED_FILE_TYPES:"Supported file types: {{types}}.",UNSUPPORTED_FILE_TYPE:"Some files have unsupported file types.",MAX_SIZE_EXCEEDED:"Maximum single file size: {{size}}.",MAX_SIZE_EXCEEDED_UNKNOWN:"Some files exceed the maximum allowed size.",MAX_FILES_EXCEEDED:"Maximum number of files ({{count}}) exceeded."},zh:{UPLOAD_FILES:"上传文件",UPLOADING:"上传中...",UPLOAD_FAILED:"上传失败",DROP_FILES_HERE:"在此处拖放文件",SUPPORTED_FILE_TYPES:"仅支持以下文件类型:{{types}}。",UNSUPPORTED_FILE_TYPE:"部分文件类型不受支持。",MAX_SIZE_EXCEEDED:"单个文件不能超过 {{size}}。",MAX_SIZE_EXCEEDED_UNKNOWN:"部分文件超过允许的最大大小。",MAX_FILES_EXCEEDED:"超过允许的最大文件数量 ({{count}})。"}})},19619:(e,t,n)=>{n.d(t,{k:()=>o});var i=n(60128),a=n(17632);function o(e,t){const n=t.accept?t.accept.split(",").map((e=>e.trim())):null;for(const o of e){if(n){const e=o.type;if(!n.some((t=>{if("*/*"===t||"*"===t)return!0;if(t.startsWith("."))return o.name.toLowerCase().endsWith(t.toLowerCase());if(t.endsWith("/*")){const n=t.split("/")[0];return e.startsWith(`${n}/`)}return e===t})))return(0,i.handleHttpError)(t.readableAccept?(0,a.t)(a.K.SUPPORTED_FILE_TYPES,{types:t.readableAccept}):(0,a.t)(a.K.UNSUPPORTED_FILE_TYPE)),!1}if(t.maxSize&&o.size>t.maxSize)return(0,i.handleHttpError)(t.readableMaxSize?(0,a.t)(a.K.MAX_SIZE_EXCEEDED,{size:t.readableMaxSize}):(0,a.t)(a.K.MAX_SIZE_EXCEEDED_UNKNOWN)),!1}return!0}},21020:(e,t,n)=>{n.d(t,{A:()=>w});var i=n(18769),a=n.n(i),o=n(59435);const r=n.p+"images/96be9327.png";var l=n(17632),s=n(72591),d=n.n(s),c=n(1740),u=n.n(c),p=n(88128),f=n.n(p),m=n(30855),E=n.n(m),g=n(93051),h=n.n(g),v=n(73656),b=n.n(v),x=n(36190),_={};_.styleTagTransform=b(),_.setAttributes=E(),_.insert=f().bind(null,"head"),_.domAPI=u(),_.insertStyleElement=h(),d()(x.A,_);const D=x.A&&x.A.locals?x.A.locals:void 0;var S=n(19619);function w(e){let{disabled:t,uploadOptions:n,onFilesDropped:s}=e;const[d,c]=(0,i.useState)(!1),u=(0,i.useRef)(0);return(0,i.useEffect)((()=>{if(t)return u.current=0,void c(!1);const e=e=>{var t;e.preventDefault(),e.stopPropagation();for(const t of e.composedPath())if(t instanceof HTMLElement&&("EO-DRAWER"===t.tagName||"EO-MODAL"===t.tagName))return;Array.from((null===(t=e.dataTransfer)||void 0===t?void 0:t.items)||[]).some((e=>"file"===e.kind))&&(u.current++,c(!0))},i=e=>{e.preventDefault(),e.stopPropagation(),u.current>0&&u.current--,0===u.current&&c(!1)},a=e=>{e.preventDefault(),e.stopPropagation()},o=e=>{e.preventDefault(),e.stopPropagation(),u.current=0,c(!1);const t=Array.from(e.dataTransfer.files);t.length>0&&(0,S.k)(t,n)&&(null==s||s(t))};return window.addEventListener("dragenter",e),window.addEventListener("dragleave",i),window.addEventListener("dragover",a),window.addEventListener("drop",o),()=>{window.removeEventListener("dragenter",e),window.removeEventListener("dragleave",i),window.removeEventListener("dragover",a),window.removeEventListener("drop",o)}}),[t,n,s]),d?(0,o.createPortal)(a().createElement("div",{className:D.overlay},a().createElement("img",{src:r,width:"91",height:"79"}),a().createElement("div",{className:D.title},(0,l.t)(l.K.DROP_FILES_HERE)),a().createElement("div",{className:D.description},null==n?void 0:n.dragTips)),document.body):null}},36190:(e,t,n)=>{n.d(t,{A:()=>l});var i=n(36758),a=n.n(i),o=n(40935),r=n.n(o)()(a());r.push([e.id,".overlay--SI1oXhAV{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(255,255,255,0.1);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);display:flex;align-items:center;justify-content:center;flex-direction:column;z-index:9999}.title--FmBT01QV{font-weight:600;font-size:20px;color:rgba(0,0,0,0.88);line-height:28px;margin-top:17px}.description--Yhdhm5wT{color:rgba(0,0,0,0.45);font-size:14px;margin-top:11px}",""]),r.locals={overlay:"overlay--SI1oXhAV",title:"title--FmBT01QV",description:"description--Yhdhm5wT"};const l=r},45387:(e,t,n)=>{n.d(t,{C:()=>p});var i=n(89575),a=n(18769),o=n.n(a),r=n(53373),l=n.n(r),s=n(30981),d=n(60136),c=n(17632);const u=(0,s.wrapBrick)("eo-icon");function p(e){let{files:t,maxFiles:n,className:a,onRemove:r,onAdd:s}=e;const d=t.every((e=>e.file.type.startsWith("image/")));return o().createElement("ul",{className:l()("files",a),onClick:e=>{e.stopPropagation()}},t.map((e=>o().createElement(f,(0,i.A)({},e,{key:e.uid,showAsImage:d,onRemove:r})))),!n||t.length<n?o().createElement("li",null,o().createElement("button",{className:"btn-add-file",onClick:s},o().createElement(u,{lib:"antd",icon:"plus"}))):null)}function f(e){let{uid:t,file:n,status:i,abortController:r,showAsImage:s,onRemove:p}=e;const[f,m]=(0,d.NL)(n.type,n.name),E=(0,d.v7)(n.size),g=n.type.startsWith("image/"),[h,v]=(0,a.useState)();(0,a.useEffect)((()=>{if(g){const e=URL.createObjectURL(n);return v(e),()=>{URL.revokeObjectURL(e)}}v(void 0)}),[n,g]);const b=o().createElement("button",{className:"file-remove",onClick:()=>{p(t,r)}},o().createElement(u,{lib:"antd",theme:"filled",icon:"close-circle"}));return s?o().createElement("li",{className:l()("file as-image",{failed:"failed"===i})},o().createElement("img",{className:"file-image",src:h}),"uploading"===i&&o().createElement("div",{className:"file-overlay"},o().createElement(u,{lib:"antd",icon:"loading-3-quarters",spinning:!0})),"failed"===i&&o().createElement("div",{className:"file-overlay"},(0,c.t)(c.K.UPLOAD_FAILED)),b):o().createElement("li",{className:l()("file",{failed:"failed"===i,uploading:"uploading"===i})},g?o().createElement("img",{className:"file-image",src:h}):o().createElement("img",{className:"file-icon",src:m,width:26,height:32}),o().createElement("div",{className:"file-content"},o().createElement("div",{className:"file-name"},n.name),o().createElement("div",{className:"file-metadata"},o().createElement("span",{className:"file-status"},`${"uploading"===i?(0,c.t)(c.K.UPLOADING):"failed"===i?(0,c.t)(c.K.UPLOAD_FAILED):f}`),` · ${E}`)),b)}},45889:(e,t,n)=>{n.d(t,{O:()=>d});var i=n(18769),a=n(60128),o=n(22919),r=n(19619),l=n(17632);let s=0;function d(e){const t=null==e?void 0:e.enabled,n=null==e?void 0:e.maxFiles,[d,c]=(0,i.useState)(),u=!!d&&d.length>0;(0,i.useEffect)((()=>{null==d||d.forEach((async e=>{if("ready"===e.status){const t=new AbortController;c((n=>null==n?void 0:n.map((n=>n.uid===e.uid?{...n,status:"uploading",abortController:t}:n))));try{const n=new FormData;n.append("file",e.file);const i=await o.http.request("api/gateway/logic.llm.aiops_service/api/v1/elevo/files/upload",{method:"POST",body:n,signal:t.signal},{interceptorParams:{ignoreLoadingBar:!0}});c((t=>null==t?void 0:t.map((t=>t.uid===e.uid?{...t,status:"done",fileInfo:i.data}:t))))}catch(t){c((t=>null==t?void 0:t.map((t=>t.uid===e.uid?{...t,status:"failed"}:t)))),(0,a.handleHttpError)(t)}}}))}),[d]);const[p,f]=(0,i.useState)(!0),[m,E]=(0,i.useState)(),g=(0,i.useRef)(!0);(0,i.useEffect)((()=>{const e=!d||d.every((e=>"done"===e.status));f(e),g.current?g.current=!1:e&&E(null==d?void 0:d.map((e=>e.fileInfo)))}),[d]);const h=(0,i.useCallback)((t=>{(0,r.k)(t,e)&&c((e=>{const i=null!=e?e:[];return n&&i.length+t.length>n?((0,a.handleHttpError)((0,l.t)(l.K.MAX_FILES_EXCEEDED,{count:n})),e):[...i,...t.map((e=>({uid:s++,file:e,status:"ready"})))]}))}),[n,e]),v=(0,i.useCallback)((()=>{c(void 0)}),[]),b=(0,i.useCallback)((e=>{c((t=>null==t?void 0:t.filter((t=>t.uid!==e))))}),[]),x=!!n&&!!d&&d.length>=n,_=(0,i.useCallback)((n=>{if(!t)return;const i=n.clipboardData.files;if(i.length>0&&t){n.preventDefault(),n.stopPropagation();const t=[...i];(0,r.k)(t,e)&&h(t)}}),[t,e,h]);return{files:d,resetFiles:v,appendFiles:h,removeFile:b,hasFiles:u,allFilesDone:p,fileInfos:m,exceeded:x,paste:_}}},51020:(e,t,n)=>{n.d(t,{A:()=>l});var i=n(36758),a=n.n(i),o=n(40935),r=n.n(o)()(a());r.push([e.id,'.files{list-style:none;margin:0;padding:4px 0 0;position:absolute;display:flex;gap:8px;top:10px;left:16px;right:16px;overflow-x:auto}.file{background:rgba(0,0,0,0.04);border-radius:6px;display:flex;width:200px;height:60px;align-items:center;padding:0 8px;position:relative}.file.uploading::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,0.06);border-radius:6px;animation:loadingAnimation 1.5s linear infinite}@keyframes loadingAnimation{0%{right:100%}100%{right:0}}.file-content{min-width:0;flex:1}.file-icon{margin:0 11px 0 6px}.file-image{margin-right:8px;object-fit:container;border-radius:4px;max-width:44px;max-height:44px}.file-name,\n.file-metadata{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-name{color:rgba(0,0,0,0.88)}.file-metadata{color:rgba(0,0,0,0.45);font-size:12px;margin-top:3px}.file-remove{position:absolute;top:-4px;right:-4px;font-size:12px;padding:1px;display:flex;color:rgba(0,0,0,0.88);cursor:pointer;background:#fff;border-radius:14px}.file:not(:hover) .file-remove{display:none}.btn-add-file{border-radius:6px;border:1px dashed rgba(0,0,0,0.1);color:rgba(0,0,0,0.45);font-size:16px;display:flex;width:60px;height:60px;align-items:center;justify-content:center;cursor:pointer}.btn-add-file:hover{background:rgba(0,0,0,0.04)}.file.failed .file-status{color:var(--color-error)}.file.as-image{width:60px;border:1px solid rgba(0,0,0,0.1);padding:0;background:none;justify-content:center}.file.as-image .file-image{max-width:100%;max-height:100%;margin:0;border-radius:6px}.file.as-image.failed{border-color:#f24c25}.file-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,10,26,0.45);border-radius:6px;color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;font-size:20px}.file.failed .file-overlay{background:rgba(0,10,26,0.7);color:#ff754f;font-size:12px}',""]);const l=r.toString()},57227:(e,t,n)=>{n.d(t,{s:()=>d});var i=n(18769),a=n.n(i),o=n(30981),r=n(17632);const l=(0,o.wrapBrick)("ai-portal.icon-button"),s={lib:"lucide",icon:"paperclip"},d=(0,i.forwardRef)(c);function c(e,t){let{accept:n,disabled:o,onChange:d}=e;const c=(0,i.useRef)(null);return(0,i.useImperativeHandle)(t,(()=>({requestUpload:()=>{var e;null===(e=c.current)||void 0===e||e.click()}}))),a().createElement(a().Fragment,null,a().createElement("input",{type:"file",accept:n,multiple:!0,hidden:!0,ref:c,onChange:e=>{const t=e.target.files;t&&(null==d||d(Array.from(t))),e.target.value=""},onClick:e=>{e.stopPropagation()}}),a().createElement(l,{variant:"light",className:"btn-upload",icon:s,tooltip:(0,r.t)(r.K.UPLOAD_FILES),disabled:o,onClick:e=>{var t;e.stopPropagation(),null===(t=c.current)||void 0===t||t.click()}}))}},80592:(e,t,n)=>{n.d(t,{w:()=>o});const i="\n min-height: 0!important;\n max-height: none!important;\n height: 0!important;\n visibility: hidden!important;\n overflow: hidden!important;\n position: absolute!important;\n z-index: -1000!important;\n top: 0!important;\n left: 0!important;\n pointer-events: none!important;\n",a=["letter-spacing","line-height","padding-top","padding-bottom","font-family","font-weight","font-size","font-variant","text-rendering","text-transform","width","text-indent","padding-left","padding-right","border-width","box-sizing","word-break","white-space"];function o(e){const t=window.getComputedStyle(e);return`${a.map((e=>`${e}:${t.getPropertyValue(e)}`)).join(";")};${i}`}},92879:(e,t,n)=>{n.d(t,{e:()=>c});var i=n(89575),a=n(18769),o=n(59435),r=n(99126),l=n(80592);let s;const d=/Mac|iPod|iPhone|iPad/.test(navigator.platform)?"metaKey":"ctrlKey",c=a.forwardRef(u);function u(e,t){let{autoResize:n,minRows:c,maxRows:u,borderSize:p,paddingSize:f,containerRef:m,value:E,style:g,submitWhen:h,desiredSelectionRef:v,onChange:b,onSubmit:x,onKeyDown:_,onCompositionStart:D,onCompositionEnd:S,...w}=e;const P=null==n||n,[A,L]=(0,a.useState)(null!=E?E:""),y=(0,a.useRef)(null),[I,R]=(0,a.useState)(null);(0,a.useImperativeHandle)(t,(()=>({focus:()=>{const e=y.current;if(e){var t;const n=null===(t=e.value)||void 0===t?void 0:t.length;e.focus(),n&&e.setSelectionRange(n,n)}},element:y.current})),[]);const C=(0,a.useCallback)((()=>{const e=y.current;if(e&&P){const t=function(e,t){const{minRows:n=null,maxRows:i=null,borderSize:a=2,paddingSize:o=8}=null!=t?t:{};let r,d,c;s||(s=document.createElement("textarea"),s.setAttribute("tab-index","-1"),s.setAttribute("aria-hidden","true"),document.body.appendChild(s)),s.setAttribute("style",(0,l.w)(e)),s.value=e.value||e.placeholder||"";let u=s.scrollHeight+a;if(null!==n||null!==i){const e=parseFloat(window.getComputedStyle(s).getPropertyValue("line-height"));null!==n&&(r=e*n+o+a,u=Math.max(r,u)),null!==i&&(d=e*i+o+a,u<=d&&(c="hidden"),u=Math.min(d,u))}const p={height:u,overflowY:c,resize:"none"};return r&&(p.minHeight=r),d&&(p.maxHeight=d),p}(e,{minRows:c,maxRows:u,borderSize:p,paddingSize:f});(0,o.flushSync)((()=>{R(t)}))}}),[P,u,c,p,f]);(0,a.useEffect)((()=>{L(null!=E?E:"")}),[E]),(0,a.useEffect)((()=>{C()}),[C,A]);const F=(0,a.useRef)(!1),N=(0,a.useCallback)((e=>{F.current=!0,null==D||D(e)}),[D]),k=(0,a.useCallback)((e=>{F.current=!1,null==S||S(e)}),[S]),U=(0,a.useCallback)((e=>{F.current||!1!==(null==_?void 0:_(e))&&"Enter"===e.key&&("enter-without-shift"===h?!e.shiftKey:"enter-with-mod"===h&&e[d])&&(e.preventDefault(),e.stopPropagation(),null==x||x(e))}),[_,x,h]);return(0,a.useLayoutEffect)((()=>{const e=null==v?void 0:v.current,t=y.current;if(e&&t){const{start:n,end:i}=e;v.current=null,t.setSelectionRange(n,i)}}),[v,A]),(0,a.useEffect)((()=>{const e=null==m?void 0:m.current;if(!e||!P)return;let t;const n=new r.A((n=>{for(const i of n)if(i.target===e){const e=i.contentBoxSize?i.contentBoxSize[0]?i.contentBoxSize[0].inlineSize:i.contentBoxSize.inlineSize:i.contentRect.width;if(void 0!==e&&e!==t){const n=!t;t=e,n||requestAnimationFrame(C)}}}));return n.observe(e),()=>{n.disconnect()}}),[P,m,C]),a.createElement("textarea",(0,i.A)({},w,{ref:y,value:A,style:{...g,...I},onChange:e=>{L(e.target.value),null==b||b(e)},onCompositionStart:N,onCompositionEnd:k,onKeyDown:U}))}}}]);
2
- //# sourceMappingURL=2324.a4a90c77.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chunks/2324.a4a90c77.js","mappings":"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","sources":["webpack:///./src/shared/FileUpload/i18n.ts","webpack:///./src/shared/FileUpload/validateFiles.ts","webpack:///./src/shared/FileUpload/GlobalDragOverlay.module.css?40e0","webpack:///./src/shared/FileUpload/GlobalDragOverlay.tsx","webpack:///./src/shared/FileUpload/GlobalDragOverlay.module.css","webpack:///./src/shared/FileUpload/UploadedFiles.tsx","webpack:///./src/shared/useFilesUploading.ts","webpack:///./src/shared/FileUpload/UploadedFiles.shadow.css","webpack:///./src/shared/FileUpload/UploadButton.tsx","webpack:///../../../src/utils/getMirroredStyle.ts","webpack:///../../../src/utils/calculateAutoSizeStyle.ts","webpack:///../../src/TextareaAutoResize.tsx"],"sourcesContent":["import { i18n, initializeI18n } from \"@next-core/i18n\";\n\nexport enum K {\n UPLOAD_FILES = \"UPLOAD_FILES\",\n UPLOADING = \"UPLOADING\",\n UPLOAD_FAILED = \"UPLOAD_FAILED\",\n DROP_FILES_HERE = \"DROP_FILES_HERE\",\n SUPPORTED_FILE_TYPES = \"SUPPORTED_FILE_TYPES\",\n UNSUPPORTED_FILE_TYPE = \"UNSUPPORTED_FILE_TYPE\",\n MAX_SIZE_EXCEEDED = \"MAX_SIZE_EXCEEDED\",\n MAX_SIZE_EXCEEDED_UNKNOWN = \"MAX_SIZE_EXCEEDED_UNKNOWN\",\n MAX_FILES_EXCEEDED = \"MAX_FILES_EXCEEDED\",\n}\n\nconst en: Locale = {\n UPLOAD_FILES: \"Upload files\",\n UPLOADING: \"Uploading...\",\n UPLOAD_FAILED: \"Upload failed\",\n DROP_FILES_HERE: \"Drop files here\",\n SUPPORTED_FILE_TYPES: \"Supported file types: {{types}}.\",\n UNSUPPORTED_FILE_TYPE: \"Some files have unsupported file types.\",\n MAX_SIZE_EXCEEDED: \"Maximum single file size: {{size}}.\",\n MAX_SIZE_EXCEEDED_UNKNOWN: \"Some files exceed the maximum allowed size.\",\n MAX_FILES_EXCEEDED: \"Maximum number of files ({{count}}) exceeded.\",\n};\n\nconst zh: Locale = {\n UPLOAD_FILES: \"上传文件\",\n UPLOADING: \"上传中...\",\n UPLOAD_FAILED: \"上传失败\",\n DROP_FILES_HERE: \"在此处拖放文件\",\n SUPPORTED_FILE_TYPES: \"仅支持以下文件类型:{{types}}。\",\n UNSUPPORTED_FILE_TYPE: \"部分文件类型不受支持。\",\n MAX_SIZE_EXCEEDED: \"单个文件不能超过 {{size}}。\",\n MAX_SIZE_EXCEEDED_UNKNOWN: \"部分文件超过允许的最大大小。\",\n MAX_FILES_EXCEEDED: \"超过允许的最大文件数量 ({{count}})。\",\n};\n\nexport const NS = \"bricks/ai-portal/FileUpload\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n\ninitializeI18n(NS, locales);\n","import { handleHttpError } from \"@next-core/runtime\";\nimport type { UploadOptions } from \"../interfaces\";\nimport { K, t } from \"./i18n\";\n\nexport function validateFiles(files: File[], options: UploadOptions) {\n const acceptedTypes = options.accept\n ? options.accept.split(\",\").map((type) => type.trim())\n : null;\n\n for (const file of files) {\n if (acceptedTypes) {\n const mimeType = file.type;\n const accepted = acceptedTypes.some((type) => {\n if (type === \"*/*\" || type === \"*\") {\n return true;\n }\n if (type.startsWith(\".\")) {\n return file.name.toLowerCase().endsWith(type.toLowerCase());\n }\n if (type.endsWith(\"/*\")) {\n const baseType = type.split(\"/\")[0];\n return mimeType.startsWith(`${baseType}/`);\n }\n return mimeType === type;\n });\n if (!accepted) {\n handleHttpError(\n options.readableAccept\n ? t(K.SUPPORTED_FILE_TYPES, { types: options.readableAccept })\n : t(K.UNSUPPORTED_FILE_TYPE)\n );\n return false;\n }\n }\n\n if (options.maxSize && file.size > options.maxSize) {\n handleHttpError(\n options.readableMaxSize\n ? t(K.MAX_SIZE_EXCEEDED, { size: options.readableMaxSize })\n : t(K.MAX_SIZE_EXCEEDED_UNKNOWN)\n );\n return false;\n }\n }\n\n return true;\n}\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./GlobalDragOverlay.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./GlobalDragOverlay.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useEffect, useRef, useState } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport dragImage from \"./drag-file@2x.png\";\nimport { K, t } from \"./i18n\";\nimport styles from \"./GlobalDragOverlay.module.css\";\nimport { validateFiles } from \"./validateFiles\";\nimport type { UploadOptions } from \"../interfaces\";\n\nexport interface GlobalDragOverlayProps {\n disabled?: boolean;\n uploadOptions?: UploadOptions;\n onFilesDropped?: (files: File[]) => void;\n}\n\nexport default function GlobalDragOverlay({\n disabled,\n uploadOptions,\n onFilesDropped,\n}: GlobalDragOverlayProps) {\n const [isDragging, setIsDragging] = useState(false);\n const dragCounterRef = useRef(0);\n\n useEffect(() => {\n if (disabled) {\n dragCounterRef.current = 0;\n setIsDragging(false);\n return;\n }\n\n const handleDragEnter = (e: DragEvent) => {\n e.preventDefault();\n e.stopPropagation();\n\n for (const target of e.composedPath()) {\n if (\n target instanceof HTMLElement &&\n (target.tagName === \"EO-DRAWER\" || target.tagName === \"EO-MODAL\")\n ) {\n return;\n }\n }\n\n // 只在拖入文件时触发(排除文字、链接等)\n const hasFiles = Array.from(e.dataTransfer?.items || []).some(\n (item) => item.kind === \"file\"\n );\n if (!hasFiles) return;\n\n dragCounterRef.current++;\n setIsDragging(true);\n };\n\n const handleDragLeave = (e: DragEvent) => {\n e.preventDefault();\n e.stopPropagation();\n if (dragCounterRef.current > 0) {\n dragCounterRef.current--;\n }\n if (dragCounterRef.current === 0) setIsDragging(false);\n };\n\n const handleDragOver = (e: DragEvent) => {\n e.preventDefault();\n e.stopPropagation();\n };\n\n const handleDrop = (e: DragEvent) => {\n e.preventDefault();\n e.stopPropagation();\n\n dragCounterRef.current = 0;\n setIsDragging(false);\n\n const files = Array.from(e.dataTransfer!.files);\n if (files.length > 0) {\n const allFilesAccepted = validateFiles(files, uploadOptions!);\n if (allFilesAccepted) {\n onFilesDropped?.(files);\n }\n }\n };\n\n window.addEventListener(\"dragenter\", handleDragEnter);\n window.addEventListener(\"dragleave\", handleDragLeave);\n window.addEventListener(\"dragover\", handleDragOver);\n window.addEventListener(\"drop\", handleDrop);\n\n return () => {\n window.removeEventListener(\"dragenter\", handleDragEnter);\n window.removeEventListener(\"dragleave\", handleDragLeave);\n window.removeEventListener(\"dragover\", handleDragOver);\n window.removeEventListener(\"drop\", handleDrop);\n };\n }, [disabled, uploadOptions, onFilesDropped]);\n\n if (!isDragging) {\n return null;\n }\n\n return createPortal(\n <div className={styles.overlay}>\n <img src={dragImage} width=\"91\" height=\"79\" />\n <div className={styles.title}>{t(K.DROP_FILES_HERE)}</div>\n <div className={styles.description}>{uploadOptions?.dragTips}</div>\n </div>,\n document.body\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.overlay--SI1oXhAV{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(255,255,255,0.1);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);display:flex;align-items:center;justify-content:center;flex-direction:column;z-index:9999}.title--FmBT01QV{font-weight:600;font-size:20px;color:rgba(0,0,0,0.88);line-height:28px;margin-top:17px}.description--Yhdhm5wT{color:rgba(0,0,0,0.45);font-size:14px;margin-top:11px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"overlay\": `overlay--SI1oXhAV`,\n\t\"title\": `title--FmBT01QV`,\n\t\"description\": `description--Yhdhm5wT`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","import React, { useEffect, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type { FileItem } from \"./interfaces\";\nimport {\n formatFileSize,\n getFileTypeAndIcon,\n} from \"../../cruise-canvas/utils/file\";\nimport { K, t } from \"./i18n\";\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nexport interface UploadedFilesProps {\n files: FileItem[];\n maxFiles?: number;\n className?: string;\n onRemove: (uid: number, abortController: AbortController | undefined) => void;\n onAdd: () => void;\n}\n\nexport function UploadedFiles({\n files,\n maxFiles,\n className,\n onRemove,\n onAdd,\n}: UploadedFilesProps) {\n const showAsImage = files.every((file) =>\n file.file.type.startsWith(\"image/\")\n );\n\n return (\n <ul\n className={classNames(\"files\", className)}\n onClick={(e) => {\n e.stopPropagation();\n }}\n >\n {files.map((file) => (\n <FileComponent\n {...file}\n key={file.uid}\n showAsImage={showAsImage}\n onRemove={onRemove}\n />\n ))}\n {!maxFiles || files.length < maxFiles ? (\n <li>\n <button className=\"btn-add-file\" onClick={onAdd}>\n <WrappedIcon lib=\"antd\" icon=\"plus\" />\n </button>\n </li>\n ) : null}\n </ul>\n );\n}\n\ninterface FileComponentProps extends FileItem {\n showAsImage?: boolean;\n onRemove: (uid: number, abortController: AbortController | undefined) => void;\n}\n\nfunction FileComponent({\n uid,\n file,\n status,\n abortController,\n showAsImage,\n onRemove,\n}: FileComponentProps) {\n const [type, icon] = getFileTypeAndIcon(file.type, file.name);\n const size = formatFileSize(file.size);\n const isImage = file.type.startsWith(\"image/\");\n const [image, setImage] = useState<string | undefined>();\n\n useEffect(() => {\n if (isImage) {\n const url = URL.createObjectURL(file);\n setImage(url);\n return () => {\n URL.revokeObjectURL(url);\n };\n } else {\n setImage(undefined);\n }\n }, [file, isImage]);\n\n const buttonRemove = (\n <button\n className=\"file-remove\"\n onClick={() => {\n onRemove(uid, abortController);\n }}\n >\n <WrappedIcon lib=\"antd\" theme=\"filled\" icon=\"close-circle\" />\n </button>\n );\n\n if (showAsImage) {\n return (\n <li\n className={classNames(\"file as-image\", { failed: status === \"failed\" })}\n >\n <img className=\"file-image\" src={image} />\n {status === \"uploading\" && (\n <div className=\"file-overlay\">\n <WrappedIcon lib=\"antd\" icon=\"loading-3-quarters\" spinning />\n </div>\n )}\n {status === \"failed\" && (\n <div className=\"file-overlay\">{t(K.UPLOAD_FAILED)}</div>\n )}\n {buttonRemove}\n </li>\n );\n }\n\n return (\n <li\n className={classNames(\"file\", {\n failed: status === \"failed\",\n uploading: status === \"uploading\",\n })}\n >\n {isImage ? (\n <img className=\"file-image\" src={image} />\n ) : (\n <img className=\"file-icon\" src={icon} width={26} height={32} />\n )}\n <div className=\"file-content\">\n <div className=\"file-name\">{file.name}</div>\n <div className=\"file-metadata\">\n <span className=\"file-status\">\n {`${status === \"uploading\" ? t(K.UPLOADING) : status === \"failed\" ? t(K.UPLOAD_FAILED) : type}`}\n </span>\n {` · ${size}`}\n </div>\n </div>\n {buttonRemove}\n </li>\n );\n}\n","import { useCallback, useEffect, useRef, useState } from \"react\";\nimport { handleHttpError } from \"@next-core/runtime\";\nimport { http } from \"@next-core/http\";\nimport type { FileItem } from \"./FileUpload/interfaces\";\nimport type { UploadFileInfo, UploadOptions } from \"./interfaces\";\nimport { validateFiles } from \"./FileUpload/validateFiles\";\nimport { K, t } from \"./FileUpload/i18n\";\n\nlet uid = 0;\n\nexport function getNextUid() {\n return uid++;\n}\n\nexport function useFilesUploading(options?: UploadOptions) {\n const enabled = options?.enabled;\n const maxFiles = options?.maxFiles;\n const [files, setFiles] = useState<FileItem[] | undefined>();\n const hasFiles = !!files && files.length > 0;\n\n useEffect(() => {\n files?.forEach(async (fileItem) => {\n if (fileItem.status === \"ready\") {\n const abortController = new AbortController();\n\n setFiles((prevFiles) => {\n return prevFiles?.map((item) => {\n if (item.uid === fileItem.uid) {\n return { ...item, status: \"uploading\", abortController };\n }\n return item;\n });\n });\n\n try {\n const formData = new FormData();\n formData.append(\"file\", fileItem.file);\n\n const response = await http.request<{ data: UploadFileInfo }>(\n \"api/gateway/logic.llm.aiops_service/api/v1/elevo/files/upload\",\n {\n method: \"POST\",\n body: formData,\n signal: abortController.signal,\n },\n {\n interceptorParams: {\n ignoreLoadingBar: true,\n },\n }\n );\n\n setFiles((prevFiles) => {\n return prevFiles?.map((item) => {\n if (item.uid === fileItem.uid) {\n return {\n ...item,\n status: \"done\",\n fileInfo: response.data,\n };\n }\n return item;\n });\n });\n } catch (error) {\n setFiles((prevFiles) => {\n return prevFiles?.map((item) => {\n if (item.uid === fileItem.uid) {\n return { ...item, status: \"failed\" };\n }\n return item;\n });\n });\n handleHttpError(error);\n }\n }\n });\n }, [files]);\n\n const [allFilesDone, setAllFilesDone] = useState(true);\n const [fileInfos, setFileInfos] = useState<UploadFileInfo[] | undefined>();\n const initialRef = useRef(true);\n\n useEffect(() => {\n const allFilesDone =\n !files || files.every((file) => file.status === \"done\");\n setAllFilesDone(allFilesDone);\n if (initialRef.current) {\n initialRef.current = false;\n return;\n }\n if (allFilesDone) {\n setFileInfos(files?.map((file) => file.fileInfo!));\n }\n }, [files]);\n\n const appendFiles = useCallback(\n (newFiles: File[]) => {\n if (!validateFiles(newFiles, options!)) {\n return;\n }\n\n setFiles((prev) => {\n const prevList = prev ?? [];\n if (maxFiles && prevList.length + newFiles.length > maxFiles) {\n handleHttpError(t(K.MAX_FILES_EXCEEDED, { count: maxFiles }));\n return prev;\n }\n return [\n ...prevList,\n ...newFiles.map<FileItem>((file) => ({\n uid: getNextUid(),\n file,\n status: \"ready\",\n })),\n ];\n });\n },\n [maxFiles, options]\n );\n\n const resetFiles = useCallback(() => {\n setFiles(undefined);\n }, []);\n\n const removeFile = useCallback((uid: number) => {\n setFiles((prev) => prev?.filter((file) => file.uid !== uid));\n }, []);\n\n const exceeded = !!maxFiles && !!files && files.length >= maxFiles;\n\n const paste = useCallback(\n (e: React.ClipboardEvent<HTMLTextAreaElement>) => {\n if (!enabled) {\n return;\n }\n const fileList = e.clipboardData.files;\n if (fileList.length > 0 && enabled) {\n e.preventDefault();\n e.stopPropagation();\n const files = [...fileList];\n const allFilesAccepted = validateFiles(files, options!);\n if (allFilesAccepted) {\n appendFiles(files);\n }\n }\n },\n [enabled, options, appendFiles]\n );\n\n return {\n files,\n resetFiles,\n appendFiles,\n removeFile,\n hasFiles,\n allFilesDone,\n fileInfos,\n exceeded,\n paste,\n };\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.files{list-style:none;margin:0;padding:4px 0 0;position:absolute;display:flex;gap:8px;top:10px;left:16px;right:16px;overflow-x:auto}.file{background:rgba(0,0,0,0.04);border-radius:6px;display:flex;width:200px;height:60px;align-items:center;padding:0 8px;position:relative}.file.uploading::before{content:\"\";position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,0.06);border-radius:6px;animation:loadingAnimation 1.5s linear infinite}@keyframes loadingAnimation{0%{right:100%}100%{right:0}}.file-content{min-width:0;flex:1}.file-icon{margin:0 11px 0 6px}.file-image{margin-right:8px;object-fit:container;border-radius:4px;max-width:44px;max-height:44px}.file-name,\n.file-metadata{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-name{color:rgba(0,0,0,0.88)}.file-metadata{color:rgba(0,0,0,0.45);font-size:12px;margin-top:3px}.file-remove{position:absolute;top:-4px;right:-4px;font-size:12px;padding:1px;display:flex;color:rgba(0,0,0,0.88);cursor:pointer;background:#fff;border-radius:14px}.file:not(:hover) .file-remove{display:none}.btn-add-file{border-radius:6px;border:1px dashed rgba(0,0,0,0.1);color:rgba(0,0,0,0.45);font-size:16px;display:flex;width:60px;height:60px;align-items:center;justify-content:center;cursor:pointer}.btn-add-file:hover{background:rgba(0,0,0,0.04)}.file.failed .file-status{color:var(--color-error)}.file.as-image{width:60px;border:1px solid rgba(0,0,0,0.1);padding:0;background:none;justify-content:center}.file.as-image .file-image{max-width:100%;max-height:100%;margin:0;border-radius:6px}.file.as-image.failed{border-color:#f24c25}.file-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,10,26,0.45);border-radius:6px;color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;font-size:20px}.file.failed .file-overlay{background:rgba(0,10,26,0.7);color:#ff754f;font-size:12px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","import React, { forwardRef, useImperativeHandle, useRef } from \"react\";\nimport type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport type { IconButton, IconButtonProps } from \"../../icon-button\";\nimport { K, t } from \"./i18n\";\n\nconst WrappedIconButton = wrapBrick<IconButton, IconButtonProps>(\n \"ai-portal.icon-button\"\n);\n\nconst ICON_UPLOAD: GeneralIconProps = {\n lib: \"lucide\",\n icon: \"paperclip\",\n};\n\nexport interface UploadButtonProps {\n accept?: string;\n disabled?: boolean;\n onChange?: (files: File[]) => void;\n}\n\nexport interface UploadButtonRef {\n requestUpload: () => void;\n}\n\nexport const UploadButton = forwardRef(LegacyUploadButton);\n\nfunction LegacyUploadButton(\n { accept, disabled, onChange }: UploadButtonProps,\n ref: React.Ref<UploadButtonRef>\n) {\n const inputRef = useRef<HTMLInputElement>(null);\n\n const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const files = e.target.files;\n if (files) {\n onChange?.(Array.from(files));\n }\n e.target.value = \"\";\n };\n\n useImperativeHandle(ref, () => ({\n requestUpload: () => {\n inputRef.current?.click();\n },\n }));\n\n return (\n <>\n <input\n type=\"file\"\n accept={accept}\n multiple\n hidden\n ref={inputRef}\n onChange={handleInputChange}\n onClick={(e) => {\n e.stopPropagation();\n }}\n />\n <WrappedIconButton\n variant=\"light\"\n className=\"btn-upload\"\n icon={ICON_UPLOAD}\n tooltip={t(K.UPLOAD_FILES)}\n disabled={disabled}\n onClick={(e) => {\n e.stopPropagation();\n inputRef.current?.click();\n }}\n />\n </>\n );\n}\n","const HIDDEN_STYLE = `\n min-height: 0!important;\n max-height: none!important;\n height: 0!important;\n visibility: hidden!important;\n overflow: hidden!important;\n position: absolute!important;\n z-index: -1000!important;\n top: 0!important;\n left: 0!important;\n pointer-events: none!important;\n`;\n\nconst SIZING_STYLE = [\n \"letter-spacing\",\n \"line-height\",\n \"padding-top\",\n \"padding-bottom\",\n \"font-family\",\n \"font-weight\",\n \"font-size\",\n \"font-variant\",\n \"text-rendering\",\n \"text-transform\",\n \"width\",\n \"text-indent\",\n \"padding-left\",\n \"padding-right\",\n \"border-width\",\n \"box-sizing\",\n \"word-break\",\n \"white-space\",\n];\n\n/**\n * 创建一个镜像元素,用于计算光标位置或文本尺寸。\n */\nexport function getMirroredStyle(element: HTMLElement) {\n const uiTextNodeStyle = window.getComputedStyle(element);\n const sizingStyle = SIZING_STYLE.map(\n (name) => `${name}:${uiTextNodeStyle.getPropertyValue(name)}`\n ).join(\";\");\n return `${sizingStyle};${HIDDEN_STYLE}`;\n}\n","// istanbul ignore file\nimport type React from \"react\";\nimport { getMirroredStyle } from \"./getMirroredStyle.js\";\n\nlet hiddenTextarea: HTMLTextAreaElement | undefined;\n\nexport interface AutoSizeOptions {\n minRows?: number | null;\n maxRows?: number | null;\n borderSize?: number;\n paddingSize?: number;\n}\n\n/**\n * 计算 textarea 高度\n * https://github.com/react-component/textarea/blob/1c0026fbe30e5f7dff1fca695b2cf262246381ca/src/calculateNodeHeight.tsx\n */\nexport default function calculateAutoSizeStyle(\n uiTextNode: HTMLTextAreaElement,\n options?: AutoSizeOptions\n): React.CSSProperties {\n const {\n minRows = null,\n maxRows = null,\n borderSize = 2,\n paddingSize = 8,\n } = options ?? {};\n\n if (!hiddenTextarea) {\n hiddenTextarea = document.createElement(\"textarea\");\n hiddenTextarea.setAttribute(\"tab-index\", \"-1\");\n hiddenTextarea.setAttribute(\"aria-hidden\", \"true\");\n document.body.appendChild(hiddenTextarea);\n }\n\n // equal style\n hiddenTextarea.setAttribute(\"style\", getMirroredStyle(uiTextNode));\n hiddenTextarea.value = uiTextNode.value || uiTextNode.placeholder || \"\";\n\n let minHeight: number | undefined;\n let maxHeight: number | undefined;\n let overflowY: React.CSSProperties[\"overflowY\"];\n\n let height = hiddenTextarea.scrollHeight + borderSize;\n\n if (minRows !== null || maxRows !== null) {\n const singleRowHeight =\n process.env.NODE_ENV === \"test\"\n ? 22\n : parseFloat(\n window\n .getComputedStyle(hiddenTextarea)\n .getPropertyValue(\"line-height\")\n );\n if (minRows !== null) {\n minHeight = singleRowHeight * minRows + paddingSize + borderSize;\n height = Math.max(minHeight, height);\n }\n if (maxRows !== null) {\n maxHeight = singleRowHeight * maxRows + paddingSize + borderSize;\n if (height <= maxHeight) {\n overflowY = \"hidden\";\n }\n height = Math.min(maxHeight, height);\n }\n }\n\n const style: React.CSSProperties = {\n height,\n overflowY,\n resize: \"none\",\n };\n\n if (minHeight) {\n style.minHeight = minHeight;\n }\n if (maxHeight) {\n style.maxHeight = maxHeight;\n }\n\n return style;\n}\n","import React, {\n useCallback,\n useEffect,\n useImperativeHandle,\n useLayoutEffect,\n useRef,\n useState,\n} from \"react\";\nimport { flushSync } from \"react-dom\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport calculateAutoSizeStyle from \"./utils/calculateAutoSizeStyle.js\";\n\n// istanbul ignore next\nconst modKey = /Mac|iPod|iPhone|iPad/.test(navigator.platform)\n ? \"metaKey\"\n : \"ctrlKey\";\n\nexport interface TextareaAutoResizeProps\n extends React.DetailedHTMLProps<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HTMLTextAreaElement\n > {\n /** @default true */\n autoResize?: boolean;\n minRows?: number | null;\n maxRows?: number | null;\n /** @default 2 */\n borderSize?: number;\n /** @default 8 */\n paddingSize?: number;\n containerRef?: React.RefObject<HTMLElement>;\n submitWhen?: \"enter-without-shift\" | \"enter-with-mod\";\n desiredSelectionRef?: React.MutableRefObject<{\n start: number;\n end: number;\n } | null>;\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void;\n /**\n * The handler can return false to prevent default behavior (submit)\n */\n onKeyDown?: (e: React.KeyboardEvent<HTMLTextAreaElement>) => void | false;\n}\n\nexport interface TextareaAutoResizeRef {\n focus(): void;\n element: HTMLTextAreaElement | null;\n}\n\nexport const TextareaAutoResize = React.forwardRef<\n TextareaAutoResizeRef,\n TextareaAutoResizeProps\n>(LegacyTextareaAutoResize);\n\nfunction LegacyTextareaAutoResize(\n {\n autoResize: _autoResize,\n minRows,\n maxRows,\n borderSize,\n paddingSize,\n containerRef,\n value: propValue,\n style,\n submitWhen,\n desiredSelectionRef,\n onChange,\n onSubmit,\n onKeyDown,\n onCompositionStart,\n onCompositionEnd,\n ...props\n }: TextareaAutoResizeProps,\n ref: React.ForwardedRef<TextareaAutoResizeRef>\n): React.JSX.Element {\n const autoResize = _autoResize ?? true;\n const [value, setValue] = useState(propValue ?? \"\");\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const [autoStyle, setAutoStyle] = useState<React.CSSProperties | null>(null);\n\n useImperativeHandle(\n ref,\n () => ({\n focus: () => {\n const textarea = textareaRef.current;\n // istanbul ignore else: defensive check\n if (textarea) {\n const valueLength = textarea.value?.length;\n textarea.focus();\n valueLength && textarea.setSelectionRange(valueLength, valueLength);\n }\n },\n element: textareaRef.current,\n }),\n []\n );\n\n const doAutoResize = useCallback(() => {\n const textarea = textareaRef.current;\n if (textarea && autoResize) {\n const style = calculateAutoSizeStyle(textarea, {\n minRows,\n maxRows,\n borderSize,\n paddingSize,\n });\n // istanbul ignore next\n if (process.env.NODE_ENV === \"test\") {\n setAutoStyle(style);\n } else {\n flushSync(() => {\n setAutoStyle(style);\n });\n }\n }\n }, [autoResize, maxRows, minRows, borderSize, paddingSize]);\n\n const handleInputChange = (\n e: React.ChangeEvent<HTMLTextAreaElement>\n ): void => {\n setValue(e.target.value);\n onChange?.(e);\n };\n\n useEffect(() => {\n setValue(propValue ?? \"\");\n }, [propValue]);\n\n useEffect(() => {\n doAutoResize();\n }, [doAutoResize, value]);\n\n const compositionRef = useRef(false);\n\n const handleCompositionStart = useCallback(\n (e: React.CompositionEvent<HTMLTextAreaElement>) => {\n compositionRef.current = true;\n onCompositionStart?.(e);\n },\n [onCompositionStart]\n );\n\n const handleCompositionEnd = useCallback(\n (e: React.CompositionEvent<HTMLTextAreaElement>) => {\n compositionRef.current = false;\n onCompositionEnd?.(e);\n },\n [onCompositionEnd]\n );\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent<HTMLTextAreaElement>) => {\n if (compositionRef.current) {\n // Ignore key events during composition\n return;\n }\n\n if (onKeyDown?.(e) === false) {\n return;\n }\n\n if (\n e.key === \"Enter\" &&\n (submitWhen === \"enter-without-shift\"\n ? !e.shiftKey\n : submitWhen === \"enter-with-mod\" && e[modKey])\n ) {\n e.preventDefault();\n e.stopPropagation();\n onSubmit?.(e);\n }\n },\n [onKeyDown, onSubmit, submitWhen]\n );\n\n useLayoutEffect(() => {\n const desiredSelection = desiredSelectionRef?.current;\n const textarea = textareaRef.current;\n if (desiredSelection && textarea) {\n const { start, end } = desiredSelection;\n desiredSelectionRef.current = null;\n textarea.setSelectionRange(start, end);\n }\n }, [desiredSelectionRef, value]);\n\n // istanbul ignore next\n useEffect(() => {\n const container = containerRef?.current;\n if (!container || !autoResize) {\n return;\n }\n let previousInlineSize: number | undefined;\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n if (entry.target === container) {\n // istanbul ignore next: compatibility\n const currentInlineSize = entry.contentBoxSize\n ? entry.contentBoxSize[0]\n ? entry.contentBoxSize[0].inlineSize\n : (entry.contentBoxSize as unknown as ResizeObserverSize)\n .inlineSize\n : entry.contentRect.width;\n if (\n currentInlineSize !== undefined &&\n currentInlineSize !== previousInlineSize\n ) {\n const isInitial = !previousInlineSize;\n previousInlineSize = currentInlineSize;\n if (!isInitial) {\n requestAnimationFrame(doAutoResize);\n }\n }\n }\n }\n });\n observer.observe(container);\n return () => {\n observer.disconnect();\n };\n }, [autoResize, containerRef, doAutoResize]);\n\n return (\n <textarea\n {...props}\n ref={textareaRef}\n value={value}\n style={{\n ...style,\n ...autoStyle,\n }}\n onChange={handleInputChange}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n onKeyDown={handleKeyDown}\n />\n );\n}\n"],"names":["K","NS","t","i18n","getFixedT","initializeI18n","en","UPLOAD_FILES","UPLOADING","UPLOAD_FAILED","DROP_FILES_HERE","SUPPORTED_FILE_TYPES","UNSUPPORTED_FILE_TYPE","MAX_SIZE_EXCEEDED","MAX_SIZE_EXCEEDED_UNKNOWN","MAX_FILES_EXCEEDED","zh","validateFiles","files","options","acceptedTypes","accept","split","map","type","trim","file","mimeType","some","startsWith","name","toLowerCase","endsWith","baseType","handleHttpError","readableAccept","types","maxSize","size","readableMaxSize","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","locals","undefined","GlobalDragOverlay","_ref","disabled","uploadOptions","onFilesDropped","isDragging","setIsDragging","useState","dragCounterRef","useRef","useEffect","current","handleDragEnter","e","_e$dataTransfer","preventDefault","stopPropagation","target","composedPath","HTMLElement","tagName","Array","from","dataTransfer","items","item","kind","handleDragLeave","handleDragOver","handleDrop","length","window","addEventListener","removeEventListener","createPortal","React","className","styles","overlay","src","dragImage","width","height","title","description","dragTips","document","body","___CSS_LOADER_EXPORT___","push","module","id","WrappedIcon","wrapBrick","UploadedFiles","maxFiles","onRemove","onAdd","showAsImage","every","classNames","onClick","FileComponent","_extends","key","uid","lib","icon","_ref2","status","abortController","getFileTypeAndIcon","formatFileSize","isImage","image","setImage","url","URL","createObjectURL","revokeObjectURL","buttonRemove","theme","failed","spinning","uploading","useFilesUploading","enabled","setFiles","hasFiles","forEach","async","fileItem","AbortController","prevFiles","formData","FormData","append","response","http","request","method","signal","interceptorParams","ignoreLoadingBar","fileInfo","data","error","allFilesDone","setAllFilesDone","fileInfos","setFileInfos","initialRef","appendFiles","useCallback","newFiles","prev","prevList","count","resetFiles","removeFile","filter","exceeded","paste","fileList","clipboardData","toString","WrappedIconButton","ICON_UPLOAD","UploadButton","forwardRef","LegacyUploadButton","ref","onChange","inputRef","useImperativeHandle","requestUpload","_inputRef$current","click","multiple","hidden","value","variant","tooltip","_inputRef$current2","HIDDEN_STYLE","SIZING_STYLE","getMirroredStyle","element","uiTextNodeStyle","getComputedStyle","getPropertyValue","join","hiddenTextarea","modKey","test","navigator","platform","TextareaAutoResize","LegacyTextareaAutoResize","autoResize","_autoResize","minRows","maxRows","borderSize","paddingSize","containerRef","propValue","style","submitWhen","desiredSelectionRef","onSubmit","onKeyDown","onCompositionStart","onCompositionEnd","props","setValue","textareaRef","autoStyle","setAutoStyle","focus","textarea","_textarea$value","valueLength","setSelectionRange","doAutoResize","uiTextNode","minHeight","maxHeight","overflowY","createElement","setAttribute","appendChild","placeholder","scrollHeight","singleRowHeight","parseFloat","Math","max","min","resize","calculateAutoSizeStyle","flushSync","compositionRef","handleCompositionStart","handleCompositionEnd","handleKeyDown","shiftKey","useLayoutEffect","desiredSelection","start","end","container","previousInlineSize","observer","ResizeObserver","entries","entry","currentInlineSize","contentBoxSize","inlineSize","contentRect","isInitial","requestAnimationFrame","observe","disconnect"],"sourceRoot":""}