@selfcommunity/react-ui 0.7.0-alpha.6 → 0.7.0-alpha.60

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (392) hide show
  1. package/lib/cjs/components/Categories/Categories.d.ts +1 -1
  2. package/lib/cjs/components/Categories/Categories.d.ts.map +1 -1
  3. package/lib/cjs/components/Categories/Categories.js +16 -6
  4. package/lib/cjs/components/Categories/Categories.js.map +1 -1
  5. package/lib/cjs/components/CategoriesFollowed/CategoriesFollowed.d.ts.map +1 -1
  6. package/lib/cjs/components/CategoriesFollowed/CategoriesFollowed.js +59 -43
  7. package/lib/cjs/components/CategoriesFollowed/CategoriesFollowed.js.map +1 -1
  8. package/lib/cjs/components/CategoriesFollowed/Skeleton.d.ts.map +1 -1
  9. package/lib/cjs/components/CategoriesFollowed/Skeleton.js +3 -1
  10. package/lib/cjs/components/CategoriesFollowed/Skeleton.js.map +1 -1
  11. package/lib/cjs/components/CategoriesPopular/CategoriesPopular.d.ts.map +1 -1
  12. package/lib/cjs/components/CategoriesPopular/CategoriesPopular.js +69 -36
  13. package/lib/cjs/components/CategoriesPopular/CategoriesPopular.js.map +1 -1
  14. package/lib/cjs/components/CategoriesPopular/Skeleton.d.ts.map +1 -1
  15. package/lib/cjs/components/CategoriesPopular/Skeleton.js +3 -1
  16. package/lib/cjs/components/CategoriesPopular/Skeleton.js.map +1 -1
  17. package/lib/cjs/components/CategoriesSuggestion/CategoriesSuggestion.d.ts +6 -0
  18. package/lib/cjs/components/CategoriesSuggestion/CategoriesSuggestion.d.ts.map +1 -1
  19. package/lib/cjs/components/CategoriesSuggestion/CategoriesSuggestion.js +54 -40
  20. package/lib/cjs/components/CategoriesSuggestion/CategoriesSuggestion.js.map +1 -1
  21. package/lib/cjs/components/CategoriesSuggestion/Skeleton.d.ts.map +1 -1
  22. package/lib/cjs/components/CategoriesSuggestion/Skeleton.js +3 -1
  23. package/lib/cjs/components/CategoriesSuggestion/Skeleton.js.map +1 -1
  24. package/lib/cjs/components/Category/Category.d.ts +4 -0
  25. package/lib/cjs/components/Category/Category.d.ts.map +1 -1
  26. package/lib/cjs/components/Category/Category.js +3 -2
  27. package/lib/cjs/components/Category/Category.js.map +1 -1
  28. package/lib/cjs/components/CommentsFeedObject/CommentsFeedObject.js +1 -1
  29. package/lib/cjs/components/CommentsFeedObject/CommentsFeedObject.js.map +1 -1
  30. package/lib/cjs/components/CustomAdv/CustomAdv.d.ts.map +1 -1
  31. package/lib/cjs/components/CustomAdv/CustomAdv.js +30 -2
  32. package/lib/cjs/components/CustomAdv/CustomAdv.js.map +1 -1
  33. package/lib/cjs/components/Editor/Editor.d.ts.map +1 -1
  34. package/lib/cjs/components/Editor/Editor.js +14 -14
  35. package/lib/cjs/components/Editor/Editor.js.map +1 -1
  36. package/lib/cjs/components/Feed/Feed.d.ts +5 -0
  37. package/lib/cjs/components/Feed/Feed.d.ts.map +1 -1
  38. package/lib/cjs/components/Feed/Feed.js +55 -30
  39. package/lib/cjs/components/Feed/Feed.js.map +1 -1
  40. package/lib/cjs/components/FeedObject/Activities/Activities.js +1 -1
  41. package/lib/cjs/components/FeedObject/FeedObject.d.ts +4 -0
  42. package/lib/cjs/components/FeedObject/FeedObject.d.ts.map +1 -1
  43. package/lib/cjs/components/FeedObject/FeedObject.js +11 -8
  44. package/lib/cjs/components/FeedObject/FeedObject.js.map +1 -1
  45. package/lib/cjs/components/Header/Header.d.ts +4 -0
  46. package/lib/cjs/components/Header/Header.d.ts.map +1 -1
  47. package/lib/cjs/components/Header/Header.js +7 -3
  48. package/lib/cjs/components/Header/Header.js.map +1 -1
  49. package/lib/cjs/components/Header/HeaderMenu.d.ts.map +1 -1
  50. package/lib/cjs/components/Header/HeaderMenu.js +3 -0
  51. package/lib/cjs/components/Header/HeaderMenu.js.map +1 -1
  52. package/lib/cjs/components/Header/MobileHeader/MobileHeader.d.ts.map +1 -1
  53. package/lib/cjs/components/Header/MobileHeader/MobileHeader.js +4 -3
  54. package/lib/cjs/components/Header/MobileHeader/MobileHeader.js.map +1 -1
  55. package/lib/cjs/components/Header/SearchBar.d.ts +4 -0
  56. package/lib/cjs/components/Header/SearchBar.d.ts.map +1 -1
  57. package/lib/cjs/components/Header/SearchBar.js +91 -35
  58. package/lib/cjs/components/Header/SearchBar.js.map +1 -1
  59. package/lib/cjs/components/IncubatorSuggestion/IncubatorSuggestion.d.ts +7 -1
  60. package/lib/cjs/components/IncubatorSuggestion/IncubatorSuggestion.d.ts.map +1 -1
  61. package/lib/cjs/components/IncubatorSuggestion/IncubatorSuggestion.js +50 -38
  62. package/lib/cjs/components/IncubatorSuggestion/IncubatorSuggestion.js.map +1 -1
  63. package/lib/cjs/components/IncubatorsList/IncubatorsList.d.ts +7 -1
  64. package/lib/cjs/components/IncubatorsList/IncubatorsList.d.ts.map +1 -1
  65. package/lib/cjs/components/IncubatorsList/IncubatorsList.js +61 -38
  66. package/lib/cjs/components/IncubatorsList/IncubatorsList.js.map +1 -1
  67. package/lib/cjs/components/LoyaltyProgram/Skeleton.d.ts +4 -0
  68. package/lib/cjs/components/LoyaltyProgram/Skeleton.d.ts.map +1 -1
  69. package/lib/cjs/components/LoyaltyProgram/Skeleton.js +40 -5
  70. package/lib/cjs/components/LoyaltyProgram/Skeleton.js.map +1 -1
  71. package/lib/cjs/components/LoyaltyProgramDetail/Skeleton.d.ts +29 -0
  72. package/lib/cjs/components/LoyaltyProgramDetail/Skeleton.d.ts.map +1 -1
  73. package/lib/cjs/components/LoyaltyProgramDetail/Skeleton.js +95 -5
  74. package/lib/cjs/components/LoyaltyProgramDetail/Skeleton.js.map +1 -1
  75. package/lib/cjs/components/MessageEditor/MessageEditor.d.ts +4 -13
  76. package/lib/cjs/components/MessageEditor/MessageEditor.d.ts.map +1 -1
  77. package/lib/cjs/components/MessageEditor/MessageEditor.js +14 -13
  78. package/lib/cjs/components/MessageEditor/MessageEditor.js.map +1 -1
  79. package/lib/cjs/components/Notification/PrivateMessage/PrivateMessage.d.ts.map +1 -1
  80. package/lib/cjs/components/Notification/PrivateMessage/PrivateMessage.js +1 -2
  81. package/lib/cjs/components/Notification/PrivateMessage/PrivateMessage.js.map +1 -1
  82. package/lib/cjs/components/PeopleSuggestion/PeopleSuggestion.d.ts +6 -0
  83. package/lib/cjs/components/PeopleSuggestion/PeopleSuggestion.d.ts.map +1 -1
  84. package/lib/cjs/components/PeopleSuggestion/PeopleSuggestion.js +56 -52
  85. package/lib/cjs/components/PeopleSuggestion/PeopleSuggestion.js.map +1 -1
  86. package/lib/cjs/components/Platform/Platform.d.ts +2 -1
  87. package/lib/cjs/components/Platform/Platform.d.ts.map +1 -1
  88. package/lib/cjs/components/Platform/Platform.js +1 -1
  89. package/lib/cjs/components/Platform/Platform.js.map +1 -1
  90. package/lib/cjs/components/PollSuggestion/PollSuggestion.d.ts +7 -1
  91. package/lib/cjs/components/PollSuggestion/PollSuggestion.d.ts.map +1 -1
  92. package/lib/cjs/components/PollSuggestion/PollSuggestion.js +49 -37
  93. package/lib/cjs/components/PollSuggestion/PollSuggestion.js.map +1 -1
  94. package/lib/cjs/components/RelatedFeedObjects/RelatedFeedObjects.d.ts +7 -1
  95. package/lib/cjs/components/RelatedFeedObjects/RelatedFeedObjects.d.ts.map +1 -1
  96. package/lib/cjs/components/RelatedFeedObjects/RelatedFeedObjects.js +71 -40
  97. package/lib/cjs/components/RelatedFeedObjects/RelatedFeedObjects.js.map +1 -1
  98. package/lib/cjs/components/Snippets/Snippets.js +1 -1
  99. package/lib/cjs/components/Snippets/Snippets.js.map +1 -1
  100. package/lib/cjs/components/Thread/Thread.d.ts.map +1 -1
  101. package/lib/cjs/components/Thread/Thread.js +5 -21
  102. package/lib/cjs/components/Thread/Thread.js.map +1 -1
  103. package/lib/cjs/components/TrendingFeed/TrendingFeed.d.ts +12 -1
  104. package/lib/cjs/components/TrendingFeed/TrendingFeed.d.ts.map +1 -1
  105. package/lib/cjs/components/TrendingFeed/TrendingFeed.js +66 -35
  106. package/lib/cjs/components/TrendingFeed/TrendingFeed.js.map +1 -1
  107. package/lib/cjs/components/TrendingPeople/TrendingPeople.d.ts +6 -0
  108. package/lib/cjs/components/TrendingPeople/TrendingPeople.d.ts.map +1 -1
  109. package/lib/cjs/components/TrendingPeople/TrendingPeople.js +68 -39
  110. package/lib/cjs/components/TrendingPeople/TrendingPeople.js.map +1 -1
  111. package/lib/cjs/components/User/User.d.ts +4 -0
  112. package/lib/cjs/components/User/User.d.ts.map +1 -1
  113. package/lib/cjs/components/User/User.js +4 -4
  114. package/lib/cjs/components/User/User.js.map +1 -1
  115. package/lib/cjs/components/UserFollowers/UserFollowers.d.ts +6 -0
  116. package/lib/cjs/components/UserFollowers/UserFollowers.d.ts.map +1 -1
  117. package/lib/cjs/components/UserFollowers/UserFollowers.js +66 -43
  118. package/lib/cjs/components/UserFollowers/UserFollowers.js.map +1 -1
  119. package/lib/cjs/components/UserProfileEdit/Section/Account.d.ts +28 -0
  120. package/lib/cjs/components/UserProfileEdit/Section/Account.d.ts.map +1 -0
  121. package/lib/cjs/components/UserProfileEdit/Section/Account.js +118 -0
  122. package/lib/cjs/components/UserProfileEdit/Section/Account.js.map +1 -0
  123. package/lib/cjs/components/UserProfileEdit/Section/AccountCredentials.d.ts +18 -0
  124. package/lib/cjs/components/UserProfileEdit/Section/AccountCredentials.d.ts.map +1 -0
  125. package/lib/cjs/components/UserProfileEdit/Section/AccountCredentials.js +260 -0
  126. package/lib/cjs/components/UserProfileEdit/Section/AccountCredentials.js.map +1 -0
  127. package/lib/cjs/components/UserProfileEdit/Section/PublicInfo.d.ts +1 -1
  128. package/lib/cjs/components/UserProfileEdit/Section/PublicInfo.d.ts.map +1 -1
  129. package/lib/cjs/components/UserProfileEdit/Section/PublicInfo.js +17 -8
  130. package/lib/cjs/components/UserProfileEdit/Section/PublicInfo.js.map +1 -1
  131. package/lib/cjs/components/UserProfileEdit/UserProfileEdit.d.ts +6 -0
  132. package/lib/cjs/components/UserProfileEdit/UserProfileEdit.d.ts.map +1 -1
  133. package/lib/cjs/components/UserProfileEdit/UserProfileEdit.js +8 -1
  134. package/lib/cjs/components/UserProfileEdit/UserProfileEdit.js.map +1 -1
  135. package/lib/cjs/components/UserProfileEdit/index.d.ts +2 -1
  136. package/lib/cjs/components/UserProfileEdit/index.d.ts.map +1 -1
  137. package/lib/cjs/components/UserProfileEdit/index.js +3 -1
  138. package/lib/cjs/components/UserProfileEdit/index.js.map +1 -1
  139. package/lib/cjs/components/UserProfileInfo/UserProfileInfo.d.ts.map +1 -1
  140. package/lib/cjs/components/UserProfileInfo/UserProfileInfo.js +56 -2
  141. package/lib/cjs/components/UserProfileInfo/UserProfileInfo.js.map +1 -1
  142. package/lib/cjs/components/UserSocialAssociation/UserSocialAssociation.d.ts +70 -0
  143. package/lib/cjs/components/UserSocialAssociation/UserSocialAssociation.d.ts.map +1 -0
  144. package/lib/cjs/components/UserSocialAssociation/UserSocialAssociation.js +160 -0
  145. package/lib/cjs/components/UserSocialAssociation/UserSocialAssociation.js.map +1 -0
  146. package/lib/cjs/components/UserSocialAssociation/index.d.ts +4 -0
  147. package/lib/cjs/components/UserSocialAssociation/index.d.ts.map +1 -0
  148. package/lib/cjs/components/UserSocialAssociation/index.js +8 -0
  149. package/lib/cjs/components/UserSocialAssociation/index.js.map +1 -0
  150. package/lib/cjs/components/UsersFollowed/UsersFollowed.d.ts +6 -0
  151. package/lib/cjs/components/UsersFollowed/UsersFollowed.d.ts.map +1 -1
  152. package/lib/cjs/components/UsersFollowed/UsersFollowed.js +66 -47
  153. package/lib/cjs/components/UsersFollowed/UsersFollowed.js.map +1 -1
  154. package/lib/cjs/constants/Pagination.d.ts +1 -1
  155. package/lib/cjs/constants/Pagination.d.ts.map +1 -1
  156. package/lib/cjs/constants/Pagination.js +1 -1
  157. package/lib/cjs/constants/Pagination.js.map +1 -1
  158. package/lib/cjs/index.d.ts +9 -3
  159. package/lib/cjs/index.d.ts.map +1 -1
  160. package/lib/cjs/index.js +16 -2
  161. package/lib/cjs/index.js.map +1 -1
  162. package/lib/cjs/shared/InfiniteScroll/index.js +1 -1
  163. package/lib/cjs/shared/InfiniteScroll/index.js.map +1 -1
  164. package/lib/cjs/shared/MetadataField/MetadataField.d.ts.map +1 -1
  165. package/lib/cjs/shared/MetadataField/MetadataField.js +6 -17
  166. package/lib/cjs/shared/MetadataField/MetadataField.js.map +1 -1
  167. package/lib/cjs/shared/PasswordTextField/index.d.ts.map +1 -1
  168. package/lib/cjs/shared/PasswordTextField/index.js +5 -2
  169. package/lib/cjs/shared/PasswordTextField/index.js.map +1 -1
  170. package/lib/cjs/shared/Tags/index.d.ts.map +1 -1
  171. package/lib/cjs/shared/Tags/index.js +10 -7
  172. package/lib/cjs/shared/Tags/index.js.map +1 -1
  173. package/lib/cjs/types/headerMenuUrls.d.ts +4 -0
  174. package/lib/cjs/types/headerMenuUrls.d.ts.map +1 -1
  175. package/lib/cjs/types/index.d.ts +2 -2
  176. package/lib/cjs/types/index.d.ts.map +1 -1
  177. package/lib/cjs/types/index.js +2 -1
  178. package/lib/cjs/types/index.js.map +1 -1
  179. package/lib/cjs/types/user.d.ts +11 -1
  180. package/lib/cjs/types/user.d.ts.map +1 -1
  181. package/lib/cjs/types/user.js +12 -1
  182. package/lib/cjs/types/user.js.map +1 -1
  183. package/lib/cjs/utils/contribution.d.ts +6 -0
  184. package/lib/cjs/utils/contribution.d.ts.map +1 -1
  185. package/lib/cjs/utils/contribution.js +16 -1
  186. package/lib/cjs/utils/contribution.js.map +1 -1
  187. package/lib/cjs/utils/highlight.d.ts +2 -0
  188. package/lib/cjs/utils/highlight.d.ts.map +1 -0
  189. package/lib/cjs/utils/highlight.js +15 -0
  190. package/lib/cjs/utils/highlight.js.map +1 -0
  191. package/lib/cjs/utils/tools.d.ts +29 -0
  192. package/lib/cjs/utils/tools.d.ts.map +1 -0
  193. package/lib/cjs/utils/tools.js +81 -0
  194. package/lib/cjs/utils/tools.js.map +1 -0
  195. package/lib/esm/components/Categories/Categories.d.ts +1 -1
  196. package/lib/esm/components/Categories/Categories.d.ts.map +1 -1
  197. package/lib/esm/components/Categories/Categories.js +16 -6
  198. package/lib/esm/components/Categories/Categories.js.map +1 -1
  199. package/lib/esm/components/CategoriesFollowed/CategoriesFollowed.d.ts.map +1 -1
  200. package/lib/esm/components/CategoriesFollowed/CategoriesFollowed.js +64 -48
  201. package/lib/esm/components/CategoriesFollowed/CategoriesFollowed.js.map +1 -1
  202. package/lib/esm/components/CategoriesFollowed/Skeleton.d.ts.map +1 -1
  203. package/lib/esm/components/CategoriesFollowed/Skeleton.js +3 -1
  204. package/lib/esm/components/CategoriesFollowed/Skeleton.js.map +1 -1
  205. package/lib/esm/components/CategoriesPopular/CategoriesPopular.d.ts.map +1 -1
  206. package/lib/esm/components/CategoriesPopular/CategoriesPopular.js +72 -39
  207. package/lib/esm/components/CategoriesPopular/CategoriesPopular.js.map +1 -1
  208. package/lib/esm/components/CategoriesPopular/Skeleton.d.ts.map +1 -1
  209. package/lib/esm/components/CategoriesPopular/Skeleton.js +3 -1
  210. package/lib/esm/components/CategoriesPopular/Skeleton.js.map +1 -1
  211. package/lib/esm/components/CategoriesSuggestion/CategoriesSuggestion.d.ts +6 -0
  212. package/lib/esm/components/CategoriesSuggestion/CategoriesSuggestion.d.ts.map +1 -1
  213. package/lib/esm/components/CategoriesSuggestion/CategoriesSuggestion.js +58 -44
  214. package/lib/esm/components/CategoriesSuggestion/CategoriesSuggestion.js.map +1 -1
  215. package/lib/esm/components/CategoriesSuggestion/Skeleton.d.ts.map +1 -1
  216. package/lib/esm/components/CategoriesSuggestion/Skeleton.js +3 -1
  217. package/lib/esm/components/CategoriesSuggestion/Skeleton.js.map +1 -1
  218. package/lib/esm/components/Category/Category.d.ts +4 -0
  219. package/lib/esm/components/Category/Category.d.ts.map +1 -1
  220. package/lib/esm/components/Category/Category.js +3 -2
  221. package/lib/esm/components/Category/Category.js.map +1 -1
  222. package/lib/esm/components/CommentsFeedObject/CommentsFeedObject.js +1 -1
  223. package/lib/esm/components/CommentsFeedObject/CommentsFeedObject.js.map +1 -1
  224. package/lib/esm/components/CustomAdv/CustomAdv.d.ts.map +1 -1
  225. package/lib/esm/components/CustomAdv/CustomAdv.js +7 -2
  226. package/lib/esm/components/CustomAdv/CustomAdv.js.map +1 -1
  227. package/lib/esm/components/Editor/Editor.d.ts.map +1 -1
  228. package/lib/esm/components/Editor/Editor.js +14 -14
  229. package/lib/esm/components/Editor/Editor.js.map +1 -1
  230. package/lib/esm/components/Feed/Feed.d.ts +5 -0
  231. package/lib/esm/components/Feed/Feed.d.ts.map +1 -1
  232. package/lib/esm/components/Feed/Feed.js +56 -31
  233. package/lib/esm/components/Feed/Feed.js.map +1 -1
  234. package/lib/esm/components/FeedObject/Activities/Activities.js +1 -1
  235. package/lib/esm/components/FeedObject/FeedObject.d.ts +4 -0
  236. package/lib/esm/components/FeedObject/FeedObject.d.ts.map +1 -1
  237. package/lib/esm/components/FeedObject/FeedObject.js +12 -9
  238. package/lib/esm/components/FeedObject/FeedObject.js.map +1 -1
  239. package/lib/esm/components/Header/Header.d.ts +4 -0
  240. package/lib/esm/components/Header/Header.d.ts.map +1 -1
  241. package/lib/esm/components/Header/Header.js +7 -3
  242. package/lib/esm/components/Header/Header.js.map +1 -1
  243. package/lib/esm/components/Header/HeaderMenu.d.ts.map +1 -1
  244. package/lib/esm/components/Header/HeaderMenu.js +3 -0
  245. package/lib/esm/components/Header/HeaderMenu.js.map +1 -1
  246. package/lib/esm/components/Header/MobileHeader/MobileHeader.d.ts.map +1 -1
  247. package/lib/esm/components/Header/MobileHeader/MobileHeader.js +4 -3
  248. package/lib/esm/components/Header/MobileHeader/MobileHeader.js.map +1 -1
  249. package/lib/esm/components/Header/SearchBar.d.ts +4 -0
  250. package/lib/esm/components/Header/SearchBar.d.ts.map +1 -1
  251. package/lib/esm/components/Header/SearchBar.js +94 -38
  252. package/lib/esm/components/Header/SearchBar.js.map +1 -1
  253. package/lib/esm/components/IncubatorSuggestion/IncubatorSuggestion.d.ts +7 -1
  254. package/lib/esm/components/IncubatorSuggestion/IncubatorSuggestion.d.ts.map +1 -1
  255. package/lib/esm/components/IncubatorSuggestion/IncubatorSuggestion.js +53 -41
  256. package/lib/esm/components/IncubatorSuggestion/IncubatorSuggestion.js.map +1 -1
  257. package/lib/esm/components/IncubatorsList/IncubatorsList.d.ts +7 -1
  258. package/lib/esm/components/IncubatorsList/IncubatorsList.d.ts.map +1 -1
  259. package/lib/esm/components/IncubatorsList/IncubatorsList.js +63 -40
  260. package/lib/esm/components/IncubatorsList/IncubatorsList.js.map +1 -1
  261. package/lib/esm/components/LoyaltyProgram/Skeleton.d.ts +4 -0
  262. package/lib/esm/components/LoyaltyProgram/Skeleton.d.ts.map +1 -1
  263. package/lib/esm/components/LoyaltyProgram/Skeleton.js +40 -5
  264. package/lib/esm/components/LoyaltyProgram/Skeleton.js.map +1 -1
  265. package/lib/esm/components/LoyaltyProgramDetail/Skeleton.d.ts +29 -0
  266. package/lib/esm/components/LoyaltyProgramDetail/Skeleton.d.ts.map +1 -1
  267. package/lib/esm/components/LoyaltyProgramDetail/Skeleton.js +93 -5
  268. package/lib/esm/components/LoyaltyProgramDetail/Skeleton.js.map +1 -1
  269. package/lib/esm/components/MessageEditor/MessageEditor.d.ts +4 -13
  270. package/lib/esm/components/MessageEditor/MessageEditor.d.ts.map +1 -1
  271. package/lib/esm/components/MessageEditor/MessageEditor.js +15 -14
  272. package/lib/esm/components/MessageEditor/MessageEditor.js.map +1 -1
  273. package/lib/esm/components/Notification/PrivateMessage/PrivateMessage.d.ts.map +1 -1
  274. package/lib/esm/components/Notification/PrivateMessage/PrivateMessage.js +1 -2
  275. package/lib/esm/components/Notification/PrivateMessage/PrivateMessage.js.map +1 -1
  276. package/lib/esm/components/PeopleSuggestion/PeopleSuggestion.d.ts +6 -0
  277. package/lib/esm/components/PeopleSuggestion/PeopleSuggestion.d.ts.map +1 -1
  278. package/lib/esm/components/PeopleSuggestion/PeopleSuggestion.js +58 -54
  279. package/lib/esm/components/PeopleSuggestion/PeopleSuggestion.js.map +1 -1
  280. package/lib/esm/components/Platform/Platform.d.ts +2 -1
  281. package/lib/esm/components/Platform/Platform.d.ts.map +1 -1
  282. package/lib/esm/components/Platform/Platform.js +1 -1
  283. package/lib/esm/components/Platform/Platform.js.map +1 -1
  284. package/lib/esm/components/PollSuggestion/PollSuggestion.d.ts +7 -1
  285. package/lib/esm/components/PollSuggestion/PollSuggestion.d.ts.map +1 -1
  286. package/lib/esm/components/PollSuggestion/PollSuggestion.js +52 -40
  287. package/lib/esm/components/PollSuggestion/PollSuggestion.js.map +1 -1
  288. package/lib/esm/components/RelatedFeedObjects/RelatedFeedObjects.d.ts +7 -1
  289. package/lib/esm/components/RelatedFeedObjects/RelatedFeedObjects.d.ts.map +1 -1
  290. package/lib/esm/components/RelatedFeedObjects/RelatedFeedObjects.js +74 -43
  291. package/lib/esm/components/RelatedFeedObjects/RelatedFeedObjects.js.map +1 -1
  292. package/lib/esm/components/Snippets/Snippets.js +1 -1
  293. package/lib/esm/components/Snippets/Snippets.js.map +1 -1
  294. package/lib/esm/components/Thread/Thread.d.ts.map +1 -1
  295. package/lib/esm/components/Thread/Thread.js +5 -21
  296. package/lib/esm/components/Thread/Thread.js.map +1 -1
  297. package/lib/esm/components/TrendingFeed/TrendingFeed.d.ts +12 -1
  298. package/lib/esm/components/TrendingFeed/TrendingFeed.d.ts.map +1 -1
  299. package/lib/esm/components/TrendingFeed/TrendingFeed.js +69 -38
  300. package/lib/esm/components/TrendingFeed/TrendingFeed.js.map +1 -1
  301. package/lib/esm/components/TrendingPeople/TrendingPeople.d.ts +6 -0
  302. package/lib/esm/components/TrendingPeople/TrendingPeople.d.ts.map +1 -1
  303. package/lib/esm/components/TrendingPeople/TrendingPeople.js +70 -41
  304. package/lib/esm/components/TrendingPeople/TrendingPeople.js.map +1 -1
  305. package/lib/esm/components/User/User.d.ts +4 -0
  306. package/lib/esm/components/User/User.d.ts.map +1 -1
  307. package/lib/esm/components/User/User.js +4 -4
  308. package/lib/esm/components/User/User.js.map +1 -1
  309. package/lib/esm/components/UserFollowers/UserFollowers.d.ts +6 -0
  310. package/lib/esm/components/UserFollowers/UserFollowers.d.ts.map +1 -1
  311. package/lib/esm/components/UserFollowers/UserFollowers.js +69 -46
  312. package/lib/esm/components/UserFollowers/UserFollowers.js.map +1 -1
  313. package/lib/esm/components/UserProfileEdit/Section/Account.d.ts +28 -0
  314. package/lib/esm/components/UserProfileEdit/Section/Account.d.ts.map +1 -0
  315. package/lib/esm/components/UserProfileEdit/Section/Account.js +89 -0
  316. package/lib/esm/components/UserProfileEdit/Section/Account.js.map +1 -0
  317. package/lib/esm/components/UserProfileEdit/Section/AccountCredentials.d.ts +18 -0
  318. package/lib/esm/components/UserProfileEdit/Section/AccountCredentials.d.ts.map +1 -0
  319. package/lib/esm/components/UserProfileEdit/Section/AccountCredentials.js +231 -0
  320. package/lib/esm/components/UserProfileEdit/Section/AccountCredentials.js.map +1 -0
  321. package/lib/esm/components/UserProfileEdit/Section/PublicInfo.d.ts +1 -1
  322. package/lib/esm/components/UserProfileEdit/Section/PublicInfo.d.ts.map +1 -1
  323. package/lib/esm/components/UserProfileEdit/Section/PublicInfo.js +18 -9
  324. package/lib/esm/components/UserProfileEdit/Section/PublicInfo.js.map +1 -1
  325. package/lib/esm/components/UserProfileEdit/UserProfileEdit.d.ts +6 -0
  326. package/lib/esm/components/UserProfileEdit/UserProfileEdit.d.ts.map +1 -1
  327. package/lib/esm/components/UserProfileEdit/UserProfileEdit.js +8 -1
  328. package/lib/esm/components/UserProfileEdit/UserProfileEdit.js.map +1 -1
  329. package/lib/esm/components/UserProfileEdit/index.d.ts +2 -1
  330. package/lib/esm/components/UserProfileEdit/index.d.ts.map +1 -1
  331. package/lib/esm/components/UserProfileEdit/index.js +2 -1
  332. package/lib/esm/components/UserProfileEdit/index.js.map +1 -1
  333. package/lib/esm/components/UserProfileInfo/UserProfileInfo.d.ts.map +1 -1
  334. package/lib/esm/components/UserProfileInfo/UserProfileInfo.js +60 -6
  335. package/lib/esm/components/UserProfileInfo/UserProfileInfo.js.map +1 -1
  336. package/lib/esm/components/UserSocialAssociation/UserSocialAssociation.d.ts +70 -0
  337. package/lib/esm/components/UserSocialAssociation/UserSocialAssociation.d.ts.map +1 -0
  338. package/lib/esm/components/UserSocialAssociation/UserSocialAssociation.js +131 -0
  339. package/lib/esm/components/UserSocialAssociation/UserSocialAssociation.js.map +1 -0
  340. package/lib/esm/components/UserSocialAssociation/index.d.ts +4 -0
  341. package/lib/esm/components/UserSocialAssociation/index.d.ts.map +1 -0
  342. package/lib/esm/components/UserSocialAssociation/index.js +3 -0
  343. package/lib/esm/components/UserSocialAssociation/index.js.map +1 -0
  344. package/lib/esm/components/UsersFollowed/UsersFollowed.d.ts +6 -0
  345. package/lib/esm/components/UsersFollowed/UsersFollowed.d.ts.map +1 -1
  346. package/lib/esm/components/UsersFollowed/UsersFollowed.js +69 -50
  347. package/lib/esm/components/UsersFollowed/UsersFollowed.js.map +1 -1
  348. package/lib/esm/constants/Pagination.d.ts +1 -1
  349. package/lib/esm/constants/Pagination.d.ts.map +1 -1
  350. package/lib/esm/constants/Pagination.js +1 -1
  351. package/lib/esm/constants/Pagination.js.map +1 -1
  352. package/lib/esm/index.d.ts +9 -3
  353. package/lib/esm/index.d.ts.map +1 -1
  354. package/lib/esm/index.js +12 -6
  355. package/lib/esm/index.js.map +1 -1
  356. package/lib/esm/shared/InfiniteScroll/index.js +1 -1
  357. package/lib/esm/shared/InfiniteScroll/index.js.map +1 -1
  358. package/lib/esm/shared/MetadataField/MetadataField.d.ts.map +1 -1
  359. package/lib/esm/shared/MetadataField/MetadataField.js +6 -17
  360. package/lib/esm/shared/MetadataField/MetadataField.js.map +1 -1
  361. package/lib/esm/shared/PasswordTextField/index.d.ts.map +1 -1
  362. package/lib/esm/shared/PasswordTextField/index.js +5 -2
  363. package/lib/esm/shared/PasswordTextField/index.js.map +1 -1
  364. package/lib/esm/shared/Tags/index.d.ts.map +1 -1
  365. package/lib/esm/shared/Tags/index.js +10 -7
  366. package/lib/esm/shared/Tags/index.js.map +1 -1
  367. package/lib/esm/types/headerMenuUrls.d.ts +4 -0
  368. package/lib/esm/types/headerMenuUrls.d.ts.map +1 -1
  369. package/lib/esm/types/index.d.ts +2 -2
  370. package/lib/esm/types/index.d.ts.map +1 -1
  371. package/lib/esm/types/index.js +2 -2
  372. package/lib/esm/types/index.js.map +1 -1
  373. package/lib/esm/types/user.d.ts +11 -1
  374. package/lib/esm/types/user.d.ts.map +1 -1
  375. package/lib/esm/types/user.js +11 -0
  376. package/lib/esm/types/user.js.map +1 -1
  377. package/lib/esm/utils/contribution.d.ts +6 -0
  378. package/lib/esm/utils/contribution.d.ts.map +1 -1
  379. package/lib/esm/utils/contribution.js +14 -0
  380. package/lib/esm/utils/contribution.js.map +1 -1
  381. package/lib/esm/utils/highlight.d.ts +2 -0
  382. package/lib/esm/utils/highlight.d.ts.map +1 -0
  383. package/lib/esm/utils/highlight.js +8 -0
  384. package/lib/esm/utils/highlight.js.map +1 -0
  385. package/lib/esm/utils/tools.d.ts +29 -0
  386. package/lib/esm/utils/tools.d.ts.map +1 -0
  387. package/lib/esm/utils/tools.js +76 -0
  388. package/lib/esm/utils/tools.js.map +1 -0
  389. package/lib/umd/react-ui.js +11 -11
  390. package/lib/umd/react-ui.js.LICENSE.txt +11 -3
  391. package/lib/umd/react-ui.js.map +1 -1
  392. package/package.json +16 -16
