From 811b8e98da9b63e8114cf40dc1cf7d596e784918 Mon Sep 17 00:00:00 2001 From: Harsh | Push Date: Thu, 2 May 2024 15:09:33 +0400 Subject: [PATCH] Uiweb restapi fixes (#1249) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Chat Preview List workable PoC (#987) * fix: revert space changes * fix: merge main * fix: signer compatibility with viem and ethers (#567) * fix: signer compatibility with viem and ethers * fix: revert space changes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.26 * Update README.md * Update README.md * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.3 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.27 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.4 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.5 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.6 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.7 * fix: add: scw sig verification (#593) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.28 * fix: url correction * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.29 * ci(socket): šŸŽ‰ cut release to socket-v0.5.2 * fix: fixed subscribe and unsubscribe * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.5 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.8 * Feat/chat components (#621) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson * fix: add alpha support to UI web * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.0 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.6 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.9 * Feat/chat components (#625) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.1 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.7 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.8 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.10 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.9 * 632 group access control sdk changes (#640) * fix: group access control changes * fix: get group access SDK fix * fix: removed unnecessary param * Update README.md * Update README.md * Update README.md * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.30 * Reduce profile creation signature to 2 (#639) * fix: reduced signatures * fix: fixed examples * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.31 * fix: Read me fixes * fix: Space rules * Update README.md * Update README.md * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.32 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.10 * Feat/chat components (#658) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) --------- Co-authored-by: Monalisha Mishra Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Kolade * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.11 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.12 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.11 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.13 * fix: update read me file * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.14 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.15 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.12 * Feat/chat components (#679) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) * Connect btn revamp (#668) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container * feat: adding rainbowkit for btn * fix: fix issues * fix: addec onnect functionality * fix: connect button * fix: added hack for rainbowkit css --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * Typebar UI issue (#666) * fix: fixed typebar space not working and theme * fix: fixed gif and emoji --------- Co-authored-by: KlausMikhaelson * fix: fixed theme colours * fix: added theme for brb * fix: added filter hat * fix: merged with main * fix: fixed msg border * fix: fixed theme * fix: fixed fonts * fix: fixed bug * Access control (#672) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added minor fix --------- Co-authored-by: Monalisha Mishra * fix: fixed padding issues * fix(f): fixed build issues * fix: fix for chat status test * Check rules access control (#678) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * 662 group access control v2 changes (#663) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix: origin in user creation (#665) * fix: origin in user creation * Update README.md * fix: review comments * 662 group access control v2 changes (#677) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix(spaces): broadcast changes and UX fixes (#674) * fix: fix UI grid view (#642) * fix: fix UI grid view * refactor: conditional added * fix: resolved muting/unmuting try catch error (#657) * fix(spaces): fix livepeer broadcast (#656) * fix(spaces): fix livepeer broadcast * fix(spaces): fix data shown for unjoined space & promote listener logic --------- Co-authored-by: Madhur Gupta * refactor(spaces): use local state instead of get from server while meta message fire (#676) --------- Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * feat: added verification option to show only on token gated groups * fix: fixing group access control --------- Co-authored-by: Monalisha Mishra Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * fix: fixed build --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Kolade Co-authored-by: Nilesh Gupta Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.2 * fix: dummy change * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.13 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.16 * Join group option (#681) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * Connect btn revamp (#668) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container * feat: adding rainbowkit for btn * fix: fix issues * fix: addec onnect functionality * fix: connect button * fix: added hack for rainbowkit css --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * Typebar UI issue (#666) * fix: fixed typebar space not working and theme * fix: fixed gif and emoji --------- Co-authored-by: KlausMikhaelson * fix: fixed theme colours * fix: added theme for brb * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added filter hat * fix: merged with main * fix: fixed msg border * fix: fixed theme * fix: fixed fonts * fix: fixed bug * Access control (#672) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added minor fix --------- Co-authored-by: Monalisha Mishra * fix: fixed padding issues * fix(f): fixed build issues * fix: fix for chat status test * feat: added verification option to show only on token gated groups * fix: fixing group access control * Check rules access control (#678) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * 662 group access control v2 changes (#663) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix: origin in user creation (#665) * fix: origin in user creation * Update README.md * fix: review comments * 662 group access control v2 changes (#677) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix(spaces): broadcast changes and UX fixes (#674) * fix: fix UI grid view (#642) * fix: fix UI grid view * refactor: conditional added * fix: resolved muting/unmuting try catch error (#657) * fix(spaces): fix livepeer broadcast (#656) * fix(spaces): fix livepeer broadcast * fix(spaces): fix data shown for unjoined space & promote listener logic --------- Co-authored-by: Madhur Gupta * refactor(spaces): use local state instead of get from server while meta message fire (#676) --------- Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * feat: added verification option to show only on token gated groups * fix: fixing group access control --------- Co-authored-by: Monalisha Mishra Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * fix: fixed build * feat: added send request to join group * fix: fixed verification on send * fix: fixed verify access btn not showing after joining group * fix: fixed join group showing for members too * fix: fixed join group showing to members * 667 chat.send enhancement (#673) * fix: changes messageObj for meta and reaction message type * fix: enhance send fn * fix: fixed intent issues * 680 group rules cosmetic changes (#682) * fix: fixed guild condition * fix: add did validation * fix: fixed * fix: fixed minor issues * fix: fixe dissue * fix: fixed minor issues * fix: check for scroll * fix: fixed scrolling * fix: fixed theme * fix: fixed * fix: fixed * fix: fixed * fix: fixed issues * fix: fixed * feat: added toast in join group btn for pvt groups * fix: fixed blurr --------- Co-authored-by: Monalisha Mishra Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> Co-authored-by: Kolade Co-authored-by: Nilesh Gupta Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Aman Gupta * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.3 * Join group option (#687) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * Connect btn revamp (#668) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container * feat: adding rainbowkit for btn * fix: fix issues * fix: addec onnect functionality * fix: connect button * fix: added hack for rainbowkit css --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * Typebar UI issue (#666) * fix: fixed typebar space not working and theme * fix: fixed gif and emoji --------- Co-authored-by: KlausMikhaelson * fix: fixed theme colours * fix: added theme for brb * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added filter hat * fix: merged with main * fix: fixed msg border * fix: fixed theme * fix: fixed fonts * fix: fixed bug * Access control (#672) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added minor fix --------- Co-authored-by: Monalisha Mishra * fix: fixed padding issues * fix(f): fixed build issues * fix: fix for chat status test * feat: added verification option to show only on token gated groups * fix: fixing group access control * Check rules access control (#678) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * 662 group access control v2 changes (#663) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix: origin in user creation (#665) * fix: origin in user creation * Update README.md * fix: review comments * 662 group access control v2 changes (#677) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix(spaces): broadcast changes and UX fixes (#674) * fix: fix UI grid view (#642) * fix: fix UI grid view * refactor: conditional added * fix: resolved muting/unmuting try catch error (#657) * fix(spaces): fix livepeer broadcast (#656) * fix(spaces): fix livepeer broadcast * fix(spaces): fix data shown for unjoined space & promote listener logic --------- Co-authored-by: Madhur Gupta * refactor(spaces): use local state instead of get from server while meta message fire (#676) --------- Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * feat: added verification option to show only on token gated groups * fix: fixing group access control --------- Co-authored-by: Monalisha Mishra Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * fix: fixed build * feat: added send request to join group * fix: fixed verification on send * fix: fixed verify access btn not showing after joining group * fix: fixed join group showing for members too * fix: fixed join group showing to members * 667 chat.send enhancement (#673) * fix: changes messageObj for meta and reaction message type * fix: enhance send fn * fix: fixed intent issues * 680 group rules cosmetic changes (#682) * fix: fixed guild condition * fix: add did validation * fix: fixed * fix: fixed minor issues * fix: fixe dissue * fix: fixed minor issues * fix: check for scroll * fix: fixed scrolling * fix: fixed theme * fix: fixed * fix: fixed * fix: fixed * fix: fixed issues * fix: fixed * feat: added toast in join group btn for pvt groups * fix: fixed blurr * fix: fixed minor issues rules * fix: fixed * fix: fixed --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Kolade Co-authored-by: Nilesh Gupta Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Aman Gupta * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.4 * Join group option (#688) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * Connect btn revamp (#668) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container * feat: adding rainbowkit for btn * fix: fix issues * fix: addec onnect functionality * fix: connect button * fix: added hack for rainbowkit css --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * Typebar UI issue (#666) * fix: fixed typebar space not working and theme * fix: fixed gif and emoji --------- Co-authored-by: KlausMikhaelson * fix: fixed theme colours * fix: added theme for brb * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added filter hat * fix: merged with main * fix: fixed msg border * fix: fixed theme * fix: fixed fonts * fix: fixed bug * Access control (#672) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added minor fix --------- Co-authored-by: Monalisha Mishra * fix: fixed padding issues * fix(f): fixed build issues * fix: fix for chat status test * feat: added verification option to show only on token gated groups * fix: fixing group access control * Check rules access control (#678) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * 662 group access control v2 changes (#663) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix: origin in user creation (#665) * fix: origin in user creation * Update README.md * fix: review comments * 662 group access control v2 changes (#677) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix(spaces): broadcast changes and UX fixes (#674) * fix: fix UI grid view (#642) * fix: fix UI grid view * refactor: conditional added * fix: resolved muting/unmuting try catch error (#657) * fix(spaces): fix livepeer broadcast (#656) * fix(spaces): fix livepeer broadcast * fix(spaces): fix data shown for unjoined space & promote listener logic --------- Co-authored-by: Madhur Gupta * refactor(spaces): use local state instead of get from server while meta message fire (#676) --------- Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * feat: added verification option to show only on token gated groups * fix: fixing group access control --------- Co-authored-by: Monalisha Mishra Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * fix: fixed build * feat: added send request to join group * fix: fixed verification on send * fix: fixed verify access btn not showing after joining group * fix: fixed join group showing for members too * fix: fixed join group showing to members * 667 chat.send enhancement (#673) * fix: changes messageObj for meta and reaction message type * fix: enhance send fn * fix: fixed intent issues * 680 group rules cosmetic changes (#682) * fix: fixed guild condition * fix: add did validation * fix: fixed * fix: fixed minor issues * fix: fixe dissue * fix: fixed minor issues * fix: check for scroll * fix: fixed scrolling * fix: fixed theme * fix: fixed * fix: fixed * fix: fixed * fix: fixed issues * fix: fixed * feat: added toast in join group btn for pvt groups * fix: fixed blurr * fix: fixed minor issues rules * fix: fixed * fix: fixed * fix: fixed socket issue * fix: fixed --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Kolade Co-authored-by: Nilesh Gupta Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Aman Gupta * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.5 * fix: fixed (#689) * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.6 * chat Load issue fixed (#690) * fix: fixed * fix: fixed minor issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.7 * fix: fixed msg bubble width (#691) * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.8 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.17 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.18 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.19 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.33 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.33 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.9 * Onboarding blocknative (#702) * fix: added reusable folder * fix: fixed theme for modal * fix: removed reusables from export * fix: fixed fallback for message input * feat: replaced rainbowkit with blocknative * fix: removed unused code --------- Co-authored-by: Monalisha Mishra * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.10 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.33 * Fix connect button issue (#710) * fix: fixed connect button blocknative * fix: fixed message fetching * fix: removed console * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.11 * fix: added condition while showing tokengatedIcon (#715) * fix: added disconnect for wallet (#721) * fix: added disconnect for wallet * fix: added autoConnect * Wallet disconnect (#722) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * Wallet disconnect (#723) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * fix: fixed errors * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.12 * Changed messageInput params Case (#725) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * fix: fixed errors * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.13 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.20 * Wallet disconnect (#728) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * fix: fixed errors * fix: added coinbase wallet * fix: img added * fix: fixed metamask not showing if not present in it --------- Co-authored-by: KlausMikhaelson * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.14 * Wallet disconnect (#732) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * fix: fixed errors * fix: added coinbase wallet * fix: img added * fix: fixed metamask not showing if not present in it * fix: fixed injected wallets --------- Co-authored-by: KlausMikhaelson * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.15 * fix: added class based implementation for notification (#699) * fix: added class based implementation for notification * fix: class based implementation for notification * fix: small fixes * fix: minor fixes and testcases * fix: fixes for testcases * fix: updated core abi and minor fixes * fix: removed comment * fix: minor fixes and additional checks * fix: minor fixes * fix: viem support for contract and new folder structure * fix: changed typescript 5.0.2 and configured eslint * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.34 * 720 pushstream class implementation (#729) * chore: added an example of automated chat using the new class based initialization * fix: fixed usecases * chore: added an example of automated chat using the new class based iā€¦ (#712) * chore: added an example of automated chat using the new class based initialization * fix: fixed usecases --------- Co-authored-by: aman035 * chore(automated chat example): tweaked automated chat example * fix: stream changes * fix: stream changes * fix: added chat.decrypt (#726) * fix: added chat.decrypt * fix: fix examples * fix: stream changes * fix: PUSH Stream Changes * fix: chat classes split * fix: Notification socket initialisations and rules backward compatibility * fix: added message decrypt * fix: review comments * fix: socket events * fix: test case fix and UserInfo to user * fix: rip PushNotification class * fix: additional check --------- Co-authored-by: harshrajat Co-authored-by: aman035 Co-authored-by: Harsh | Push Co-authored-by: akp111 * fix: remove only from test * fix: error fixed * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.35 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.35 * fix: stream cases * 720 pushstream class implementation (#737) * fix: stream changes * fix: stream changes * fix: stream changes * fix: PUSH Stream Changes * fix: chat classes split * fix: Notification socket initialisations and rules backward compatibility * fix: added message decrypt * fix: review comments * fix: socket events * fix: test case fix and UserInfo to user * fix: rip PushNotification class * fix: additional check * fix: minor fixes --------- Co-authored-by: Mohammed S * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.21 * fix: corrected example * fix: some changes on stream * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.36 * fix: minor fixes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.37 * fix: error handling in socket events * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.38 * fix: more fixes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.39 * fix: minor fixes * fix: socket enabled * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.40 * fix: minor fixes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.41 * Add counter for update channel (#740) * fix: added counter to update group * fix: added counter logic, moved delegate and alias function to channel class * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.42 * Add counter for update channel (#741) * fix: added counter to update group * fix: added counter logic, moved delegate and alias function to channel class * fix: added readme for notification * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.43 * fix: minor fix * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.14 * fix: log removed * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.44 * docs: fix tests * Feat/space backup (#746) * refactor: added code for joining livekit room for listeners (#731) * feat: drop in livekit inplace of livepeer (#736) * feat: drop in livekit inplace of livepeer * feat: added microphone * feat: added mic * feat: added access control --------- Co-authored-by: Nilesh Gupta * fix: Notification event mutation * Notification setting changes (#752) * Arbitrum changes (#735) * fix: inital implementation for arbitrum changes * fix: more changes * fix: added final changes * fix: minor fixes * fix: fixed typo * fix: notification settings related changes * fix: added index parameter for notification * fix: restored config * Arnab/livekit fixes (#754) * refactor: added code for joining livekit room for listeners (#731) * feat: drop in livekit inplace of livepeer * feat: added microphone * feat: added mic * feat: added access control * feat: fixes for livekit API call --------- Co-authored-by: Nilesh Gupta * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.22 * fix: added settings * fix: added settings (#762) * fix: build fix * fix: minor fix * fix: minor fix * Added initial chat sidebar * fix: pagination done * fix: added fuse network * Working stream with hacks, working badges, working loading, partial loading, not working accept stream * fix: focus back to message input after sending the message (#1014) * fix: added support for ens (#1008) * feat: add video SDK v2 and video stream (#1017) * add: ethers support (#952) * fix: fix viem support, add ethers support * fix: remove @pushprotocol/socket dependency from restapi * fix: changed ethers fn * fix: fix ether changes * fix: fix subscribev2 * chore: readme changes * fix: fix ethers provider issue * fix: fix channel.update * feat(video-v2): add video v2 class and stream (#930) * feat(video-v2): add highlevel video class * feat(video): add video stream * fix(sendnotification): modify rules.access.data to be an object & code cleanup * fix(video): remove signer from input, throw err if signer, decrypted pgp key not found * feat(video): add sendNotification calls in connect, disconnect methods * fix(videonotificationrules): typo in VideoNotificationRules interface * feat(video stream): handle connect, retry internally from the SDK * feat(video connect): remove the connect method from the videov2 SDK * fix(videov2): create push signer instance to get chain id in initialize() * fix(video stream): add backwards compatibilty to rules object for older SDK versions * fix(video stream): fix bug in rules object creation * feat(video): update param names for video.initialize() * feat(video): add internal event handlers for stream in video SDK --------- Co-authored-by: Mohammed S --------- Co-authored-by: Aman Gupta Co-authored-by: Mohammed S * fix: Added ethersV6SignerType in uiweb signer types (#1018) * fix: added pushUser and stream (#1023) * fix: case sensative file inclusion (#1024) * fix: added themisation and ens resolve * fix: fixed a bug * 963 improvement proposal support for fuse network (#1026) * fix: case sensative file inclusion * fix: changed icon dimesnion * streaming tweaks * streaming tweaks with connected in restapi * fix(video stream): add video event type enum in CONSTANTS (#1032) * fix: added search for chatPreviewList * fix: added error codes * frontend react demo adjustment and rebasing * duplicate import fix * fix: refatored code * fix: changed chatSender to chatParticipant * adding onChatSelected and onUnreadCountChange * fix: name change fix --------- Co-authored-by: aman035 Co-authored-by: Mohammed S Co-authored-by: Mohammed S Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta Co-authored-by: Monalisha Mishra Co-authored-by: Kolade Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Ashis Kumar Pradhan <38760485+akp111@users.noreply.github.com> Co-authored-by: akp111 Co-authored-by: Pritipriya Singh * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * fix: fixed issues on chatpreviewlist (#1044) * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * fix: added a dynamic component for no chatId (#1042) * fix: changed pushUser to user (#1058) * Chatpreview bug (#1063) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * fix: fixed pagination bug and added functions for preload * fix: added review comments --------- Co-authored-by: Mohammed S * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * fix: fixed minor limit bug (#1065) * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * Bug fix (#1068) * fix: fixed minor limit bug * fix: exposed chatParticipant * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.4 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.2.5 * Chatprofile (#1040) * Added initial chat sidebar * fix: pagination done * Working stream with hacks, working badges, working loading, partial loading, not working accept stream * fix: added themisation and ens resolve * fix: fixed a bug * streaming tweaks * streaming tweaks with connected in restapi * fix: added search for chatPreviewList * fix: added error codes * frontend react demo adjustment and rebasing * duplicate import fix * fix: refatored code * fix: addec chat profile and create group changes * fix: changed chatSender to chatParticipant * fix: fixed scroll when not needed * fix: changed group size * fix: stream not getting connected * fix: tested socket events * fix: fixed bugs --------- Co-authored-by: harshrajat Co-authored-by: Pritipriya Singh Co-authored-by: KlausMikhaelson * fix: fixed preview bugs (#1078) * Userprofile (#1084) * feat(video-v2): add highlevel video class * feat(video): add video stream * fix(sendnotification): modify rules.access.data to be an object & code cleanup * fix(video): remove signer from input, throw err if signer, decrypted pgp key not found * feat(video): add sendNotification calls in connect, disconnect methods * fix(videonotificationrules): typo in VideoNotificationRules interface * add: useStream.ts video-v2-example-app * add: videoV2.tsx in video-v2-example-app * feat(video stream): handle connect, retry internally from the SDK * feat(video connect): remove the connect method from the videov2 SDK * fix(videov2): create push signer instance to get chain id in initialize() * fix(videov2-example): refactor react example component & remove useStream hook * fix(video stream): add backwards compatibilty to rules object for older SDK versions * fix(video stream): fix bug in rules object creation * fix(video stream): call connect() for ApproveVideo event * feat(example-video-1.5): video v2 example app implementation * feat(sdk-frontend): few ui changes * fix(video-v2-example-app): initialisevdeo call after a call ends * feat(video stream): add request, deny evennt handlers * feat(sdk-frontend and sdk-frontend-react): added video-v2 example implementation * fix: few fixes * refactor: refator and remove console logs * fix: fix import error * feat(video): update param names for video.initialize() * fix: param name changes * chore: added few comments * chore: ui toast added * fix(video example): remove pushprotocol sdk direct dir reference for initVideoCallData * fix(video example): import React in examples & update SDK version in sdk-frontend * feat(video example): replace video events from CONSTANTS obj * Edited video example to make it more versatile * Update index.js * fix: added layout for userProfile * fix: added modal * fix: added modal * fix: added modal content * fix: added theme for userprofile * fix: fixed bugs in profile --------- Co-authored-by: Madhur Gupta Co-authored-by: Siddesh Sankhya <79219618+Siddesh7@users.noreply.github.com> Co-authored-by: Siddesh Co-authored-by: harshrajat Co-authored-by: Harsh | Push * fix: removed console * fix: fixed length issue in test * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * fix: fixed pagination bug * fix: the messages disappearing on scroll (#1077) Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: fixed chat preview stream issues (#1085) * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.5 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.6 * 897 improvement proposal spaces high level functions (#898) * fix: spaces high level * fix: spaces high level function * fix: spaces test cases * fix: spaces stream changes * fix: removed unnecessary logs * Add spaces high level audio methods (#993) * feat(spaces): add high level audio methods * fix: socket url fix (#995) * feat(spaces-highlevel-audio-methods): add media function in Spaces class --------- Co-authored-by: Mohammed S * feat(space stream): add 'start', 'stop' events (#1027) * fix(high level spaces sdk): fix list() method to uses spaces(), requests() methods (#1061) --------- Co-authored-by: Madhur Gupta * fix(restapi): build errors from spaces (#1098) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * feat(spaces v2): update space.initialize() param name, rename media() in SpacesV2 (#1101) * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.7 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * fix: media emoji added * fix: sending first message now shows in the inbox * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.8 * fix: for requests for receivers * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: added notification widget layout (#1076) * feat(video-v2): add highlevel video class * feat(video): add video stream * fix(sendnotification): modify rules.access.data to be an object & code cleanup * fix(video): remove signer from input, throw err if signer, decrypted pgp key not found * feat(video): add sendNotification calls in connect, disconnect methods * fix(videonotificationrules): typo in VideoNotificationRules interface * add: useStream.ts video-v2-example-app * add: videoV2.tsx in video-v2-example-app * feat(video stream): handle connect, retry internally from the SDK * feat(video connect): remove the connect method from the videov2 SDK * fix(videov2): create push signer instance to get chain id in initialize() * fix(videov2-example): refactor react example component & remove useStream hook * fix(video stream): add backwards compatibilty to rules object for older SDK versions * fix(video stream): fix bug in rules object creation * fix(video stream): call connect() for ApproveVideo event * feat(example-video-1.5): video v2 example app implementation * feat(sdk-frontend): few ui changes * fix(video-v2-example-app): initialisevdeo call after a call ends * feat(video stream): add request, deny evennt handlers * feat(sdk-frontend and sdk-frontend-react): added video-v2 example implementation * fix: few fixes * refactor: refator and remove console logs * fix: fix import error * feat(video): update param names for video.initialize() * fix: param name changes * chore: added few comments * chore: ui toast added * fix(video example): remove pushprotocol sdk direct dir reference for initVideoCallData * fix(video example): import React in examples & update SDK version in sdk-frontend * feat(video example): replace video events from CONSTANTS obj * Edited video example to make it more versatile * Update index.js * fix: fixed message parsing (#1051) * Minor fixes and improvements in video v2 (#1062) * feat(video v2): add VIDEO constants and types * feat(video v2): modify approve, deny to use internally stored peerInfo * fix(video constants): rename DEFAULT_DATA to INITIAL_DATA * 1050 update video example implementation in sdk-frontend (#1070) * fix: use latest imports in example app * feat: use latest rainbowkit library * chore: use latest restapi package * chore: remove unnecessary libs * fix: fixed signer bug (#1073) * fix: send intent in history and latest. (#1069) * fix: send intent in history and latest. * fix: get chat info API sdk changes * fix: stream helper functions * fix: caching implementation on user profile API (#1053) * fix: caching implementation on user profile API * fix: cache code review comments * fix: fix public key in read mode (#1074) * fix: added notification widget layout * fix: fixed naming convention * fix: added layout for hyperlink * Pub key cache to speed up chat messages verification (#1081) * fix: minor fixes * fix: cache implementation for public keys * fix: fix encV1 key decryption (#1088) * fix: add benchamark tests, fix reference msgs' (#1089) * fix: added resuables * bolierplate examples * bolierplate examples * bolierplate examples * fix: added connect button * fix: fixed lint * fix: v2 user creation / upgrades / downgrades (#1099) * fix: fix v2 user * test: remove only * Add filter for subscription (#1102) * fix: added parsing for settings * fix: minor fixes * fix: added manage notifiction * fix: added channel setting parse logic (#1107) * fix: fixed css * added user downgrade example * fix: fixed lint * fix: fixed connect modal * fix: added readmode * fix: fixed readMode --------- Co-authored-by: Madhur Gupta Co-authored-by: Siddesh Sankhya <79219618+Siddesh7@users.noreply.github.com> Co-authored-by: Siddesh Co-authored-by: harshrajat Co-authored-by: Harsh | Push Co-authored-by: Aman Gupta Co-authored-by: Mohammed S Co-authored-by: Ashis Kumar Pradhan <38760485+akp111@users.noreply.github.com> Co-authored-by: Mohammed S * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * Alpha deployment (#1112) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues --------- Co-authored-by: Mohammed S * fix: fixed minor bugs * Alpha deployment (#1114) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs --------- Co-authored-by: Mohammed S * fix: fixed chatpreview and widget issues * Alpha deployment (#1116) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues --------- Co-authored-by: Mohammed S * fix: fixed chat bugs * 1119 read only mode bug fix (#1120) * fix: optimize chat.list (#1115) * fix: read only guest mode * fix: review comments --------- Co-authored-by: Aman Gupta * fix: fixed readmode * Alpha deployment (#1121) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues * fix: fixed chat bugs * fix: fixed readmode --------- Co-authored-by: Mohammed S * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.70 * Mark ethers optional (#1124) * fix: optimize chat.list (#1115) * fix: allow groupImage and groupDesc to be updated to null (#1118) * fix: mark ethers as optional peer dependency * fix: change typeDataDomain * fix: update readme * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.71 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.9 * fix: added prefillChatList (#1122) * fix: troubleshoot * fix: fixed minor issue * Alpha deployment (#1132) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues * fix: fixed chat bugs * fix: fixed readmode * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.70 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.71 --------- Co-authored-by: Mohammed S * fix: fixed gues mode user profile * fix: fixed subscription error * Minor changes in spaces v2 SDK (#1136) * refactor(spaces v2): call createUserAudio internally before start, join as speaker * fix(spaces v2): add a check before creating stream in start, join as speaker * fix(spaces v2): make 'private' param in space.create() as optional * feat(spaces v2): export space types, constants from TYPES, CONSTANTS * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.72 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.10 * Alpha deployment (#1134) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues * fix: fixed chat bugs * fix: fixed readmode * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.70 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.71 * fix: troubleshoot * fix: fixed gues mode user profile * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.72 --------- Co-authored-by: Mohammed S * fix: stream connection support chat + pushUser to user fix (#1066) * fix: stream connection support chat + pushUser to user fix * fix: change console messages * fix: ens added * fix: z-index re added --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * Alpha deployment (#1146) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues * fix: fixed chat bugs * fix: fixed readmode * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.70 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.71 * fix: troubleshoot * fix: fixed gues mode user profile * fix: fixed subscription error * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.72 --------- Co-authored-by: Mohammed S * fix: z-index modal (#1152) * Revert "fix: z-index modal (#1152)" (#1153) This reverts commit 4e40221385750a240afde708c73d7b1221e5db0c. * Fix role change stream event (#1157) * fix: fix roleChange stream * fix: fix testcases * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.45 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.73 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.74 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.11 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.2.6 * Added channel.list API (#1160) * Added channel.list API * Added channel.list API * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.0 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.2.7 * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.1 * fix: some types are fixed * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.2 * fix: horizontal scroll (#1156) * fix: horizontal scroll * fix: z-index of prodile modal * fix: remove chat profile z-index * fix: remove chat profile z-index * fix: modal overlay z-index inc * fix: added word break to parent * fix: revert z-index profile * fix: fixed span * Alpha deployment (#1178) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues * fix: fixed chat bugs * fix: fixed readmode * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.70 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.71 * fix: troubleshoot * fix: fixed gues mode user profile * fix: fixed subscription error * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.72 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.45 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.73 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.74 * fix: fixed span --------- Co-authored-by: Mohammed S * fix: support chat scroll (#1184) * fix: support chat scroll * fix: when the scroll touches the last message it does fluctuate * Group fixes (#1182) * fix: fixed group minor issues * fix: fixed group fiex * fix: fixed user giving undefined for info (#1194) * Chatviewlist migration (#1164) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues * fix: fixed chat bugs * fix: added fetch chT * fix: fix * fix: added fetching chat * fix: fixed lint issues * fix: fixed * fix: converted send to class based * fix: fixed * fix: debugging stream issue * fix: debugging stream issue * fix: hack for stream fix * fix: removed event listeners * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.15 * fix: fixed chat bugs * fix: fixing stream issue * fix: fixed lint * fix: temp fix for stream * fix: fixed --------- Co-authored-by: Mohammed S * Alpha deployment (#1200) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues * fix: fixed chat bugs * fix: fixed readmode * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.68 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.70 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.71 * fix: troubleshoot * fix: fixed gues mode user profile * fix: fixed subscription error * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.72 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.45 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.73 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.74 * fix: fixed span --------- Co-authored-by: Mohammed S * Revert "Alpha deployment (#1200)" (#1201) This reverts commit 029e34d3a51a0ce4e0bc6adbad168e71b5c6129b. * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.75 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.75 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.77 * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.3 * Chatviewlist migration (#1202) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * fix: fix errors * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.64 * fix: changed stream type to any * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.16 * fix: minor change * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.17 * fix: minor fix * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.37 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.38 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.39 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.40 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.41 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.65 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.42 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.66 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.43 * fix: fixed build issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.36 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.44 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.67 * fix: fixed minor bugs * fix: fixed chatpreview and widget issues * fix: fixed chat bugs * fix: added fetch chT * fix: fix * fix: added fetching chat * fix: fixed lint issues * fix: fixed * fix: converted send to class based * fix: fixed * fix: debugging stream issue * fix: debugging stream issue * fix: hack for stream fix * fix: removed event listeners * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.15 * fix: fixed chat bugs * fix: fixing stream issue * fix: fixed lint * fix: temp fix for stream * fix: fixed * fix: fixed copy --------- Co-authored-by: Mohammed S * feat(uiweb): return response in createGroupModal (#1198) * feat(uiweb): return response in createGroupModal return group information when group is successfully created in uiweb createGroupModal * fix: fixed build issue --------- Co-authored-by: Monalisha Mishra Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * feat(uiweb): return response in createGroupModal (#1198) (#1215) * feat(uiweb): return response in createGroupModal return group information when group is successfully created in uiweb createGroupModal * fix: fixed build issue --------- Co-authored-by: Siddesh Sankhya <79219618+Siddesh7@users.noreply.github.com> * Add Polygon Amoy Support (#1221) * feat: add Polygon Amoy Support * test: added amoy test cases --------- Co-authored-by: Pratham Bhatnagar Co-authored-by: aman035 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.78 * 1220 add polygon amoy support (#1222) * feat: add Polygon Amoy Support * test: added amoy test cases * fix: fix minor changes --------- Co-authored-by: Pratham Bhatnagar Co-authored-by: aman035 * Tweaked UIWeb Chat * fix: added instanceids for push user and stream (#1224) * 1223 return id for push api and stream init (#1226) * fix: added instanceids for push user and stream * fix: review comments * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.79 * fixed conversation private or not * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.80 * fix: chat info changes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.81 * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.4 * Fixing chat components * fix: bug fixes * fix: renamed sender to account * fix: fix fn definitions (#1232) * fix: fix tmp error * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.82 * fix: update chat * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.83 * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.5 * fix: push api account public * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.6 * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.7 * fix: add public params * ci(restapi): šŸŽ‰ cut release to restapi-v1.7.8 * commit to pull changes from alpha * added .gitignore for .yarn * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.84 * fixed ChatProfile and PushUser * fix: error meta fix * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.85 * Rebased few icons to PushIcons.tsx, optimized resolveWeb3Name, added ChatProfile web3 name with divider * Added prettier in UIWeb and format rules, rebased icon and changed tooltip to flex * vscode settings and rebasing helpers * feat: Add Polygon zkEvm Cardona support (#1243) * Alpha (#1237) * ci(restapi): šŸŽ‰ cut release to restapi-v1.5.1 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.2.0 * add: ethers support (#952) * fix: fix viem support, add ethers support * fix: remove @pushprotocol/socket dependency from restapi * fix: changed ethers fn * fix: fix ether changes * fix: fix subscribev2 * chore: readme changes * fix: fix ethers provider issue * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.61 * fix: fix channel.update * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.62 * ci(restapi): šŸŽ‰ cut release to restapi-v1.5.2 * ci(restapi): šŸŽ‰ cut release to restapi-v1.5.3 * ci(restapi): šŸŽ‰ cut release to restapi-v1.5.4 * ci(restapi): šŸŽ‰ cut release to restapi-v1.5.5 * ci(restapi): šŸŽ‰ cut release to restapi-v1.5.6 * ci(restapi): šŸŽ‰ cut release to restapi-v1.5.7 * feat(video-v2): add video v2 class and stream (#930) * feat(video-v2): add highlevel video class * feat(video): add video stream * fix(sendnotification): modify rules.access.data to be an object & code cleanup * fix(video): remove signer from input, throw err if signer, decrypted pgp key not found * feat(video): add sendNotification calls in connect, disconnect methods * fix(videonotificationrules): typo in VideoNotificationRules interface * feat(video stream): handle connect, retry internally from the SDK * feat(video connect): remove the connect method from the videov2 SDK * fix(videov2): create push signer instance to get chain id in initialize() * fix(video stream): add backwards compatibilty to rules object for older SDK versions * fix(video stream): fix bug in rules object creation * feat(video): update param names for video.initialize() * feat(video): add internal event handlers for stream in video SDK --------- Co-authored-by: Mohammed S * ci(restapi): šŸŽ‰ cut release to restapi-v0.9.0 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.63 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.2.1 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.0 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.2.2 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.1 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.2.3 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.2.4 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.2 * ci(restapi): šŸŽ‰ cut release to restapi-v1.6.3 * Chat Preview List workable PoC (#987) * fix: revert space changes * fix: merge main * fix: signer compatibility with viem and ethers (#567) * fix: signer compatibility with viem and ethers * fix: revert space changes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.26 * Update README.md * Update README.md * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.3 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.27 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.4 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.5 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.6 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.7 * fix: add: scw sig verification (#593) * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.28 * fix: url correction * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.29 * ci(socket): šŸŽ‰ cut release to socket-v0.5.2 * fix: fixed subscribe and unsubscribe * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.5 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.8 * Feat/chat components (#621) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson * fix: add alpha support to UI web * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.0 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.6 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.9 * Feat/chat components (#625) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.1 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.7 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.8 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.10 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.9 * 632 group access control sdk changes (#640) * fix: group access control changes * fix: get group access SDK fix * fix: removed unnecessary param * Update README.md * Update README.md * Update README.md * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.30 * Reduce profile creation signature to 2 (#639) * fix: reduced signatures * fix: fixed examples * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.31 * fix: Read me fixes * fix: Space rules * Update README.md * Update README.md * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.32 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.10 * Feat/chat components (#658) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) --------- Co-authored-by: Monalisha Mishra Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Kolade * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.11 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.12 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.11 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.13 * fix: update read me file * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.14 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.15 * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.12 * Feat/chat components (#679) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) * Connect btn revamp (#668) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container * feat: adding rainbowkit for btn * fix: fix issues * fix: addec onnect functionality * fix: connect button * fix: added hack for rainbowkit css --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * Typebar UI issue (#666) * fix: fixed typebar space not working and theme * fix: fixed gif and emoji --------- Co-authored-by: KlausMikhaelson * fix: fixed theme colours * fix: added theme for brb * fix: added filter hat * fix: merged with main * fix: fixed msg border * fix: fixed theme * fix: fixed fonts * fix: fixed bug * Access control (#672) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added minor fix --------- Co-authored-by: Monalisha Mishra * fix: fixed padding issues * fix(f): fixed build issues * fix: fix for chat status test * Check rules access control (#678) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * 662 group access control v2 changes (#663) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix: origin in user creation (#665) * fix: origin in user creation * Update README.md * fix: review comments * 662 group access control v2 changes (#677) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix(spaces): broadcast changes and UX fixes (#674) * fix: fix UI grid view (#642) * fix: fix UI grid view * refactor: conditional added * fix: resolved muting/unmuting try catch error (#657) * fix(spaces): fix livepeer broadcast (#656) * fix(spaces): fix livepeer broadcast * fix(spaces): fix data shown for unjoined space & promote listener logic --------- Co-authored-by: Madhur Gupta * refactor(spaces): use local state instead of get from server while meta message fire (#676) --------- Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * feat: added verification option to show only on token gated groups * fix: fixing group access control --------- Co-authored-by: Monalisha Mishra Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * fix: fixed build --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Kolade Co-authored-by: Nilesh Gupta Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.2 * fix: dummy change * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.13 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.16 * Join group option (#681) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * Connect btn revamp (#668) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container * feat: adding rainbowkit for btn * fix: fix issues * fix: addec onnect functionality * fix: connect button * fix: added hack for rainbowkit css --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * Typebar UI issue (#666) * fix: fixed typebar space not working and theme * fix: fixed gif and emoji --------- Co-authored-by: KlausMikhaelson * fix: fixed theme colours * fix: added theme for brb * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added filter hat * fix: merged with main * fix: fixed msg border * fix: fixed theme * fix: fixed fonts * fix: fixed bug * Access control (#672) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added minor fix --------- Co-authored-by: Monalisha Mishra * fix: fixed padding issues * fix(f): fixed build issues * fix: fix for chat status test * feat: added verification option to show only on token gated groups * fix: fixing group access control * Check rules access control (#678) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * 662 group access control v2 changes (#663) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix: origin in user creation (#665) * fix: origin in user creation * Update README.md * fix: review comments * 662 group access control v2 changes (#677) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix(spaces): broadcast changes and UX fixes (#674) * fix: fix UI grid view (#642) * fix: fix UI grid view * refactor: conditional added * fix: resolved muting/unmuting try catch error (#657) * fix(spaces): fix livepeer broadcast (#656) * fix(spaces): fix livepeer broadcast * fix(spaces): fix data shown for unjoined space & promote listener logic --------- Co-authored-by: Madhur Gupta * refactor(spaces): use local state instead of get from server while meta message fire (#676) --------- Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * feat: added verification option to show only on token gated groups * fix: fixing group access control --------- Co-authored-by: Monalisha Mishra Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * fix: fixed build * feat: added send request to join group * fix: fixed verification on send * fix: fixed verify access btn not showing after joining group * fix: fixed join group showing for members too * fix: fixed join group showing to members * 667 chat.send enhancement (#673) * fix: changes messageObj for meta and reaction message type * fix: enhance send fn * fix: fixed intent issues * 680 group rules cosmetic changes (#682) * fix: fixed guild condition * fix: add did validation * fix: fixed * fix: fixed minor issues * fix: fixe dissue * fix: fixed minor issues * fix: check for scroll * fix: fixed scrolling * fix: fixed theme * fix: fixed * fix: fixed * fix: fixed * fix: fixed issues * fix: fixed * feat: added toast in join group btn for pvt groups * fix: fixed blurr --------- Co-authored-by: Monalisha Mishra Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> Co-authored-by: Kolade Co-authored-by: Nilesh Gupta Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Aman Gupta * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.3 * Join group option (#687) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * Connect btn revamp (#668) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container * feat: adding rainbowkit for btn * fix: fix issues * fix: addec onnect functionality * fix: connect button * fix: added hack for rainbowkit css --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * Typebar UI issue (#666) * fix: fixed typebar space not working and theme * fix: fixed gif and emoji --------- Co-authored-by: KlausMikhaelson * fix: fixed theme colours * fix: added theme for brb * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added filter hat * fix: merged with main * fix: fixed msg border * fix: fixed theme * fix: fixed fonts * fix: fixed bug * Access control (#672) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added minor fix --------- Co-authored-by: Monalisha Mishra * fix: fixed padding issues * fix(f): fixed build issues * fix: fix for chat status test * feat: added verification option to show only on token gated groups * fix: fixing group access control * Check rules access control (#678) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * 662 group access control v2 changes (#663) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix: origin in user creation (#665) * fix: origin in user creation * Update README.md * fix: review comments * 662 group access control v2 changes (#677) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix(spaces): broadcast changes and UX fixes (#674) * fix: fix UI grid view (#642) * fix: fix UI grid view * refactor: conditional added * fix: resolved muting/unmuting try catch error (#657) * fix(spaces): fix livepeer broadcast (#656) * fix(spaces): fix livepeer broadcast * fix(spaces): fix data shown for unjoined space & promote listener logic --------- Co-authored-by: Madhur Gupta * refactor(spaces): use local state instead of get from server while meta message fire (#676) --------- Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * feat: added verification option to show only on token gated groups * fix: fixing group access control --------- Co-authored-by: Monalisha Mishra Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * fix: fixed build * feat: added send request to join group * fix: fixed verification on send * fix: fixed verify access btn not showing after joining group * fix: fixed join group showing for members too * fix: fixed join group showing to members * 667 chat.send enhancement (#673) * fix: changes messageObj for meta and reaction message type * fix: enhance send fn * fix: fixed intent issues * 680 group rules cosmetic changes (#682) * fix: fixed guild condition * fix: add did validation * fix: fixed * fix: fixed minor issues * fix: fixe dissue * fix: fixed minor issues * fix: check for scroll * fix: fixed scrolling * fix: fixed theme * fix: fixed * fix: fixed * fix: fixed * fix: fixed issues * fix: fixed * feat: added toast in join group btn for pvt groups * fix: fixed blurr * fix: fixed minor issues rules * fix: fixed * fix: fixed --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Kolade Co-authored-by: Nilesh Gupta Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Aman Gupta * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.4 * Join group option (#688) * feat: created architechture * fix: added context values (#594) * Chat dataprovider (#596) * feat: data provider for chat component * fix: replaced react.usestate to usestate * fix: added props as the initial state and changed state name * fix: reverted chat context changes and renamed values * fix: added test page for chat ui components (#597) * added chatbubble component (#602) * feat: added chatbubble component * fix: made the messageBubble's width to fit-content --------- Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> * fix: added theme * Group chat bubble (#604) * feat: moved test component to testui folder & replaced dummy data with sdk response * feat: added twitter card and address for group chat received msg * feat: made the messageaddress reusable, added account from context * fix: removed unnecessary div and unused props and console logs * feat: adding pfp in text bubbles * fix: replaced hook with function and added pfp to messagebubble * fix: fixed image alignment * fix: changed border-radius of msg bubble and changed function name * fix: fixed theme and decryptedPrivateKey name (#616) * fix: fixed theme and decryptedPrivateKey name * fix: fixed bug * fix: fixed theme reviews * Message list (#615) * fix: message list comp * fix: message list comp * fix: added pagination * fix: added pagination * fix: pagination * fix: create useChatData hook * fix: fixed minor bug * fix: socket issues fixed * fix: added theme in msgbubble (#620) * fix: added theme in msgbubble * fix: fixed import --------- Co-authored-by: Monalisha Mishra * fix: exported the theme (#623) * fix: exported the theme * fix: fixed issues --------- Co-authored-by: Monalisha Mishra * Typebar component (#631) * feat: added typebar UI * feat: added functions to typebar * fix: added icon * fix: fixed theme issues --------- Co-authored-by: Monalisha Mishra * feat: added connectbutton * fix: fixed connectbtn ui and remove disconnect and fixed error on disconnect * fix: fixed create account getting called twice * Profile Header Component (#636) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * Message container (#635) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * fix: updated svg to react component * fix: changed svg to tsx component * fix: fixed review changes (#646) * fix: fixed review changes * fix: resolved issues --------- Co-authored-by: Nilesh Gupta * Profile Header -> Chat Profile fixes (#647) * feat: profile header * feat: update profile header * fix: update hooks * fix: video icon ui * feat: add group modal * fix: add modal info * fix: edit components * fix: commit modal theme * fix: updating UI * fix: ensname * fix: add notifs * fix: remove alerts * fix: remove alert logs * fix: push fixes * fix: conflicts * fix: notifs * fix: correct theme colors * fix: renaming profileHeader * fix: qa fixes * fix: loader * refactor: resolved issues * fix: edit types --------- Co-authored-by: Nilesh Gupta * fix: resolved package not added issue * Fix: modal issue in group info && alert remove members (#653) * fix: modal * fix: update changes * refactor: resolved issue --------- Co-authored-by: Nilesh Gupta * fix: QA fixes (#654) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * Connect btn revamp (#668) * fix: added theme in msgbubble * fix: fixed import * fix: fixed message-list * fix: added approve intent * fix: added fixes * fix: fixed socket bug * fix: fixed message from socket * fix: fixed minor issues * fix: fixed typebar theming * fix: fixed env issue * fix: fixed message not updating issue * refactor: added isConnected prop in msgContainer * refactor: resolve merge conflicts * fix: fixed request sending * fix: fixed decryption * fix: fixed env issue * feat: added profile header in message container * feat: adding rainbowkit for btn * fix: fix issues * fix: addec onnect functionality * fix: connect button * fix: added hack for rainbowkit css --------- Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta * Typebar UI issue (#666) * fix: fixed typebar space not working and theme * fix: fixed gif and emoji --------- Co-authored-by: KlausMikhaelson * fix: fixed theme colours * fix: added theme for brb * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added filter hat * fix: merged with main * fix: fixed msg border * fix: fixed theme * fix: fixed fonts * fix: fixed bug * Access control (#672) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * fix: added minor fix --------- Co-authored-by: Monalisha Mishra * fix: fixed padding issues * fix(f): fixed build issues * fix: fix for chat status test * feat: added verification option to show only on token gated groups * fix: fixing group access control * Check rules access control (#678) * fix: fixed typebar space not working and theme * feat: created access control UI * feat: created verify access control hook * fix: fixed access control hook issue * feat: added access control verification * feat: added onclick props for integration team to pass function and fixed btn ui * fix: added link for learn more * fix: fixed msg not updating in socket issue * 662 group access control v2 changes (#663) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix: origin in user creation (#665) * fix: origin in user creation * Update README.md * fix: review comments * 662 group access control v2 changes (#677) * fix: spaces access API * fix: custom endpoint doc impl * Update README.md * Update README.md * fix: review comments change * fix: read me update * Update README.md * Update README.md * fix(spaces): broadcast changes and UX fixes (#674) * fix: fix UI grid view (#642) * fix: fix UI grid view * refactor: conditional added * fix: resolved muting/unmuting try catch error (#657) * fix(spaces): fix livepeer broadcast (#656) * fix(spaces): fix livepeer broadcast * fix(spaces): fix data shown for unjoined space & promote listener logic --------- Co-authored-by: Madhur Gupta * refactor(spaces): use local state instead of get from server while meta message fire (#676) --------- Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * feat: added verification option to show only on token gated groups * fix: fixing group access control --------- Co-authored-by: Monalisha Mishra Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Nilesh Gupta * fix: fixed build * feat: added send request to join group * fix: fixed verification on send * fix: fixed verify access btn not showing after joining group * fix: fixed join group showing for members too * fix: fixed join group showing to members * 667 chat.send enhancement (#673) * fix: changes messageObj for meta and reaction message type * fix: enhance send fn * fix: fixed intent issues * 680 group rules cosmetic changes (#682) * fix: fixed guild condition * fix: add did validation * fix: fixed * fix: fixed minor issues * fix: fixe dissue * fix: fixed minor issues * fix: check for scroll * fix: fixed scrolling * fix: fixed theme * fix: fixed * fix: fixed * fix: fixed * fix: fixed issues * fix: fixed * feat: added toast in join group btn for pvt groups * fix: fixed blurr * fix: fixed minor issues rules * fix: fixed * fix: fixed * fix: fixed socket issue * fix: fixed --------- Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Kolade Co-authored-by: Nilesh Gupta Co-authored-by: Mohammed S Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Aman Gupta * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.5 * fix: fixed (#689) * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.6 * chat Load issue fixed (#690) * fix: fixed * fix: fixed minor issues * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.7 * fix: fixed msg bubble width (#691) * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.8 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.17 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.18 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.19 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.33 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.33 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.9 * Onboarding blocknative (#702) * fix: added reusable folder * fix: fixed theme for modal * fix: removed reusables from export * fix: fixed fallback for message input * feat: replaced rainbowkit with blocknative * fix: removed unused code --------- Co-authored-by: Monalisha Mishra * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.10 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.33 * Fix connect button issue (#710) * fix: fixed connect button blocknative * fix: fixed message fetching * fix: removed console * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.11 * fix: added condition while showing tokengatedIcon (#715) * fix: added disconnect for wallet (#721) * fix: added disconnect for wallet * fix: added autoConnect * Wallet disconnect (#722) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * Wallet disconnect (#723) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * fix: fixed errors * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.12 * Changed messageInput params Case (#725) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * fix: fixed errors * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.13 * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.20 * Wallet disconnect (#728) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * fix: fixed errors * fix: added coinbase wallet * fix: img added * fix: fixed metamask not showing if not present in it --------- Co-authored-by: KlausMikhaelson * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.14 * Wallet disconnect (#732) * fix: added disconnect for wallet * fix: added autoConnect * fix: changed onClick to onGetTokenClick * fix: fixed errors * fix: added coinbase wallet * fix: img added * fix: fixed metamask not showing if not present in it * fix: fixed injected wallets --------- Co-authored-by: KlausMikhaelson * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.15 * fix: added class based implementation for notification (#699) * fix: added class based implementation for notification * fix: class based implementation for notification * fix: small fixes * fix: minor fixes and testcases * fix: fixes for testcases * fix: updated core abi and minor fixes * fix: removed comment * fix: minor fixes and additional checks * fix: minor fixes * fix: viem support for contract and new folder structure * fix: changed typescript 5.0.2 and configured eslint * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.34 * 720 pushstream class implementation (#729) * chore: added an example of automated chat using the new class based initialization * fix: fixed usecases * chore: added an example of automated chat using the new class based iā€¦ (#712) * chore: added an example of automated chat using the new class based initialization * fix: fixed usecases --------- Co-authored-by: aman035 * chore(automated chat example): tweaked automated chat example * fix: stream changes * fix: stream changes * fix: added chat.decrypt (#726) * fix: added chat.decrypt * fix: fix examples * fix: stream changes * fix: PUSH Stream Changes * fix: chat classes split * fix: Notification socket initialisations and rules backward compatibility * fix: added message decrypt * fix: review comments * fix: socket events * fix: test case fix and UserInfo to user * fix: rip PushNotification class * fix: additional check --------- Co-authored-by: harshrajat Co-authored-by: aman035 Co-authored-by: Harsh | Push Co-authored-by: akp111 * fix: remove only from test * fix: error fixed * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.35 * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.35 * fix: stream cases * 720 pushstream class implementation (#737) * fix: stream changes * fix: stream changes * fix: stream changes * fix: PUSH Stream Changes * fix: chat classes split * fix: Notification socket initialisations and rules backward compatibility * fix: added message decrypt * fix: review comments * fix: socket events * fix: test case fix and UserInfo to user * fix: rip PushNotification class * fix: additional check * fix: minor fixes --------- Co-authored-by: Mohammed S * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.21 * fix: corrected example * fix: some changes on stream * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.36 * fix: minor fixes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.37 * fix: error handling in socket events * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.38 * fix: more fixes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.39 * fix: minor fixes * fix: socket enabled * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.40 * fix: minor fixes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.41 * Add counter for update channel (#740) * fix: added counter to update group * fix: added counter logic, moved delegate and alias function to channel class * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.42 * Add counter for update channel (#741) * fix: added counter to update group * fix: added counter logic, moved delegate and alias function to channel class * fix: added readme for notification * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.43 * fix: minor fix * ci(uiweb): šŸŽ‰ cut release to uiweb-v1.1.14 * fix: log removed * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.44 * docs: fix tests * Feat/space backup (#746) * refactor: added code for joining livekit room for listeners (#731) * feat: drop in livekit inplace of livepeer (#736) * feat: drop in livekit inplace of livepeer * feat: added microphone * feat: added mic * feat: added access control --------- Co-authored-by: Nilesh Gupta * fix: Notification event mutation * Notification setting changes (#752) * Arbitrum changes (#735) * fix: inital implementation for arbitrum changes * fix: more changes * fix: added final changes * fix: minor fixes * fix: fixed typo * fix: notification settings related changes * fix: added index parameter for notification * fix: restored config * Arnab/livekit fixes (#754) * refactor: added code for joining livekit room for listeners (#731) * feat: drop in livekit inplace of livepeer * feat: added microphone * feat: added mic * feat: added access control * feat: fixes for livekit API call --------- Co-authored-by: Nilesh Gupta * ci(restapi): šŸŽ‰ cut release to restapi-v1.4.22 * fix: added settings * fix: added settings (#762) * fix: build fix * fix: minor fix * fix: minor fix * Added initial chat sidebar * fix: pagination done * fix: added fuse network * Working stream with hacks, working badges, working loading, partial loading, not working accept stream * fix: focus back to message input after sending the message (#1014) * fix: added support for ens (#1008) * feat: add video SDK v2 and video stream (#1017) * add: ethers support (#952) * fix: fix viem support, add ethers support * fix: remove @pushprotocol/socket dependency from restapi * fix: changed ethers fn * fix: fix ether changes * fix: fix subscribev2 * chore: readme changes * fix: fix ethers provider issue * fix: fix channel.update * feat(video-v2): add video v2 class and stream (#930) * feat(video-v2): add highlevel video class * feat(video): add video stream * fix(sendnotification): modify rules.access.data to be an object & code cleanup * fix(video): remove signer from input, throw err if signer, decrypted pgp key not found * feat(video): add sendNotification calls in connect, disconnect methods * fix(videonotificationrules): typo in VideoNotificationRules interface * feat(video stream): handle connect, retry internally from the SDK * feat(video connect): remove the connect method from the videov2 SDK * fix(videov2): create push signer instance to get chain id in initialize() * fix(video stream): add backwards compatibilty to rules object for older SDK versions * fix(video stream): fix bug in rules object creation * feat(video): update param names for video.initialize() * feat(video): add internal event handlers for stream in video SDK --------- Co-authored-by: Mohammed S --------- Co-authored-by: Aman Gupta Co-authored-by: Mohammed S * fix: Added ethersV6SignerType in uiweb signer types (#1018) * fix: aā€¦ * test: fix test case * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.86 * ci(uiweb): šŸŽ‰ cut beta release to uiweb-v0.0.1-alpha.46 * fixed localstorage and displaying chat profile * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.87 * Changing stream operations * feat: support chat v2 added (#1236) * feat: support chat v2 added * fix: changed supportchatv2 to chatwidget * fix: changed support chat to chatwidget * feat: support chat v2 added (#1236) (#1248) * feat: support chat v2 added * fix: changed supportchatv2 to chatwidget * fix: changed support chat to chatwidget * fix: logs * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.88 * partial commit before alpha merge * fix: stream fixes * ci(restapi): šŸŽ‰ cut beta release to restapi-v0.0.1-alpha.89 * Enabled debug mode * fix: chat stream fixes * chat stream fixes * Before toast rebase * Fixed most issues including toast, zIndex * Added comment for clarity on ChatPreviewList * fix: fixed chat qa issues * fix: fixed issue --------- Co-authored-by: aman035 Co-authored-by: Mohammed S Co-authored-by: Mohammed S Co-authored-by: Monalisha Mishra <42746736+mishramonalisha76@users.noreply.github.com> Co-authored-by: Satyam <100528412+KlausMikhaelson@users.noreply.github.com> Co-authored-by: KlausMikhaelson Co-authored-by: Nilesh Gupta Co-authored-by: Monalisha Mishra Co-authored-by: Kolade Co-authored-by: Madhur Gupta Co-authored-by: Arnab Chatterjee <60937304+arn4b@users.noreply.github.com> Co-authored-by: Ashis Kumar Pradhan <38760485+akp111@users.noreply.github.com> Co-authored-by: akp111 Co-authored-by: Pritipriya Singh Co-authored-by: Siddesh Sankhya <79219618+Siddesh7@users.noreply.github.com> Co-authored-by: Siddesh Co-authored-by: Pratham Bhatnagar <84272138+pratham-bhatnagar@users.noreply.github.com> Co-authored-by: Pratham Bhatnagar --- .vscode/settings.json | 3 +- .yarnrc.yml | 1 + package.json | 10 +- packages/examples/boilerplate/index.js | 19 +- packages/examples/boilerplate/package.json | 2 +- .../src/app/ChatSupportTest.tsx | 38 +- .../src/app/ChatUITest/ChatPreviewList.tsx | 151 +- .../src/app/ChatUITest/ChatViewComponent.tsx | 44 +- .../sdk-frontend-react/src/app/app.tsx | 15 +- .../example-chat-group-profile-update.js | 38 + .../example-chat-guest-mode-functions.js | 18 + .../example-chat-profile-update.js | 39 + .../restapi/src/lib/pushstream/PushStream.ts | 693 +- packages/restapi/yarn.lock | 5 + packages/uiweb/.editorconfig | 17 + packages/uiweb/.prettierrc | 11 + packages/uiweb/package.json | 7 +- packages/uiweb/src/declerations.d.ts | 3 + .../chat/ChatPreview/ChatPreview.tsx | 83 +- .../chat/ChatPreviewList/ChatPreviewList.tsx | 478 +- .../chat/ChatProfile/AddWalletContent.tsx | 24 +- .../chat/ChatProfile/ChatProfile.tsx | 392 +- ...InfoModal.tsx => ChatProfileInfoModal.tsx} | 638 +- .../chat/ChatProfile/MemberListContainer.tsx | 19 +- .../chat/ChatProfile/MemberProfileCard.tsx | 26 +- .../chat/ChatProfile/PendingMembers.tsx | 159 +- .../chat/ChatView/ChatViewComponent.tsx | 139 +- .../chat/ChatViewBubble/ChatViewBubble.tsx | 277 +- .../chat/ChatViewList/ActionRequestBubble.tsx | 236 + .../ChatViewList/ApproveRequestBubble.tsx | 121 - .../chat/ChatViewList/ChatViewList.tsx | 541 +- .../chat/ChatViewList/MessageEncryption.tsx | 105 +- .../chat/ConnectButton/ConnectButton.tsx | 57 +- .../chat/CreateGroup/AddCriteria.tsx | 203 +- .../chat/CreateGroup/AddGroupMembers.tsx | 49 +- .../chat/CreateGroup/CreateGroupModal.tsx | 167 +- .../chat/MessageInput/MessageInput.tsx | 471 +- .../UserProfile/UpdateUserProfileModal.tsx | 135 +- .../chat/UserProfile/UserProfile.tsx | 92 +- .../src/lib/components/chat/exportedTypes.ts | 21 +- .../src/lib/components/chat/helpers/helper.ts | 183 +- .../src/lib/components/chat/helpers/index.ts | 7 +- .../lib/components/chat/helpers/twitter.ts | 16 +- .../components/chat/reusables/AddWallets.tsx | 99 +- .../chat/reusables/MemberListContainer.tsx | 54 +- .../lib/components/chat/reusables/Modal.tsx | 84 +- .../components/chat/reusables/NewToast.tsx | 114 +- .../chat/reusables/ProfileContainer.tsx | 207 +- .../src/lib/components/chat/theme/index.ts | 330 +- .../src/lib/components/chat/types/index.ts | 75 +- .../src/lib/components/chatWidget/Modal.tsx | 64 +- .../components/notification/chainDetails.tsx | 18 +- .../src/lib/components/notification/index.tsx | 26 +- .../reusables/ParticleEffectButton/index.tsx | 398 + .../reusables/ParticleEffectButton/styles.css | 23 + .../src/lib/components/reusables/Spinner.tsx | 4 +- .../src/lib/components/reusables/Tooltip.tsx | 2 +- .../components/reusables/sharedStyling.tsx | 305 +- .../components/supportChat/AddressInfo.tsx | 8 +- packages/uiweb/src/lib/context/chatContext.ts | 167 +- .../lib/dataProviders/ChatDataProvider.tsx | 487 +- .../src/lib/dataProviders/WidgetProvider.tsx | 18 +- packages/uiweb/src/lib/helpers/address.ts | 73 +- packages/uiweb/src/lib/helpers/blockies.ts | 129 + packages/uiweb/src/lib/helpers/chat/chat.ts | 118 +- .../src/lib/helpers/chat/localStorage.ts | 69 +- packages/uiweb/src/lib/helpers/chat/search.ts | 54 +- packages/uiweb/src/lib/helpers/debug.ts | 19 + packages/uiweb/src/lib/helpers/index.ts | 6 +- packages/uiweb/src/lib/helpers/udResolver.ts | 2 +- packages/uiweb/src/lib/helpers/utils.ts | 35 + packages/uiweb/src/lib/hooks/chat/index.ts | 7 +- .../lib/hooks/chat/useApproveChatRequest.ts | 21 +- .../src/lib/hooks/chat/useCreateGatedGroup.ts | 11 +- .../uiweb/src/lib/hooks/chat/useFetchChat.ts | 12 +- .../hooks/chat/useFetchMessageUtilities.ts | 148 +- .../lib/hooks/chat/useGroupMemberUtilities.ts | 95 +- ...ket.ts => usePushChatSocket.ts.deprecated} | 0 .../src/lib/hooks/chat/usePushChatStream.ts | 347 +- .../src/lib/hooks/chat/usePushSendMessage.ts | 9 +- .../lib/hooks/chat/useRejectChatRequest.ts | 45 + .../src/lib/hooks/chat/useUpdateGroup.ts | 42 +- .../lib/hooks/chat/useUserInfoUtilities.ts | 29 +- .../lib/hooks/chat/useVerifyAccessControl.ts | 9 +- packages/uiweb/src/lib/hooks/exportedHooks.ts | 2 - .../src/lib/hooks/exportedHooks.ts.deprecated | 0 packages/uiweb/src/lib/hooks/index.ts | 19 +- .../uiweb/src/lib/hooks/useInitializeUser.ts | 31 - packages/uiweb/src/lib/hooks/usePushUser.ts | 73 + ...rofile.ts => useUserProfile.deprecated.ts} | 7 +- packages/uiweb/src/lib/icons/CopySvg2.tsx | 14 - packages/uiweb/src/lib/icons/PushIcons.tsx | 184 + packages/uiweb/src/lib/icons/copyVector.svg | 5 +- .../src/lib/icons/raw/AcceptCircleIcon.svg | 3 + .../src/lib/icons/raw/CancelCircleIcon.svg | 12 + .../PublicChatIcon.svg} | 0 .../lib/icons/{ => raw}/TokenGatedIcon.svg | 0 packages/uiweb/src/lib/index.ts | 4 +- packages/uiweb/tsconfig.lib.json | 12 +- packages/uiweb/yarn.lock | 3040 +++--- yarn.lock | 9700 +++++++++-------- 101 files changed, 12495 insertions(+), 10127 deletions(-) create mode 100644 .yarnrc.yml create mode 100644 packages/examples/several-examples/example-chat-group-profile-update.js create mode 100644 packages/examples/several-examples/example-chat-guest-mode-functions.js create mode 100644 packages/examples/several-examples/example-chat-profile-update.js create mode 100644 packages/uiweb/.editorconfig create mode 100644 packages/uiweb/.prettierrc create mode 100644 packages/uiweb/src/declerations.d.ts rename packages/uiweb/src/lib/components/chat/ChatProfile/{GroupInfoModal.tsx => ChatProfileInfoModal.tsx} (66%) create mode 100644 packages/uiweb/src/lib/components/chat/ChatViewList/ActionRequestBubble.tsx delete mode 100644 packages/uiweb/src/lib/components/chat/ChatViewList/ApproveRequestBubble.tsx create mode 100644 packages/uiweb/src/lib/components/reusables/ParticleEffectButton/index.tsx create mode 100644 packages/uiweb/src/lib/components/reusables/ParticleEffectButton/styles.css create mode 100644 packages/uiweb/src/lib/helpers/blockies.ts create mode 100644 packages/uiweb/src/lib/helpers/debug.ts create mode 100644 packages/uiweb/src/lib/helpers/utils.ts rename packages/uiweb/src/lib/hooks/chat/{usePushChatSocket.ts => usePushChatSocket.ts.deprecated} (100%) create mode 100644 packages/uiweb/src/lib/hooks/chat/useRejectChatRequest.ts delete mode 100644 packages/uiweb/src/lib/hooks/exportedHooks.ts create mode 100644 packages/uiweb/src/lib/hooks/exportedHooks.ts.deprecated delete mode 100644 packages/uiweb/src/lib/hooks/useInitializeUser.ts create mode 100644 packages/uiweb/src/lib/hooks/usePushUser.ts rename packages/uiweb/src/lib/hooks/{useUserProfile.ts => useUserProfile.deprecated.ts} (80%) delete mode 100644 packages/uiweb/src/lib/icons/CopySvg2.tsx create mode 100644 packages/uiweb/src/lib/icons/PushIcons.tsx create mode 100644 packages/uiweb/src/lib/icons/raw/AcceptCircleIcon.svg create mode 100644 packages/uiweb/src/lib/icons/raw/CancelCircleIcon.svg rename packages/uiweb/src/lib/icons/{Public-Chat.svg => raw/PublicChatIcon.svg} (100%) rename packages/uiweb/src/lib/icons/{ => raw}/TokenGatedIcon.svg (100%) diff --git a/.vscode/settings.json b/.vscode/settings.json index e1786ec1c..8f5881e8b 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -1,3 +1,4 @@ { - "workbench.activityBar.orientation": "vertical" + "workbench.activityBar.orientation": "vertical", + "editor.formatOnSave": true } \ No newline at end of file diff --git a/.yarnrc.yml b/.yarnrc.yml new file mode 100644 index 000000000..3186f3f07 --- /dev/null +++ b/.yarnrc.yml @@ -0,0 +1 @@ +nodeLinker: node-modules diff --git a/package.json b/package.json index 2d6720e6e..91a810c5a 100644 --- a/package.json +++ b/package.json @@ -56,11 +56,6 @@ "viem": "^1.3.0" }, "devDependencies": { - "browserify-zlib": "^0.2.0", - "https-browserify": "^1.0.0", - "node-polyfill-webpack-plugin": "^3.0.0", - "stream-browserify": "^3.0.0", - "stream-http": "^3.2.0", "@commitlint/cli": "^17.0.0", "@commitlint/config-angular": "^17.0.0", "@jscutlery/semver": "^2.27.1", @@ -101,6 +96,7 @@ "@web3-react/types": "^6.0.7", "babel-jest": "27.5.1", "babel-plugin-styled-components": "^1.10.7", + "browserify-zlib": "^0.2.0", "chai-as-promised": "^7.1.1", "commitizen": "^4.2.5", "cz-conventional-changelog": "^3.3.0", @@ -110,6 +106,7 @@ "eslint-plugin-jsx-a11y": "^6.5.1", "eslint-plugin-react": "^7.29.4", "eslint-plugin-react-hooks": "^4.5.0", + "https-browserify": "^1.0.0", "husky": "^8.0.0", "jest": "27.5.1", "jest-react-native": "18.0.0", @@ -117,6 +114,7 @@ "metro-babel-register": "0.70.2", "metro-react-native-babel-preset": "0.70.2", "metro-resolver": "0.70.2", + "node-polyfill-webpack-plugin": "^3.0.0", "nx": "14.1.7", "patch-package": "^6.4.7", "prettier": "^2.5.1", @@ -124,6 +122,8 @@ "react-native-svg": "12.3.0", "react-native-svg-transformer": "1.0.0", "react-test-renderer": "17.0.2", + "stream-browserify": "^3.0.0", + "stream-http": "^3.2.0", "ts-jest": "27.1.4", "ts-node": "9.1.1", "typescript": "5.0.2" diff --git a/packages/examples/boilerplate/index.js b/packages/examples/boilerplate/index.js index bc28a594a..4fa9735bd 100644 --- a/packages/examples/boilerplate/index.js +++ b/packages/examples/boilerplate/index.js @@ -1,6 +1,19 @@ import { CONSTANTS, PushAPI } from '@pushprotocol/restapi'; import { ethers } from 'ethers'; -import input from 'input'; -console.log("Hello... what's my purpose?") -console.log("To train all the hackers..") +// Creating a random signer from a wallet, ideally this is the wallet you will connect +const signerAlice = ethers.Wallet.createRandom(); + +// Initialize wallet user, pass 'prod' instead of 'staging' for mainnet apps +const userAlice = await PushAPI.initialize(signerAlice, { env: CONSTANTS.ENV.PROD }); +const userBobAddress = '0x8D4625b4e04d7dE7F158df470a71C5FC4D4d5F4B'; + +const generateRandomWordsWithTimestamp = () => { + return `${Math.random().toString(36).substring(2)} - ${new Date().toISOString()}`; +} + +userAlice.chat.send(userBobAddress, { + content: "Gm gm! It's a me... Alice! - " + generateRandomWordsWithTimestamp(), +}); + +console.log('Message sent from Alice to ', userBobAddress); \ No newline at end of file diff --git a/packages/examples/boilerplate/package.json b/packages/examples/boilerplate/package.json index ad9aae1c9..69caee583 100644 --- a/packages/examples/boilerplate/package.json +++ b/packages/examples/boilerplate/package.json @@ -14,7 +14,7 @@ "author": "", "license": "ISC", "dependencies": { - "@pushprotocol/restapi": "latest", + "@pushprotocol/restapi": "1.7.11", "ethers": "5.7.2", "input": "1.0.1" }, diff --git a/packages/examples/sdk-frontend-react/src/app/ChatSupportTest.tsx b/packages/examples/sdk-frontend-react/src/app/ChatSupportTest.tsx index 336586c14..6f7d9a89c 100644 --- a/packages/examples/sdk-frontend-react/src/app/ChatSupportTest.tsx +++ b/packages/examples/sdk-frontend-react/src/app/ChatSupportTest.tsx @@ -33,23 +33,31 @@ export const ChatSupportTest = () => { return ( //works as Chat as well as Support Chat -

Welcome

-

new chat

-

Welcome

-

new chat

-

Welcome

-

new chat

-

Welcome

- - - } - + key={'460336a9fa83112c95894af5471cd2b1091290a11298d87ec824ed74b7c14974'} + chatId="4ac5ab85c9c3d57adbdf2dba79357e56b2f9ef0256befe750d9f93af78d2ca68" + welcomeComponent={ +
+

Welcome

+

new chat

+

Welcome

+

new chat

+

Welcome

+

new chat

+

Welcome

+
+ } /> // { // define controls @@ -17,52 +17,69 @@ const ChatPreviewListTest = () => { setAddress((e.target as HTMLInputElement).value); }; - - const prefill:Array = [{ chatPreviewPayload: + const prefill: Array = [ + { + chatPreviewPayload: { + chatId: + '460336a9fa83112c95894af5471cd2b1091290a11298d87ec824ed74b7c14974', + chatPic: + '', + chatParticipant: 'eip155:0x99A08ac6254dcf7ccc37CeC662aeba8eFA666666', + chatGroup: false, + chatTimestamp: 1708516854492, + chatMsg: { + messageType: 'Text', + messageContent: + '"Hgkb" - a succinct and eloquent expression that encapsulates the essence of brevity in a world of verbosity. Your choice of letters is like a haiku in the vast expanse of literature, a tiny gem that shines bright amidst the sea of words. "Hgkb" - a phrase that dares to challenge the norms of communication, elevating simplicity to an art form worth celebrating. Bravo, my dear linguist, for bestowing upon us such a profound revelation in just four letters.', + }, + }, + }, + { + chatPreviewPayload: { + chatId: + '4ac5ab85c9c3d57adbdf2dba79357e56b2f9ef0256befe750d9f93af78d2ca68', + chatPic: + '', + chatParticipant: 'BRB Chat', + chatGroup: true, + chatTimestamp: 1705100044656, + chatMsg: { + messageType: 'Text', + messageContent: + 'Hi! Stay tuned, while BRB IRL dev tour has wrapped up, We still have BRB Online with challenges from global projects that still needs to be solved: https://push.org/brb', + }, + }, + }, + { + chatPreviewPayload: { + chatId: + '257221c02396ea210ab82c80d6e1d34abc36ea76dbeb3cb19d5e2e8313ff676f', + chatPic: + '', + chatParticipant: 'eip155:0x56A734ba4C7c7b117774C9aAcCEf521eBE66d65b', + chatGroup: false, + chatTimestamp: 1708357604562, + chatMsg: { + messageType: 'Text', + messageContent: 'hii', + }, + }, + }, { - chatId: "460336a9fa83112c95894af5471cd2b1091290a11298d87ec824ed74b7c14974", - chatPic: "", - chatParticipant: "eip155:0x99A08ac6254dcf7ccc37CeC662aeba8eFA666666", - chatGroup: false, - chatTimestamp: 1708516854492, - chatMsg: { - messageType: "Text", - messageContent: "\"Hgkb\" - a succinct and eloquent expression that encapsulates the essence of brevity in a world of verbosity. Your choice of letters is like a haiku in the vast expanse of literature, a tiny gem that shines bright amidst the sea of words. \"Hgkb\" - a phrase that dares to challenge the norms of communication, elevating simplicity to an art form worth celebrating. Bravo, my dear linguist, for bestowing upon us such a profound revelation in just four letters." - } - }}, - {chatPreviewPayload: { - "chatId": "4ac5ab85c9c3d57adbdf2dba79357e56b2f9ef0256befe750d9f93af78d2ca68", - "chatPic": "", - "chatParticipant": "BRB Chat", - "chatGroup": true, - "chatTimestamp": 1705100044656, - "chatMsg": { - "messageType": "Text", - "messageContent": "Hi! Stay tuned, while BRB IRL dev tour has wrapped up, We still have BRB Online with challenges from global projects that still needs to be solved: https://push.org/brb" - } - }}, - {chatPreviewPayload:{ - "chatId": "257221c02396ea210ab82c80d6e1d34abc36ea76dbeb3cb19d5e2e8313ff676f", - "chatPic": "", - "chatParticipant": "eip155:0x56A734ba4C7c7b117774C9aAcCEf521eBE66d65b", - "chatGroup": false, - "chatTimestamp": 1708357604562, - "chatMsg": { - "messageType": "Text", - "messageContent": "hii" - } - }}, - {chatPreviewPayload:{ - "chatId": "d8f9b8bd5d4a16eaf69dc438f4a39c4214ec38853e7fea465f647dd555e71c74", - "chatPic": "", - "chatParticipant": "eip155:0xb038a592435A2F7cFDDC44FD9e4139d4c6Fa4CDC", - "chatGroup": false, - "chatTimestamp": 1708347333547, - "chatMsg": { - "messageType": "Text", - "messageContent": "sdgqergqerg" - } - }}, + chatPreviewPayload: { + chatId: + 'd8f9b8bd5d4a16eaf69dc438f4a39c4214ec38853e7fea465f647dd555e71c74', + chatPic: + '', + chatParticipant: 'eip155:0xb038a592435A2F7cFDDC44FD9e4139d4c6Fa4CDC', + chatGroup: false, + chatTimestamp: 1708347333547, + chatMsg: { + messageType: 'Text', + messageContent: 'sdgqergqerg', + }, + }, + }, // { // "chatId": "c8428b00107de879fcb212211bd56d0c4596547343eb0a49cc256aa4d99801f5", // "chatPic": "", @@ -129,7 +146,7 @@ const ChatPreviewListTest = () => { // "messageContent": "hii" // } // } - ] + ]; return ( <> { />
-
- + { console.log("Chat id: ", chatid,chatParticipant) }} - onUnreadCountChange={(count) => { console.log("Count is: ", count) }} - onLoading={(loadingData) => { console.log("loading data: ", loadingData) }} - onPaging={(chats) => { console.log("paging chats are: ", chats) }} - onPreload={(chats) => { console.log("preload chats are: ", chats) }} - // prefillChatPreviewList={prefill} + onChatSelected={(chatid, chatParticipant) => { + console.log('Chat id: ', chatid, chatParticipant); + }} + onUnreadCountChange={(count) => { + console.log('Count is: ', count); + }} + onLoading={(loadingData) => { + console.log('loading data: ', loadingData); + }} + onPaging={(chats) => { + console.log('paging chats are: ', chats); + }} + onPreload={(chats) => { + console.log('preload chats are: ', chats); + }} + // prefillChatPreviewList={prefill} // listType='SEARCH' // searchParamter='c2d544ad9d1efd5c5a593b143bf8232875c926cf28015564e70ad078b95f807e' />
- ) -} + ); +}; -export default ChatPreviewListTest; \ No newline at end of file +export default ChatPreviewListTest; diff --git a/packages/examples/sdk-frontend-react/src/app/ChatUITest/ChatViewComponent.tsx b/packages/examples/sdk-frontend-react/src/app/ChatUITest/ChatViewComponent.tsx index 397a1ff89..20b26b84d 100644 --- a/packages/examples/sdk-frontend-react/src/app/ChatUITest/ChatViewComponent.tsx +++ b/packages/examples/sdk-frontend-react/src/app/ChatUITest/ChatViewComponent.tsx @@ -1,6 +1,12 @@ import styled from 'styled-components'; -import { ChatView, CreateGroupModal, MODAL_BACKGROUND_TYPE, MODAL_POSITION_TYPE, UserProfile } from "@pushprotocol/uiweb"; +import { + ChatView, + CreateGroupModal, + MODAL_BACKGROUND_TYPE, + MODAL_POSITION_TYPE, + UserProfile, +} from '@pushprotocol/uiweb'; import { Section } from '../components/StyledComponents'; import Img from '../../assets/epnsLogo.png'; @@ -13,22 +19,26 @@ const ChatViewComponentTest = () => { return (

Chat View Test page

- - {console.log('in close')}} /> - - {/* {console.log('in close')}} modalBackground={MODAL_BACKGROUND_TYPE.OVERLAY} modalPositionType={MODAL_POSITION_TYPE.RELATIVE}/> */} - console.log("Verification Failed")} - chatId='0xf8250D363BD1F25f52F10C21188fe82c68C049c4' - chatProfileLeftHelperComponent={console.debug('clicked')}/>} + {/* { + console.log('in close'); + }} + /> */} + + {/* {console.log('in close')}} modalBackground={MODAL_BACKGROUND_TYPE.OVERLAY} modalPositionType={MODAL_POSITION_TYPE.RELATIVE}/> */} + console.log('Verification Failed')} + chatId="4ac5ab85c9c3d57adbdf2dba79357e56b2f9ef0256befe750d9f93af78d2ca68" + chatProfileLeftHelperComponent={ + console.debug('clicked')} /> + } chatProfileRightHelperComponent={
right component
} - limit={10} - isConnected={true} + isConnected={true} groupInfoModalBackground={MODAL_BACKGROUND_TYPE.OVERLAY} - groupInfoModalPositionType={MODAL_POSITION_TYPE.RELATIVE} - verificationFailModalPosition={MODAL_POSITION_TYPE.RELATIVE} + // groupInfoModalPositionType={MODAL_POSITION_TYPE.RELATIVE} + // verificationFailModalPosition={MODAL_POSITION_TYPE.RELATIVE} // welcomeComponent={
//

