jiti-meet/modules/UI/side_pannels
virtuacoplenny 28013f6ffa ref(avatars): remove Avatar.js (#2289)
* ref(avatars): remove Avatar.js

- Rely on redux getting updated with new participant state
and any calls to getAvatarURL passing in the redux
participant state. This way the state within Avatar.js can
be removed.
- Clean up methods on UI.js. Because all state is in the
store, separate methods for updating the avatar aren't as
necessary. Instead centralize accessing of the avatar for
components outside of redux and centralize the call to
update avatars for non-react components.
- Controversial: cache a participant's avatarURL on the
participant state. Currently the participant's avatarURL
that is generated without jwt (which sets the avatarURL directly)
is not cached. Without cache, there can be many redundant
calls to APP.API.notifyAvatarChanged.

* Leverage middleware timing to diff avatars

One alternative implementation is to leverage middleware's
ability to intercept updates before and after redux has
upated and then compare avatarURLs.

* kill UI.getAvatarUrl

* profile button sets its own avatar url (solves update timing)

* remove calls to updating avatar outside of middleware

* update UI.js doc

* remove left over logic from initial implementation

* try to move local user fallback into selector func

* default to id 'local' in selector
2017-12-19 17:11:54 -06:00
..
chat ref(deps): remove jquery-ui 2017-11-17 16:49:10 -06:00
contactlist feat(eslint): Enable for non react files 2017-10-16 14:36:29 -05:00
profile ref(avatars): remove Avatar.js (#2289) 2017-12-19 17:11:54 -06:00
settings ref(settings): convert panel to react 2017-12-04 16:19:18 -06:00
SideContainerToggler.js feat(eslint): Enable for non react files 2017-10-16 14:36:29 -05:00
SidePanels.js feat(eslint): Enable for non react files 2017-10-16 14:36:29 -05:00