@@ -1,11 +1,12 @@
1
- import React, { useContext, useEffect, useState } from 'react';
1
+ import React, { useContext, useEffect, useMemo, useReducer, useState } from 'react';
2
2
  import { styled } from '@mui/material/styles';
3
3
  import List from '@mui/material/List';
4
4
  import { Button, CardContent, ListItem, Typography, useMediaQuery, useTheme } from '@mui/material';
5
5
  import Widget from '../Widget';
6
6
  import { http, Endpoints } from '@selfcommunity/api-services';
7
- import { Logger } from '@selfcommunity/utils';
8
- import { SCPreferences, SCPreferencesContext, SCUserContext, useIsComponentMountedRef } from '@selfcommunity/react-core';
7
+ import { CacheStrategies, Logger } from '@selfcommunity/utils';
8
+ import { SCCache, SCPreferences, SCPreferencesContext, SCUserContext, useIsComponentMountedRef } from '@selfcommunity/react-core';
9
+ import { actionToolsTypes, dataToolsReducer, stateToolsInitializer } from '../../utils/tools';
9
10
  import Skeleton from './Skeleton';
10
11
  import User from '../User';
11
12
  import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
@@ -87,63 +88,82 @@ export default function UserFollowers(inProps) {
87
88
  props: inProps,
88
89
  name: PREFIX
89
90
  });