Welcome

@@ -39,20 +49,18 @@ const ChatViewComponentTest = () => { //

new chat

//

Welcome

- //
} - - /> + />
); -} +}; export default ChatViewComponentTest; const ChatViewComponentCard = styled(Section)` height: 80vh; - position:relative; + position: relative; `; //c2d544ad9d1efd5c5a593b143bf8232875c926cf28015564e70ad078b95f807e //4ac5ab85c9c3d57adbdf2dba79357e56b2f9ef0256befe750d9f93af78d2ca68 diff --git a/packages/examples/sdk-frontend-react/src/app/app.tsx b/packages/examples/sdk-frontend-react/src/app/app.tsx index 8237d5984..bb55e117c 100644 --- a/packages/examples/sdk-frontend-react/src/app/app.tsx +++ b/packages/examples/sdk-frontend-react/src/app/app.tsx @@ -268,7 +268,7 @@ export function App() { const user = await PushApi.user.get({ account: account, env }); let pgpPrivateKey; const librarySigner = await library.getSigner(account); - const pushUser = await PushAPI.initialize(librarySigner!, { + const pushUser = await PushAPI.initialize({ env: env, account: account, alpha: { feature: ['SCALABILITY_V2'] }, @@ -339,13 +339,13 @@ export function App() { - + @@ -410,7 +410,10 @@ export function App() { element={} /> } /> - } /> + } + /> } /> 0 && pk.substr(0, 2) !== '0x') { + pk = '0x' + pk; +} + +// Loading signer from private key, ideally this is the wallet you will connect for group chat +const signer = pk.length > 0 ? new ethers.Wallet(pk) : ethers.Wallet.createRandom(); + +// Print wallet address +console.log('Wallet address: ', signer.address); + +// Initialize wallet user, pass 'prod' instead of 'staging' for mainnet apps +let userAlice = await PushAPI.initialize(signer, { env: CONSTANTS.ENV.PROD }); +console.log('User initialized the user', userAlice); + +// Get chat id +let chatid = await input.text('Enter ChatId for the group -'); + +// Manually input this as base64 encoded image might be too long +let desc = await input.text('Enter chat group description -'); +const base64Image = ''; + +userAlice = await userAlice.chat.group.update(chatid, { + description: desc !== '' ? desc : null, + image: base64Image +}); +console.log('User updated the profile', userAlice); \ No newline at end of file diff --git a/packages/examples/several-examples/example-chat-guest-mode-functions.js b/packages/examples/several-examples/example-chat-guest-mode-functions.js new file mode 100644 index 000000000..d996d85fc --- /dev/null +++ b/packages/examples/several-examples/example-chat-guest-mode-functions.js @@ -0,0 +1,18 @@ +import { CONSTANTS, PushAPI } from '@pushprotocol/restapi'; +import { ethers } from 'ethers'; +import input from 'input'; + +console.log("Hello... what's my purpose?") +console.log("To train all the hackers..") + +// Create read only user +const readOnlyAccount = await PushAPI.initialize(null, { + account: '0x0000000000000000000000000000000000000001', + env: CONSTANTS.ENV.PROD +}); + +// get chat info +const recipient = 'eip155:0x99A08ac6254dcf7ccc37CeC662aeba8eFA666666'; +const chatInfo = await readOnlyAccount.chat.info(recipient); + +console.log('Chat Info:', chatInfo); diff --git a/packages/examples/several-examples/example-chat-profile-update.js b/packages/examples/several-examples/example-chat-profile-update.js new file mode 100644 index 000000000..3be1f7681 --- /dev/null +++ b/packages/examples/several-examples/example-chat-profile-update.js @@ -0,0 +1,39 @@ +import { CONSTANTS, PushAPI } from '@pushprotocol/restapi'; +import { ethers } from 'ethers'; +import input from 'input'; + +console.log("Hello... what's my purpose?") +console.log("To train all the hackers..") + +// Requesting private key from user +// This is a demo to show how profile of a user can be changed +console.log("This demo requires a wallet to be initialized via private key so that the profile can be applied"); +console.log("Alternatively just leave the input empty and we will create a new user"); +let pk = await input.text('Enter private key of your wallet -'); +if (pk.length > 0 && pk.substr(0, 2) !== '0x') { + pk = '0x' + pk; +} + +// Loading signer from private key, ideally this is the wallet you will connect +const signer = pk.length > 0 ? new ethers.Wallet(pk) : ethers.Wallet.createRandom(); + +// Print wallet address +console.log('Wallet address: ', signer.address); + +// Initialize wallet user, pass 'prod' instead of 'staging' for mainnet apps +let userAlice = await PushAPI.initialize(signer, { env: CONSTANTS.ENV.PROD }); +console.log('User initialized the user', userAlice); + +let name = await input.text('Enter Push Profile Name -'); +let desc = await input.text('Enter Push Profile Desc -'); + +// Manually input this as base64 encoded image might be too long +let image = await input.text('Enter Push Profile Image -'); + +userAlice = await userAlice.profile.update({ + name: name !== '' ? name : null, + desc: desc !== '' ? desc : null, + image: image !== '' ? image : null +}); +console.log('User updated the profile', userAlice); + diff --git a/packages/restapi/src/lib/pushstream/PushStream.ts b/packages/restapi/src/lib/pushstream/PushStream.ts index f7b09ebcf..5f4345ac8 100644 --- a/packages/restapi/src/lib/pushstream/PushStream.ts +++ b/packages/restapi/src/lib/pushstream/PushStream.ts @@ -124,398 +124,427 @@ export class PushStream extends EventEmitter { } public async connect(): Promise { - return new Promise(async (resolve, reject) => { - const shouldInitializeChatSocket = - !this.listen || - this.listen.length === 0 || - this.listen.includes(STREAM.CHAT) || - this.listen.includes(STREAM.CHAT_OPS) || - this.listen.includes(STREAM.SPACE) || - this.listen.includes(STREAM.SPACE_OPS); - const shouldInitializeNotifSocket = - !this.listen || - this.listen.length === 0 || - this.listen.includes(STREAM.NOTIF) || - this.listen.includes(STREAM.NOTIF_OPS) || - this.listen.includes(STREAM.VIDEO); - - let isChatSocketConnected = false; - let isNotifSocketConnected = false; - // Function to check and emit the STREAM.CONNECT event - const checkAndEmitConnectEvent = () => { - if ( - ((shouldInitializeChatSocket && isChatSocketConnected) || - !shouldInitializeChatSocket) && - ((shouldInitializeNotifSocket && isNotifSocketConnected) || - !shouldInitializeNotifSocket) - ) { - this.emit(STREAM.CONNECT); - console.log('RestAPI::PushStream::connect - Emitted STREAM.CONNECT'); - resolve(); - } - }; + return new Promise((resolve, reject) => { + (async () => { + const shouldInitializeChatSocket = + !this.listen || + this.listen.length === 0 || + this.listen.includes(STREAM.CHAT) || + this.listen.includes(STREAM.CHAT_OPS) || + this.listen.includes(STREAM.SPACE) || + this.listen.includes(STREAM.SPACE_OPS); + const shouldInitializeNotifSocket = + !this.listen || + this.listen.length === 0 || + this.listen.includes(STREAM.NOTIF) || + this.listen.includes(STREAM.NOTIF_OPS) || + this.listen.includes(STREAM.VIDEO); + + let isChatSocketConnected = false; + let isNotifSocketConnected = false; + // Function to check and emit the STREAM.CONNECT event + const checkAndEmitConnectEvent = () => { + if ( + ((shouldInitializeChatSocket && isChatSocketConnected) || + !shouldInitializeChatSocket) && + ((shouldInitializeNotifSocket && isNotifSocketConnected) || + !shouldInitializeNotifSocket) + ) { + this.emit(STREAM.CONNECT); + console.log( + 'RestAPI::PushStream::connect - Emitted STREAM.CONNECT' + ); + resolve(); + } + }; - const TIMEOUT_DURATION = 5000; // Timeout duration in milliseconds - setTimeout(() => { - if (!(this.notifSocketConnected || this.chatSocketConnected)) { - reject(new Error('Connection timeout')); // Reject the promise if connect event is not emitted within the timeout - } - }, TIMEOUT_DURATION); - - const handleSocketDisconnection = async ( - socketType: 'chat' | 'notif' - ) => { - if (socketType === 'chat') { - isChatSocketConnected = false; - this.chatSocketConnected = false; - this.chatSocketCount--; - if (isNotifSocketConnected) { - if ( - this.pushNotificationSocket && - this.pushNotificationSocket.connected - ) { + const TIMEOUT_DURATION = 5000; // Timeout duration in milliseconds + setTimeout(() => { + if (!(this.notifSocketConnected || this.chatSocketConnected)) { + reject(new Error('Connection timeout')); // Reject the promise if connect event is not emitted within the timeout + } + }, TIMEOUT_DURATION); + + const handleSocketDisconnection = async ( + socketType: 'chat' | 'notif' + ) => { + if (socketType === 'chat') { + isChatSocketConnected = false; + this.chatSocketConnected = false; + this.chatSocketCount--; + if (isNotifSocketConnected) { + if ( + this.pushNotificationSocket && + this.pushNotificationSocket.connected + ) { + console.log( + 'RestAPI::PushStream::handleSocketDisconnection - Disconnecting Notification Socket...' + ); + this.pushNotificationSocket.disconnect(); + } + } else { + // Emit STREAM.DISCONNECT only if the notification socket was already disconnected + this.emit(STREAM.DISCONNECT); console.log( - 'RestAPI::PushStream::handleSocketDisconnection - Disconnecting Notification Socket...' + 'RestAPI::PushStream::handleSocketDisconnection - Emitted STREAM.DISCONNECT for chat.' ); - this.pushNotificationSocket.disconnect(); } - } else { - // Emit STREAM.DISCONNECT only if the notification socket was already disconnected - this.emit(STREAM.DISCONNECT); - console.log( - 'RestAPI::PushStream::handleSocketDisconnection - Emitted STREAM.DISCONNECT for chat.' - ); - } - } else if (socketType === 'notif') { - isNotifSocketConnected = false; - this.notifSocketConnected = false; - this.notifSocketCount--; - if (isChatSocketConnected) { - if (this.pushChatSocket && this.pushChatSocket.connected) { + } else if (socketType === 'notif') { + isNotifSocketConnected = false; + this.notifSocketConnected = false; + this.notifSocketCount--; + if (isChatSocketConnected) { + if (this.pushChatSocket && this.pushChatSocket.connected) { + console.log( + 'RestAPI::PushStream::handleSocketDisconnection - Disconnecting Chat Socket...' + ); + this.pushChatSocket.disconnect(); + } + } else { + // Emit STREAM.DISCONNECT only if the chat socket was already disconnected + this.emit(STREAM.DISCONNECT); console.log( - 'RestAPI::PushStream::handleSocketDisconnection - Disconnecting Chat Socket...' + 'RestAPI::PushStream::handleSocketDisconnection - Emitted STREAM.DISCONNECT for notification.' ); - this.pushChatSocket.disconnect(); } - } else { - // Emit STREAM.DISCONNECT only if the chat socket was already disconnected - this.emit(STREAM.DISCONNECT); - console.log( - 'RestAPI::PushStream::handleSocketDisconnection - Emitted STREAM.DISCONNECT for notification.' - ); } - } - }; - - if (shouldInitializeChatSocket) { - if (!this.pushChatSocket) { - // If pushChatSocket does not exist, create a new socket connection - console.log( - 'RestAPI::PushStream::ChatSocket::Create - pushChatSocket does not exist, creating new socket connection...' - ); - - this.pushChatSocket = await createSocketConnection({ - user: walletToPCAIP10(this.account), - socketType: 'chat', - socketOptions: { - autoConnect: this.options?.connection?.auto ?? true, - reconnectionAttempts: this.options?.connection?.retries ?? 3, - }, - env: this.options?.env as ENV, - }); + }; + if (shouldInitializeChatSocket) { if (!this.pushChatSocket) { - reject( - new Error( - 'RestAPI::PushStream::ChatSocket::Error - Push chat socket not connected' - ) + // If pushChatSocket does not exist, create a new socket connection + console.log( + 'RestAPI::PushStream::ChatSocket::Create - pushChatSocket does not exist, creating new socket connection...' ); - } - } else if (this.pushChatSocket && !this.chatSocketConnected) { - // If pushChatSocket exists but is not connected, attempt to reconnect - console.log( - 'RestAPI::PushStream::ChatSocket::Reconnect - Attempting to reconnect push chat socket...' - ); - this.pushChatSocket.connect(); // Assuming connect() is the method to re-establish connection - } else { - console.log( - 'RestAPI::PushStream::ChatSocket::Status - Push chat socket already connected' - ); - } - } - if (shouldInitializeNotifSocket) { - if (!this.pushNotificationSocket) { - // If pushNotificationSocket does not exist, create a new socket connection - console.log( - 'RestAPI::PushStream::NotifSocket::Create - pushNotificationSocket does not exist, creating new socket connection...' - ); - this.pushNotificationSocket = await createSocketConnection({ - user: pCAIP10ToWallet(this.account), - env: this.options?.env as ENV, - socketOptions: { - autoConnect: this.options?.connection?.auto ?? true, - reconnectionAttempts: this.options?.connection?.retries ?? 3, - }, - }); - - if (!this.pushNotificationSocket) { - reject( - new Error( - 'RestAPI::PushStream::NotifSocket::Error - Push notification socket not connected' - ) + this.pushChatSocket = await createSocketConnection({ + user: walletToPCAIP10(this.account), + socketType: 'chat', + socketOptions: { + autoConnect: this.options?.connection?.auto ?? true, + reconnectionAttempts: this.options?.connection?.retries ?? 3, + }, + env: this.options?.env as ENV, + }); + + if (!this.pushChatSocket) { + reject( + new Error( + 'RestAPI::PushStream::ChatSocket::Error - Push chat socket not connected' + ) + ); + } + } else if (this.pushChatSocket && !this.chatSocketConnected) { + // If pushChatSocket exists but is not connected, attempt to reconnect + console.log( + 'RestAPI::PushStream::ChatSocket::Reconnect - Attempting to reconnect push chat socket...' + ); + this.pushChatSocket.connect(); // Assuming connect() is the method to re-establish connection + } else { + console.log( + 'RestAPI::PushStream::ChatSocket::Status - Push chat socket already connected' ); } - } else if (this.pushNotificationSocket && !this.notifSocketConnected) { - // If pushNotificationSocket exists but is not connected, attempt to reconnect - console.log( - 'RestAPI::PushStream::NotifSocket::Reconnect - Attempting to reconnect push notification socket...' - ); - this.notifSocketCount++; - this.pushNotificationSocket.connect(); // Assuming connect() is the method to re-establish connection - } else { - // If pushNotificationSocket is already connected - console.log( - 'RestAPI::PushStream::NotifSocket::Status - Push notification socket already connected' - ); - } - } - - const shouldEmit = (eventType: STREAM): boolean => { - if (!this.listen || this.listen.length === 0) { - return true; } - return this.listen.includes(eventType); - }; - - if (this.pushChatSocket) { - this.pushChatSocket.on(EVENTS.CONNECT, async () => { - isChatSocketConnected = true; - this.chatSocketCount++; - this.chatSocketConnected = true; - checkAndEmitConnectEvent(); - console.log( - `RestAPI::PushStream::EVENTS.CONNECT::Chat Socket Connected (ID: ${this.pushChatSocket.id})` - ); - }); - - this.pushChatSocket.on(EVENTS.DISCONNECT, async () => { - await handleSocketDisconnection('chat'); - }); - this.pushChatSocket.on(EVENTS.CHAT_GROUPS, (data: any) => { - try { - const modifiedData = DataModifier.handleChatGroupEvent( - data, - this.raw - ); - modifiedData.event = DataModifier.convertToProposedName( - modifiedData.event + if (shouldInitializeNotifSocket) { + if (!this.pushNotificationSocket) { + // If pushNotificationSocket does not exist, create a new socket connection + console.log( + 'RestAPI::PushStream::NotifSocket::Create - pushNotificationSocket does not exist, creating new socket connection...' ); - modifiedData.streamUid = this.uid; - DataModifier.handleToField(modifiedData); - if (this.shouldEmitChat(data.chatId)) { - if ( - data.eventType === GroupEventType.JoinGroup || - data.eventType === GroupEventType.LeaveGroup || - data.eventType === MessageEventType.Request || - data.eventType === GroupEventType.Remove || - data.eventType === GroupEventType.RoleChange - ) { - if (shouldEmit(STREAM.CHAT)) { - this.emit(STREAM.CHAT, modifiedData); - } - } else { - if (shouldEmit(STREAM.CHAT_OPS)) { - this.emit(STREAM.CHAT_OPS, modifiedData); - } - } + this.pushNotificationSocket = await createSocketConnection({ + user: pCAIP10ToWallet(this.account), + env: this.options?.env as ENV, + socketOptions: { + autoConnect: this.options?.connection?.auto ?? true, + reconnectionAttempts: this.options?.connection?.retries ?? 3, + }, + }); + + if (!this.pushNotificationSocket) { + reject( + new Error( + 'RestAPI::PushStream::NotifSocket::Error - Push notification socket not connected' + ) + ); } - } catch (error) { - console.error( - 'Error handling CHAT_GROUPS event:', - error, - 'Data:', - data + } else if ( + this.pushNotificationSocket && + !this.notifSocketConnected + ) { + // If pushNotificationSocket exists but is not connected, attempt to reconnect + console.log( + 'RestAPI::PushStream::NotifSocket::Reconnect - Attempting to reconnect push notification socket...' + ); + this.notifSocketCount++; + this.pushNotificationSocket.connect(); // Assuming connect() is the method to re-establish connection + } else { + // If pushNotificationSocket is already connected + console.log( + 'RestAPI::PushStream::NotifSocket::Status - Push notification socket already connected' ); } - }); + } - this.pushChatSocket.on( - EVENTS.CHAT_RECEIVED_MESSAGE, - async (data: any) => { - try { - if ( - data.messageCategory == 'Chat' || - data.messageCategory == 'Request' - ) { - // Dont call this if read only mode ? - if (this.decryptedPgpPvtKey) { - data = await this.chatInstance.decrypt([data]); - data = data[0]; - } - } + const shouldEmit = (eventType: STREAM): boolean => { + if (!this.listen || this.listen.length === 0) { + return true; + } + return this.listen.includes(eventType); + }; + + if (this.pushChatSocket) { + this.pushChatSocket.on(EVENTS.CONNECT, async () => { + isChatSocketConnected = true; + this.chatSocketCount++; + this.chatSocketConnected = true; + checkAndEmitConnectEvent(); + console.log( + `RestAPI::PushStream::EVENTS.CONNECT::Chat Socket Connected (ID: ${this.pushChatSocket.id})` + ); + }); - const modifiedData = DataModifier.handleChatEvent(data, this.raw); + this.pushChatSocket.on(EVENTS.DISCONNECT, async () => { + await handleSocketDisconnection('chat'); + }); + + this.pushChatSocket.on(EVENTS.CHAT_GROUPS, (data: any) => { + try { + const modifiedData = DataModifier.handleChatGroupEvent( + data, + this.raw + ); modifiedData.event = DataModifier.convertToProposedName( modifiedData.event ); + modifiedData.streamUid = this.uid; DataModifier.handleToField(modifiedData); if (this.shouldEmitChat(data.chatId)) { - if (shouldEmit(STREAM.CHAT)) { - this.emit(STREAM.CHAT, modifiedData); + if ( + data.eventType === GroupEventType.JoinGroup || + data.eventType === GroupEventType.LeaveGroup || + data.eventType === MessageEventType.Request || + data.eventType === GroupEventType.Remove || + data.eventType === GroupEventType.RoleChange + ) { + if (shouldEmit(STREAM.CHAT)) { + this.emit(STREAM.CHAT, modifiedData); + } + } else { + if (shouldEmit(STREAM.CHAT_OPS)) { + this.emit(STREAM.CHAT_OPS, modifiedData); + } } } } catch (error) { console.error( - 'Error handling CHAT_RECEIVED_MESSAGE event:', + 'Error handling CHAT_GROUPS event:', error, 'Data:', data ); } - } - ); - - this.pushChatSocket.on('SPACES', (data: any) => { - try { - const modifiedData = DataModifier.handleSpaceEvent(data, this.raw); - modifiedData.event = DataModifier.convertToProposedNameForSpace( - modifiedData.event - ); - - DataModifier.handleToField(modifiedData); + }); - if (this.shouldEmitSpace(data.spaceId)) { - if ( - data.eventType === SpaceEventType.Join || - data.eventType === SpaceEventType.Leave || - data.eventType === MessageEventType.Request || - data.eventType === SpaceEventType.Remove || - data.eventType === SpaceEventType.Start || - data.eventType === SpaceEventType.Stop - ) { - if (shouldEmit(STREAM.SPACE)) { - this.emit(STREAM.SPACE, modifiedData); + this.pushChatSocket.on( + EVENTS.CHAT_RECEIVED_MESSAGE, + async (data: any) => { + try { + if ( + data.messageCategory == 'Chat' || + data.messageCategory == 'Request' + ) { + // Dont call this if read only mode ? + if (this.decryptedPgpPvtKey) { + data = await this.chatInstance.decrypt([data]); + data = data[0]; + } } - } else { - if (shouldEmit(STREAM.SPACE_OPS)) { - this.emit(STREAM.SPACE_OPS, modifiedData); + + const modifiedData = DataModifier.handleChatEvent( + data, + this.raw + ); + modifiedData.event = DataModifier.convertToProposedName( + modifiedData.event + ); + DataModifier.handleToField(modifiedData); + if (this.shouldEmitChat(data.chatId)) { + if (shouldEmit(STREAM.CHAT)) { + this.emit(STREAM.CHAT, modifiedData); + } } + } catch (error) { + console.error( + 'Error handling CHAT_RECEIVED_MESSAGE event:', + error, + 'Data:', + data + ); } } - } catch (error) { - console.error('Error handling SPACES event:', error, 'Data:', data); - } - }); + ); - this.pushChatSocket.on('SPACES_MESSAGES', (data: any) => { - try { - const modifiedData = DataModifier.handleSpaceEvent(data, this.raw); - modifiedData.event = DataModifier.convertToProposedNameForSpace( - modifiedData.event - ); + this.pushChatSocket.on('SPACES', (data: any) => { + try { + const modifiedData = DataModifier.handleSpaceEvent( + data, + this.raw + ); + modifiedData.event = DataModifier.convertToProposedNameForSpace( + modifiedData.event + ); - DataModifier.handleToField(modifiedData); + DataModifier.handleToField(modifiedData); - if (this.shouldEmitSpace(data.spaceId)) { - if (shouldEmit(STREAM.SPACE)) { - this.emit(STREAM.SPACE, modifiedData); + if (this.shouldEmitSpace(data.spaceId)) { + if ( + data.eventType === SpaceEventType.Join || + data.eventType === SpaceEventType.Leave || + data.eventType === MessageEventType.Request || + data.eventType === SpaceEventType.Remove || + data.eventType === SpaceEventType.Start || + data.eventType === SpaceEventType.Stop + ) { + if (shouldEmit(STREAM.SPACE)) { + this.emit(STREAM.SPACE, modifiedData); + } + } else { + if (shouldEmit(STREAM.SPACE_OPS)) { + this.emit(STREAM.SPACE_OPS, modifiedData); + } + } } + } catch (error) { + console.error( + 'Error handling SPACES event:', + error, + 'Data:', + data + ); } - } catch (error) { - console.error('Error handling SPACES event:', error, 'Data:', data); - } - }); - } + }); - if (this.pushNotificationSocket) { - this.pushNotificationSocket.on(EVENTS.CONNECT, async () => { - console.log( - `RestAPI::PushStream::NotifSocket::Connect - Notification Socket Connected (ID: ${this.pushNotificationSocket.id})` - ); - isNotifSocketConnected = true; - this.notifSocketCount++; - this.notifSocketConnected = true; - checkAndEmitConnectEvent(); - }); - - this.pushNotificationSocket.on(EVENTS.DISCONNECT, async () => { - console.log( - 'RestAPI::PushStream::NotifSocket::Disconnect - Notification socket disconnected.' - ); - await handleSocketDisconnection('notif'); - }); - - this.pushNotificationSocket.on(EVENTS.USER_FEEDS, (data: any) => { - try { - if ( - data.payload.data.additionalMeta?.type === - `${ADDITIONAL_META_TYPE.PUSH_VIDEO}+1` && - shouldEmit(STREAM.VIDEO) && - this.shouldEmitVideo(data.sender) - ) { - // Video Notification - const modifiedData = DataModifier.mapToVideoEvent( + this.pushChatSocket.on('SPACES_MESSAGES', (data: any) => { + try { + const modifiedData = DataModifier.handleSpaceEvent( data, - this.account === data.sender - ? MessageOrigin.Self - : MessageOrigin.Other, this.raw ); - - this.emit(STREAM.VIDEO, modifiedData); - } else { - // Channel Notification - const modifiedData = DataModifier.mapToNotificationEvent( - data, - NotificationEventType.INBOX, - this.account === data.sender ? 'self' : 'other', - this.raw + modifiedData.event = DataModifier.convertToProposedNameForSpace( + modifiedData.event ); - if (this.shouldEmitChannel(modifiedData.from)) { - if (shouldEmit(STREAM.NOTIF)) { - this.emit(STREAM.NOTIF, modifiedData); + DataModifier.handleToField(modifiedData); + + if (this.shouldEmitSpace(data.spaceId)) { + if (shouldEmit(STREAM.SPACE)) { + this.emit(STREAM.SPACE, modifiedData); } } - } - } catch (error) { - console.error( - `RestAPI::PushStream::NotifSocket::UserFeeds::Error - Error handling event: ${error}, Data: ${JSON.stringify( + } catch (error) { + console.error( + 'Error handling SPACES event:', + error, + 'Data:', data - )}` + ); + } + }); + } + + if (this.pushNotificationSocket) { + this.pushNotificationSocket.on(EVENTS.CONNECT, async () => { + console.log( + `RestAPI::PushStream::NotifSocket::Connect - Notification Socket Connected (ID: ${this.pushNotificationSocket.id})` ); - } - }); - - this.pushNotificationSocket.on(EVENTS.USER_SPAM_FEEDS, (data: any) => { - try { - const modifiedData = DataModifier.mapToNotificationEvent( - data, - NotificationEventType.SPAM, - this.account === data.sender ? 'self' : 'other', - this.raw + isNotifSocketConnected = true; + this.notifSocketCount++; + this.notifSocketConnected = true; + checkAndEmitConnectEvent(); + }); + + this.pushNotificationSocket.on(EVENTS.DISCONNECT, async () => { + console.log( + 'RestAPI::PushStream::NotifSocket::Disconnect - Notification socket disconnected.' ); - modifiedData.origin = - this.account === modifiedData.from ? 'self' : 'other'; - if (this.shouldEmitChannel(modifiedData.from)) { - if (shouldEmit(STREAM.NOTIF)) { - this.emit(STREAM.NOTIF, modifiedData); + await handleSocketDisconnection('notif'); + }); + + this.pushNotificationSocket.on(EVENTS.USER_FEEDS, (data: any) => { + try { + if ( + data.payload.data.additionalMeta?.type === + `${ADDITIONAL_META_TYPE.PUSH_VIDEO}+1` && + shouldEmit(STREAM.VIDEO) && + this.shouldEmitVideo(data.sender) + ) { + // Video Notification + const modifiedData = DataModifier.mapToVideoEvent( + data, + this.account === data.sender + ? MessageOrigin.Self + : MessageOrigin.Other, + this.raw + ); + + this.emit(STREAM.VIDEO, modifiedData); + } else { + // Channel Notification + const modifiedData = DataModifier.mapToNotificationEvent( + data, + NotificationEventType.INBOX, + this.account === data.sender ? 'self' : 'other', + this.raw + ); + + if (this.shouldEmitChannel(modifiedData.from)) { + if (shouldEmit(STREAM.NOTIF)) { + this.emit(STREAM.NOTIF, modifiedData); + } + } + } + } catch (error) { + console.error( + `RestAPI::PushStream::NotifSocket::UserFeeds::Error - Error handling event: ${error}, Data: ${JSON.stringify( + data + )}` + ); + } + }); + + this.pushNotificationSocket.on( + EVENTS.USER_SPAM_FEEDS, + (data: any) => { + try { + const modifiedData = DataModifier.mapToNotificationEvent( + data, + NotificationEventType.SPAM, + this.account === data.sender ? 'self' : 'other', + this.raw + ); + modifiedData.origin = + this.account === modifiedData.from ? 'self' : 'other'; + if (this.shouldEmitChannel(modifiedData.from)) { + if (shouldEmit(STREAM.NOTIF)) { + this.emit(STREAM.NOTIF, modifiedData); + } + } + } catch (error) { + console.error( + 'Error handling USER_SPAM_FEEDS event:', + error, + 'Data:', + data + ); } } - } catch (error) { - console.error( - 'Error handling USER_SPAM_FEEDS event:', - error, - 'Data:', - data - ); - } - }); - } + ); + } - this.disconnected = false; + this.disconnected = false; + })(); }); } diff --git a/packages/restapi/yarn.lock b/packages/restapi/yarn.lock index 9a57755d5..147348c8d 100644 --- a/packages/restapi/yarn.lock +++ b/packages/restapi/yarn.lock @@ -589,6 +589,11 @@ engine.io-parser@~5.2.1: resolved "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.2.1.tgz" integrity sha512-9JktcM3u18nU9N2Lz3bWeBgxVgOKpw7yhRaoxQA3FUDZzzw+9WlA6p4G4u0RixNkg14fH7EfEc/RhpurtiROTQ== +envfile@^7.1.0: + version "7.1.0" + resolved "https://registry.yarnpkg.com/envfile/-/envfile-7.1.0.tgz#c0b101279dc710c25546602d5d17cfb9ab132e48" + integrity sha512-dyH4QnnZsArCLhPASr29eqBWDvKpq0GggQFTmysTT/S9TTmt1JrEKNvTBc09Cd7ujVZQful2HBGRMe2agu7Krg== + err-code@^3.0.1: version "3.0.1" resolved "https://registry.npmjs.org/err-code/-/err-code-3.0.1.tgz" diff --git a/packages/uiweb/.editorconfig b/packages/uiweb/.editorconfig new file mode 100644 index 000000000..200496778 --- /dev/null +++ b/packages/uiweb/.editorconfig @@ -0,0 +1,17 @@ +# EditorConfig helps developers define and maintain consistent coding styles between different editors and IDEs +root = true + +[*] +end_of_line = lf +insert_final_newline = true + +[*.js] +indent_style = space +indent_size = 2 + +[*.json] +indent_style = space +indent_size = 2 + +[*.md] +trim_trailing_whitespace = true \ No newline at end of file diff --git a/packages/uiweb/.prettierrc b/packages/uiweb/.prettierrc new file mode 100644 index 000000000..d676e9c7e --- /dev/null +++ b/packages/uiweb/.prettierrc @@ -0,0 +1,11 @@ +{ + "semi": true, + "singleQuote": true, + "printWidth": 120, + "prettier.trailingComma": "all", + "tabWidth": 2, + "bracketSameLine": false, + "useTabs": false, + "arrowParens": "always", + "singleAttributePerLine": true +} diff --git a/packages/uiweb/package.json b/packages/uiweb/package.json index a3639a92f..787414948 100644 --- a/packages/uiweb/package.json +++ b/packages/uiweb/package.json @@ -23,15 +23,18 @@ "html-react-parser": "^1.4.13", "livekit-client": "^1.13.3", "moment": "^2.29.4", - "react-icons": "^4.10.1", "react-easy-crop": "^4.1.4", + "react-icons": "^4.10.1", "react-image-file-resizer": "^0.4.7", + "animejs": "^2.2.0", + "classnames": "^2.2.5", + "raf": "^3.4.0", "react-toastify": "^9.1.3", "react-twitter-embed": "^4.0.4", "uuid": "^9.0.1" }, "peerDependencies": { - "@pushprotocol/restapi": "^1.2.15", + "@pushprotocol/restapi": "0.0.1-alpha.80", "@pushprotocol/socket": "^0.5.0", "react": ">=16.8.0", "styled-components": "^6.0.8" diff --git a/packages/uiweb/src/declerations.d.ts b/packages/uiweb/src/declerations.d.ts new file mode 100644 index 000000000..ea37db547 --- /dev/null +++ b/packages/uiweb/src/declerations.d.ts @@ -0,0 +1,3 @@ +declare module 'ParticleEffectButton'; +declare module 'animejs'; +declare module 'raf'; diff --git a/packages/uiweb/src/lib/components/chat/ChatPreview/ChatPreview.tsx b/packages/uiweb/src/lib/components/chat/ChatPreview/ChatPreview.tsx index ff1fdb83f..d96773885 100644 --- a/packages/uiweb/src/lib/components/chat/ChatPreview/ChatPreview.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatPreview/ChatPreview.tsx @@ -5,15 +5,16 @@ import styled from 'styled-components'; import { useChatData } from '../../../hooks'; import { Button, Image, Section } from '../../reusables'; +import { CONSTANTS } from '@pushprotocol/restapi'; +import { ethers } from 'ethers'; +import { CiImageOn } from 'react-icons/ci'; +import { FaFile } from 'react-icons/fa'; +import { CoreContractChainId, InfuraAPIKey } from '../../../config'; +import { resolveWeb3Name, shortenText } from '../../../helpers'; import { IChatPreviewProps } from '../exportedTypes'; +import { formatAddress, formatDate } from '../helpers'; import { IChatTheme } from '../theme'; import { ThemeContext } from '../theme/ThemeProvider'; -import { formatAddress, formatDate } from '../helpers'; -import { resolveNewEns, shortenText } from '../../../helpers'; -import { CoreContractChainId, InfuraAPIKey } from '../../../config'; -import { ethers } from 'ethers'; -import { FaFile } from 'react-icons/fa'; -import { CiImageOn } from 'react-icons/ci'; /** * @interface IThemeProps * this interface is used for defining the props for styled components @@ -23,25 +24,21 @@ interface IThemeProps { blur?: boolean; } -export const ChatPreview: React.FC = ( - options: IChatPreviewProps -) => { +export const ChatPreview: React.FC = (options: IChatPreviewProps) => { + // get hooks + const { user } = useChatData(); + const theme = useContext(ThemeContext); - const { env } = useChatData(); - const provider = new ethers.providers.InfuraProvider( - CoreContractChainId[env], - InfuraAPIKey - ); const [formattedAddress, setFormattedAddress] = useState(''); const [web3Name, setWeb3Name] = useState(null); useEffect(() => { (async () => { - const address = await formatAddress(options.chatPreviewPayload, env); + const address = await formatAddress(options.chatPreviewPayload, user?.env || CONSTANTS.ENV.PROD); setFormattedAddress(address); if (!options.chatPreviewPayload?.chatGroup) { try { - const result = await resolveNewEns(address, provider, env); + const result = await resolveWeb3Name(address, user); if (result) setWeb3Name(result); } catch (e) { // console.debug(e); @@ -51,22 +48,18 @@ export const ChatPreview: React.FC = ( }, []); const getProfileName = (formattedAddress: string) => { - return options.chatPreviewPayload?.chatGroup - ? formattedAddress - : web3Name - ? web3Name - : formattedAddress; + return options.chatPreviewPayload?.chatGroup ? formattedAddress : web3Name ? web3Name : formattedAddress; }; return ( - + @@ -206,7 +196,7 @@ const Account = styled.div` flex: 1; align-self: stretch; text-align: start; - // text-overflow: ellipsis ellipsis; + text-overflow: ellipsis; white-space: nowrap; overflow: hidden; margin-right: 10px; @@ -226,20 +216,19 @@ const Message = styled.div` flex: 1; align-self: stretch; text-align: start; - // text-overflow: ellipsis; + text-overflow: ellipsis; white-space: nowrap; overflow: hidden; margin-right: 10px; `; const Badge = styled.div` - background: ${(props) => - props.theme.backgroundColor?.chatPreviewBadgeBackground}; + background: ${(props) => props.theme.backgroundColor?.chatPreviewBadgeBackground}; font-weight: ${(props) => props.theme.fontWeight?.chatPreviewBadgeText}; font-size: ${(props) => props.theme.fontSize?.chatPreviewBadgeText}; color: ${(props) => props.theme.textColor?.chatPreviewBadgeText}; padding: 0px 8px; - min-height: 24px; + text-overflow: ellipsis; border-radius: 24px; align-self: center; `; diff --git a/packages/uiweb/src/lib/components/chat/ChatPreviewList/ChatPreviewList.tsx b/packages/uiweb/src/lib/components/chat/ChatPreviewList/ChatPreviewList.tsx index 1a37642ab..64724d9b4 100644 --- a/packages/uiweb/src/lib/components/chat/ChatPreviewList/ChatPreviewList.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatPreviewList/ChatPreviewList.tsx @@ -1,41 +1,42 @@ +// React + Web3 Essentials +import { ethers } from 'ethers'; import React, { useContext, useEffect, useRef, useState } from 'react'; -import { - ChatPreviewListErrorCodes, - Group, - IChatPreviewListError, - IChatPreviewListProps, - IChatPreviewPayload, -} from '../exportedTypes'; - +// External Packages import { CONSTANTS, IFeeds, IUser } from '@pushprotocol/restapi'; -import { ethers } from 'ethers'; import styled from 'styled-components'; +// Internal Compoonents +import { getAddress, getNewChatUser, pCAIP10ToWallet, traceStackCalls, walletToPCAIP10 } from '../../../helpers'; import { useChatData, usePushChatStream } from '../../../hooks'; +import useFetchChat from '../../../hooks/chat/useFetchChat'; import useFetchMessageUtilities from '../../../hooks/chat/useFetchMessageUtilities'; import useGetGroupByIDnew from '../../../hooks/chat/useGetGroupByIDnew'; +import usePushUser from '../../../hooks/usePushUser'; import { Button, Section, Span, Spinner } from '../../reusables'; import { ChatPreview } from '../ChatPreview'; -import useUserProfile from '../../../hooks/useUserProfile'; - -import { - getAddress, - getNewChatUser, - pCAIP10ToWallet, - walletToPCAIP10, -} from '../../../helpers'; import { displayDefaultUser, generateRandomNonce, transformChatItems, transformStreamToIChatPreviewPayload, } from '../helpers'; -import { IChatTheme } from '../theme'; + +// Internal Configs import { ThemeContext } from '../theme/ThemeProvider'; -import useFetchChat from '../../../hooks/chat/useFetchChat'; -// Define Interfaces +// Assets + +// Interfaces & Types +import { + ChatPreviewListErrorCodes, + Group, + IChatPreviewListError, + IChatPreviewListProps, + IChatPreviewPayload, +} from '../exportedTypes'; +import { IChatTheme } from '../theme'; + /** * @interface IThemeProps * this interface is used for defining the props for styled components @@ -65,16 +66,17 @@ interface IChatPreviewListMeta { }; } -// Define Constants +// Constants const CHAT_PAGE_LIMIT = 10; const SCROLL_LIMIT = 25; -export const ChatPreviewList: React.FC = ( - options: IChatPreviewListProps -) => { +// Exported Interfaces & Types + +// Exported Functions +export const ChatPreviewList: React.FC = (options: IChatPreviewListProps) => { // get hooks - const { env, signer, account, user } = useChatData(); - const { fetchUserProfile } = useUserProfile(); + const { user } = useChatData(); + const { fetchUserProfile } = usePushUser(); const { getGroupByIDnew } = useGetGroupByIDnew(); const { fetchLatestMessage, fetchChatList } = useFetchMessageUtilities(); @@ -92,17 +94,10 @@ export const ChatPreviewList: React.FC = ( error: null, }); // set chat preview list meta - const [chatPreviewListMeta, setChatPreviewListMeta] = - useState({ - selectedChatId: undefined, - badges: {}, - }); - - //hack to fix stream - const [chatStream, setChatStream] = useState({}); // to track any new messages - const [chatAcceptStream, setChatAcceptStream] = useState({}); // to track any new messages - const [chatRequestStream, setChatRequestStream] = useState({}); // any message in request - const [groupCreateStream, setGroupCreateStream] = useState({}); // any message in request + const [chatPreviewListMeta, setChatPreviewListMeta] = useState({ + selectedChatId: undefined, + badges: {}, + }); // set theme const theme = useContext(ThemeContext); @@ -110,52 +105,42 @@ export const ChatPreviewList: React.FC = ( // set ref const listInnerRef = useRef(null); - // const { chatRequestStream, chatAcceptStream } = - // usePushChatStream(); - //event listeners - usePushChatStream(); + // setup stream + const { chatStream, chatAcceptStream, chatRequestStream, chatRejectStream, groupCreateStream } = useChatData(); + // If push user changes or if options param changes useEffect(() => { - window.addEventListener('chatStream', (e: any) => setChatStream(e.detail)); - window.addEventListener('chatAcceptStream', (e: any) => - setChatAcceptStream(e.detail) - ); - window.addEventListener('chatRequestStream', (e: any) => - setChatRequestStream(e.detail) - ); - window.addEventListener('groupCreateStream', (e: any) => - setGroupCreateStream(e.detail) - ); - return () => { - window.removeEventListener('chatStream', (e: any) => - setChatStream(e.detail) - ); - window.removeEventListener('chatAcceptStream', (e: any) => - setChatAcceptStream(e.detail) - ); - window.removeEventListener('chatRequestStream', (e: any) => - setChatRequestStream(e.detail) - ); - window.removeEventListener('groupCreateStream', (e: any) => - setGroupCreateStream(e.detail) - ); - }; - }, []); + if (!user) { + return; + } + + // reset the entire state + if (!options?.prefillChatPreviewList) { + setChatPreviewList({ + nonce: generateRandomNonce(), + items: [], + page: 1, + preloading: true, + loading: false, + loaded: false, + reset: true, + resume: false, + errored: false, + error: null, + }); + } + }, [user, options?.prefillChatPreviewList, options?.searchParamter, options.listType, options.overrideAccount]); // Helper Functions // Add to chat items - const addChatItems: ( + const addChatItems: (items: IChatPreviewPayload[], incrementBadge?: boolean) => void = ( items: IChatPreviewPayload[], incrementBadge?: boolean - ) => void = (items: IChatPreviewPayload[], incrementBadge?:boolean) => { - const combinedItems: IChatPreviewPayload[] = [ - ...items, - ...chatPreviewList.items, - ].filter( - (item, index, self) => - index === self.findIndex((t) => t.chatId === item.chatId) + ) => { + const combinedItems: IChatPreviewPayload[] = [...items, ...chatPreviewList.items].filter( + (item, index, self) => index === self.findIndex((t) => t.chatId === item.chatId) ); setChatPreviewList((prev) => ({ @@ -167,12 +152,10 @@ export const ChatPreviewList: React.FC = ( items.forEach((item) => { // only increment if not selected if (chatPreviewListMeta.selectedChatId !== item.chatId) { - + console.debug('::ChatPreviewList::incrementing badge', item); setBadge( item.chatId!, - chatPreviewListMeta.badges[item.chatId!] - ? chatPreviewListMeta.badges[item.chatId!] + 1 - : 1 + chatPreviewListMeta.badges[item.chatId!] ? chatPreviewListMeta.badges[item.chatId!] + 1 : 1 ); } }); @@ -181,9 +164,9 @@ export const ChatPreviewList: React.FC = ( // Remove from chat items const removeChatItems: (items: string[]) => void = (items: string[]) => { - const combinedItems: IChatPreviewPayload[] = [ - ...chatPreviewList.items, - ].filter((item) => !items.includes(item.chatId!)); + const combinedItems: IChatPreviewPayload[] = [...chatPreviewList.items].filter( + (item) => !items.includes(item.chatId!) + ); setChatPreviewList((prev) => ({ ...prev, @@ -197,9 +180,7 @@ export const ChatPreviewList: React.FC = ( }; //Transform group creation stream - const transformGroupCreationStream: (item: any) => void = async ( - item: any - ) => { + const transformGroupCreationStream: (item: any) => void = async (item: any) => { const transformedItem: IChatPreviewPayload = { chatId: item?.chatId, chatPic: item?.meta.image, @@ -211,7 +192,7 @@ export const ChatPreviewList: React.FC = ( messageContent: '', }, }; - addChatItems([transformedItem],false); + addChatItems([transformedItem], false); }; // Transform stream message @@ -220,15 +201,12 @@ export const ChatPreviewList: React.FC = ( return; } - console.debug('Transforming stream message', item); - // transform the item to IChatPreviewPayload const modItem = transformStreamToIChatPreviewPayload(item); + console.debug('Transforming stream message', modItem); // now check if this message is already present in the list - const chatItem = chatPreviewList.items.find( - (chatItem) => chatItem.chatId === modItem.chatId - ); + const chatItem = chatPreviewList.items.find((chatItem) => chatItem.chatId === modItem.chatId); // if chat item is present, take pfp an group name if request if (chatItem) { @@ -247,9 +225,9 @@ export const ChatPreviewList: React.FC = ( modItem.chatParticipant = profile.groupName; } } + // modify the chat items - console.debug('calling twice') - addChatItems([modItem],true); + addChatItems([modItem], true); }; // Transform accepted request @@ -270,12 +248,8 @@ export const ChatPreviewList: React.FC = ( // get type and override account const getTypeAndAccount = () => { - const type = options.listType - ? options.listType - : CONSTANTS.CHAT.LIST_TYPE.CHATS; - const overrideAccount = options.overrideAccount - ? options.overrideAccount - : undefined; + const type = options.listType ? options.listType : CONSTANTS.CHAT.LIST_TYPE.CHATS; + const overrideAccount = options.overrideAccount ? options.overrideAccount : undefined; return { type, overrideAccount }; }; @@ -299,15 +273,10 @@ export const ChatPreviewList: React.FC = ( if (chatList) { // get and transform chats const transformedChats = transformChatItems(chatList); - console.debug( - `currentNonce: ${currentNonce}, chatPreviewList.nonce: ${chatPreviewList.nonce}` - ); + console.debug(`currentNonce: ${currentNonce}, chatPreviewList.nonce: ${chatPreviewList.nonce}`); // return if nonce doesn't match or if page is not 1 - if ( - currentNonce !== chatPreviewList.nonce || - chatPreviewList.page !== 1 - ) { + if (currentNonce !== chatPreviewList.nonce || chatPreviewList.page !== 1) { return; } setChatPreviewList((prev) => ({ @@ -328,9 +297,7 @@ export const ChatPreviewList: React.FC = ( } } else { // return if nonce doesn't match - console.debug( - `Errored: currentNonce: ${currentNonce}, chatPreviewList.nonce: ${chatPreviewList.nonce}` - ); + console.debug(`Errored: currentNonce: ${currentNonce}, chatPreviewList.nonce: ${chatPreviewList.nonce}`); if (currentNonce !== chatPreviewList.nonce) { return; } @@ -364,10 +331,7 @@ export const ChatPreviewList: React.FC = ( const currentNonce = chatPreviewList.nonce; const currentPage = newpage; - if ( - type === CONSTANTS.CHAT.LIST_TYPE.CHATS || - type === CONSTANTS.CHAT.LIST_TYPE.REQUESTS - ) { + if (type === CONSTANTS.CHAT.LIST_TYPE.CHATS || type === CONSTANTS.CHAT.LIST_TYPE.REQUESTS) { const chatList = await fetchChatList({ type, page: newpage, @@ -379,18 +343,14 @@ export const ChatPreviewList: React.FC = ( const transformedChats = transformChatItems(chatList); // return if nonce doesn't match or if page plus 1 is not the same as new page - if ( - currentNonce !== chatPreviewList.nonce || - chatPreviewList.page + 1 !== currentPage - ) { + if (currentNonce !== chatPreviewList.nonce || chatPreviewList.page + 1 !== currentPage) { return; } setChatPreviewList((prev) => ({ nonce: generateRandomNonce(), items: [...prev.items, ...transformedChats].filter( - (item, index, self) => - index === self.findIndex((t) => t.chatId === item.chatId) + (item, index, self) => index === self.findIndex((t) => t.chatId === item.chatId) ), page: newpage, preloading: false, @@ -406,10 +366,7 @@ export const ChatPreviewList: React.FC = ( } } else { // return if nonce doesn't match or if page plus 1 is not the same as new page - if ( - currentNonce !== chatPreviewList.nonce || - chatPreviewList.page + 1 !== newpage - ) { + if (currentNonce !== chatPreviewList.nonce || chatPreviewList.page + 1 !== newpage) { return; } @@ -450,10 +407,7 @@ export const ChatPreviewList: React.FC = ( }; // Set badge - const setBadge: (chatId: string, num: number) => void = ( - chatId: string, - num: number - ) => { + const setBadge: (chatId: string, num: number) => void = (chatId: string, num: number) => { // increment badge setChatPreviewListMeta((prev) => ({ ...prev, @@ -476,15 +430,10 @@ export const ChatPreviewList: React.FC = ( // Effects useEffect(() => { - if ( - options?.prefillChatPreviewList && - options?.prefillChatPreviewList.length - ) { + if (options?.prefillChatPreviewList && options?.prefillChatPreviewList.length) { setChatPreviewList({ nonce: generateRandomNonce(), - items: options?.prefillChatPreviewList.map( - (list) => list.chatPreviewPayload - ), + items: options?.prefillChatPreviewList.map((list) => list.chatPreviewPayload), page: 1, preloading: false, loading: false, @@ -496,67 +445,40 @@ export const ChatPreviewList: React.FC = ( }); } }, [options?.prefillChatPreviewList]); - // If account, env or signer changes - useEffect(() => { - if (!options?.prefillChatPreviewList) { - setChatPreviewList({ - nonce: generateRandomNonce(), - items: [], - page: 1, - preloading: true, - loading: false, - loaded: false, - reset: false, - resume: false, - errored: false, - error: null, - }); - resetBadge(); - } - }, [account, env, signer]); + + // // This is initialize function, only called if user changes (user?.account, user.env, etc are not required for update) + // useEffect(() => { + // if (!user) { + // return; + // } + + // if (!options?.prefillChatPreviewList) { + // setChatPreviewList({ + // nonce: generateRandomNonce(), + // items: [], + // page: 1, + // preloading: true, + // loading: false, + // loaded: false, + // reset: false, + // resume: false, + // errored: false, + // error: null, + // }); + // resetBadge(); + // } + // }, [user, options?.prefillChatPreviewList]); useEffect(() => { if (options?.onLoading) { options?.onLoading({ preload: chatPreviewList.preloading, - loading: chatPreviewList.loading, + loading: chatPreviewList.loading || chatPreviewList.preloading, finished: chatPreviewList.loaded, - paging: chatPreviewList.loading || chatPreviewList.resume, + paging: chatPreviewList.page > 1, }); } - }, [ - chatPreviewList.loading, - chatPreviewList.preloading, - chatPreviewList.loaded, - chatPreviewList.resume, - ]); - // If push user changes | preloading - useEffect(() => { - if (!user) { - return; - } - - // reset the entire state - if (!options?.prefillChatPreviewList) { - setChatPreviewList({ - nonce: generateRandomNonce(), - items: [], - page: 1, - preloading: true, - loading: false, - loaded: false, - reset: true, - resume: false, - errored: false, - error: null, - }); - } - }, [ - options?.searchParamter, - user, - options.listType, - options.overrideAccount, - ]); + }, [chatPreviewList.loading, chatPreviewList.preloading, chatPreviewList.loaded, chatPreviewList.page]); useEffect(() => { if ( @@ -564,14 +486,10 @@ export const ChatPreviewList: React.FC = ( listInnerRef?.current && listInnerRef?.current?.parentElement && !chatPreviewList.preloading && - (options.listType === CONSTANTS.CHAT.LIST_TYPE.CHATS || - options.listType === CONSTANTS.CHAT.LIST_TYPE.REQUESTS) && + (options.listType === CONSTANTS.CHAT.LIST_TYPE.CHATS || options.listType === CONSTANTS.CHAT.LIST_TYPE.REQUESTS) && !options?.prefillChatPreviewList ) { - if ( - listInnerRef.current.clientHeight + SCROLL_LIMIT > - listInnerRef.current.parentElement.clientHeight - ) { + if (listInnerRef.current.clientHeight + SCROLL_LIMIT > listInnerRef.current.parentElement.clientHeight) { // set loading to true setChatPreviewList((prev) => ({ ...prev, @@ -597,10 +515,7 @@ export const ChatPreviewList: React.FC = ( // If loading becomes active useEffect(() => { - if ( - (chatPreviewList.loading || chatPreviewList.resume) && - !options.prefillChatPreviewList - ) { + if ((chatPreviewList.loading || chatPreviewList.resume) && !options.prefillChatPreviewList) { loadMoreChats(); } }, [chatPreviewList.loading, chatPreviewList.resume]); @@ -608,10 +523,7 @@ export const ChatPreviewList: React.FC = ( // If badges count change useEffect(() => { // Count all badges object that are greater than 0 - const count = Object.values(chatPreviewListMeta.badges).reduce( - (acc, cur) => (acc > 0 ? 1 + cur : cur), - 0 - ); + const count = Object.values(chatPreviewListMeta.badges).reduce((acc, cur) => (acc > 0 ? 1 + cur : cur), 0); // Call onBadgeCountChange if present if (options?.onUnreadCountChange) { @@ -619,65 +531,61 @@ export const ChatPreviewList: React.FC = ( } }, [chatPreviewListMeta.badges]); + // If conversation count change + useEffect(() => { + // Call onConversationCountChange if present + if (options?.onChatsCountChange) { + options.onChatsCountChange(chatPreviewList.items.length); + } + }, [chatPreviewList.items]); + // Define stream objects + // When chat comes in useEffect(() => { - if ( - Object.keys(chatStream || {}).length > 0 && - chatStream.constructor === Object - ) { + if (Object.keys(chatStream || {}).length > 0 && chatStream.constructor === Object) { if (options.listType === CONSTANTS.CHAT.LIST_TYPE.CHATS) { transformStreamMessage(chatStream); } } }, [chatStream]); + // When group is created useEffect(() => { - if ( - Object.keys(groupCreateStream).length > 0 && - groupCreateStream.constructor === Object - ) { - if ( - options.listType === CONSTANTS.CHAT.LIST_TYPE.CHATS && - groupCreateStream.origin === 'self' - ) { + if (Object.keys(groupCreateStream).length > 0 && groupCreateStream.constructor === Object) { + if (options.listType === CONSTANTS.CHAT.LIST_TYPE.CHATS && groupCreateStream.origin === 'self') { transformGroupCreationStream(groupCreateStream); - } else if ( - options.listType === CONSTANTS.CHAT.LIST_TYPE.REQUESTS && - groupCreateStream.origin === 'other' - ) { + } else if (options.listType === CONSTANTS.CHAT.LIST_TYPE.REQUESTS && groupCreateStream.origin === 'other') { transformGroupCreationStream(groupCreateStream); } } }, [groupCreateStream]); + // When chat request comes in useEffect(() => { - if ( - Object.keys(chatRequestStream || {}).length > 0 && - chatRequestStream.constructor === Object - ) { - if ( - options.listType === CONSTANTS.CHAT.LIST_TYPE.CHATS && - chatRequestStream.origin === 'self' - ) { + if (Object.keys(chatRequestStream || {}).length > 0 && chatRequestStream.constructor === Object) { + if (options.listType === CONSTANTS.CHAT.LIST_TYPE.CHATS && chatRequestStream.origin === 'self') { transformStreamMessage(chatRequestStream); - } else if ( - options.listType === CONSTANTS.CHAT.LIST_TYPE.REQUESTS && - chatRequestStream.origin === 'other' - ) { + } else if (options.listType === CONSTANTS.CHAT.LIST_TYPE.REQUESTS && chatRequestStream.origin === 'other') { transformStreamMessage(chatRequestStream); } } }, [chatRequestStream]); - console.debug(chatStream, 'chat preview list chat stream event'); + + // When chat accept comes in useEffect(() => { - if ( - Object.keys(chatAcceptStream || {}).length > 0 && - chatAcceptStream.constructor === Object - ) { + if (Object.keys(chatAcceptStream || {}).length > 0 && chatAcceptStream.constructor === Object) { transformAcceptedRequest(chatAcceptStream); } }, [chatAcceptStream]); + // When chat reject comes in, this applies for groups as well + // chat should be removed from both sender and receiver + useEffect(() => { + if (Object.keys(chatRejectStream || {}).length > 0 && chatRejectStream.constructor === Object) { + removeChatItems([chatRejectStream.chatId]); + } + }, [chatRejectStream]); + //search method for a chatId const handleSearch = async (currentNonce: string) => { let error; @@ -701,7 +609,7 @@ export const ChatPreviewList: React.FC = ( let groupProfile: Group; if (formattedChatId.includes('.')) { - const address = await getAddress(formattedChatId, env)!; + const address = await getAddress(formattedChatId, user ? user.env : CONSTANTS.ENV.PROD); if (address) formattedChatId = pCAIP10ToWallet(address); else { error = { @@ -710,7 +618,7 @@ export const ChatPreviewList: React.FC = ( }; } } - if (pCAIP10ToWallet(formattedChatId) == pCAIP10ToWallet(account!)) { + if (pCAIP10ToWallet(formattedChatId) === pCAIP10ToWallet(user?.account || '')) { error = { code: ChatPreviewListErrorCodes.CHAT_PREVIEW_LIST_INVALID_SEARCH_ERROR, message: 'Invalid search', @@ -724,18 +632,16 @@ export const ChatPreviewList: React.FC = ( groupProfile = await getGroupByIDnew({ groupId: formattedChatId, }); - else if (account) + else if (user?.account) formattedChatId = pCAIP10ToWallet( - chatInfo?.participants.find( - (address) => address != walletToPCAIP10(account) - ) || formattedChatId + chatInfo?.participants.find((address) => address != walletToPCAIP10(user?.account)) || formattedChatId ); //fetch profile if (!groupProfile) { userProfile = await getNewChatUser({ searchText: formattedChatId, - env, + env: user?.env ? user?.env : CONSTANTS.ENV.PROD, fetchChatProfile: fetchUserProfile, user, }); @@ -751,12 +657,8 @@ export const ChatPreviewList: React.FC = ( ...searchedChat, chatId: chatInfo?.chatId || formattedChatId, chatGroup: !!groupProfile, - chatPic: - (userProfile?.profile?.picture ?? groupProfile?.groupImage) || - null, - chatParticipant: groupProfile - ? groupProfile?.groupName - : formattedChatId!, + chatPic: (userProfile?.profile?.picture ?? groupProfile?.groupImage) || null, + chatParticipant: groupProfile ? groupProfile?.groupName : formattedChatId!, }; //fetch latest chat const latestMessage = await fetchLatestMessage({ @@ -774,10 +676,7 @@ export const ChatPreviewList: React.FC = ( } // return if nonce doesn't match or if page is not 1 - if ( - currentNonce !== chatPreviewList.nonce || - chatPreviewList.page !== 1 - ) { + if (currentNonce !== chatPreviewList.nonce || chatPreviewList.page !== 1) { return; } setChatPreviewList((prev) => ({ @@ -817,9 +716,7 @@ export const ChatPreviewList: React.FC = ( } catch (e) { // return if nonce doesn't match console.debug(e); - console.debug( - `Errored: currentNonce: ${currentNonce}, chatPreviewList.nonce: ${chatPreviewList.nonce}` - ); + console.debug(`Errored: currentNonce: ${currentNonce}, chatPreviewList.nonce: ${chatPreviewList.nonce}`); if (currentNonce !== chatPreviewList.nonce) { return; } @@ -868,11 +765,11 @@ export const ChatPreviewList: React.FC = ( } }; - // Helper functions - // Render return ( = ( key={item.chatId} chatPreviewPayload={item} badge={ - options?.prefillChatPreviewList && - options?.prefillChatPreviewList[index].badge + options?.prefillChatPreviewList && options?.prefillChatPreviewList[index].badge ? options?.prefillChatPreviewList[index].badge : chatPreviewListMeta.badges ? { count: chatPreviewListMeta.badges[item.chatId!] } : { count: 0 } } selected={ - options?.prefillChatPreviewList && - options?.prefillChatPreviewList[index].selected + options?.prefillChatPreviewList && options?.prefillChatPreviewList[index].selected ? options?.prefillChatPreviewList[index].selected : chatPreviewListMeta.selectedChatId === item.chatId ? true : false } setSelected={ - options?.prefillChatPreviewList && - options?.prefillChatPreviewList[index].setSelected + options?.prefillChatPreviewList && options?.prefillChatPreviewList[index].setSelected ? options?.prefillChatPreviewList[index].setSelected : setSelectedBadge } + readmode={user?.readmode()} /> ); })} {/* if errored out for any reason */} {chatPreviewList.errored && ( -
+
{chatPreviewList.error?.message} {!!( - chatPreviewList.error?.code !== - ChatPreviewListErrorCodes.CHAT_PREVIEW_LIST_INVALID_SEARCH_ERROR && - chatPreviewList.error?.code !== - ChatPreviewListErrorCodes.CHAT_PREVIEW_LIST_INSUFFICIENT_INPUT + chatPreviewList.error?.code !== ChatPreviewListErrorCodes.CHAT_PREVIEW_LIST_INVALID_SEARCH_ERROR && + chatPreviewList.error?.code !== ChatPreviewListErrorCodes.CHAT_PREVIEW_LIST_INSUFFICIENT_INPUT ) && (
)} - {(chatPreviewList.preloading || chatPreviewList.loading) && - !chatPreviewList.errored && ( -
- -
- )} + {(chatPreviewList.preloading || chatPreviewList.loading) && !chatPreviewList.errored && ( +
+ +
+ )} ); }; diff --git a/packages/uiweb/src/lib/components/chat/ChatProfile/AddWalletContent.tsx b/packages/uiweb/src/lib/components/chat/ChatProfile/AddWalletContent.tsx index e9839a793..f458b4cb6 100644 --- a/packages/uiweb/src/lib/components/chat/ChatProfile/AddWalletContent.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatProfile/AddWalletContent.tsx @@ -3,13 +3,11 @@ import { useContext, useState } from 'react'; import { ChatMemberProfile, IUser } from '@pushprotocol/restapi'; import { MdError } from 'react-icons/md'; -import useToast from '../reusables/NewToast'; +import { useChatData } from '../../../hooks'; -import { Group, } from '../exportedTypes'; +import { Group } from '../exportedTypes'; import { addWalletValidation } from '../helpers/helper'; -import { - AddWallets, -} from '../reusables'; +import { AddWallets } from '../reusables'; import useGroupMemberUtilities from '../../../hooks/chat/useGroupMemberUtilities'; type AddWalletContentProps = { @@ -32,10 +30,9 @@ export const AddWalletContent = ({ isLoading = false, groupInfo, }: AddWalletContentProps) => { - const { fetchMemberStatus } = useGroupMemberUtilities(); - const groupInfoToast = useToast(); - + const { toast } = useChatData(); + const addMemberToList = async (member: IUser) => { let errorMessage = ''; const memberStatus = await fetchMemberStatus({ @@ -51,11 +48,16 @@ export const AddWalletContent = ({ ); if (errorMessage) { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: errorMessage, toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } else { handleMemberList((prev: any) => [...prev, { ...member, isAdmin: false }]); @@ -77,4 +79,4 @@ export const AddWalletContent = ({ groupMembers={groupMembers} /> ); -}; \ No newline at end of file +}; diff --git a/packages/uiweb/src/lib/components/chat/ChatProfile/ChatProfile.tsx b/packages/uiweb/src/lib/components/chat/ChatProfile/ChatProfile.tsx index 63c4bcce5..4f7f542eb 100644 --- a/packages/uiweb/src/lib/components/chat/ChatProfile/ChatProfile.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatProfile/ChatProfile.tsx @@ -1,42 +1,60 @@ -// @typescript-eslint/no-non-null-asserted-optional-chain - +// React + Web3 Essentials +import { ethers } from 'ethers'; import { useContext, useEffect, useRef, useState } from 'react'; +import { createPortal } from 'react-dom'; +// External Packages +import { CONSTANTS, PushAPI } from '@pushprotocol/restapi'; +import 'react-toastify/dist/ReactToastify.min.css'; import styled from 'styled-components'; -import type { IUser } from '@pushprotocol/restapi'; -import { ethers } from 'ethers'; -import { ToastContainer } from 'react-toastify'; -import { Image, Section, Span } from '../../reusables'; +// Internal Compoonents +import { + deriveChatId, + getAddress, + pCAIP10ToWallet, + resolveWeb3Name, + shortenText, + walletToPCAIP10, +} from '../../../helpers'; import { useChatData, useClickAway } from '../../../hooks'; -import { ThemeContext } from '../theme/ThemeProvider'; +import useFetchChat from '../../../hooks/chat/useFetchChat'; import useGetGroupByIDnew from '../../../hooks/chat/useGetGroupByIDnew'; -import useChatProfile from '../../../hooks/chat/useChatProfile'; -import { GroupInfoModal } from './GroupInfoModal'; -import useMediaQuery from '../../../hooks/useMediaQuery'; -import { createBlockie } from '../../space/helpers/blockies'; -import { ProfileContainer } from '../reusables'; -import 'react-toastify/dist/ReactToastify.min.css'; -import { Group, IChatProfile } from '../exportedTypes'; +import usePushUser from '../../../hooks/usePushUser'; import { MODAL_BACKGROUND_TYPE, MODAL_POSITION_TYPE } from '../../../types'; +import { Div, Image, Section, Span, Tooltip } from '../../reusables'; +import { ProfileContainer } from '../reusables'; +import { GroupInfoModal } from './ChatProfileInfoModal'; -import { - CoreContractChainId, - InfuraAPIKey, - allowedNetworks, - device, -} from '../../../config'; -import { getAddress, pCAIP10ToWallet, resolveNewEns, shortenText, walletToPCAIP10 } from '../../../helpers'; -import { formatAddress, isValidETHAddress } from '../helpers/helper'; -import PublicChatIcon from '../../../icons/Public-Chat.svg'; -import GreyImage from '../../../icons/greyImage.png'; -import InfoIcon from '../../../icons/infodark.svg'; +// Internal Configs +import { CoreContractChainId, InfuraAPIKey, allowedNetworks, device } from '../../../config'; +import { ThemeContext } from '../theme/ThemeProvider'; + +// Assets +import { PublicChatIcon, TokenGatedIcon } from '../../../icons/PushIcons'; import VerticalEllipsisIcon from '../../../icons/VerticalEllipsis.svg'; -import { TokenGatedSvg } from '../../../icons/TokenGatedSvg'; -import useUserProfile from '../../../hooks/useUserProfile'; +import InfoIcon from '../../../icons/infodark.svg'; + +// Interfaces & Types +import { Group, IChatProfile } from '../exportedTypes'; import { ChatInfoResponse } from '../types'; -import useFetchChat from '../../../hooks/chat/useFetchChat'; +import useUserInfoUtilities from '../../../hooks/chat/useUserInfoUtilities'; + +// Constants + +// Exported Interfaces & Types +export interface IChatProfileUserInfo { + name: string | null; + icon: string | null; + chatId: string | null; + recipient: string | null; + abbrRecipient: string | null; + web3Name: string | null; + desc: string | null; + isGroup?: boolean | null; +} +// Exported Functions export const ChatProfile: React.FC = ({ chatId, groupInfoModalBackground = MODAL_BACKGROUND_TYPE.OVERLAY, @@ -45,117 +63,163 @@ export const ChatProfile: React.FC = ({ chatProfileLeftHelperComponent = null, }) => { const theme = useContext(ThemeContext); - const { account, env, user } = useChatData(); + const { user } = useChatData(); + const [showoptions, setShowOptions] = useState(false); + const { fetchChat } = useFetchChat(); const { getGroupByIDnew } = useGetGroupByIDnew(); - const { fetchUserProfile } = useUserProfile(); - - // const [isGroup, setIsGroup] = useState(false); - const [options, setOptions] = useState(false); - const [formattedChatId, setFormattedChatId] = useState(''); - const [chatInfo, setChatInfo] = useState(null); - const [userInfo, setUserInfo] = useState(); - const [groupInfo, setGroupInfo] = useState(); - const [web3Name, setWeb3Name] = useState(null); - const isMobile = useMediaQuery(device.tablet); - const provider = new ethers.providers.InfuraProvider( - CoreContractChainId[env], - InfuraAPIKey - ); + const { fetchProfileInfo } = useUserInfoUtilities(); + + const [initialized, setInitialized] = useState({ + loading: false, + profile: { + name: null, + icon: null, + chatId: null, + recipient: null, + abbrRecipient: null, + web3Name: null, + desc: null, + isGroup: null, + } as IChatProfileUserInfo, + groupInfo: null as Group | null, + }); + const DropdownRef = useRef(null); const [modal, setModal] = useState(false); - const { fetchChat } = useFetchChat(); - useClickAway(DropdownRef, () => { - setOptions(false); + setShowOptions(false); }); - const ShowModal = () => { - setModal(true); - }; + // To setup web3 name, asynchrounously + const setupWeb3Name = async (address: string) => { + console.debug('UIWeb::ChatProfile::setupWeb3Name sending address for resolution', address); + const result = await resolveWeb3Name(address, user); + console.debug('UIWeb::ChatProfile::setupWeb3Name got result as ', address, result); - const fetchProfileData = async () => { - - if (chatInfo && !chatInfo?.meta?.group && chatInfo?.participants && account) { - const recipient = pCAIP10ToWallet(chatInfo?.participants.find((address)=>address != walletToPCAIP10(account)) || formattedChatId); - const ChatProfile = await fetchUserProfile({ profileId: recipient, env,user }); - - // const ChatProfile = await fetchUserProfile({ - // profileId: formattedChatId, - // env, - // user, - // }); - const result = await resolveNewEns(recipient, provider, env); - setWeb3Name(result); - setUserInfo(ChatProfile); - setGroupInfo(null); - // setIsGroup(false); - } else if (chatInfo && chatInfo?.meta?.group) { - const GroupProfile = await getGroupByIDnew({ groupId: formattedChatId }); - setGroupInfo(GroupProfile); - setUserInfo(null); - setWeb3Name(null); - } + setInitialized((prevState) => ({ + ...prevState, + profile: { ...prevState.profile, web3Name: result }, + })); }; - const getImage = () => { - if (userInfo || groupInfo) { - return Object.keys(groupInfo || {}).length - ? groupInfo?.groupImage ?? GreyImage - : userInfo?.profile?.picture ?? - createBlockie?.(formattedChatId)?.toDataURL()?.toString(); - } else { - return createBlockie?.(formattedChatId)?.toDataURL()?.toString(); - } - }; + // To get the abbreviated recipient + const getAbbreiatedRecipient = (recipient: string) => { + // split recipient into two parts, 6 characters each and join them with '...' but only if recipient is more than 15 characters + if (recipient.length <= 15) return recipient; - const getProfileName = () => { - return Object.keys(groupInfo || {}).length - ? shortenText(groupInfo?.chatId || '', 6, true) - : userInfo - ? shortenText(userInfo.did?.split(':')[1] ?? '', 6, true) - : shortenText(chatId?.split(':')[1], 6, true); + const firstPart = recipient.slice(0, 6); + const secondPart = recipient.slice(-6); + return `${firstPart}...${secondPart}`; }; + // Initiate profile fetch if chatId, account or user changes useEffect(() => { - (async () => { - if (!user) return; - if(chatId){ - let formattedChatId; - if (chatId.includes('eip155:')) { - formattedChatId = chatId.replace('eip155:', ''); - } else if (chatId.includes('.')) { - formattedChatId = (await getAddress(chatId, env))!; - - } else formattedChatId = chatId; - setFormattedChatId(formattedChatId); - const chat = await fetchChat({ chatId: formattedChatId }); - if (Object.keys(chat || {}).length) { - setChatInfo(chat as ChatInfoResponse); + if (!user || !chatId || chatId === '' || initialized.loading) return; + + setInitialized((currentState) => ({ ...currentState, loading: true })); + + try { + // derive chatId + const derivedChatId = await deriveChatId(chatId, user); + + // We have derived chatId, fetch chat info to see if it's group or dm + const chatInfo = await fetchChat({ chatId: derivedChatId }); + + if (chatInfo) { + let groupInfo; + + // eslint-disable-next-line prefer-const + let profile = {} as IChatProfileUserInfo; + + // If group + if (chatInfo.meta && chatInfo.meta.group) { + groupInfo = await getGroupByIDnew({ groupId: derivedChatId }); + if (groupInfo) { + profile.name = groupInfo.groupName; + profile.icon = groupInfo.groupImage; + profile.chatId = chatInfo.chatId; + profile.recipient = derivedChatId; + profile.abbrRecipient = getAbbreiatedRecipient(derivedChatId); + profile.desc = groupInfo.groupDescription; + profile.isGroup = true; + } + + // TODO - HANDLE ERROR IN UI + } else { + // This is DM + const recipient = await deriveChatId(chatInfo.recipient, user); + console.debug('UIWeb::ChatProfile::user.chat.info fetched', chatInfo, recipient); + + try { + const profileInfo = await fetchProfileInfo({ + recipient, + }); + if (profileInfo) { + console.debug('UIWeb::ChatProfile::user.profile.info fetched', profileInfo); + + profile.name = profileInfo.name; + profile.icon = profileInfo.picture; + profile.chatId = chatInfo.chatId; + profile.recipient = recipient; + profile.abbrRecipient = getAbbreiatedRecipient(recipient); + profile.desc = profileInfo.profile?.desc; + profile.isGroup = false; + } + } catch (error) { + console.warn( + 'UIWeb::ChatProfile::user.profile.info fetch error, possible push user does not exist.', + error + ); + profile.name = ''; + profile.icon = null; + profile.chatId = chatInfo.chatId; + profile.recipient = recipient; + profile.abbrRecipient = getAbbreiatedRecipient(recipient); + profile.desc = ''; + profile.isGroup = false; + } + + // get and set web3 name asynchrounously + if (profile.recipient) { + setupWeb3Name(profile.recipient); + } + } + + // Finally set everything + setInitialized({ + loading: false, + profile: profile, + groupInfo: groupInfo, + }); + } else { + // Handle Error + console.error('UIWeb::ChatProfile::ChatInfo is null'); } - + } catch (error) { + console.error('UIWeb::ChatProfile::Error', error); + + // TODO - Handle the error appropriately } - })(); - }, [chatId, account, user]); - useEffect(() => { - (async () => { - await fetchProfileData(); - })(); - }, [chatInfo]); + }, [chatId, user]); + + // useEffect(() => { + // (async () => { + // await fetchProfileData(); + // })(); + // }, [chatInfo]); if (chatId) { return ( + {/* For showing Chat Profile */}
{chatProfileLeftHelperComponent && (
= ({
+ + {/* For showing group related icons and menu */}
= ({ margin="0 10px 0 auto" alignSelf="center" > - {chatProfileRightHelperComponent && !groupInfo && ( + {/* For showing chat profile right helper component */} + {chatProfileRightHelperComponent && !initialized.groupInfo && (
{chatProfileRightHelperComponent}
)} - {!!Object.keys(groupInfo?.rules || {}).length && } - {!!groupInfo?.isPublic && ( - + + {/* For showing Token Gated Group Icon */} + {!!Object.keys(initialized.groupInfo?.rules || {}).length && ( + + + )} - {!!Object.keys(groupInfo || {}).length && ( - setOptions(true)}> + {!!initialized.groupInfo?.isPublic && ( + + + + )} + + {!initialized.loading && ( + setShowOptions(true)}> = ({ cursor="pointer" /> - {options && ( - - + {showoptions && ( + + setModal(true)} + > = ({ cursor="pointer" /> - Group Info + {initialized.groupInfo ? 'Group Info' : 'User Info'} )} )}
- {modal && ( - - )} - {/* {!isGroup && - - - - } */} - - + + {/* For showing chat info modal | modal && */} + {modal && + createPortal( + + setInitialized((prevState) => ({ + ...prevState, + mutatedGroupInfo, + })) + } + groupInfoModalBackground={groupInfoModalBackground} + groupInfoModalPositionType={groupInfoModalPositionType} + />, + document.body + )} ); } else { diff --git a/packages/uiweb/src/lib/components/chat/ChatProfile/GroupInfoModal.tsx b/packages/uiweb/src/lib/components/chat/ChatProfile/ChatProfileInfoModal.tsx similarity index 66% rename from packages/uiweb/src/lib/components/chat/ChatProfile/GroupInfoModal.tsx rename to packages/uiweb/src/lib/components/chat/ChatProfile/ChatProfileInfoModal.tsx index 19e08615f..22e023da8 100644 --- a/packages/uiweb/src/lib/components/chat/ChatProfile/GroupInfoModal.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatProfile/ChatProfileInfoModal.tsx @@ -1,55 +1,37 @@ import { useEffect, useRef, useState } from 'react'; -import styled from 'styled-components'; -import { - ChatMemberProfile, - GroupParticipantCounts, - IUser, - ParticipantStatus, -} from '@pushprotocol/restapi'; +import { ChatMemberProfile, GroupParticipantCounts, IUser, ParticipantStatus } from '@pushprotocol/restapi'; import { MdCheckCircle, MdError } from 'react-icons/md'; +import styled from 'styled-components'; import { useChatData, usePushChatStream } from '../../../hooks'; -import { Section, Span, Image } from '../../reusables/sharedStyling'; -import { AddWalletContent } from './AddWalletContent'; -import { Modal, ModalHeader } from '../reusables'; -import useMediaQuery from '../../../hooks/useMediaQuery'; -import useToast from '../reusables/NewToast'; import useUpdateGroup from '../../../hooks/chat/useUpdateGroup'; +import useMediaQuery from '../../../hooks/useMediaQuery'; +import { Spinner } from '../../reusables'; +import { Image, Section, Span } from '../../reusables/sharedStyling'; import ConditionsComponent from '../CreateGroup/ConditionsComponent'; +import { Modal, ModalHeader } from '../reusables'; +import { AddWalletContent } from './AddWalletContent'; +import { IChatProfileUserInfo } from './ChatProfile'; import { AcceptedMembers, PendingMembers } from './PendingMembers'; -import { Spinner } from '../../reusables'; -import { IChatTheme } from '../theme'; import { device } from '../../../config'; +import { copyToClipboard, shortenText } from '../../../helpers'; import LockIcon from '../../../icons/Lock.png'; import LockSlashIcon from '../../../icons/LockSlash.png'; import addIcon from '../../../icons/addicon.svg'; -import { copyToClipboard, shortenText } from '../../../helpers'; -import { - ACCEPTED_MEMBERS_LIMIT, - ACCESS_TYPE_TITLE, - OPERATOR_OPTIONS_INFO, - PENDING_MEMBERS_LIMIT, -} from '../constants'; -import { getRuleInfo } from '../helpers/getRulesToCondtionArray'; +import { MODAL_BACKGROUND_TYPE, MODAL_POSITION_TYPE, ModalBackgroundType, ModalPositionType } from '../../../types'; +import { ACCEPTED_MEMBERS_LIMIT, ACCESS_TYPE_TITLE, OPERATOR_OPTIONS_INFO, PENDING_MEMBERS_LIMIT } from '../constants'; import { Group } from '../exportedTypes'; -import { - MODAL_BACKGROUND_TYPE, - MODAL_POSITION_TYPE, - ModalBackgroundType, - ModalPositionType, -} from '../../../types'; +import { getRuleInfo } from '../helpers/getRulesToCondtionArray'; +import { IChatTheme } from '../theme'; +import useChatProfile from '../../../hooks/chat/useChatProfile'; +import useGroupMemberUtilities from '../../../hooks/chat/useGroupMemberUtilities'; +import usePushUser from '../../../hooks/usePushUser'; import { TokenGatedSvg } from '../../../icons/TokenGatedSvg'; +import { resolvePromisesSeq, transformIUserToChatMemberProfile } from '../helpers'; import { GROUP_ROLES } from '../types'; -import useGroupMemberUtilities from '../../../hooks/chat/useGroupMemberUtilities'; -import useChatProfile from '../../../hooks/chat/useChatProfile'; -import { - resolvePromisesSeq, - transformIUserToChatMemberProfile, -} from '../helpers'; -import useUserProfile from '../../../hooks/useUserProfile'; export interface MemberPaginationData { page: number; @@ -72,20 +54,13 @@ interface ConditionsInformationProps { subheader?: string; } -export const ConditionsInformation = ({ - theme, - groupInfo, - alert, - header, - subheader, -}: ConditionsInformationProps) => { +export const ConditionsInformation = ({ theme, groupInfo, alert, header, subheader }: ConditionsInformationProps) => { const groupRules = getRuleInfo(groupInfo?.rules); const isMobile = useMediaQuery(device.mobileL); const getOperator = (key: keyof typeof groupRules) => { if (groupRules[key as keyof typeof groupRules].length) { - return groupRules[key as keyof typeof groupRules][0][0] - ?.operator as keyof typeof OPERATOR_OPTIONS_INFO; + return groupRules[key as keyof typeof groupRules][0][0]?.operator as keyof typeof OPERATOR_OPTIONS_INFO; } return null; }; @@ -117,32 +92,33 @@ export const ConditionsInformation = ({ {Object.keys(ACCESS_TYPE_TITLE).map((key, idx) => ( <> {getOperator(key as keyof typeof groupRules) ? ( -
+
- { - ACCESS_TYPE_TITLE[key as keyof typeof ACCESS_TYPE_TITLE] - ?.heading - } + {ACCESS_TYPE_TITLE[key as keyof typeof ACCESS_TYPE_TITLE]?.heading} - + { OPERATOR_OPTIONS_INFO[ - groupRules[key as keyof typeof groupRules][0][0] - ?.operator as keyof typeof OPERATOR_OPTIONS_INFO + groupRules[key as keyof typeof groupRules][0][0]?.operator as keyof typeof OPERATOR_OPTIONS_INFO ]?.head } {' '} { OPERATOR_OPTIONS_INFO[ - groupRules[key as keyof typeof groupRules][0][0] - ?.operator as keyof typeof OPERATOR_OPTIONS_INFO + groupRules[key as keyof typeof groupRules][0][0]?.operator as keyof typeof OPERATOR_OPTIONS_INFO ]?.tail } @@ -235,13 +211,9 @@ type GroupSectionProps = GroupInfoModalProps & { handlePreviousInformation?: () => void; pendingMemberPaginationData: MemberPaginationData; groupMembers: MembersType; - setPendingMemberPaginationData: React.Dispatch< - React.SetStateAction - >; + setPendingMemberPaginationData: React.Dispatch>; acceptedMemberPaginationData: MemberPaginationData; - setAcceptedMemberPaginationData: React.Dispatch< - React.SetStateAction - >; + setAcceptedMemberPaginationData: React.Dispatch>; membersCount: GroupParticipantCounts; setShowAddMoreWalletModal: React.Dispatch>; }; @@ -251,6 +223,7 @@ type GroupInfoModalProps = { setModal: React.Dispatch>; groupInfo: Group; setGroupInfo: React.Dispatch>; + chatProfileInfo?: IChatProfileUserInfo; groupInfoModalBackground?: ModalBackgroundType; groupInfoModalPositionType?: ModalPositionType; }; @@ -260,12 +233,12 @@ export const GROUPINFO_STEPS = { CRITERIA: 2, } as const; -export type GROUP_INFO_TYPE = - typeof GROUPINFO_STEPS[keyof typeof GROUPINFO_STEPS]; +export type GROUP_INFO_TYPE = typeof GROUPINFO_STEPS[keyof typeof GROUPINFO_STEPS]; const GroupInformation = ({ theme, groupInfo, + chatProfileInfo, handleNextInformation, pendingMemberPaginationData, setPendingMemberPaginationData, @@ -275,127 +248,139 @@ const GroupInformation = ({ setShowAddMoreWalletModal, membersCount, }: GroupSectionProps) => { - const { account, user } = useChatData(); - const [accountStatus, setAccountStatus] = useState( - null - ); - const [showPendingRequests, setShowPendingRequests] = - useState(false); + const { user, toast } = useChatData(); + const [accountStatus, setAccountStatus] = useState(null); + const [showPendingRequests, setShowPendingRequests] = useState(false); const [copyText, setCopyText] = useState(''); const isMobile = useMediaQuery(device.mobileL); - const groupInfoToast = useToast(); const { fetchMemberStatus } = useGroupMemberUtilities(); useEffect(() => { - if (account && groupInfo?.chatId) { + if (user?.account && chatProfileInfo?.isGroup && chatProfileInfo?.chatId) { (async () => { const status = await fetchMemberStatus({ - chatId: groupInfo?.chatId, - accountId: account, + chatId: chatProfileInfo?.chatId ?? '', + accountId: user?.account, }); if (status && typeof status !== 'string') { setAccountStatus(status); } else { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: 'Error in fetching member details', toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } })(); } }, []); - return ( - - - Chat ID - -
{ - copyToClipboard(groupInfo!.chatId!); - setCopyText('copied'); - }} - onMouseEnter={() => { - setCopyText('click to copy'); - }} - onMouseLeave={() => { - setCopyText(''); - }} - > + {chatProfileInfo?.chatId && ( + - {shortenText(groupInfo!.chatId!, 8, true)} + Chat ID - {!!copyText && ( +
{ + copyToClipboard(chatProfileInfo?.chatId ?? ''); + setCopyText('copied'); + }} + onMouseEnter={() => { + setCopyText('click to copy'); + }} + onMouseLeave={() => { + setCopyText(''); + }} + > + {shortenText(chatProfileInfo?.chatId ?? '', 8, true)} + + {!!copyText && ( + + {copyText} + + )} +
+
+ )} + + {chatProfileInfo?.isGroup || + (chatProfileInfo?.desc && ( + + + {chatProfileInfo?.isGroup ? 'Group Description' : 'Profile Description'} + + - {copyText} + {chatProfileInfo?.desc} - )} -
-
- - - Group Description - - - {groupInfo?.groupDescription} - - - - } - header={groupInfo?.isPublic ? 'Open' : 'Encrypted'} - subheader={ - groupInfo?.isPublic - ? 'Chats are not encrypted' - : 'Chats are end-to-end encrypted' - } - /> - {!!Object.keys(groupInfo?.rules || {}).length && ( + + ))} + + {chatProfileInfo?.isGroup && ( + + } + header={groupInfo?.isPublic ? 'Open' : 'Encrypted'} + subheader={groupInfo?.isPublic ? 'Chats are not encrypted' : 'Chats are end-to-end encrypted'} + /> + )} + + {chatProfileInfo?.isGroup && !!Object.keys(groupInfo?.rules || {}).length && ( )} - {accountStatus?.role === GROUP_ROLES.ADMIN.toLowerCase() && + {chatProfileInfo?.isGroup && + accountStatus?.role === GROUP_ROLES.ADMIN.toLowerCase() && groupMembers?.accepted && - groupMembers?.accepted?.length < - (groupInfo?.isPublic ? 25000 : 5000) && ( + groupMembers?.accepted?.length < (groupInfo?.isPublic ? 25000 : 5000) && ( setShowAddMoreWalletModal(true)} @@ -434,19 +419,23 @@ const GroupInformation = ({ )} -
- {groupMembers.loading ? ( - - ) : ( - <> - {groupMembers && - groupMembers?.pending && - groupMembers?.pending?.length > 0 && ( + {chatProfileInfo?.isGroup && ( +
+ {groupMembers.loading ? ( + + ) : ( + <> + {groupMembers && groupMembers?.pending && groupMembers?.pending?.length > 0 && ( )} - - - )} -
+ + + )} +
+ )}
); }; @@ -473,134 +464,69 @@ export const GroupInfoModal = ({ setModal, setGroupInfo, groupInfo, + chatProfileInfo, groupInfoModalBackground = MODAL_BACKGROUND_TYPE.OVERLAY, groupInfoModalPositionType = MODAL_POSITION_TYPE.GLOBAL, }: GroupInfoModalProps) => { - const [activeComponent, setActiveComponent] = useState( - GROUPINFO_STEPS.GROUP_INFO - ); + const [activeComponent, setActiveComponent] = useState(GROUPINFO_STEPS.GROUP_INFO); const [memberList, setMemberList] = useState([]); const [isLoading, setIsLoading] = useState(false); const [membersCount, setMembersCount] = useState({ participants: 0, pending: 0, }); - const [showAddMoreWalletModal, setShowAddMoreWalletModal] = - useState(false); + const [showAddMoreWalletModal, setShowAddMoreWalletModal] = useState(false); useState(false); - const [pendingMemberPaginationData, setPendingMemberPaginationData] = - useState({ - page: 1, - finishedFetching: false, - loading: false, - reset: false, - }); - const [acceptedMemberPaginationData, setAcceptedMemberPaginationData] = - useState({ - page: 1, - finishedFetching: false, - loading: false, - reset: false, - }); + const [pendingMemberPaginationData, setPendingMemberPaginationData] = useState({ + page: 1, + finishedFetching: false, + loading: false, + reset: false, + }); + const [acceptedMemberPaginationData, setAcceptedMemberPaginationData] = useState({ + page: 1, + finishedFetching: false, + loading: false, + reset: false, + }); const isMobile = useMediaQuery(device.mobileL); - const groupInfoToast = useToast(); const [groupMembers, setGroupMembers] = useState({ accepted: [], pending: [], loading: false, }); const { fetchMembers, loading: membersLoading } = useGroupMemberUtilities(); - const { user } = useChatData(); + const { user, toast } = useChatData(); const { addMember } = useUpdateGroup(); const { fetchMembersCount } = useGroupMemberUtilities(); - const { fetchUserProfile } = useUserProfile(); - - //hack for stream not working - const [chatAcceptStream, setChatAcceptStream] = useState({}); // to track any new messages - const [chatRejectStream, setChatRejectStream] = useState({}); // to track any rejected request - - const [participantRoleChangeStream, setParticipantRoleChangeStream] = - useState({}); // to track if a participant role is changed in a group - - const [participantRemoveStream, setParticipantRemoveStream] = useState( - {} - ); // to track if a participant is removed from group - const [participantLeaveStream, setParticipantLeaveStream] = useState({}); // to track if a participant leaves a group - const [participantJoinStream, setParticipantJoinStream] = useState({}); // to track if a participant joins a group - - const [groupUpdateStream, setGroupUpdateStream] = useState({}); - - //event listners - usePushChatStream(); - useEffect(() => { - window.addEventListener('chatAcceptStream', (e: any) => - setChatAcceptStream(e.detail) - ); - window.addEventListener('chatRejectStream', (e: any) => - setChatRejectStream(e.detail) - ); - window.addEventListener('participantRoleChangeStream', (e: any) => - setParticipantRoleChangeStream(e.detail) - ); - window.addEventListener('participantRemoveStream', (e: any) => - setParticipantRemoveStream(e.detail) - ); - window.addEventListener('participantLeaveStream', (e: any) => - setParticipantLeaveStream(e.detail) - ); - window.addEventListener('participantJoinStream', (e: any) => - setParticipantJoinStream(e.detail) - ); - window.addEventListener('groupUpdateStream', (e: any) => - setGroupUpdateStream(e.detail) - ); - return () => { - window.removeEventListener('chatAcceptStream', (e: any) => - setChatAcceptStream(e.detail) - ); - window.removeEventListener('chatRejectStream', (e: any) => - setChatRejectStream(e.detail) - ); - window.removeEventListener('participantRoleChangeStream', (e: any) => - setParticipantRoleChangeStream(e.detail) - ); - window.removeEventListener('participantRemoveStream', (e: any) => - setParticipantRemoveStream(e.detail) - ); - window.removeEventListener('participantLeaveStream', (e: any) => - setParticipantLeaveStream(e.detail) - ); - window.removeEventListener('participantJoinStream', (e: any) => - setParticipantJoinStream(e.detail) - ); - window.removeEventListener('groupUpdateStream', (e: any) => - setGroupUpdateStream(e.detail) - ); - }; - }, []); - - // const { - // chatAcceptStream, - // chatRejectStream, - // participantRemoveStream, - // participantLeaveStream, - // participantJoinStream, - // groupUpdateStream, - // participantRoleChangeStream, - // } = usePushChatStream(); + const { fetchUserProfile } = usePushUser(); + + // setup stream + const { + chatAcceptStream, + chatRejectStream, + participantRemoveStream, + participantLeaveStream, + participantJoinStream, + participantRoleChangeStream, + groupUpdateStream, + } = useChatData(); //stream listeners useEffect(() => { if ( + chatProfileInfo?.isGroup && Object.keys(chatAcceptStream || {}).length > 0 && chatAcceptStream.constructor === Object ) transformAcceptedRequest(chatAcceptStream); }, [chatAcceptStream]); + useEffect(() => { if ( + chatProfileInfo?.isGroup && Object.keys(chatRejectStream || {}).length > 0 && chatRejectStream.constructor === Object ) @@ -609,13 +535,16 @@ export const GroupInfoModal = ({ useEffect(() => { if ( + chatProfileInfo?.isGroup && Object.keys(participantRemoveStream || {}).length > 0 && participantRemoveStream.constructor === Object ) transformParticipantRemove(participantRemoveStream); }, [participantRemoveStream]); + useEffect(() => { if ( + chatProfileInfo?.isGroup && Object.keys(participantLeaveStream || {}).length > 0 && participantLeaveStream.constructor === Object ) @@ -625,6 +554,7 @@ export const GroupInfoModal = ({ useEffect(() => { (async () => { if ( + chatProfileInfo?.isGroup && Object.keys(participantJoinStream || {}).length > 0 && participantJoinStream.constructor === Object ) @@ -634,6 +564,7 @@ export const GroupInfoModal = ({ useEffect(() => { if ( + chatProfileInfo?.isGroup && Object.keys(groupUpdateStream || {}).length > 0 && groupUpdateStream.constructor === Object ) @@ -642,23 +573,29 @@ export const GroupInfoModal = ({ useEffect(() => { if ( + chatProfileInfo?.isGroup && Object.keys(participantRoleChangeStream || {}).length > 0 && participantRoleChangeStream.constructor === Object ) transformRoleChange(participantRoleChangeStream); }, [participantRoleChangeStream]); + + // fetch members count if group is true useEffect(() => { (async () => { - const count = await fetchMembersCount({ chatId: groupInfo!.chatId! }); - if (count) { - setMembersCount(count); + if (chatProfileInfo?.isGroup) { + const count = await fetchMembersCount({ chatId: chatProfileInfo!.chatId! }); + if (count) { + setMembersCount(count); + } } })(); - }, []); + }, [user]); + //add dependencies useEffect(() => { (async () => { - if (Object.keys(groupInfo || {}).length) { + if (chatProfileInfo?.isGroup && Object.keys(groupInfo || {}).length) { setGroupMembers((prev) => ({ ...prev, loading: true })); await initialiseMemberPaginationData('pending', fetchPendingMembers); await initialiseMemberPaginationData('accepted', fetchAcceptedMembers); @@ -669,23 +606,15 @@ export const GroupInfoModal = ({ useEffect(() => { (async () => { - if (pendingMemberPaginationData?.page > 1) - await callMembers( - pendingMemberPaginationData?.page, - setPendingMemberPaginationData, - fetchPendingMembers - ); + if (chatProfileInfo?.isGroup && pendingMemberPaginationData?.page > 1) + await callMembers(pendingMemberPaginationData?.page, setPendingMemberPaginationData, fetchPendingMembers); })(); }, [pendingMemberPaginationData?.page]); useEffect(() => { (async () => { - if (acceptedMemberPaginationData?.page > 1) - await callMembers( - acceptedMemberPaginationData?.page, - setAcceptedMemberPaginationData, - fetchAcceptedMembers - ); + if (chatProfileInfo?.isGroup && acceptedMemberPaginationData?.page > 1) + await callMembers(acceptedMemberPaginationData?.page, setAcceptedMemberPaginationData, fetchAcceptedMembers); })(); }, [acceptedMemberPaginationData?.page]); @@ -704,15 +633,9 @@ export const GroupInfoModal = ({ })); setGroupMembers((prevMembers: MembersType) => ({ ...prevMembers, - pending: [ - ...prevMembers!.pending, - ...(fetchedPendingMembers?.members || ([] as ChatMemberProfile[])), - ] + pending: [...prevMembers!.pending, ...(fetchedPendingMembers?.members || ([] as ChatMemberProfile[]))] .slice() - .filter( - (item, index, self) => - index === self.findIndex((t) => t.address === item.address) - ), + .filter((item, index, self) => index === self.findIndex((t) => t.address === item.address)), })); }; const fetchAcceptedMembers = async (page: number): Promise => { @@ -728,24 +651,14 @@ export const GroupInfoModal = ({ })); setGroupMembers((prevMembers: MembersType) => ({ ...prevMembers, - accepted: [ - ...prevMembers!.accepted, - ...(fetchedAcceptedMembers?.members || ([] as ChatMemberProfile[])), - ] + accepted: [...prevMembers!.accepted, ...(fetchedAcceptedMembers?.members || ([] as ChatMemberProfile[]))] .slice() - .filter( - (item, index, self) => - index === self.findIndex((t) => t.address === item.address) - ), + .filter((item, index, self) => index === self.findIndex((t) => t.address === item.address)), })); }; - const initialiseMemberPaginationData = async ( - property: string, - fetchMembers: (page: number) => Promise - ) => { - if (!groupMembers[property as 'accepted' | 'pending'].length) - await fetchMembers(1); + const initialiseMemberPaginationData = async (property: string, fetchMembers: (page: number) => Promise) => { + if (!groupMembers[property as 'accepted' | 'pending'].length) await fetchMembers(1); }; const removePendingMember = (items: string[]): void => { @@ -754,10 +667,7 @@ export const GroupInfoModal = ({ pending: [...groupMembers.pending!] .filter((item) => !items.includes(item.address!)) .slice() - .filter( - (item, index, self) => - index === self.findIndex((t) => t.address === item.address) - ), + .filter((item, index, self) => index === self.findIndex((t) => t.address === item.address)), })); }; @@ -767,10 +677,7 @@ export const GroupInfoModal = ({ accepted: [...groupMembers.accepted!] .filter((item) => !items.includes(item.address!)) .slice() - .filter( - (item, index, self) => - index === self.findIndex((t) => t.address === item.address) - ), + .filter((item, index, self) => index === self.findIndex((t) => t.address === item.address)), })); }; const addAcceptedMember = (items: ChatMemberProfile[]): void => { @@ -778,20 +685,13 @@ export const GroupInfoModal = ({ ...prevMembers, accepted: [...items, ...groupMembers.accepted] .slice() - .filter( - (item, index, self) => - index === self.findIndex((t) => t.address === item.address) - ), + .filter((item, index, self) => index === self.findIndex((t) => t.address === item.address)), })); }; const memberRoleChange = (item: any): void => { - const acceptedMember: ChatMemberProfile[] = groupMembers?.accepted.map( - (member) => - member.address == item.to[0] - ? { ...member, role: item.newRole } - : member + const acceptedMember: ChatMemberProfile[] = groupMembers?.accepted.map((member) => + member.address == item.to[0] ? { ...member, role: item.newRole } : member ); - console.debug(acceptedMember); setGroupMembers((prevMembers: MembersType) => ({ ...prevMembers, accepted: acceptedMember, @@ -800,10 +700,9 @@ export const GroupInfoModal = ({ const transformAcceptedRequest = (item: any): void => { if (item?.meta?.group && groupInfo?.chatId === item?.chatId) { - const acceptedMember: ChatMemberProfile | undefined = - groupMembers?.pending?.find((member: ChatMemberProfile) => { - return member?.address === item?.from; - }); + const acceptedMember: ChatMemberProfile | undefined = groupMembers?.pending?.find((member: ChatMemberProfile) => { + return member?.address === item?.from; + }); if (acceptedMember) { addAcceptedMember([acceptedMember]); removePendingMember([acceptedMember?.address]); @@ -830,10 +729,7 @@ export const GroupInfoModal = ({ const transformParticipantJoin = async (item: any): Promise => { if (groupInfo?.chatId === item?.chatId) { const profile = await fetchUserProfile({ profileId: item?.from, user }); - const transformedProfile = transformIUserToChatMemberProfile( - profile, - true - ); + const transformedProfile = transformIUserToChatMemberProfile(profile, true); addAcceptedMember([transformedProfile]); } }; @@ -875,9 +771,7 @@ export const GroupInfoModal = ({ const callMembers = async ( page: number, - setMemberPaginationData: React.Dispatch< - React.SetStateAction - >, + setMemberPaginationData: React.Dispatch>, fetchMembers: (page: number) => Promise ) => { try { @@ -912,57 +806,61 @@ export const GroupInfoModal = ({ setIsLoading(true); let adminResponse = {}; let memberResponse = {}; - const admins = memberList - .filter((member: any) => member.isAdmin) - .map((member: any) => member.wallets); - const members = memberList - .filter((member: any) => !member.isAdmin) - .map((member: any) => member.wallets); + const admins = memberList.filter((member: any) => member.isAdmin).map((member: any) => member.wallets); + const members = memberList.filter((member: any) => !member.isAdmin).map((member: any) => member.wallets); if (admins.length) { adminResponse = await addMember({ - memberList: memberList - .filter((member: any) => member.isAdmin) - .map((member: any) => member.wallets), + memberList: memberList.filter((member: any) => member.isAdmin).map((member: any) => member.wallets), chatId: groupInfo!.chatId!, role: GROUP_ROLES.ADMIN, }); } if (members.length) { memberResponse = await addMember({ - memberList: memberList - .filter((member: any) => !member.isAdmin) - .map((member: any) => member.wallets), + memberList: memberList.filter((member: any) => !member.isAdmin).map((member: any) => member.wallets), chatId: groupInfo!.chatId!, role: GROUP_ROLES.MEMBER, }); } - if ( - typeof adminResponse !== 'string' && - typeof memberResponse !== 'string' - ) { - groupInfoToast.showMessageToast({ + if (typeof adminResponse !== 'string' && typeof memberResponse !== 'string') { + toast.showMessageToast({ toastTitle: 'Success', toastMessage: 'Group Invitation sent', toastType: 'SUCCESS', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } else { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: 'Error in adding member', toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } } catch (error) { console.error('Error', error); - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: 'Please, try again', toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } finally { setIsLoading(false); @@ -979,6 +877,7 @@ export const GroupInfoModal = ({ theme={theme} setModal={setModal} groupInfo={groupInfo} + chatProfileInfo={chatProfileInfo} setGroupInfo={setGroupInfo} groupMembers={groupMembers} pendingMemberPaginationData={pendingMemberPaginationData} @@ -990,7 +889,12 @@ export const GroupInfoModal = ({ /> ); case GROUPINFO_STEPS.CRITERIA: - return ; + return ( + + ); default: return ( @@ -999,6 +903,7 @@ export const GroupInfoModal = ({ theme={theme} setModal={setModal} groupInfo={groupInfo} + chatProfileInfo={chatProfileInfo} setGroupInfo={setGroupInfo} groupMembers={groupMembers} pendingMemberPaginationData={pendingMemberPaginationData} @@ -1020,7 +925,7 @@ export const GroupInfoModal = ({ setModal(false); }; - if (groupInfo) { + if (chatProfileInfo) { return ( -
+
- {groupInfo?.groupName} + {chatProfileInfo?.name} {/* )} - {showAddMoreWalletModal && ( + {chatProfileInfo?.isGroup && showAddMoreWalletModal && ( ` width: 100%; gap: 12px; align-items: center; - border: ${(props) => - props?.alert - ? '1px solid #E93636' - : props.theme.border.modalInnerComponents}; + border: ${(props) => (props?.alert ? '1px solid #E93636' : props.theme.border.modalInnerComponents)}; border-radius: ${(props) => props.theme.borderRadius.modalInnerComponents}; padding: 12px 16px; box-sizing: border-box; diff --git a/packages/uiweb/src/lib/components/chat/ChatProfile/MemberListContainer.tsx b/packages/uiweb/src/lib/components/chat/ChatProfile/MemberListContainer.tsx index 50965c2d8..cf161de73 100644 --- a/packages/uiweb/src/lib/components/chat/ChatProfile/MemberListContainer.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatProfile/MemberListContainer.tsx @@ -2,18 +2,18 @@ import { useContext, useRef, useState } from 'react'; import styled from 'styled-components'; -import { ThemeContext } from '../theme/ThemeProvider'; import { useClickAway } from '../../../hooks'; -import Dropdown, { DropdownValueType } from '../reusables/DropDown'; import { Section, Span } from '../../reusables/sharedStyling'; +import Dropdown, { DropdownValueType } from '../reusables/DropDown'; +import { ThemeContext } from '../theme/ThemeProvider'; -import DismissAdmin from '../../../icons/dismissadmin.svg'; +import { device } from '../../../config'; +import { shortenText } from '../../../helpers'; import AddAdmin from '../../../icons/addadmin.svg'; +import DismissAdmin from '../../../icons/dismissadmin.svg'; import Remove from '../../../icons/remove.svg'; import { IChatTheme, User } from '../exportedTypes'; import { findObject } from '../helpers/helper'; -import { device } from '../../../config'; -import { shortenText } from '../../../helpers'; import { ProfileContainer } from '../reusables'; @@ -113,8 +113,13 @@ export const MemberListContainer = ({ diff --git a/packages/uiweb/src/lib/components/chat/ChatProfile/MemberProfileCard.tsx b/packages/uiweb/src/lib/components/chat/ChatProfile/MemberProfileCard.tsx index 01787a63e..42c7f261c 100644 --- a/packages/uiweb/src/lib/components/chat/ChatProfile/MemberProfileCard.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatProfile/MemberProfileCard.tsx @@ -5,16 +5,15 @@ import React, { useContext, useState } from 'react'; import styled from 'styled-components'; // Internal Components -import { MoreLightIcon } from '../../../icons/MoreLight'; -import { shortenText } from '../../../helpers'; -import { ThemeContext } from '../theme/ThemeProvider'; +import { device } from '../../../config'; +import { pCAIP10ToWallet, shortenText } from '../../../helpers'; import { useChatData } from '../../../hooks'; +import { MoreLightIcon } from '../../../icons/MoreLight'; import { Section, Span } from '../../reusables'; -import Dropdown from '../reusables/DropDown'; -import { pCAIP10ToWallet } from '../../../helpers'; -import { device } from '../../../config'; -import { ProfileContainer } from '../reusables'; import { isAdmin } from '../helpers'; +import { ProfileContainer } from '../reusables'; +import Dropdown from '../reusables/DropDown'; +import { ThemeContext } from '../theme/ThemeProvider'; type MemberProfileCardProps = { key?: number | string; @@ -35,7 +34,7 @@ export const MemberProfileCard = ({ dropdownRef, }: MemberProfileCardProps) => { const theme = useContext(ThemeContext); - const { account } = useChatData(); + const { user } = useChatData(); const [dropdownHeight, setDropdownHeight] = useState(0); @@ -60,8 +59,13 @@ export const MemberProfileCard = ({
@@ -78,7 +82,7 @@ export const MemberProfileCard = ({ )} {pCAIP10ToWallet(member?.address)!.toLowerCase() !== - pCAIP10ToWallet(account!.toLowerCase()!) && + pCAIP10ToWallet(user!.account!.toLowerCase()!) && dropdownValues.length > 0 && (
- >; + setPendingMemberPaginationData: React.Dispatch>; pendingMembers: ChatMemberProfile[]; setShowPendingRequests: React.Dispatch>; showPendingRequests: boolean; @@ -39,10 +36,9 @@ type PendingMembersProps = { }; type AcceptedMembersProps = { acceptedMemberPaginationData: MemberPaginationData; - setAcceptedMemberPaginationData: React.Dispatch< - React.SetStateAction - >; + setAcceptedMemberPaginationData: React.Dispatch>; acceptedMembers: ChatMemberProfile[]; + accountStatus: ParticipantStatus | null; chatId: string; theme: IChatTheme; }; @@ -75,11 +71,7 @@ export const PendingMembers = ({ const isInViewportPending = useIsInViewport(pendingMemberPageRef, '1px'); useEffect(() => { - if ( - !isInViewportPending || - pendingMemberPaginationData.loading || - pendingMemberPaginationData.finishedFetching - ) { + if (!isInViewportPending || pendingMemberPaginationData.loading || pendingMemberPaginationData.finishedFetching) { return; } @@ -93,10 +85,11 @@ export const PendingMembers = ({ if (pendingMembers && pendingMembers.length) { return ( - setShowPendingRequests(!showPendingRequests)} - > - + setShowPendingRequests(!showPendingRequests)}> + Pending Requests {count} @@ -126,12 +119,13 @@ export const PendingMembers = ({ - +
)} -
+
); @@ -160,48 +160,20 @@ export const AcceptedMembers = ({ acceptedMembers, setAcceptedMemberPaginationData, acceptedMemberPaginationData, + accountStatus, chatId, theme, }: AcceptedMembersProps) => { - const { account } = useChatData(); + const { toast } = useChatData(); const acceptedMemberPageRef = useRef(null); - const [accountStatus, setAccountStatus] = useState( - null - ); - const [selectedMemberAddress, setSelectedMemberAddress] = useState< - string | null - >(null); + const [selectedMemberAddress, setSelectedMemberAddress] = useState(null); const dropdownRef = useRef(null); - const { - addMember, - removeMember, - modifyLoading, - addLoading, - removeLoading, - modifyParticipant, - } = useUpdateGroup(); - const groupInfoToast = useToast(); - const { fetchMemberStatus } = useGroupMemberUtilities(); + const { addMember, removeMember, modifyLoading, addLoading, removeLoading, modifyParticipant } = useUpdateGroup(); const isInViewportPending = useIsInViewport(acceptedMemberPageRef, '1px'); useEffect(() => { - if (account && chatId) { - (async () => { - const status = await fetchMemberStatus({ chatId, accountId: account }); - if (status) { - setAccountStatus(status); - } - })(); - } - }, []); - - useEffect(() => { - if ( - !isInViewportPending || - acceptedMemberPaginationData.loading || - acceptedMemberPaginationData.finishedFetching - ) { + if (!isInViewportPending || acceptedMemberPaginationData.loading || acceptedMemberPaginationData.finishedFetching) { return; } @@ -228,11 +200,16 @@ export const AcceptedMembers = ({ handleError(response, SUCCESS_MESSAGE[UPDATE_KEYS.REMOVE_MEMBER]); } } catch (error) { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: 'Please, try again', toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } finally { setSelectedMemberAddress(null); @@ -253,32 +230,46 @@ export const AcceptedMembers = ({ handleError(response, SUCCESS_MESSAGE[UPDATE_KEYS.REMOVE_ADMIN]); } } catch (error) { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: 'Please, try again', toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } finally { setSelectedMemberAddress(null); } }; - const handleError = (response: any, errMessage: string) => { if (typeof response !== 'string') { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Success', toastMessage: errMessage, toastType: 'SUCCESS', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } else { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: 'Error', toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); } }; @@ -319,8 +310,7 @@ export const AcceptedMembers = ({ key={index} member={item} dropdownValues={ - isAdmin(item) && - accountStatus?.role === GROUP_ROLES.ADMIN.toLowerCase() + isAdmin(item) && accountStatus?.role === GROUP_ROLES.ADMIN.toLowerCase() ? [removeAdminDropdown, removeMemberDropdown] : accountStatus?.role === GROUP_ROLES.ADMIN.toLowerCase() ? [addAdminDropdown, removeMemberDropdown] @@ -331,10 +321,16 @@ export const AcceptedMembers = ({ dropdownRef={dropdownRef} /> ))} -
+
{acceptedMemberPaginationData.loading && (
- +
)} @@ -381,8 +377,7 @@ const PendingSection = styled.div` const ArrowImage = styled(Image)` margin-left: auto; - transform: ${(props) => - props?.setPosition ? 'rotate(0)' : 'rotate(180deg)'}; + transform: ${(props) => (props?.setPosition ? 'rotate(0)' : 'rotate(180deg)')}; `; const Badge = styled.div` diff --git a/packages/uiweb/src/lib/components/chat/ChatView/ChatViewComponent.tsx b/packages/uiweb/src/lib/components/chat/ChatView/ChatViewComponent.tsx index b7aaa0e6f..ea26efc56 100644 --- a/packages/uiweb/src/lib/components/chat/ChatView/ChatViewComponent.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatView/ChatViewComponent.tsx @@ -1,13 +1,10 @@ -import React, { useContext } from 'react'; -import { - IChatTheme, - IChatViewComponentProps, - -} from '../exportedTypes'; +import React, { useContext, useEffect, useState } from 'react'; import { MODAL_BACKGROUND_TYPE, MODAL_POSITION_TYPE } from '../../../types'; +import { IChatTheme, IChatViewComponentProps } from '../exportedTypes'; import { chatLimit, device } from '../../../config'; -import { Section, Span } from '../../reusables'; +import { deriveChatId } from '../../../helpers'; +import { Section, Span, Spinner } from '../../reusables'; import { ChatViewList } from '../ChatViewList'; import styled from 'styled-components'; @@ -25,9 +22,7 @@ interface IThemeProps { theme?: IChatTheme; } -export const ChatViewComponent: React.FC = ( - options: IChatViewComponentProps -) => { +export const ChatViewComponent: React.FC = (options: IChatViewComponentProps) => { const { chatId = null, chatFilterList = [], @@ -50,36 +45,73 @@ export const ChatViewComponent: React.FC = ( welcomeComponent = null, } = options || {}; - const { env, signer, account, pgpPrivateKey } = useChatData(); - - // const [conversationHash, setConversationHash] = useState(); - + const { user } = useChatData(); const theme = useContext(ThemeContext); const isMobile = useMediaQuery(device.mobileL); + if (!user) { + console.warn( + 'Chat::ChatView::You need to pass either push user, or a signer, or account and pgpPrivateKey in ChatViewComponent to send messages.' + ); + } + + // set loading state + const [initialized, setInitialized] = useState({ + loading: true, + derivedChatId: '', + }); + + useEffect(() => { + const fetchDerivedChatId = async () => { + setInitialized((currentState) => ({ ...currentState, loading: true })); + + if (chatId) { + const id = await deriveChatId(chatId, user); + setInitialized({ loading: false, derivedChatId: id }); + } else { + setInitialized({ loading: false, derivedChatId: '' }); + } + }; + + fetchDerivedChatId(); + }, [chatId, user]); // Re-run this effect if chatId or env changes + return ( - {chatId ? ( + {/* If initialized is loading then show spinner */} + {initialized.loading && ( +
+ +
+ )} + + {/* If chat id is present and initialized is not loading then show chat view */} + {!initialized.loading && chatId ? ( <> - {chatProfile && - } + {/* Load ChatProfile if in options */} + {chatProfile && ( + + )} + + {/* Load ChatViewList if in options */}
= ( flexDirection="column" justifyContent="start" > - { chatViewList && ( + {chatViewList && ( )}
- {/* )} */} - {!signer && !(!!account && !!pgpPrivateKey) && !isConnected && ( + + {/* Check if user is not in read mode */} + {/* This will probably be not needed anymore */} + {/* {!signer && !(!!account && !!pgpPrivateKey) && !isConnected && (
- - You need to either pass signer or isConnected to send messages{' '} - + +
+ )} */} + + {/* Load MessageInput if in options and user is present */} + {messageInput && user && ( +
+
)} - {messageInput && - (!!signer || (!!account && !!pgpPrivateKey) || isConnected) && ( -
- -
- )} ) : ( -
- { welcomeComponent } -
+
{welcomeComponent}
)}
); @@ -135,6 +169,5 @@ export const ChatViewComponent: React.FC = ( //styles const Conatiner = styled(Section)` border: ${(props) => props.theme.border?.chatViewComponent}; - backdrop-filter: ${(props) => props.theme.backdropFilter}; box-sizing: border-box; `; diff --git a/packages/uiweb/src/lib/components/chat/ChatViewBubble/ChatViewBubble.tsx b/packages/uiweb/src/lib/components/chat/ChatViewBubble/ChatViewBubble.tsx index 9d5874222..f1702b277 100644 --- a/packages/uiweb/src/lib/components/chat/ChatViewBubble/ChatViewBubble.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatViewBubble/ChatViewBubble.tsx @@ -1,60 +1,46 @@ -import { - ReactElement, - ReactNode, - useContext, - useEffect, - useState, -} from 'react'; +import { ReactElement, ReactNode, useContext, useEffect, useState } from 'react'; import moment from 'moment'; -import styled from 'styled-components'; import { TwitterTweetEmbed } from 'react-twitter-embed'; +import styled from 'styled-components'; +import { MdDownload } from 'react-icons/md'; -import { Section, Span, Image } from '../../reusables'; -import { checkTwitterUrl } from '../helpers/twitter'; import { ChatDataContext } from '../../../context'; import { useChatData } from '../../../hooks'; +import { Image, Section, Span } from '../../reusables'; +import { checkTwitterUrl } from '../helpers/twitter'; import { ThemeContext } from '../theme/ThemeProvider'; +import { FILE_ICON } from '../../../config'; +import { formatFileSize, getPfp, pCAIP10ToWallet, shortenText } from '../../../helpers'; import { FileMessageContent } from '../../../types'; import { IMessagePayload, TwitterFeedReturnType } from '../exportedTypes'; -import { FILE_ICON } from '../../../config'; -import { - formatFileSize, - getPfp, - pCAIP10ToWallet, - shortenText, -} from '../../../helpers'; const SenderMessageAddress = ({ chat }: { chat: IMessagePayload }) => { - const { account } = useContext(ChatDataContext); + const { user } = useContext(ChatDataContext); const theme = useContext(ThemeContext); - return ( - <> - {chat.fromCAIP10.split(':')[1] !== account && ( - - {chat.fromDID.split(':')[1].slice(0, 6)}... - {chat.fromDID.split(':')[1].slice(-6)} - - )} - - ); + return chat.fromCAIP10?.split(':')[1] !== user?.account ? ( + + {chat.fromDID?.split(':')[1].slice(0, 6)}... + {chat.fromDID?.split(':')[1].slice(-6)} + + ) : null; }; const SenderMessageProfilePicture = ({ chat }: { chat: IMessagePayload }) => { - const { account, env } = useContext(ChatDataContext); + const { user } = useContext(ChatDataContext); const [pfp, setPfp] = useState(''); const getUserPfp = async () => { const pfp = await getPfp({ - account: chat.fromCAIP10.split(':')[1], - env: env, + user: user, + recipient: chat.fromCAIP10?.split(':')[1], }); if (pfp) { setPfp(pfp); @@ -62,10 +48,14 @@ const SenderMessageProfilePicture = ({ chat }: { chat: IMessagePayload }) => { }; useEffect(() => { getUserPfp(); - }, [account, chat.fromCAIP10]); + }, [chat.fromCAIP10]); + return ( -
- {chat.fromCAIP10.split(':')[1] !== account && ( +
+ {chat.fromCAIP10?.split(':')[1] !== user?.account && (
{pfp && ( {isGroup && } -
+
{isGroup && } {children}
-
); }; -const MessageCard = ({ - chat, - position, - isGroup, -}: { - chat: IMessagePayload; - position: number; - isGroup: boolean; -}) => { +const MessageCard = ({ chat, position, isGroup }: { chat: IMessagePayload; position: number; isGroup: boolean }) => { const theme = useContext(ThemeContext); const time = moment(chat.timestamp).format('hh:mm a'); return ( - + {' '} -
- {chat.messageContent.split('\n').map((str) => ( +
+ {chat?.messageContent?.split('\n').map((str) => ( {str} @@ -191,11 +166,7 @@ const MessageCard = ({ ? `${theme.fontWeight?.chatSentBubbleTimestampText}` : `${theme.fontWeight?.chatReceivedBubbleTimestampText}` } - color={ - position - ? `${theme.textColor?.chatSentBubbleText}` - : `${theme.textColor?.chatReceivedBubbleText}` - } + color={position ? `${theme.textColor?.chatSentBubbleText}` : `${theme.textColor?.chatReceivedBubbleText}`} bottom="6px" right="10px" > @@ -206,22 +177,19 @@ const MessageCard = ({ ); }; -const FileCard = ({ - chat, - isGroup, -}: { - chat: IMessagePayload; - position: number; - isGroup: boolean; -}) => { - const fileContent: FileMessageContent = JSON.parse(chat.messageContent); +const FileCard = ({ chat, isGroup }: { chat: IMessagePayload; position: number; isGroup: boolean }) => { + const fileContent: FileMessageContent = JSON.parse(chat?.messageContent); const name = fileContent.name; const content = fileContent.content as string; const size = fileContent.size; return ( - +
extension icon -
- +
+ {shortenText(name, 11)} - + {formatFileSize(size)}
@@ -253,24 +230,19 @@ const FileCard = ({ rel="noopener noreferrer" download > -
); }; -const ImageCard = ({ - chat, - position, - isGroup, -}: { - chat: IMessagePayload; - position: number; - isGroup: boolean; -}) => { +const ImageCard = ({ chat, position, isGroup }: { chat: IMessagePayload; position: number; isGroup: boolean }) => { return ( - +
{ +const GIFCard = ({ chat, position, isGroup }: { chat: IMessagePayload; position: number; isGroup: boolean }) => { return ( - +
{ return ( - +
{ - const { account } = useChatData(); +export const ChatViewBubble = ({ + decryptedMessagePayload, + isGroup = false, +}: { + decryptedMessagePayload: IMessagePayload; + isGroup?: boolean; +}) => { + const { user } = useChatData(); const position = - pCAIP10ToWallet(decryptedMessagePayload.fromDID).toLowerCase() !== account?.toLowerCase() - ? 0 - : 1; + pCAIP10ToWallet(decryptedMessagePayload.fromDID).toLowerCase() !== user?.account?.toLowerCase() ? 0 : 1; const { tweetId, messageType }: TwitterFeedReturnType = checkTwitterUrl({ message: decryptedMessagePayload?.messageContent, }); - const [isGroup, setIsGroup] = useState(false); - useEffect(() => { - if (decryptedMessagePayload.toDID.split(':')[0] === 'eip155') { - if (isGroup) { - setIsGroup(false); - } - } else { - if (!isGroup) { - setIsGroup(true); - } - } - }, [decryptedMessagePayload.toDID, isGroup]); if (messageType === 'TwitterFeedLink') { decryptedMessagePayload.messageType = 'TwitterFeedLink'; } if (decryptedMessagePayload.messageType === 'GIF') { - return ; + return ( + + ); } if (decryptedMessagePayload.messageType === 'Image') { - return ; + return ( + + ); } if (decryptedMessagePayload.messageType === 'File') { - return ; + return ( + + ); } if (decryptedMessagePayload.messageType === 'TwitterFeedLink') { return ( @@ -386,17 +368,18 @@ export const ChatViewBubble = ({ decryptedMessagePayload }: { decryptedMessagePa /> ); } - return ; + return ( + + ); }; -const FileDownloadIcon = styled.i` - color: #575757; -`; - const FileDownloadIconAnchor = styled.a` font-size: 20px; `; -const MessageSection = styled(Section)<{border:string}>` -border: ${(props) => props.border}; +const MessageSection = styled(Section)<{ border: string }>` + border: ${(props) => props.border}; `; - diff --git a/packages/uiweb/src/lib/components/chat/ChatViewList/ActionRequestBubble.tsx b/packages/uiweb/src/lib/components/chat/ChatViewList/ActionRequestBubble.tsx new file mode 100644 index 000000000..46d5ae188 --- /dev/null +++ b/packages/uiweb/src/lib/components/chat/ChatViewList/ActionRequestBubble.tsx @@ -0,0 +1,236 @@ +import { IFeeds } from '@pushprotocol/restapi'; +import { Dispatch, useContext, useState } from 'react'; +import { MdCheckCircle } from 'react-icons/md'; +import styled from 'styled-components'; +import { useChatData } from '../../../hooks'; +import useApproveChatRequest from '../../../hooks/chat/useApproveChatRequest'; +import useRejectChatRequest from '../../../hooks/chat/useRejectChatRequest'; +import { Section, Span, Spinner } from '../../reusables'; +import ParticleEffectButton from '../../reusables/ParticleEffectButton'; +import { Group } from '../exportedTypes'; +import { IChatTheme } from '../theme'; +import { ThemeContext } from '../theme/ThemeProvider'; +import { ChatInfoResponse } from '../types'; +import { AcceptCircleIcon, CancelCircleIcon } from '../../../icons/PushIcons'; + +// Constants +const APPROVE_REQUEST_TEXT = { + GROUP: `You were invited to this group. Please accept to continue messaging in this group.`, + W2W: `This wallet wants to chat with you! Please accept to continue or reject to decline.`, +}; + +/** + * @interface IThemeProps + * this interface is used for defining the props for styled components + */ +interface IThemeProps { + theme?: IChatTheme; +} +export interface IActionRequestBubbleProps { + chatInfo?: ChatInfoResponse | null; +} + +export const ActionRequestBubble = ({ chatInfo = null }: IActionRequestBubbleProps) => { + const { user, toast } = useChatData(); + + const theme = useContext(ThemeContext); + const { approveChatRequest, loading: approveLoading } = useApproveChatRequest(); + const { rejectChatRequest, loading: rejectLoading } = useRejectChatRequest(); + + const [isApproved, setIsApproved] = useState(false); + const [isRejected, setIsRejected] = useState(false); + + const handleApproveChatRequest = async () => { + try { + if (!user || user.readmode()) { + return; + } + + if (chatInfo?.recipient) { + const response = await approveChatRequest({ + chatId: chatInfo?.recipient, // since recipient is chatId for group but wallet for dms + }); + setIsApproved(true); + } else { + toast.showMessageToast({ + toastTitle: 'Error', + toastMessage: 'Invalid Chat', + toastType: 'ERROR', + getToastIcon: (size: number) => ( + + ), + }); + } + } catch (err: Error | any) { + console.error(`UIWeb::ActionRequestBubble::handleApproveChatRequest::error`, err); + } + }; + + const handleRejectChatRequest = async () => { + try { + if (!user || user.readmode()) { + return; + } + + if (chatInfo?.recipient) { + const response = await rejectChatRequest({ + chatId: chatInfo?.recipient, // since recipient is chatId for group but wallet for dms + }); + setIsRejected(true); + + toast.showMessageToast({ + toastTitle: 'Invitation Declined', + toastMessage: 'This conversation has been removed from your request list.', + toastType: 'WARNING', + getToastIcon: (size: number) => ( + + ), + }); + } else { + toast.showMessageToast({ + toastTitle: 'Error', + toastMessage: 'Invalid Chat ID', + toastType: 'ERROR', + getToastIcon: (size: number) => ( + + ), + }); + } + } catch (err: Error | any) { + console.error(`UIWeb::ActionRequestBubble::handleRejectChatRequest::error`, err); + } + }; + + // Render + return ( +
+ +
+ ); +}; + +//styles +const Button = styled.button` + border: none; + cursor: pointer; + border-radius: 100%; + background: transparent; + padding: 0px; + border: none; + height: 40px; + width: 40px; + display: flex; + justify-content: center; + align-items: center; + + &.disabled { + cursor: not-allowed; + opacity: 0.5; + } + + &.primary.active { + background: ${(props) => props.theme.iconColor?.approveRequest}; + } + + &.secondary.active { + background: ${(props) => props.theme.iconColor?.rejectRequest}; + } +`; diff --git a/packages/uiweb/src/lib/components/chat/ChatViewList/ApproveRequestBubble.tsx b/packages/uiweb/src/lib/components/chat/ChatViewList/ApproveRequestBubble.tsx deleted file mode 100644 index 231f3b7a6..000000000 --- a/packages/uiweb/src/lib/components/chat/ChatViewList/ApproveRequestBubble.tsx +++ /dev/null @@ -1,121 +0,0 @@ -import { IFeeds } from '@pushprotocol/restapi'; -import { ThemeContext } from '../theme/ThemeProvider'; -import { Dispatch, useContext } from 'react'; -import { Section, Span, Spinner } from '../../reusables'; -import useApproveChatRequest from '../../../hooks/chat/useApproveChatRequest'; -import { useChatData } from '../../../hooks'; -import styled from 'styled-components'; -import { IChatTheme } from '../theme'; -import { Group } from '../exportedTypes'; -import useToast from '../reusables/NewToast'; -import { MdCheckCircle } from 'react-icons/md'; - -/** - * @interface IThemeProps - * this interface is used for defining the props for styled components - */ -interface IThemeProps { - theme?: IChatTheme; -} -export interface IApproveRequestBubbleProps { - chatId: string; - groupInfo?: Group | null; -} - - -export const ApproveRequestBubble = ({ - groupInfo = null, - chatId, -}: IApproveRequestBubbleProps) => { - const { pgpPrivateKey } = useChatData(); - - const ApproveRequestText = { - GROUP: `You were invited to the group ${groupInfo?.groupName}. Please accept to continue messaging in this group.`, - W2W: ` Please accept to enable push chat from this wallet`, - }; - - const theme = useContext(ThemeContext); - const { approveChatRequest, loading: approveLoading } = - useApproveChatRequest(); - const approveToast = useToast(); - - const handleApproveChatRequest = async () => { - try { - if (!pgpPrivateKey) { - return; - } - - const response = await approveChatRequest({ - chatId, - }); - - if (response) { - approveToast.showMessageToast({ - toastTitle: 'Success', - toastMessage: 'Group Invitation sent', - toastType: 'SUCCESS', - getToastIcon: (size) => , - }); - } - } catch (error_: Error | any) { - console.log(error_.message); - } - }; - return ( -
- - {groupInfo - ? ApproveRequestText.GROUP - : ApproveRequestText.W2W} - - - -
- ); -}; - -//styles -const Button = styled.button` - border: none; - cursor: pointer; - border-radius: 8px; - background: ${(props) => props.theme.backgroundColor!.buttonBackground}; - border: none; - color: ${(props) => props.theme.textColor!.buttonText}; - width: 100%; - font-size: 16px; - font-weight: 600; - line-height: 24px; - max-height: 48px; - min-height: 48px; - padding: 0px 24px; - display: flex; - justify-content: center; - align-items: center; -`; diff --git a/packages/uiweb/src/lib/components/chat/ChatViewList/ChatViewList.tsx b/packages/uiweb/src/lib/components/chat/ChatViewList/ChatViewList.tsx index 5d2a0ca77..a5461664e 100644 --- a/packages/uiweb/src/lib/components/chat/ChatViewList/ChatViewList.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatViewList/ChatViewList.tsx @@ -1,43 +1,36 @@ +// React + Web3 Essentials import React, { useContext, useEffect, useRef, useState } from 'react'; -import { - IMessageIPFS, - IMessageIPFSWithCID, - IUser, -} from '@pushprotocol/restapi'; +// External Packages +import { IMessageIPFS, IMessageIPFSWithCID, IUser } from '@pushprotocol/restapi'; import moment from 'moment'; -import styled from 'styled-components'; -import { ToastContainer } from 'react-toastify'; import { MdError } from 'react-icons/md'; +import styled from 'styled-components'; +// Internal Compoonents import { chatLimit } from '../../../config'; -import { - appendUniqueMessages, - dateToFromNowDaily, - getAddress, - pCAIP10ToWallet, - walletToPCAIP10, -} from '../../../helpers'; +import { appendUniqueMessages, dateToFromNowDaily, pCAIP10ToWallet, walletToPCAIP10 } from '../../../helpers'; import { useChatData, usePushChatStream } from '../../../hooks'; +import useFetchChat from '../../../hooks/chat/useFetchChat'; import useFetchMessageUtilities from '../../../hooks/chat/useFetchMessageUtilities'; +import useGetGroupByIDnew from '../../../hooks/chat/useGetGroupByIDnew'; +import useGroupMemberUtilities from '../../../hooks/chat/useGroupMemberUtilities'; +import usePushUser from '../../../hooks/usePushUser'; import { Section, Span, Spinner } from '../../reusables'; import { ChatViewBubble } from '../ChatViewBubble'; -import { Group, IChatViewListProps } from '../exportedTypes'; -import { IChatTheme } from '../theme'; +import { checkIfNewRequest, transformStreamToIMessageIPFSWithCID } from '../helpers'; +import { ActionRequestBubble } from './ActionRequestBubble'; +import { ENCRYPTION_KEYS, EncryptionMessage } from './MessageEncryption'; + +// Internal Configs import { ThemeContext } from '../theme/ThemeProvider'; -import useFetchChat from '../../../hooks/chat/useFetchChat'; -import { ApproveRequestBubble } from './ApproveRequestBubble'; -import { ENCRYPTION_KEYS, EncryptionMessage } from './MessageEncryption'; -import useGroupMemberUtilities from '../../../hooks/chat/useGroupMemberUtilities'; +// Assets + +// Interfaces & Types +import { Group, IChatViewListProps } from '../exportedTypes'; +import { IChatTheme } from '../theme'; import { ChatInfoResponse } from '../types'; -import useUserProfile from '../../../hooks/useUserProfile'; -import useGetGroupByIDnew from '../../../hooks/chat/useGetGroupByIDnew'; -import useToast from '../reusables/NewToast'; -import { - checkIfNewRequest, - transformStreamToIMessageIPFSWithCID, -} from '../helpers'; /** * @interface IThemeProps @@ -47,202 +40,162 @@ interface IThemeProps { theme?: IChatTheme; blur: boolean; } -const ChatStatus = { + +interface IChatViewListInitialized { + loading: boolean; + chatInfo: ChatInfoResponse | null; + groupInfo: Group | null; + isParticipant: boolean; + isHidden: boolean; + invalidChat: boolean; +} + +// Constants +const CHAT_STATUS = { FIRST_CHAT: `This is your first conversation with recipient.\n Start the conversation by sending a message.`, INVALID_CHAT: 'Invalid chatId', }; -export const ChatViewList: React.FC = ( - options: IChatViewListProps -) => { +// Exported Interfaces & Types + +// Exported Functions +export const ChatViewList: React.FC = (options: IChatViewListProps) => { + // setup loading state + const [initialized, setInitialized] = useState({ + loading: true, + chatInfo: null, + groupInfo: null, + isParticipant: false, + isHidden: false, + invalidChat: false, + }); + + const [loading, setLoading] = useState(true); + const { chatId, limit = chatLimit, chatFilterList = [] } = options || {}; - const { account, user } = useChatData(); + const { user, toast } = useChatData(); const [chatInfo, setChatInfo] = useState(null); const [groupInfo, setGroupInfo] = useState(null); const [userInfo, setUserInfo] = useState(null); - const [chatStatusText, setChatStatusText] = useState(''); + // const [chatStatusText, setChatStatusText] = useState(''); const [messages, setMessages] = useState([]); - const [loading, setLoading] = useState(true); - const { historyMessages, historyLoading: messageLoading } = - useFetchMessageUtilities(); + const { historyMessages, historyLoading: messageLoading } = useFetchMessageUtilities(); const listInnerRef = useRef(null); - const [isMember, setIsMember] = useState(false); + const [stopPagination, setStopPagination] = useState(false); const { fetchChat } = useFetchChat(); - const { fetchUserProfile } = useUserProfile(); const { getGroupByIDnew } = useGetGroupByIDnew(); const { fetchMemberStatus } = useGroupMemberUtilities(); - const chatViewListToast = useToast(); - - //hack for stream not working - const [chatStream, setChatStream] = useState({}); // to track any new messages - const [chatRequestStream, setChatRequestStream] = useState({}); // to track any new messages - - const [chatAcceptStream, setChatAcceptStream] = useState({}); // to track any new messages - const [participantRemoveStream, setParticipantRemoveStream] = useState( - {} - ); // to track if a participant is removed from group - const [participantLeaveStream, setParticipantLeaveStream] = useState({}); // to track if a participant leaves a group - const [participantJoinStream, setParticipantJoinStream] = useState({}); // to track if a participant joins a group - - const [groupUpdateStream, setGroupUpdateStream] = useState({}); - const [formattedChatId, setFormattedChatId] = useState(''); - - // const { - // chatStream, - // groupUpdateStream, - // chatAcceptStream, - // participantJoinStream, - // participantLeaveStream, - // participantRemoveStream, - // } = usePushChatStream(); - - //event listeners - usePushChatStream(); - useEffect(() => { - window.addEventListener('chatStream', (e: any) => setChatStream(e.detail)); - window.addEventListener('chatRequestStream', (e: any) => - setChatRequestStream(e.detail) - ); - window.addEventListener('chatAcceptStream', (e: any) => - setChatAcceptStream(e.detail) - ); - window.addEventListener('participantRemoveStream', (e: any) => - setParticipantRemoveStream(e.detail) - ); - window.addEventListener('participantLeaveStream', (e: any) => - setParticipantLeaveStream(e.detail) - ); - window.addEventListener('participantJoinStream', (e: any) => - setParticipantJoinStream(e.detail) - ); - window.addEventListener('groupUpdateStream', (e: any) => - setGroupUpdateStream(e.detail) - ); - return () => { - window.removeEventListener('chatStream', (e: any) => - setChatStream(e.detail) - ); - window.removeEventListener('chatRequestStream', (e: any) => - setChatRequestStream(e.detail) - ); - - window.removeEventListener('chatAcceptStream', (e: any) => - setChatAcceptStream(e.detail) - ); - window.removeEventListener('participantRemoveStream', (e: any) => - setParticipantRemoveStream(e.detail) - ); - window.removeEventListener('participantLeaveStream', (e: any) => - setParticipantLeaveStream(e.detail) - ); - window.removeEventListener('participantJoinStream', (e: any) => - setParticipantJoinStream(e.detail) - ); - window.removeEventListener('groupUpdateStream', (e: any) => - setGroupUpdateStream(e.detail) - ); - }; - }, []); + + // for stream + const { + chatStream, + chatAcceptStream, + chatRequestStream, + participantJoinStream, + participantLeaveStream, + participantRemoveStream, + groupUpdateStream, + } = useChatData(); + const theme = useContext(ThemeContext); const dates = new Set(); - const { env } = useChatData(); - useEffect(() => { - setChatStatusText(''); - }, [chatId, account, env, user]); - - useEffect(() => { - setChatInfo(null); - setMessages([]); - setGroupInfo(null); - }, [chatId, account, user, env]); + // Primary Hook that fetches and sets ChatInfo which then fetches and sets UserInfo or GroupInfo + // Which then calls await getMessagesCall(); to fetch messages useEffect(() => { (async () => { if (!user) return; if (chatId) { - let formattedChatId; - if (chatId.includes('.')) { - formattedChatId = (await getAddress(chatId, env))!; - } else formattedChatId = chatId; - setFormattedChatId(formattedChatId); - const chat = await fetchChat({ chatId: formattedChatId }); - if (Object.keys(chat || {}).length) { - setChatInfo(chat as ChatInfoResponse); + const info = await fetchChat({ chatId: chatId }); + + // get group info + let groupMeta; + if (info && info?.meta?.group) { + groupMeta = await getGroupByIDnew({ groupId: chatId }); } - setLoading(false); - } - })(); - }, [chatId, user, account, env]); - useEffect(() => { - (async () => { - let UserProfile, GroupProfile; - if ( - chatInfo && - !chatInfo?.meta?.group && - chatInfo?.participants && - account - ) { - UserProfile = await fetchUserProfile({ - profileId: pCAIP10ToWallet( - chatInfo?.participants.find( - (address) => address != walletToPCAIP10(account) - ) || formattedChatId - ), - env, - user, + // get member status + const status = await fetchMemberStatus({ + chatId: chatId, + accountId: user?.account || '', }); - if (UserProfile) setUserInfo(UserProfile); - setChatStatusText(ChatStatus.FIRST_CHAT); - } else if (chatInfo && chatInfo?.meta?.group) { - GroupProfile = await getGroupByIDnew({ groupId: formattedChatId }); - if (GroupProfile) setGroupInfo(GroupProfile); - else { - setChatStatusText(ChatStatus.INVALID_CHAT); + + // also find out if chat is encrypted + let hidden = false; + if ( + user && + !user.readmode() && + ((info?.meta?.group && status?.participant) || + (!info?.meta?.group && (info?.list === 'CHATS' || info?.list === 'REQUESTS')) || + (info?.meta?.group && groupMeta?.isPublic)) + ) { + hidden = false; + } else { + hidden = true; } + + // Finally initialize the component + setInitialized({ + loading: false, + chatInfo: Object.keys(info || {}).length ? (info as ChatInfoResponse) : null, + groupInfo: groupMeta ? groupMeta : null, + isParticipant: status?.participant ?? false, + isHidden: hidden, + invalidChat: info === undefined ? true : false, + }); } })(); - }, [chatInfo]); + + // cleanup + return () => { + setInitialized({ + loading: true, + chatInfo: null, + groupInfo: null, + isParticipant: false, + isHidden: false, + invalidChat: false, + }); + }; + }, [chatId, user, chatAcceptStream, participantJoinStream, participantLeaveStream, participantRemoveStream]); + + // When loading is done + useEffect(() => { + if (initialized.loading) return; + + (async function () { + await getMessagesCall(); + })(); + }, [initialized.loading]); //moniters stream changes useEffect(() => { - if ( - Object.keys(chatAcceptStream || {}).length > 0 && - chatAcceptStream.constructor === Object - ) { + if (Object.keys(chatAcceptStream || {}).length > 0 && chatAcceptStream.constructor === Object) { const updatedChatInfo = { ...(chatInfo as ChatInfoResponse) }; if (updatedChatInfo) updatedChatInfo.list = 'CHATS'; setChatInfo(updatedChatInfo); } }, [chatAcceptStream]); + useEffect(() => { - if ( - Object.keys(chatStream || {}).length > 0 && - chatStream.constructor === Object - ) { + if (Object.keys(chatStream || {}).length > 0 && chatStream.constructor === Object) { transformSteamMessage(chatStream); - setChatStatusText(''); + // setChatStatusText(''); scrollToBottom(); } }, [chatStream]); useEffect(() => { - if ( - Object.keys(chatRequestStream || {}).length > 0 && - chatRequestStream.constructor === Object - ) { + if (Object.keys(chatRequestStream || {}).length > 0 && chatRequestStream.constructor === Object) { transformSteamMessage(chatRequestStream); - setChatStatusText(''); + // setChatStatusText(''); scrollToBottom(); } }, [chatRequestStream]); useEffect(() => { - if ( - Object.keys(groupUpdateStream || {}).length > 0 && - groupUpdateStream.constructor === Object - ) + if (Object.keys(groupUpdateStream || {}).length > 0 && groupUpdateStream.constructor === Object) transformGroupDetails(groupUpdateStream); }, [groupUpdateStream]); @@ -250,17 +203,11 @@ export const ChatViewList: React.FC = ( if (!user) { return; } - if ( - chatInfo && - (item?.chatId == chatInfo?.chatId || checkIfNewRequest(item, formattedChatId)) - ) { + + if (initialized.chatInfo && (item?.chatId === initialized.chatInfo?.chatId || checkIfNewRequest(item, chatId))) { const transformedMessage = transformStreamToIMessageIPFSWithCID(item); if (messages && messages.length) { - const newChatViewList = appendUniqueMessages( - messages, - [transformedMessage], - false - ); + const newChatViewList = appendUniqueMessages(messages, [transformedMessage], false); setFilteredMessages(newChatViewList); } else { setFilteredMessages([transformedMessage]); @@ -282,57 +229,18 @@ export const ChatViewList: React.FC = ( } }; - useEffect(() => { - if (chatInfo) { - (async function () { - await getMessagesCall(); - })(); - } - }, [chatInfo, user?.readmode(), account, env, chatId]); - useEffect(() => { if (messages && messages?.length && messages?.length <= limit) { - setChatStatusText(''); + // setChatStatusText(''); scrollToBottom(); } }, [messages]); - useEffect(() => { - if (user && account && groupInfo) { - (async () => { - const status = await fetchMemberStatus({ - chatId: groupInfo.chatId!, - accountId: account, - }); - if (status && typeof status !== 'string') { - setIsMember(status?.participant); - } else { - //show toast - chatViewListToast.showMessageToast({ - toastTitle: 'Error', - toastMessage: 'Error in fetching member details', - toastType: 'ERROR', - getToastIcon: (size) => , - }); - } - })(); - } - }, [ - account, - groupInfo, - chatInfo, - chatAcceptStream, - participantJoinStream, - participantLeaveStream, - participantRemoveStream, - ]); - //methods const scrollToBottom = () => { setTimeout(() => { if (listInnerRef.current) { - listInnerRef.current.scrollTop = - listInnerRef.current.scrollHeight + 100; + listInnerRef.current.scrollTop = listInnerRef.current.scrollHeight + 100; } }, 0); }; @@ -355,46 +263,41 @@ export const ChatViewList: React.FC = ( const getMessagesCall = async () => { let reference = null; + let stopFetchingChats = false; if (messages && messages?.length) { reference = messages[0].link; + if (!reference) { + stopFetchingChats = true; + setStopPagination(stopFetchingChats); + } } - if (user) { + if (user && !stopFetchingChats) { const chatHistory = await historyMessages({ limit: limit, - chatId:formattedChatId, + chatId: chatId, reference, }); + if (chatHistory?.length) { + const reversedChatHistory = chatHistory?.reverse(); if (messages && messages?.length) { - const newChatViewList = appendUniqueMessages( - messages, - chatHistory.reverse(), - true - ); + const newChatViewList = appendUniqueMessages(messages, reversedChatHistory, true); setFilteredMessages(newChatViewList as IMessageIPFSWithCID[]); } else { - setFilteredMessages(chatHistory.reverse() as IMessageIPFSWithCID[]); + setFilteredMessages(reversedChatHistory as IMessageIPFSWithCID[]); } } } }; const setFilteredMessages = (messageList: Array) => { - const updatedMessageList = messageList.filter( - (msg) => !chatFilterList.includes(msg.cid) - ); + const updatedMessageList = messageList.filter((msg) => !chatFilterList.includes(msg.cid)); if (updatedMessageList && updatedMessageList.length) { setMessages([...updatedMessageList]); } }; - const ifBlurChat = () => { - return !!( - user && - ((groupInfo && !groupInfo?.isPublic && !isMember) || user?.readmode()) - ); - }; type RenderDataType = { chat: IMessageIPFS; @@ -415,8 +318,10 @@ export const ChatViewList: React.FC = ( ); }; + return ( = ( justifyContent="start" padding="0 2px" theme={theme} - blur={ifBlurChat()} onScroll={(e) => { e.stopPropagation(); - onScroll(); + if (!stopPagination) onScroll(); }} > - {loading ? : ''} - {!loading && ( - <> - {(userInfo && userInfo.publicKey) || - (groupInfo && !groupInfo?.isPublic) ? ( +
+ {initialized.loading && ( + + )} + + {!initialized.loading && + ((user && user.pgpPublicKey) || (initialized.groupInfo && !initialized.groupInfo?.isPublic) ? ( + ) : user && user.readmode() ? ( + ) : ( - - )} - - {chatStatusText && ( -
- - {chatStatusText} - -
- )} - {messageLoading ? : ''} + + ))} +
+ + {initialized.loading ? : ''} + {!initialized.loading && ( + <> + {/* Loading section and information about the chat */} +
+ + {messages && + messages.length === 0 && + !messageLoading && + !groupInfo && + !initialized.invalidChat && + CHAT_STATUS.FIRST_CHAT} + {initialized.invalidChat && CHAT_STATUS.INVALID_CHAT} + + + {messageLoading ? : ''} +
{ - <> -
- {messages && - messages?.map((chat: IMessageIPFS, index: number) => { - const dateNum = moment(chat.timestamp).format('L'); - const position = - pCAIP10ToWallet(chat.fromDID)?.toLowerCase() !== - account?.toLowerCase() - ? 0 - : 1; - return ( - <> - {dates.has(dateNum) - ? null - : renderDate({ chat, dateNum })} -
- -
- - ); - })} -
- {chatInfo && chatInfo?.list === 'REQUESTS' && ( - + + {messages && + messages?.map((chat: IMessageIPFS, index: number) => { + const dateNum = moment(chat.timestamp).format('L'); + // TODO: This is a hack as chat.fromDID is converted with eip to match with user.account creating a bug for omnichain + const position = + pCAIP10ToWallet(chat.fromDID)?.toLowerCase() !== user?.account?.toLowerCase() ? 0 : 1; + return ( + <> + {dates.has(dateNum) ? null : renderDate({ chat, dateNum })} +
+ +
+ + ); + })} + + {initialized.chatInfo && initialized.chatInfo?.list === 'REQUESTS' && ( + )} - +
} )} -
); }; @@ -515,11 +434,11 @@ const ChatViewListCard = styled(Section)` &::-webkit-scrollbar { width: 5px; } - ${({ blur }) => - blur && - ` - filter: blur(12px); - `} + overscroll-behavior: contain; scroll-behavior: smooth; `; + +const ChatViewListCardInner = styled(Section)` + filter: ${(props) => (props.blur ? 'blur(6px)' : 'none')}; +`; diff --git a/packages/uiweb/src/lib/components/chat/ChatViewList/MessageEncryption.tsx b/packages/uiweb/src/lib/components/chat/ChatViewList/MessageEncryption.tsx index 89a4cd2e2..9fc476822 100644 --- a/packages/uiweb/src/lib/components/chat/ChatViewList/MessageEncryption.tsx +++ b/packages/uiweb/src/lib/components/chat/ChatViewList/MessageEncryption.tsx @@ -1,20 +1,27 @@ -import styled from "styled-components"; -import { Div, Section, Span } from "../../reusables"; -import { useDeviceWidthCheck } from "../../../hooks"; -import { useContext } from "react"; -import { ThemeContext } from "../theme/ThemeProvider"; -import { NoEncryptionIcon } from "../../../icons/NoEncryption"; -import { EncryptionIcon } from "../../../icons/Encryption"; +import { useContext } from 'react'; +import styled from 'styled-components'; +import { useDeviceWidthCheck } from '../../../hooks'; +import { EncryptionIcon } from '../../../icons/Encryption'; +import { NoEncryptionIcon } from '../../../icons/NoEncryption'; +import { PublicChatIcon } from '../../../icons/PushIcons'; +import { Div, Section, Span } from '../../reusables'; +import { ThemeContext } from '../theme/ThemeProvider'; export const ENCRYPTION_KEYS = { ENCRYPTED: 'ENCRYPTED', NO_ENCRYPTED: 'NO_ENCRYPTED', - NO_ENCRYPTED_GROUP: 'NO_ENCRYPTED_GROUP' + NO_ENCRYPTED_GROUP: 'NO_ENCRYPTED_GROUP', + PREVIEW: 'PREVIEW', + LOADING: 'LOADING', } as const; -export type EncryptionKeys = (typeof ENCRYPTION_KEYS)[keyof typeof ENCRYPTION_KEYS]; +export type EncryptionKeys = typeof ENCRYPTION_KEYS[keyof typeof ENCRYPTION_KEYS]; -const EncryptionMessageContent = { +export const EncryptionMessage = ({ id, className }: { id: EncryptionKeys; className?: string }) => { + const theme = useContext(ThemeContext); + const isMobile = useDeviceWidthCheck(771); + + const EncryptionMessageContent = { ENCRYPTED: { IconComponent: , text: 'Messages are end-to-end encrypted. Only users in this chat can view or listen to them. Click to learn more.', @@ -22,48 +29,58 @@ const EncryptionMessageContent = { NO_ENCRYPTED: { IconComponent: , text: `Messages are not encrypted`, - }, NO_ENCRYPTED_GROUP: { IconComponent: , text: `Messages in this group are not encrypted`, }, - - }; - export const EncryptionMessage = ({ id }: { id: EncryptionKeys}) => { - const theme = useContext(ThemeContext); - const isMobile = useDeviceWidthCheck(771); - return ( -
- - {EncryptionMessageContent[id].IconComponent} - - - {EncryptionMessageContent[id].text} - - -
- ); + PREVIEW: { + IconComponent: ( + + ), + text: `Chat in preview mode. Only public groups messages are visible.`, + }, + LOADING: { + IconComponent: null, + text: `Please wait while Push Chat loads the status of this chat...`, + }, }; - //styles - const EncryptionMessageDiv = styled(Div)` - display:flex; + return ( +
+ + {EncryptionMessageContent[id].IconComponent ? EncryptionMessageContent[id].IconComponent : null} + + + {EncryptionMessageContent[id].text} + + +
+ ); +}; + +//styles +const EncryptionMessageDiv = styled(Div)` + display: flex; text-align: center; svg { vertical-align: middle; } -`; \ No newline at end of file +`; diff --git a/packages/uiweb/src/lib/components/chat/ConnectButton/ConnectButton.tsx b/packages/uiweb/src/lib/components/chat/ConnectButton/ConnectButton.tsx index c8c18a89e..6922db0de 100644 --- a/packages/uiweb/src/lib/components/chat/ConnectButton/ConnectButton.tsx +++ b/packages/uiweb/src/lib/components/chat/ConnectButton/ConnectButton.tsx @@ -6,10 +6,10 @@ import { ethers } from 'ethers'; import { useAccount, useChatData } from '../../../hooks'; import { ThemeContext } from '../theme/ThemeProvider'; - import { getAddressFromSigner } from '../../../helpers'; import { IChatTheme } from '../theme'; import { device } from '../../../config'; +import { CONSTANTS } from '@pushprotocol/restapi'; /** * @interface IThemeProps @@ -19,42 +19,36 @@ interface IThemeProps { theme?: IChatTheme; } +export const ConnectButtonSub = ({ autoConnect = false }) => { + const { user, preInitializeUser } = useChatData(); + const { wallet, connecting, connect, disconnect } = useAccount({ env: user ? user.env : CONSTANTS.ENV.PROD }); -export const ConnectButtonSub = ({autoConnect = false}) => { - const {env} = useChatData() - const {wallet, connecting , connect, disconnect} = useAccount({env}); - - const { - signer, - setAccount, - setSigner, - } = useChatData(); + const { signer, setAccount, setSigner } = useChatData(); const theme = useContext(ThemeContext); - const setUserData = () => { if (wallet) { (async () => { - const ethersProvider = new ethers.providers.Web3Provider(wallet.provider, 'any') - const signer = ethersProvider.getSigner() - const newAdd = await getAddressFromSigner(signer) - setSigner(signer) - setAccount(newAdd); - })() + const ethersProvider = new ethers.providers.Web3Provider(wallet.provider, 'any'); + const signer = ethersProvider.getSigner(); + const newAdd = await getAddressFromSigner(signer); + preInitializeUser(newAdd, signer); + })(); } else if (!wallet) { - setAccount('') - setSigner(undefined) + setAccount(''); + setSigner(undefined); } - } + }; useEffect(() => { - if(wallet && !autoConnect) - disconnect(wallet); - setUserData() - }, [wallet]) + if (wallet && !autoConnect) disconnect(wallet); + setUserData(); + }, [wallet]); return !signer ? ( - + ) : ( <> @@ -64,22 +58,21 @@ export const ConnectButtonSub = ({autoConnect = false}) => { //styles const ConnectButtonDiv = styled.div` width: fit-content; - - button{ + + button { background: ${(props) => `${props.theme.backgroundColor?.buttonBackground}!important`}; color: ${(props) => `${props.theme.textColor?.buttonText}!important`}; - text-align:center; + text-align: center; font-size: 1em; - cursor:pointer; + cursor: pointer; border-radius: 10px; padding: 10px 20px; outline: none; border: none; cursor: pointer; font-weight: 600; - } - button:hover{ + button:hover { scale: 1.05; transition: 0.3s; } @@ -89,4 +82,4 @@ const ConnectButtonDiv = styled.div` body.modal-open { overflow-y: hidden; } -`; \ No newline at end of file +`; diff --git a/packages/uiweb/src/lib/components/chat/CreateGroup/AddCriteria.tsx b/packages/uiweb/src/lib/components/chat/CreateGroup/AddCriteria.tsx index 1c893821f..6f564ec87 100644 --- a/packages/uiweb/src/lib/components/chat/CreateGroup/AddCriteria.tsx +++ b/packages/uiweb/src/lib/components/chat/CreateGroup/AddCriteria.tsx @@ -3,14 +3,7 @@ import { useContext, useEffect, useState } from 'react'; import styled from 'styled-components'; import { MdError } from 'react-icons/md'; -import { - Button, - DropDownInput, - DropdownValueType, - InfoContainer, - ModalHeader, - TextInput, -} from '../reusables'; +import { Button, DropDownInput, DropdownValueType, InfoContainer, ModalHeader, TextInput } from '../reusables'; import { Section, Span, Spinner } from '../../reusables'; import useMediaQuery from '../../../hooks/useMediaQuery'; import { ModalHeaderProps } from './CreateGroupModal'; @@ -39,13 +32,7 @@ import { TypeKeys, ReadonlyInputType, } from '../types'; -import useToast from '../reusables/NewToast'; -import { - CriteriaValidationErrorType, - GuildData, - PushData, - Rule, -} from '../types/tokenGatedGroupCreationType'; +import { CriteriaValidationErrorType, GuildData, PushData, Rule } from '../types/tokenGatedGroupCreationType'; import { checkIfCustomEndpoint, checkIfGuild, @@ -58,18 +45,13 @@ import { validationCriteria, } from '../helpers'; import { IChatTheme } from '../exportedTypes'; +import { CONSTANTS } from '@pushprotocol/restapi'; -const AddCriteria = ({ - handlePrevious, - onClose, - criteriaStateManager, -}: ModalHeaderProps) => { +const AddCriteria = ({ handlePrevious, onClose, criteriaStateManager }: ModalHeaderProps) => { const [selectedTypeValue, setSelectedTypeValue] = useState(0); - const [validationErrors, setValidationErrors] = - useState({}); + const [validationErrors, setValidationErrors] = useState({}); const [selectedCategoryValue, setSelectedCategoryValue] = useState(0); - const [selectedSubCategoryValue, setSelectedSubCategoryValue] = - useState(0); + const [selectedSubCategoryValue, setSelectedSubCategoryValue] = useState(0); const [validationLoading, setValidationLoading] = useState(false); const [guildComparison, setGuildComparison] = useState(''); const [selectedChainValue, setSelectedChainValue] = useState(0); @@ -88,9 +70,9 @@ const AddCriteria = ({ value: 0, range: 0, }); - const { env } = useChatData(); + const { user, toast } = useChatData(); + const env = user ? user.env : CONSTANTS.ENV.PROD; const theme = useContext(ThemeContext); - const groupInfoToast = useToast(); const isMobile = useMediaQuery(device.mobileL); @@ -209,8 +191,7 @@ const AddCriteria = ({ const dropdownChainsValues: Array = [ { id: 0, - value: - BLOCKCHAIN_NETWORK[env as keyof typeof BLOCKCHAIN_NETWORK].ETHEREUM, + value: BLOCKCHAIN_NETWORK[env as keyof typeof BLOCKCHAIN_NETWORK].ETHEREUM, title: 'Ethereum', icon: EthereumSvg, function: () => setSelectedChainValue(0), @@ -231,16 +212,14 @@ const AddCriteria = ({ }, { id: 3, - value: - BLOCKCHAIN_NETWORK[env as keyof typeof BLOCKCHAIN_NETWORK].OPTIMISM, + value: BLOCKCHAIN_NETWORK[env as keyof typeof BLOCKCHAIN_NETWORK].OPTIMISM, title: 'Optimism', icon: OptimismSvg, function: () => setSelectedChainValue(3), }, { id: 4, - value: - BLOCKCHAIN_NETWORK[env as keyof typeof BLOCKCHAIN_NETWORK].ARBITRUM, + value: BLOCKCHAIN_NETWORK[env as keyof typeof BLOCKCHAIN_NETWORK].ARBITRUM, title: 'Arbitrum', icon: ArbitrumSvg, function: () => setSelectedChainValue(4), @@ -252,35 +231,27 @@ const AddCriteria = ({ icon: FuseSvg, function: () => setSelectedChainValue(5), }, - ]; - if(env !== ENV.PROD) - { - - dropdownChainsValues.push( { + if (env !== ENV.PROD) { + dropdownChainsValues.push({ id: 6, value: BLOCKCHAIN_NETWORK[env].BERACHAIN, title: 'Berachain', icon: BerachainSvg, function: () => setSelectedChainValue(6), - } as DropdownValueType) + } as DropdownValueType); } - const onQuantityChange = (e: any) => { setQuantity({ ...quantity, value: e.target.value }); }; const verifyAndDoNext = async () => { setValidationLoading(true); - const _type = dropdownTypeValues[selectedTypeValue].value as - | 'PUSH' - | 'GUILD'; + const _type = dropdownTypeValues[selectedTypeValue].value as 'PUSH' | 'GUILD'; const category: string = _type === 'PUSH' - ? (dropdownCategoryValues[_type] as DropdownValueType[])[ - selectedCategoryValue - ].value || CATEGORY.ERC20 + ? (dropdownCategoryValues[_type] as DropdownValueType[])[selectedCategoryValue].value || CATEGORY.ERC20 : 'ROLES'; let subCategory = 'DEFAULT'; @@ -337,24 +308,18 @@ const AddCriteria = ({ useEffect(() => { if (criteriaState.isUpdateCriteriaEnabled()) { //Load the states - const oldValue = - criteriaState.selectedRules[criteriaState.updateCriteriaIdx]; + const oldValue = criteriaState.selectedRules[criteriaState.updateCriteriaIdx]; if (oldValue.type === 'PUSH') { // category setSelectedCategoryValue( - (dropdownCategoryValues.PUSH as DropdownValueType[]).findIndex( - (obj) => obj.value === oldValue.category - ) + (dropdownCategoryValues.PUSH as DropdownValueType[]).findIndex((obj) => obj.value === oldValue.category) ); const pushData = oldValue.data as PushData; // sub category - if ( - oldValue.category === CATEGORY.ERC20 || - oldValue.category === CATEGORY.ERC721 - ) { + if (oldValue.category === CATEGORY.ERC20 || oldValue.category === CATEGORY.ERC721) { if (pushData.token) { setUnit(pushData.token); } @@ -364,21 +329,14 @@ const AddCriteria = ({ } // TODO: make helper function for this - const contractAndChain: string[] = ( - pushData.contract || 'eip155:1:0x' - ).split(':'); + const contractAndChain: string[] = (pushData.contract || 'eip155:1:0x').split(':'); setSelectedChainValue( - dropdownChainsValues.findIndex( - (obj) => - obj.value === contractAndChain[0] + ':' + contractAndChain[1] - ) + dropdownChainsValues.findIndex((obj) => obj.value === contractAndChain[0] + ':' + contractAndChain[1]) ); setContract(contractAndChain.length === 3 ? contractAndChain[2] : ''); setQuantity({ value: pushData.amount || 0, - range: dropdownQuantityRangeValues.findIndex( - (obj) => obj.value === pushData.comparison - ), + range: dropdownQuantityRangeValues.findIndex((obj) => obj.value === pushData.comparison), }); } else if (oldValue.category === CATEGORY.INVITE) { setInviteCheckboxes({ @@ -393,15 +351,10 @@ const AddCriteria = ({ // guild condition setGuildId((oldValue.data as GuildData).id); setSpecificRoleId((oldValue.data as GuildData).role); - setGuildComparison( - (oldValue.data as GuildData).comparison || - GUILD_COMPARISON_OPTIONS[2].value - ); + setGuildComparison((oldValue.data as GuildData).comparison || GUILD_COMPARISON_OPTIONS[2].value); } - setSelectedTypeValue( - dropdownTypeValues.findIndex((obj) => obj.value === oldValue.type) - ); + setSelectedTypeValue(dropdownTypeValues.findIndex((obj) => obj.value === oldValue.type)); } }, []); @@ -426,11 +379,16 @@ const AddCriteria = ({ }, [contract, selectedCategoryValue, selectedChainValue]); const showError = (errorMessage: string) => { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: errorMessage, toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); }; @@ -448,11 +406,7 @@ const AddCriteria = ({
-
+
{Array.isArray( getCategoryDropdownValues({ dropdownCategoryValues, @@ -564,7 +521,11 @@ const AddCriteria = ({ selectedValue={selectedChainValue} dropdownValues={dropdownChainsValues} /> -
+
- {!!validationErrors?.tokenError && ( - {validationErrors?.tokenError} - )} + {!!validationErrors?.tokenError && {validationErrors?.tokenError}}
-
+
- {!!validationErrors?.tokenAmount && ( - {validationErrors?.tokenAmount} - )} + {!!validationErrors?.tokenAmount && {validationErrors?.tokenAmount}}
)} @@ -599,7 +560,11 @@ const AddCriteria = ({ selectedCategoryValue, selectedTypeValue, }) && ( -
+
- {!!validationErrors?.url && ( - {validationErrors?.url} - )} + {!!validationErrors?.url && {validationErrors?.url}}
)} {checkIfPushInvite({ @@ -618,21 +581,20 @@ const AddCriteria = ({ selectedCategoryValue, selectedTypeValue, }) && ( -
+
{Object.keys(INVITE_CHECKBOX_LABEL).map((key) => ( setInviteCheckboxes({ admin: true, owner: true, }) } - checked={ - inviteCheckboxes[key as keyof typeof INVITE_CHECKBOX_LABEL] - } + checked={inviteCheckboxes[key as keyof typeof INVITE_CHECKBOX_LABEL]} /> ))}
@@ -640,7 +602,11 @@ const AddCriteria = ({ {checkIfGuild(dropdownTypeValues, selectedTypeValue) && ( <> -
+
- {!!validationErrors?.guildId && ( - {validationErrors?.guildId} - )} + {!!validationErrors?.guildId && {validationErrors?.guildId}}
-
+
- {!!validationErrors?.guildComparison && ( - {validationErrors?.guildComparison} - )} + {!!validationErrors?.guildComparison && {validationErrors?.guildComparison}}
{guildComparison === 'specific' && ( -
+
- {!!validationErrors?.guildRole && ( - {validationErrors?.guildRole} - )} + {!!validationErrors?.guildRole && {validationErrors?.guildRole}}
)} )} - { - const groupInfoToast = useToast(); - const { account } = useChatData(); + const { user, toast } = useChatData(); const addMemberToList = async (member: IUser) => { let errorMessage = ''; - if ( - pCAIP10ToWallet(member.wallets.toLowerCase()) === - pCAIP10ToWallet((account?? '').toLowerCase()) - ) - { - errorMessage = 'Group Creator cannot be added as member'; + if (pCAIP10ToWallet(member.wallets.toLowerCase()) === pCAIP10ToWallet((user?.account ?? '').toLowerCase())) { + errorMessage = 'Group Creator cannot be added as member'; + } + if (findObject(member, memberList, 'wallets')) { + errorMessage = 'Address is already added'; } - if(findObject(member, memberList, 'wallets')){ - errorMessage = 'Address is already added'; + if (errorMessage) { + toast.showMessageToast({ + toastTitle: 'Error', + toastMessage: errorMessage, + toastType: 'ERROR', + getToastIcon: (size: number) => ( + + ), + }); + } else { + const updatedMemberList = memberList; + updatedMemberList.push({ ...member, isAdmin: false }); + handleMemberList(updatedMemberList); } - if (errorMessage) { - - groupInfoToast.showMessageToast({ - toastTitle: 'Error', - toastMessage: errorMessage, - toastType: 'ERROR', - getToastIcon: (size) => , - }); - } else { - const updatedMemberList = memberList; - updatedMemberList.push( { ...member, isAdmin: false }) - handleMemberList(updatedMemberList); - } }; return ( @@ -72,4 +69,4 @@ export const AddGroupMembers = ({ handleMemberList={handleMemberList} /> ); -}; \ No newline at end of file +}; diff --git a/packages/uiweb/src/lib/components/chat/CreateGroup/CreateGroupModal.tsx b/packages/uiweb/src/lib/components/chat/CreateGroup/CreateGroupModal.tsx index 4114e71f5..99e39a8fe 100644 --- a/packages/uiweb/src/lib/components/chat/CreateGroup/CreateGroupModal.tsx +++ b/packages/uiweb/src/lib/components/chat/CreateGroup/CreateGroupModal.tsx @@ -1,7 +1,6 @@ import React, { useContext, useEffect, useRef, useState } from 'react'; import styled from 'styled-components'; -import { ToastContainer } from 'react-toastify'; import { AiTwotoneCamera } from 'react-icons/ai'; import { MdCheckCircle, MdError } from 'react-icons/md'; @@ -16,13 +15,10 @@ import useMediaQuery from '../../../hooks/useMediaQuery'; import { DefineCondtion } from './DefineCondition'; import AddCriteria from './AddCriteria'; import { ThemeContext } from '../theme/ThemeProvider'; -import { - CriteriaStateManagerType, - useCriteriaStateManager, -} from '../../../hooks/chat/useCriteriaState'; +import { CriteriaStateManagerType, useCriteriaStateManager } from '../../../hooks/chat/useCriteriaState'; import { AddGroupMembers } from './AddGroupMembers'; import { useCreateGatedGroup } from '../../../hooks/chat/useCreateGatedGroup'; -import useToast from '../reusables/NewToast'; +import { useChatData } from '../../../hooks'; import { Image } from '../../../config/styles'; import { ProfilePicture, device } from '../../../config'; @@ -40,8 +36,7 @@ export const CREATE_GROUP_STEP_KEYS = { ADD_MEMBERS: 5, } as const; -export type CreateGroupStepKeys = - typeof CREATE_GROUP_STEP_KEYS[keyof typeof CREATE_GROUP_STEP_KEYS]; +export type CreateGroupStepKeys = typeof CREATE_GROUP_STEP_KEYS[keyof typeof CREATE_GROUP_STEP_KEYS]; export interface GroupInputDetailsType { groupName: string; @@ -62,7 +57,7 @@ export const CreateGroupModal: React.FC = ({ CREATE_GROUP_STEP_KEYS.INPUT_DETAILS ); const { createGatedGroup, loading } = useCreateGatedGroup(); - const groupInfoToast = useToast(); + const { toast, user } = useChatData(); const handleNext = () => { setActiveComponent((activeComponent + 1) as CreateGroupStepKeys); }; @@ -90,29 +85,30 @@ export const CreateGroupModal: React.FC = ({ const useDummyGroupInfo = false; const [checked, setChecked] = useState(true); - const [groupInputDetails, setGroupInputDetails] = - useState({ - groupName: useDummyGroupInfo ? 'This is duumy group name' : '', - groupDescription: useDummyGroupInfo - ? 'This is dummy group description for testing' - : '', - groupImage: useDummyGroupInfo ? ProfilePicture : '', - groupMembers: [], - groupEncryptionType: GROUP_TYPE_OPTIONS[0].value, - }); + const [groupInputDetails, setGroupInputDetails] = useState({ + groupName: useDummyGroupInfo ? 'This is duumy group name' : '', + groupDescription: useDummyGroupInfo ? 'This is dummy group description for testing' : '', + groupImage: useDummyGroupInfo ? ProfilePicture : '', + groupMembers: [], + groupEncryptionType: GROUP_TYPE_OPTIONS[0].value, + }); const [isImageUploaded, setIsImageUploaded] = useState(false); const showError = (errorMessage: string) => { - groupInfoToast.showMessageToast({ + toast.showMessageToast({ toastTitle: 'Error', toastMessage: errorMessage, toastType: 'ERROR', - getToastIcon: (size) => , + getToastIcon: (size: number) => ( + + ), }); }; const getEncryptionType = () => { - console.debug(groupInputDetails.groupEncryptionType, 'encryptionTypeee'); if (groupInputDetails.groupEncryptionType === 'encrypted') { return false; } @@ -120,34 +116,53 @@ export const CreateGroupModal: React.FC = ({ }; const createGroupService = async () => { - const groupInfo = { - groupName: groupInputDetails.groupName, - groupDescription: groupInputDetails.groupDescription, - groupImage: groupInputDetails.groupImage || ProfilePicture, - isPublic: getEncryptionType(), - members: groupInputDetails.groupMembers - .filter((member: any) => !member.isAdmin) - .map((member: any) => member.wallets), - admins: groupInputDetails.groupMembers - .filter((member: any) => member.isAdmin) - .map((member: any) => member.wallets), - }; - const rules: any = checked ? criteriaStateManager.generateRule() : {}; - const { success: isGroupCreated, data: APIResponse } = - await createGatedGroup(groupInfo, rules); - if (isGroupCreated === true) { - onSuccess && onSuccess(APIResponse); - groupInfoToast.showMessageToast({ - toastTitle: 'Success', - toastMessage: 'Group created successfully', - toastType: 'SUCCESS', - getToastIcon: (size: string | number | undefined) => ( - - ), - }); - onClose(); - } else { - showError('Group creation failed'); + if (user) { + if (user.readmode()) { + console.error('UIWeb::CreateGroupModal::createGroupService::User is in read mode.Switch to write mode'); + toast.showMessageToast({ + toastTitle: 'Error', + toastMessage: 'Unable to create group in readMode. Switch to write mode', + toastType: 'ERROR', + getToastIcon: (size: number) => ( + + ), + }); + } else { + const groupInfo = { + groupName: groupInputDetails.groupName, + groupDescription: groupInputDetails.groupDescription, + groupImage: groupInputDetails.groupImage || ProfilePicture, + isPublic: getEncryptionType(), + members: groupInputDetails.groupMembers + .filter((member: any) => !member.isAdmin) + .map((member: any) => member.wallets), + admins: groupInputDetails.groupMembers + .filter((member: any) => member.isAdmin) + .map((member: any) => member.wallets), + }; + const rules: any = checked ? criteriaStateManager.generateRule() : {}; + const { success: isGroupCreated, data: APIResponse } = await createGatedGroup(groupInfo, rules); + if (isGroupCreated === true) { + onSuccess && onSuccess(APIResponse); + toast.showMessageToast({ + toastTitle: 'Success', + toastMessage: 'Group created successfully', + toastType: 'SUCCESS', + getToastIcon: (size: string | number | undefined) => ( + + ), + }); + onClose(); + } else { + showError('Group creation failed'); + } + } } }; @@ -246,7 +261,7 @@ export const CreateGroupModal: React.FC = ({ modalBackground={modalBackground} modalPositionType={modalPositionType} > - {renderComponent()} + {renderComponent()} ); }; @@ -261,17 +276,13 @@ export interface ModalHeaderProps { handleAddWallets?: () => void; isImageUploaded?: boolean; setIsImageUploaded?: React.Dispatch>; - setGroupInputDetails?: React.Dispatch< - React.SetStateAction - >; + setGroupInputDetails?: React.Dispatch>; groupInputDetails?: GroupInputDetailsType; } interface GroupDetailState { groupInputDetails: GroupInputDetailsType; - setGroupInputDetails: React.Dispatch< - React.SetStateAction - >; + setGroupInputDetails: React.Dispatch>; } export interface GroupTypeState { @@ -288,8 +299,7 @@ const CreateGroupDetail = ({ }: ModalHeaderProps & GroupDetailState) => { const { groupName, groupDescription, groupImage } = groupInputDetails; const theme = useContext(ThemeContext); - const [validationErrors, setValidationErrors] = - useState({}); + const [validationErrors, setValidationErrors] = useState({}); const fileUploadInputRef = useRef(null); const isMobile = useMediaQuery(device.mobileL); const [imageSrc, setImageSrc] = useState(); @@ -331,7 +341,7 @@ const CreateGroupDetail = ({ }); return; } - if (groupName.trim().length <3) { + if (groupName.trim().length < 3) { setValidationErrors({ groupName: 'Group name should have minimum 3 character', }); @@ -345,7 +355,7 @@ const CreateGroupDetail = ({ }); return; } - if (groupDescription.trim().length <3) { + if (groupDescription.trim().length < 3) { setValidationErrors({ groupDescription: 'Group Description should have minimum 3 character', }); @@ -373,7 +383,10 @@ const CreateGroupDetail = ({ justifyContent="start" width={!isMobile ? '400px' : '300px'} > - + {isImageUploaded ? ( groupImage ? ( @@ -401,7 +414,10 @@ const CreateGroupDetail = ({ ) ) : ( - + )} handleChange(e as unknown as Event)} /> -
+
- {!!validationErrors?.groupName && ( - {validationErrors?.groupName} - )} + {!!validationErrors?.groupName && {validationErrors?.groupName}}
-
+