90
- const { userId, autoHide, className, UserProps = {} } = props;
91
+ const { userId, autoHide, className, UserProps = {}, cacheStrategy = CacheStrategies.NETWORK_ONLY, onHeightChange, onStateChange } = props;
91
92
  // REFS
92
93
  const isMountedRef = useIsComponentMountedRef();
93
94
  // STATE
94
95
  const theme = useTheme();
95
96
  const isMobile = useMediaQuery(theme.breakpoints.down('md'));
96
- const [followers, setFollowers] = useState([]);
97
- const [visibleUsers, setVisibleUsers] = useState(limit);
98
- const [loading, setLoading] = useState(true);
99
- const [hasMore, setHasMore] = useState(false);
100
- const [total, setTotal] = useState(0);
97
+ const [state, dispatch] = useReducer(dataToolsReducer, {
98
+ isLoadingNext: true,
99
+ next: `${Endpoints.UserFollowers.url({ id: userId })}?limit=10`,
100
+ cacheKey: SCCache.getToolsStateCacheKey(SCCache.USER_FOLLOWERS_TOOLS_STATE_CACHE_PREFIX_KEY, userId),
101
+ cacheStrategy
102
+ }, stateToolsInitializer);
101
103
  const [openUserFollowersDialog, setOpenUserFollowersDialog] = useState(false);
102
- const [next, setNext] = useState(`${Endpoints.UserFollowers.url({ id: userId })}?limit=10`);
104
+ // CONST
105
+ const authUserId = scUserContext.user ? scUserContext.user.id : null;
103
106
  /**
104
107
  * Fetches the list of users followers
105
108
  */
106
- function fetchFollowers() {
107
- if (next) {
108
- http
109
- .request({
110
- url: next,
111
- method: Endpoints.UserFollowers.method
112
- })
109
+ const fetchFollowers = useMemo(() => () => {
110
+ return http.request({
111
+ url: state.next,
112
+ method: Endpoints.UserFollowers.method
113
+ });
114
+ }, [dispatch, state.next, state.isLoadingNext]);
115
+ useEffect(() => {
116
+ if (!userId) {
117
+ return;
118
+ }
119
+ else if (!contentAvailability && !authUserId) {
120
+ return;
121
+ }
122
+ else if (cacheStrategy === CacheStrategies.NETWORK_ONLY) {
123
+ onStateChange && onStateChange({ cacheStrategy: CacheStrategies.CACHE_FIRST });
124
+ }
125
+ }, [authUserId]);
126
+ /**
127
+ * On mount, fetches the list of users followers
128
+ */
129
+ useEffect(() => {
130
+ let ignore = false;
131
+ if (state.next) {
132
+ fetchFollowers()
113
133
  .then((res) => {
114
- if (isMountedRef.current) {
134
+ if (res.status < 300 && isMountedRef.current && !ignore) {
115
135
  const data = res.data;
116
- setFollowers([...followers, ...data.results]);
117
- setHasMore(data.count > visibleUsers);
118
- setNext(data['next']);
119
- setLoading(false);
120
- setTotal(data.count);
136
+ dispatch({
137
+ type: actionToolsTypes.LOAD_NEXT_SUCCESS,
138
+ payload: {
139
+ results: data.results,
140
+ count: data.count,
141
+ next: data.next
142
+ }
143
+ });
121
144
  }
122
145
  })
123
146
  .catch((error) => {
124
- setLoading(false);
147
+ dispatch({ type: actionToolsTypes.LOAD_NEXT_FAILURE, payload: { errorLoadNext: error } });
125
148
  Logger.error(SCOPE_SC_UI, error);
126
149
  });
150
+ return () => {
151
+ ignore = true;
152
+ };
127
153
  }
128
- }
154
+ }, [state.next]);
129
155
  /**
130
- * On mount, fetches the list of users followers
156
+ * Virtual feed update
131
157
  */
132
158
  useEffect(() => {
133
- if (!contentAvailability && !scUserContext.user) {
134
- return;
135
- }
136
- if (!userId) {
137
- return;
138
- }
139
- fetchFollowers();
140
- }, [scUserContext.user]);
159
+ onHeightChange && onHeightChange();
160
+ }, [state.results.length]);
141
161
  /**
142
162
  * Handles followers counter update on follow/unfollow action.
143
163
  * @param user
144
164
  */
145
165
  function handleFollowersUpdate(user) {
146
- const newUsers = [...followers];
166
+ const newUsers = [...state.results];
147
167
  const index = newUsers.findIndex((u) => u.id === user.id);
148
168
  if (index !== -1) {
149
169
  if (user.connection_status === 'followed') {
@@ -154,41 +174,44 @@ export default function UserFollowers(inProps) {
154
174
  newUsers[index].followers_counter = user.followers_counter + 1;
155
175
  newUsers[index].connection_status = 'followed';
156
176
  }
157
- setFollowers(newUsers);
177
+ dispatch({
178
+ type: actionToolsTypes.SET_RESULTS,
179
+ payload: { results: newUsers }
180
+ });
158
181
  }
159
182
  }
160
183
  /**
161
184
  * Renders the list of users followers
162
185
  */
163
- if (loading) {
164
- React.createElement(Skeleton, null);
186
+ if (state.isLoadingNext) {
187
+ return React.createElement(Skeleton, null);
165
188
  }
166
189
  const u = (React.createElement(CardContent, null,
167
- React.createElement(Typography, { className: classes.title, variant: "h5" }, `${intl.formatMessage(messages.title, { total: total })}`),
168
- !total ? (React.createElement(Typography, { className: classes.noResults, variant: "body2" }, `${intl.formatMessage(messages.noFollowers)}`)) : (React.createElement(React.Fragment, null,
169
- React.createElement(List, null, followers.slice(0, visibleUsers).map((user) => (React.createElement(ListItem, { key: user.id },
190
+ React.createElement(Typography, { className: classes.title, variant: "h5" }, `${intl.formatMessage(messages.title, { total: state.count })}`),
191
+ !state.count ? (React.createElement(Typography, { className: classes.noResults, variant: "body2" }, `${intl.formatMessage(messages.noFollowers)}`)) : (React.createElement(React.Fragment, null,
192
+ React.createElement(List, null, state.results.slice(0, limit).map((user) => (React.createElement(ListItem, { key: user.id },
170
193
  React.createElement(User, Object.assign({ elevation: 0, user: user, className: classes.followersItem }, (followEnabled
171
194
  ? { followConnectUserButtonProps: { onFollow: handleFollowersUpdate } }
172
195
  : { followConnectUserButtonProps: { onChangeConnectionStatus: handleFollowersUpdate } }), UserProps)))))),
173
- hasMore && (React.createElement(Button, { size: "small", className: classes.showMore, onClick: () => setOpenUserFollowersDialog(true) },
196
+ limit < state.count && (React.createElement(Button, { size: "small", className: classes.showMore, onClick: () => setOpenUserFollowersDialog(true) },
174
197
  React.createElement(FormattedMessage, { id: "ui.userFollowers.button.showAll", defaultMessage: "ui.userFollowers.button.showAll" }))),
175
- openUserFollowersDialog && (React.createElement(BaseDialog, { title: isMobile ? (React.createElement(FormattedMessage, { id: "ui.userFollowers.modal.title", defaultMessage: "ui.userFollowers.modal.title" })) : (`${intl.formatMessage(messages.title, { total: total })}`), onClose: () => setOpenUserFollowersDialog(false), open: openUserFollowersDialog }, loading ? (React.createElement(CentralProgress, { size: 50 })) : (React.createElement(InfiniteScroll, { dataLength: followers.length, next: fetchFollowers, hasMoreNext: Boolean(next), loaderNext: React.createElement(CentralProgress, { size: 30 }), height: isMobile ? '100vh' : 400, endMessage: React.createElement("p", { style: { textAlign: 'center' } },
198
+ openUserFollowersDialog && (React.createElement(BaseDialog, { title: isMobile ? (React.createElement(FormattedMessage, { id: "ui.userFollowers.modal.title", defaultMessage: "ui.userFollowers.modal.title" })) : (`${intl.formatMessage(messages.title, { total: state.count })}`), onClose: () => setOpenUserFollowersDialog(false), open: openUserFollowersDialog }, state.isLoadingNext ? (React.createElement(CentralProgress, { size: 50 })) : (React.createElement(InfiniteScroll, { dataLength: state.results.length, next: fetchFollowers, hasMoreNext: Boolean(state.next), loaderNext: React.createElement(CentralProgress, { size: 30 }), height: isMobile ? '100vh' : 400, endMessage: React.createElement("p", { style: { textAlign: 'center' } },
176
199
  React.createElement("b", null,
177
200
  React.createElement(FormattedMessage, { id: "ui.userFollowers.noMoreResults", defaultMessage: "ui.userFollowers.noMoreResults" }))) },
178
- React.createElement(List, null, followers.map((f) => (React.createElement(ListItem, { key: f.id },
201
+ React.createElement(List, null, state.results.map((f) => (React.createElement(ListItem, { key: f.id },
179
202
  React.createElement(User, Object.assign({ elevation: 0, user: f, className: classes.followersItem }, (followEnabled
180
203
  ? { followConnectUserButtonProps: { onFollow: handleFollowersUpdate } }
181
204
  : { followConnectUserButtonProps: { onChangeConnectionStatus: handleFollowersUpdate } }), UserProps))))))))))))));
182
205
  /**
183
206
  * if there are no results and autoHide prop is set to true ,component is hidden
184
207
  */
185
- if (autoHide && !total) {
208
+ if (autoHide && !state.count) {
186
209
  return React.createElement(HiddenPlaceholder, null);
187
210
  }
188
211
  /**
189
212
  * If content availability community option is false and user is anonymous , component is hidden.
190
213
  */
191
- if (!contentAvailability && !scUserContext.user) {
214
+ if (!contentAvailability && !authUserId) {
192
215
  return React.createElement(HiddenPlaceholder, null);
193
216
  }
194
217
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"UserFollowers.js","sourceRoot":"","sources":["../../../../src/components/UserFollowers/UserFollowers.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"UserFollowers.js","sourceRoot":"","sources":["../../../../src/components/UserFollowers/UserFollowers.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ export interface AccountProps {
2
+ /**
3
+ * Overrides or extends the styles applied to the component.
4
+ * @default null
5
+ */
6
+ className?: string;
7
+ /**
8
+ * Handles create association callback
9
+ * @param provider
10
+ */
11
+ handleAssociationCreate?: (provider: any) => void;
12
+ /**
13
+ * If true, shows email and password section
14
+ * @default false
15
+ */
16
+ showCredentialsSection?: boolean;
17
+ /**
18
+ * If true, shows social account section
19
+ *@default true
20
+ */
21
+ showSocialAccountSection?: boolean;
22
+ /**
23
+ * Any other properties
24
+ */
25
+ [p: string]: any;
26
+ }
27
+ export default function Account(inProps: AccountProps): JSX.Element;
28
+ //# sourceMappingURL=Account.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Account.d.ts","sourceRoot":"","sources":["../../../../../src/components/UserProfileEdit/Section/Account.tsx"],"names":[],"mappings":"AAwCA,MAAM,WAAW,YAAY;IAC3B;;;OAGG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;;OAGG;IACH,uBAAuB,CAAC,EAAE,CAAC,QAAQ,KAAA,KAAK,IAAI,CAAC;IAC7C;;;OAGG;IACH,sBAAsB,CAAC,EAAE,OAAO,CAAC;IACjC;;;OAGG;IACH,wBAAwB,CAAC,EAAE,OAAO,CAAC;IACnC;;OAEG;IACH,CAAC,CAAC,EAAE,MAAM,GAAG,GAAG,CAAC;CAClB;AACD,MAAM,CAAC,OAAO,UAAU,OAAO,CAAC,OAAO,EAAE,YAAY,GAAG,GAAG,CAAC,OAAO,CAwElE"}
@@ -0,0 +1,89 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React, { useState } from 'react';
13
+ import { styled } from '@mui/material/styles';
14
+ import { Box, Typography } from '@mui/material';
15
+ import classNames from 'classnames';
16
+ import { useThemeProps } from '@mui/system';
17
+ import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
18
+ import ConfirmDialog from '../../../shared/ConfirmDialog/ConfirmDialog';
19
+ import UserSocialAssociation from '../../UserSocialAssociation';
20
+ import { UserService } from '@selfcommunity/api-services';
21
+ import { SCOPE_SC_UI } from '../../../constants/Errors';
22
+ import { Logger } from '@selfcommunity/utils';
23
+ import { useSCUser } from '@selfcommunity/react-core';
24
+ import AccountCredentials from './AccountCredentials';
25
+ const messages = defineMessages({
26
+ socialTitle: {
27
+ id: 'ui.userProfileEditAccount.socialAssociations.title',
28
+ defaultMessage: 'ui.userProfileEditAccount.socialAssociations.title'
29
+ },
30
+ dialogTitleMsg: {
31
+ id: 'ui.userProfileEditAccount.socialAssociations.dialog.msg',
32
+ defaultMessage: 'ui.userProfileEditAccount.socialAssociations.dialog.msg'
33
+ },
34
+ deleteDialogMsg: {
35
+ id: 'ui.userProfileEditAccount.socialAssociations.dialog.msg',
36
+ defaultMessage: 'ui.userProfileEditAccount.socialAssociations.dialog.msg'
37
+ }
38
+ });
39
+ const PREFIX = 'SCUserProfileEditSectionAccount';
40
+ const classes = {
41
+ root: `${PREFIX}-root`
42
+ };
43
+ const Root = styled(Box, {
44
+ name: PREFIX,
45
+ slot: 'Root',
46
+ overridesResolver: (props, styles) => styles.root
47
+ })(({ theme }) => ({}));
48
+ export default function Account(inProps) {
49
+ // PROPS
50
+ const props = useThemeProps({
51
+ props: inProps,
52
+ name: PREFIX
53
+ });
54
+ // CONTEXT
55
+ const scUserContext = useSCUser();
56
+ const { className = null, handleAssociationCreate, showSocialAccountSection = true, showCredentialsSection = false } = props, rest = __rest(props, ["className", "handleAssociationCreate", "showSocialAccountSection", "showCredentialsSection"]);
57
+ // STATE
58
+ const [provider, setProvider] = useState(null);
59
+ const [openDeleteDialog, setOpenDeleteDialog] = useState(false);
60
+ const [shouldUpdate, setShouldUpdate] = useState(false);
61
+ // INTL
62
+ const intl = useIntl();
63
+ function handleDelete() {
64
+ const data = { user_id: scUserContext.user.id, provider: provider.provider, ext_id: provider.ext_id };
65
+ UserService.deleteProviderAssociation(data)
66
+ .then(() => {
67
+ setShouldUpdate(true);
68
+ setOpenDeleteDialog(false);
69
+ })
70
+ .catch((error) => {
71
+ console.log(error);
72
+ Logger.error(SCOPE_SC_UI, error);
73
+ });
74
+ }
75
+ const handleOpenDeleteDialog = (p) => {
76
+ setOpenDeleteDialog(true);
77
+ setProvider(p);
78
+ };
79
+ if (!scUserContext.user) {
80
+ return;
81
+ }
82
+ return (React.createElement(Root, Object.assign({ className: classNames(classes.root, className) }, rest),
83
+ showCredentialsSection && React.createElement(AccountCredentials, { user: scUserContext === null || scUserContext === void 0 ? void 0 : scUserContext.user }),
84
+ showSocialAccountSection && (React.createElement(UserSocialAssociation, { children: React.createElement(Typography, { variant: "body1", mb: 1, sx: { fontWeight: 'bold' } },
85
+ ' ',
86
+ intl.formatMessage(messages.socialTitle)), direction: "row", userId: scUserContext.user.id, onDeleteAssociation: handleOpenDeleteDialog, onCreateAssociation: handleAssociationCreate, deletingProvider: shouldUpdate ? provider : null })),
87
+ openDeleteDialog && (React.createElement(ConfirmDialog, { open: openDeleteDialog, title: intl.formatMessage(messages.dialogTitleMsg, { field: provider.provider }), btnConfirm: React.createElement(FormattedMessage, { id: "ui.userProfileEditAccount.socialAssociations.dialog.confirm", defaultMessage: "ui.userProfileEditAccount.socialAssociations.dialog.confirm" }), onConfirm: handleDelete, onClose: () => setOpenDeleteDialog(false) }))));
88
+ }
89
+ //# sourceMappingURL=Account.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Account.js","sourceRoot":"","sources":["../../../../../src/components/UserProfileEdit/Section/Account.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { SCUserType } from '@selfcommunity/types';
2
+ export interface AccountCredentialProps {
3
+ /**
4
+ * The user obj
5
+ */
6
+ user?: SCUserType;
7
+ /**
8
+ * Overrides or extends the styles applied to the component.
9
+ * @default null
10
+ */
11
+ className?: string;
12
+ /**
13
+ * Any other properties
14
+ */
15
+ [p: string]: any;
16
+ }
17
+ export default function AccountCredentials(inProps: AccountCredentialProps): JSX.Element;
18
+ //# sourceMappingURL=AccountCredentials.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AccountCredentials.d.ts","sourceRoot":"","sources":["../../../../../src/components/UserProfileEdit/Section/AccountCredentials.tsx"],"names":[],"mappings":"AAYA,OAAO,EAAwB,UAAU,EAAC,MAAM,sBAAsB,CAAC;AA6DvE,MAAM,WAAW,sBAAsB;IACrC;;OAEG;IACH,IAAI,CAAC,EAAE,UAAU,CAAC;IAClB;;;OAGG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;OAEG;IACH,CAAC,CAAC,EAAE,MAAM,GAAG,GAAG,CAAC;CAClB;AACD,MAAM,CAAC,OAAO,UAAU,kBAAkB,CAAC,OAAO,EAAE,sBAAsB,GAAG,GAAG,CAAC,OAAO,CA4RvF"}
@@ -0,0 +1,231 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React, { useState } from 'react';
13
+ import { styled } from '@mui/material/styles';
14
+ import { Box, Button, CircularProgress, FormGroup, IconButton, InputAdornment, Popover, Typography } from '@mui/material';
15
+ import classNames from 'classnames';
16
+ import { useThemeProps } from '@mui/system';
17
+ import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
18
+ import { formatHttpError, UserService } from '@selfcommunity/api-services';
19
+ import { SCOPE_SC_UI } from '../../../constants/Errors';
20
+ import { Logger } from '@selfcommunity/utils';
21
+ import BaseDialog from '../../../shared/BaseDialog';
22
+ import PasswordTextField from '../../../shared/PasswordTextField';
23
+ import EmailTextField from '../../../shared/EmailTextField';
24
+ import { LoadingButton } from '@mui/lab';
25
+ import Icon from '@mui/material/Icon';
26
+ import { useSnackbar } from 'notistack';
27
+ const messages = defineMessages({
28
+ changePasswordTitle: {
29
+ id: 'ui.userProfileEditAccountCredentials.changePassword',
30
+ defaultMessage: 'ui.userProfileEditAccountCredentials.changePassword'
31
+ },
32
+ confirmPasswordError: {
33
+ id: 'ui.userProfileEditAccountCredentials.confirmPassword.error',
34
+ defaultMessage: 'ui.userProfileEditAccountCredentials.confirmPassword.error'
35
+ },
36
+ emptyEmailError: {
37
+ id: 'ui.userProfileEditAccountCredentials.email.empty.error',
38
+ defaultMessage: 'ui.userProfileEditAccountCredentials.email.empty.error'
39
+ }
40
+ });
41
+ const PREFIX = 'SCAccountCredential';
42
+ const DIALOG_PREFIX = `${PREFIX}-password-dialog`;
43
+ const classes = {
44
+ root: `${PREFIX}-root`,
45
+ email: `${PREFIX}-email`,
46
+ success: `${PREFIX}-success`,
47
+ error: `${PREFIX}-error`,
48
+ form: `${DIALOG_PREFIX}-password-form`,
49
+ formField: `${DIALOG_PREFIX}-form-field`,
50
+ password: `${DIALOG_PREFIX}-password`,
51
+ confirmChangeButton: `${DIALOG_PREFIX}-confirm-change-button`
52
+ };
53
+ const Root = styled(Box, {
54
+ name: PREFIX,
55
+ slot: 'Root',
56
+ overridesResolver: (props, styles) => styles.root
57
+ })(({ theme }) => ({
58
+ [`& .${classes.email}, .${classes.password}`]: {
59
+ margin: theme.spacing(1, 0, 1, 0),
60
+ fontWeight: 'bold'
61
+ }
62
+ }));
63
+ const PasswordDialog = styled(BaseDialog, {
64
+ name: DIALOG_PREFIX,
65
+ slot: 'Root',
66
+ overridesResolver: (props, styles) => styles.root
67
+ })(({ theme }) => ({
68
+ '& .MuiDialogContent-root': {
69
+ [`& .${classes.form}`]: {
70
+ [`& .${classes.formField}`]: {
71
+ margin: theme.spacing(1, 1, 1, 0)
72
+ }
73
+ }
74
+ },
75
+ [`& .${classes.confirmChangeButton}`]: {
76
+ marginTop: theme.spacing(1)
77
+ }
78
+ }));
79
+ export default function AccountCredentials(inProps) {
80
+ var _a;
81
+ // PROPS
82
+ const props = useThemeProps({
83
+ props: inProps,
84
+ name: PREFIX
85
+ });
86
+ // CONTEXT
87
+ const { className = null, user } = props, rest = __rest(props, ["className", "user"]);
88
+ // STATE
89
+ const [openChangePasswordDialog, setOpenChangePasswordDialog] = useState(false);
90
+ const initialFieldState = {
91
+ email: (_a = user === null || user === void 0 ? void 0 : user.email) !== null && _a !== void 0 ? _a : '',
92
+ password: '',
93
+ newPassword: '',
94
+ confirmPassword: ''
95
+ };
96
+ const initialErrorState = {
97
+ email: '',
98
+ password: '',
99
+ newPassword: '',
100
+ confirmPassword: ''
101
+ };
102
+ const [field, setField] = useState(initialFieldState);
103
+ const [error, setError] = useState(initialErrorState);
104
+ const [isEditing, setIsEditing] = useState(false);
105
+ const [isSubmittingPassword, setIsSubmittingPassword] = useState(false);
106
+ const [isSubmitting, setIsSubmitting] = useState(false);
107
+ const [anchorEl, setAnchorEl] = useState(null);
108
+ const open = Boolean(anchorEl);
109
+ const { enqueueSnackbar, closeSnackbar } = useSnackbar();
110
+ // INTL
111
+ const intl = useIntl();
112
+ // HANDLERS
113
+ const handlePopoverOpen = (event) => {
114
+ setAnchorEl(event.currentTarget);
115
+ };
116
+ const handlePopoverClose = () => {
117
+ setAnchorEl(null);
118
+ };
119
+ const handleChange = (event) => {
120
+ const { name, value } = event.target;
121
+ setField((prev) => (Object.assign(Object.assign({}, prev), { [name]: value })));
122
+ if (!value) {
123
+ setError((prev) => (Object.assign(Object.assign({}, prev), { [name]: value })));
124
+ }
125
+ };
126
+ const handleEmailBlur = (e) => {
127
+ if (!e.target.value) {
128
+ setField((prev) => (Object.assign(Object.assign({}, prev), { ['email']: user === null || user === void 0 ? void 0 : user.email })));
129
+ setIsEditing(false);
130
+ }
131
+ };
132
+ const validateInput = () => {
133
+ if (field.newPassword !== field.confirmPassword) {
134
+ setError((prev) => (Object.assign(Object.assign({}, prev), { ['confirmPassword']: intl.formatMessage(messages.confirmPasswordError) })));
135
+ }
136
+ };
137
+ const handleCloseDialog = () => {
138
+ setOpenChangePasswordDialog(false);
139
+ setField(initialFieldState);
140
+ setError(initialErrorState);
141
+ };
142
+ const handleSubmitPassword = (event) => {
143
+ event.preventDefault();
144
+ event.stopPropagation();
145
+ setIsSubmittingPassword(true);
146
+ UserService.changeUserPassword(user === null || user === void 0 ? void 0 : user.id, field.password, field.newPassword)
147
+ .then(() => {
148
+ setIsSubmittingPassword(false);
149
+ handleCloseDialog();
150
+ })
151
+ .catch((error) => {
152
+ setIsSubmittingPassword(false);
153
+ const _error = formatHttpError(error);
154
+ Logger.error(SCOPE_SC_UI, error);
155
+ if (_error.passwordError) {
156
+ setError((prev) => (Object.assign(Object.assign({}, prev), { ['password']: _error.passwordError.error })));
157
+ }
158
+ if (_error.newPasswordError) {
159
+ setError((prev) => (Object.assign(Object.assign({}, prev), { ['newPassword']: _error.newPasswordError.error })));
160
+ }
161
+ });
162
+ };
163
+ const handleSubmitEmail = (e) => {
164
+ e.preventDefault();
165
+ e.stopPropagation();
166
+ setIsSubmitting(true);
167
+ UserService.changeUserMail(user === null || user === void 0 ? void 0 : user.id, field.email, true)
168
+ .then((res) => {
169
+ handleVerifyEmail(res.validation_code);
170
+ })
171
+ .catch((error) => {
172
+ setIsSubmitting(false);
173
+ const _error = formatHttpError(error);
174
+ setError((prev) => (Object.assign(Object.assign({}, prev), { ['email']: _error.error })));
175
+ });
176
+ };
177
+ const handleVerifyEmail = (code) => {
178
+ UserService.confirmChangeUserMail(user === null || user === void 0 ? void 0 : user.id, field.email, code)
179
+ .then(() => {
180
+ setIsEditing(false);
181
+ setIsSubmitting(false);
182
+ enqueueSnackbar(React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.email.success", defaultMessage: "ui.userProfileEditAccountCredentials.email.success" }), {
183
+ variant: 'success',
184
+ autoHideDuration: 1500
185
+ });
186
+ })
187
+ .catch((error) => {
188
+ const _error = formatHttpError(error);
189
+ setError((prev) => (Object.assign(Object.assign({}, prev), { ['email']: _error.error })));
190
+ setIsSubmitting(false);
191
+ });
192
+ };
193
+ if (!user) {
194
+ return;
195
+ }
196
+ return (React.createElement(Root, Object.assign({ className: classNames(classes.root, className) }, rest),
197
+ React.createElement(React.Fragment, null,
198
+ React.createElement(Typography, { variant: "body1", className: classes.email },
199
+ React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.email", defaultMessage: "ui.userProfileEditAccountCredentials.email" })),
200
+ React.createElement(React.Fragment, null, isSubmitting ? (React.createElement(CircularProgress, null)) : (React.createElement(React.Fragment, null,
201
+ React.createElement(EmailTextField, { name: "email", disabled: !isEditing || isSubmitting, size: "small", value: field.email, onChange: handleChange, onBlur: handleEmailBlur, error: Boolean(error.email), helperText: error.email, InputProps: {
202
+ endAdornment: (React.createElement(InputAdornment, { position: "end" }, !isEditing ? (React.createElement(IconButton, { onClick: () => setIsEditing(true), edge: "end" },
203
+ React.createElement(Icon, null, "edit"))) : error.email ? (React.createElement(Icon, { color: "error" }, "error")) : (React.createElement(IconButton, { onClick: handleSubmitEmail, edge: "end", color: "primary", disabled: !field.email },
204
+ React.createElement(Icon, null, "check")))))
205
+ } })))),
206
+ React.createElement(Typography, { variant: "body1", className: classes.password },
207
+ React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.passwordLabel", defaultMessage: "ui.userProfileEditAccountCredentials.passwordLabel" })),
208
+ React.createElement(Button, { size: "small", variant: "outlined", onClick: () => setOpenChangePasswordDialog(true), sx: { mb: 1 } },
209
+ React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.changePassword", defaultMessage: "ui.userProfileEditAccountCredentials.changePassword" }))),
210
+ openChangePasswordDialog && (React.createElement(PasswordDialog, Object.assign({ title: intl.formatMessage(messages.changePasswordTitle), open: openChangePasswordDialog, onClose: handleCloseDialog }, rest),
211
+ React.createElement(FormGroup, { className: classes.form },
212
+ React.createElement(PasswordTextField, { className: classes.formField, name: "password", disabled: isSubmittingPassword, label: React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.password", defaultMessage: "ui.userProfileEditAccountCredentials.password" }), size: "medium", value: field.password, onChange: handleChange, error: Boolean(error.password), helperText: error.password }),
213
+ React.createElement(PasswordTextField, { name: "newPassword", className: classes.formField, disabled: isSubmittingPassword, label: React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.newPassword", defaultMessage: "ui.userProfileEditAccountCredentials.newPassword" }), size: "medium", value: field.newPassword, onChange: handleChange, error: Boolean(error.newPassword), helperText: error.newPassword, InputProps: {
214
+ endAdornment: (React.createElement(InputAdornment, { position: "end" },
215
+ React.createElement(IconButton, { "aria-label": "info", onClick: handlePopoverOpen, edge: "end" }, React.createElement(Icon, null, "info"))))
216
+ } }),
217
+ React.createElement(Popover, { open: open, anchorEl: anchorEl, anchorOrigin: {
218
+ vertical: 'center',
219
+ horizontal: 'left'
220
+ }, transformOrigin: {
221
+ vertical: 'center',
222
+ horizontal: 'right'
223
+ }, onClose: handlePopoverClose },
224
+ React.createElement(Box, { sx: { p: '10px' } },
225
+ React.createElement(Typography, { component: 'span', sx: { whiteSpace: 'pre-line' } },
226
+ React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.newPassword.info", defaultMessage: "ui.userProfileEditAccountCredentials.newPassword.info" })))),
227
+ React.createElement(PasswordTextField, { name: "confirmPassword", className: classes.formField, disabled: isSubmittingPassword, label: React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.confirmPassword", defaultMessage: "ui.userProfileEditAccountCredentials.confirmPassword" }), size: "medium", value: field.confirmPassword, onChange: handleChange, onBlur: validateInput, error: Boolean(error.confirmPassword), helperText: error.confirmPassword })),
228
+ React.createElement(LoadingButton, { className: classes.confirmChangeButton, loading: isSubmittingPassword, disabled: !field.confirmPassword || Boolean(error.password) || Boolean(error.newPassword), variant: "contained", onClick: handleSubmitPassword },
229
+ React.createElement(FormattedMessage, { id: "ui.userProfileEditAccountCredentials.changePassword", defaultMessage: "ui.userProfileEditAccountCredentials.changePassword" }))))));
230
+ }
231
+ //# sourceMappingURL=AccountCredentials.js.map