Skip to content
This repository has been archived by the owner on Sep 11, 2024. It is now read-only.

Bi-directional widget postMessaging API (stickerpacks) [WIP] #1672

Merged
merged 177 commits into from
Apr 3, 2018
Merged
Changes from 1 commit
Commits
Show all changes
177 commits
Select commit Hold shift + click to select a range
26c6c25
Add dom-to-image dep.
rxl881 Dec 3, 2017
3a89b90
Add stub handler for image snapshot
rxl881 Dec 3, 2017
c9b8aab
Workings for future posterity - Can't access iframe content from pare…
rxl881 Dec 3, 2017
f410112
Merge branch 'develop' of github.com:matrix-org/matrix-react-sdk into…
rxl881 Dec 15, 2017
c234e20
Add postmessage api and move functions in to class
rxl881 Dec 15, 2017
56f497d
Add comments and outbound postmessage action to request a widget scre…
rxl881 Dec 15, 2017
9f733eb
Fix binding and promise handling
rxl881 Dec 15, 2017
f2ad7be
Add event handlers and comments.
rxl881 Dec 15, 2017
954c6ee
Set correct API name.
rxl881 Dec 15, 2017
e63f569
Screenshot handlers
rxl881 Dec 15, 2017
83f9a41
Request capabilities (e.g. ability to take snapshots) from widgets.
rxl881 Dec 16, 2017
774774c
Remove unused dep.
rxl881 Dec 19, 2017
8e5c3f0
License and linting fixes.
rxl881 Dec 19, 2017
536d4ef
Fix comments.
rxl881 Dec 19, 2017
08bcfc5
Make sure that capabilities array is initialised.
rxl881 Dec 19, 2017
baf472b
Only show snapshot button when apps are maximised.
rxl881 Dec 19, 2017
3724a1a
Bump build
rxl881 Dec 28, 2017
7b59774
Update comment.
rxl881 Dec 28, 2017
7660176
Fix comment linting errors.
rxl881 Dec 28, 2017
a408b98
Set widget ID on WidgetMessaging instance.
rxl881 Dec 29, 2017
e96d199
Inject stickers
rxl881 Jan 4, 2018
b85efa0
Merge branch 'rxl881/snapshot' of github.com:matrix-org/matrix-react-…
rxl881 Jan 4, 2018
eb4053b
Handle sticker message payloads
rxl881 Jan 4, 2018
32aecd0
Fix event call
rxl881 Jan 4, 2018
da199da
Merge branch 'rxl881/snapshot' of https://github.com/matrix-org/matri…
rxl881 Jan 4, 2018
d20aebf
Correctly handle sticker message events.
rxl881 Jan 4, 2018
54671ab
Send m.sticker messages
rxl881 Jan 4, 2018
1c8586e
Add sticker message rendering.
rxl881 Jan 4, 2018
d652f11
Remove click handlers etc.
rxl881 Jan 4, 2018
7b313b7
Comment logging.
rxl881 Jan 4, 2018
d256e47
Fix header and remove unused deps.
rxl881 Jan 4, 2018
5724749
Remove unused deps.
rxl881 Jan 4, 2018
54d1286
Comment logging.
rxl881 Jan 4, 2018
dc14230
De-register listener.
rxl881 Jan 8, 2018
486b2cf
Handle sticker message event.
rxl881 Jan 8, 2018
5df9a01
Use m.room.sticker event.
rxl881 Jan 8, 2018
0577316
Fix duplicate event registration.
rxl881 Jan 8, 2018
adebf71
Set user widgets on application data.
rxl881 Jan 8, 2018
60e7646
Save user widgets in accountData
rxl881 Jan 8, 2018
9e9de76
Handle user widgets.
rxl881 Jan 9, 2018
6b0b25c
Translations
rxl881 Jan 9, 2018
9abb160
Replace apps button with stickers button in message composer.
rxl881 Jan 9, 2018
53b590f
Add stickers popover.
rxl881 Jan 10, 2018
2bb51ba
Content placeholder.
rxl881 Jan 10, 2018
52f28d0
Stickerpack styling
rxl881 Jan 10, 2018
1a994b8
Move widget utility functions in to their own file.
rxl881 Jan 11, 2018
2cf9da8
Load user stickerpacks
rxl881 Jan 11, 2018
78bd25e
Sticker popover styling
rxl881 Jan 11, 2018
d0c16fa
Convert to ES6 class.
rxl881 Jan 11, 2018
4f36709
Bind functions
rxl881 Jan 11, 2018
1ab71f6
Load stickers in AppTile
rxl881 Jan 11, 2018
9df4dae
Used forked version of react-popover
rxl881 Jan 11, 2018
90b7cb3
Consistent popover size
rxl881 Jan 11, 2018
2354361
Add react-popover-tiny
rxl881 Jan 12, 2018
a3c6dd3
Stickers popover.
rxl881 Jan 12, 2018
351bbdf
Styling
rxl881 Jan 15, 2018
0fab905
Cleanup styles.
rxl881 Jan 15, 2018
5e6da4d
* Fix key error
rxl881 Jan 15, 2018
5a9a4ea
Remove arrow opacity.
rxl881 Jan 15, 2018
82b9897
Select apropriate theme colour for popover.
rxl881 Jan 15, 2018
87d8ed5
Add comment
rxl881 Jan 16, 2018
cb7f25f
Remove rubbish lib.
rxl881 Jan 16, 2018
86542d8
Move stickers into stand-alone component.
rxl881 Jan 16, 2018
9339284
Stickerpack content placeholder.
rxl881 Jan 16, 2018
7676fc0
Handle stickerpack close.
rxl881 Jan 16, 2018
38ed01b
Pass room to stickerpack
rxl881 Jan 16, 2018
86da204
Add manage stickerpacks link
rxl881 Jan 16, 2018
614a10c
Add manage integration link.
rxl881 Jan 17, 2018
3331c8a
Use dispatcher ref for unregister call.
rxl881 Jan 17, 2018
5a42712
Keep reference to stickers menu
rxl881 Jan 17, 2018
fa336b7
Bring hide stickers icon to front when menu open.
rxl881 Jan 17, 2018
aa524c3
Update class names.
rxl881 Jan 17, 2018
b6f85fb
Don't treat sticker messages as info messages.
rxl881 Jan 17, 2018
f8d7ab1
Handle non-m.room.message event types.
rxl881 Jan 17, 2018
1293c53
Cleanup
rxl881 Jan 18, 2018
917d85d
Refer rest parameters
rxl881 Jan 18, 2018
910623d
Close context menu on resize.
rxl881 Jan 18, 2018
23bef68
Fix duplicate message listeners
rxl881 Jan 18, 2018
0441487
Manage sticker packs link and add comments
rxl881 Jan 22, 2018
29962ed
Add stickerpack strings.
rxl881 Feb 5, 2018
34de372
Add method to remove all stickerpacks.
rxl881 Feb 5, 2018
992c477
Add button to remove all stickerpacks
rxl881 Feb 5, 2018
e508f06
Add asset add / remove messaging clauses.
rxl881 Feb 5, 2018
393236b
Update / remove stickerpacks
rxl881 Feb 7, 2018
f3943be
Check for empty user widgets.
rxl881 Feb 7, 2018
7b75dbb
Use default AppTile menu bar.
rxl881 Feb 7, 2018
5e30468
Linting
rxl881 Feb 7, 2018
234ca8b
Remove top padding from app tile.
rxl881 Feb 8, 2018
9e3c1fb
Pass room name.
rxl881 Feb 9, 2018
5559341
Hide apps drawer when viewining room settings.
rxl881 Feb 9, 2018
ce560c5
Fix link spacing
rxl881 Feb 22, 2018
9a5c916
Close modal on integration manager launch.
rxl881 Feb 22, 2018
88288ff
Add error handling for failure to connect to integration manager.
rxl881 Feb 23, 2018
fefc325
Remove unused dep.
rxl881 Feb 23, 2018
46f94b3
Ensure that roomId is validated before accessing room-based widgets.
rxl881 Feb 23, 2018
57b027b
Fix API names.
rxl881 Feb 23, 2018
d755b82
Remove logging and cleanup.
rxl881 Feb 23, 2018
9b667f2
Reduce logging.
rxl881 Feb 23, 2018
9ae89e2
Reduce logging.
rxl881 Feb 23, 2018
b2bf4d4
Merge branch 'develop' of https://github.com/matrix-org/matrix-react-…
rxl881 Feb 23, 2018
891199b
Force rebuild
rxl881 Feb 23, 2018
332892f
Pull in changes from develop
rxl881 Feb 23, 2018
86461bc
Disable all widget assets on widget removal.
rxl881 Feb 24, 2018
ee4310c
Avoid potential NPE.
rxl881 Feb 25, 2018
e249e3d
Correct stickerpicker naming,
rxl881 Feb 25, 2018
c93faf7
Fix promise wrapping.
rxl881 Feb 25, 2018
2b0790b
Fix PropTypes.
rxl881 Feb 25, 2018
20a442c
Add comment.
rxl881 Feb 25, 2018
d3de44e
Global interface to start integration manager.
rxl881 Feb 26, 2018
14d52c9
Open integration manager from widget postMessage.
rxl881 Feb 26, 2018
707e3f3
Temp. revert unintended commit.
rxl881 Feb 26, 2018
73c8ef5
Fix current roomID.
rxl881 Feb 26, 2018
b64736a
Add listener to close stickerpicker.
rxl881 Feb 26, 2018
5ca0fc3
Make MStickerBody extend MImageBody.
rxl881 Feb 26, 2018
8e7564b
Wrap the close menu trigger in a timeout
rxl881 Feb 26, 2018
ef4d137
Wrap menu close in timeout to avoid element disappearing unexpectedly.
rxl881 Feb 27, 2018
57c98d9
Update widget type.
rxl881 Feb 27, 2018
0fdbddf
Show sticker description as a tooltip, on hover.
rxl881 Feb 27, 2018
21c8bed
Bump build
rxl881 Feb 28, 2018
f3c928a
Lint.
rxl881 Feb 28, 2018
e2cedbe
Pull in changes from develop
rxl881 Mar 5, 2018
7755a3c
Nest sticker image element for correct positioning of tooltips.
rxl881 Mar 6, 2018
d5465cf
Prefix and clarify global variable naming.
rxl881 Mar 6, 2018
b529edb
Linting
rxl881 Mar 6, 2018
7f91b47
Move sticker picker icon.
rxl881 Mar 7, 2018
b2bb15b
Remove accidentally checked in yarn.lock
rxl881 Mar 7, 2018
c59dd5b
Add placeholders for sticker images (and fancy transitions).
rxl881 Mar 8, 2018
3ab8b1f
Hide sticker picker delete button and show minimise button.
rxl881 Mar 8, 2018
fdec4b3
Hide padding if last control.
rxl881 Mar 8, 2018
e36ae3c
Fix context menu offset.
rxl881 Mar 8, 2018
e7c19fd
Don't render placeholder when image is visible.
rxl881 Mar 8, 2018
a338593
Use getUserWidgets where possible.
rxl881 Mar 9, 2018
7e06209
Cleanup timeout before unmount.
rxl881 Mar 9, 2018
46f46ee
Simplify request mapping.
rxl881 Mar 9, 2018
b2d23b6
Switch to 'm.sticker' message events. Allow whitelisting of wisget ca…
rxl881 Mar 12, 2018
a81269c
Check if user widget.
rxl881 Mar 13, 2018
de33294
Center loading spinner.
rxl881 Mar 13, 2018
53b716b
Throw capability request exception.
rxl881 Mar 13, 2018
f820374
Logging.
rxl881 Mar 13, 2018
7d13edc
Get user widgets by default (if roomID is not specified).
rxl881 Mar 13, 2018
8b311c7
Null guard widget listener
rxl881 Mar 13, 2018
66ea78d
Clean up whitelisted permission addition / logging.
rxl881 Mar 13, 2018
83412ac
Display sticker content (URL), rather than thumbnail.
rxl881 Mar 14, 2018
4d8f507
Allow react performance profiling on widget iframes.
rxl881 Mar 16, 2018
7462812
Bump CI build
rxl881 Mar 22, 2018
4ac9653
Refactor widget postMessage API.
rxl881 Mar 28, 2018
b4e70e3
Expects object, not naked ID.
rxl881 Mar 28, 2018
5fc9b8a
Indentation.
rxl881 Mar 29, 2018
a1581ad
Don't swallow error.
rxl881 Mar 29, 2018
23a52bd
Indentation.
rxl881 Mar 29, 2018
35fcb2c
Catch rather than 'done' error handler.
rxl881 Mar 29, 2018
aefccb1
Ensure deleting is set to false.
rxl881 Mar 29, 2018
cafbd29
Remove unused ref.
rxl881 Mar 29, 2018
f383298
Remove duplicate event handler.
rxl881 Mar 29, 2018
9c10d24
Add comment.
rxl881 Mar 29, 2018
38c8bc7
Consistent function naming.
rxl881 Mar 29, 2018
e21cc14
Comment.
rxl881 Mar 29, 2018
67f755e
Comment.
rxl881 Mar 29, 2018
c8f9586
Check for valid reference.
rxl881 Mar 29, 2018
6181ca6
"Stickerpack" translation.
rxl881 Mar 29, 2018
b1e7dcf
Cleanup / simplify code.
rxl881 Mar 29, 2018
3d9bdb9
Consistent async / await / promises.
rxl881 Mar 29, 2018
5ba18b5
Avoid redefining function parameter
rxl881 Mar 29, 2018
20cbc01
Add callback handler for integration manager close.
rxl881 Mar 29, 2018
9a3f356
Wait for setAccountData to complete.
rxl881 Mar 29, 2018
93804e8
Return promise
rxl881 Mar 29, 2018
2e6d6c8
Add back in body 'ref'
rxl881 Mar 29, 2018
003cf61
Handle remove sticker picker errors.
rxl881 Mar 29, 2018
ff0834a
Add comment.
rxl881 Mar 29, 2018
9cc3d3c
Move default sticker content into generator function.
rxl881 Mar 29, 2018
557a45e
Remove inline styling.
rxl881 Mar 29, 2018
11915b0
Fix user widget event type.
rxl881 Apr 2, 2018
d83b6f1
Use AccessibleButton.
rxl881 Apr 2, 2018
49bea1a
Move stickerpicker content out of state in to generator function.
rxl881 Apr 2, 2018
8241afe
Fix content references
rxl881 Apr 2, 2018
b109c93
Put stickers behind labs flag.
rxl881 Apr 2, 2018
f8f8bc4
Merge branch 'develop' of https://github.com/matrix-org/matrix-react-…
rxl881 Apr 3, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Stickers popover.
rxl881 committed Jan 12, 2018
commit a3c6dd36eff90f386b553af96b45166a30dc3dc6
129 changes: 79 additions & 50 deletions src/components/views/rooms/MessageComposer.js
Original file line number Diff line number Diff line change
@@ -23,7 +23,7 @@ import sdk from '../../../index';
import dis from '../../../dispatcher';
import Autocomplete from './Autocomplete';
import SettingsStore, {SettingLevel} from "../../../settings/SettingsStore";
import Popover from 'react-simple-popover';
import Popover, {ArrowContainer} from 'react-tiny-popover';
import Widgets from '../../../utils/widgets';
import AppTile from '../elements/AppTile';

@@ -266,7 +266,13 @@ export default class MessageComposer extends React.Component {
alt={e2eTitle} title={e2eTitle}
/>,
);
let callButton, videoCallButton, hangupButton, showStickersButton, hideStickersButton;

let callButton;
let videoCallButton;
let hangupButton;
let stickersButton;

// Call buttons
if (this.props.callState && this.props.callState !== 'ended') {
hangupButton =
<div key="controls_hangup" className="mx_MessageComposer_hangup" onClick={this.onHangupClick}>
@@ -284,74 +290,97 @@ export default class MessageComposer extends React.Component {
}

// Stickers
if (this.state.showStickers) {
const popoverWidth = '300px';
const popoverHeight = '300px';
const stickerpackWidget = Widgets.getStickerpackWidgets()[0];
let stickersContent = <p>Click here to add your first sitckerpack</p>;
if (stickerpackWidget && stickerpackWidget.content && stickerpackWidget.content.url) {
stickersContent = <div style={{
const popoverWidth = '300px';
const popoverHeight = '300px';
const stickerpackWidget = Widgets.getStickerpackWidgets()[0];

// Load stickerpack content
if (stickerpackWidget && stickerpackWidget.content && stickerpackWidget.content.url) {
this.state.stickersContent = <div
id='stickersContent'
className='mx_StickersContent'
style={{
border: 'none',
height: popoverHeight,
width: popoverWidth,
}}>
<AppTile
id={stickerpackWidget.id}
url={stickerpackWidget.content.url}
name={stickerpackWidget.content.name}
room={this.props.room}
type={stickerpackWidget.content.type}
fullWidth={true}
userId={stickerpackWidget.sender || MatrixClientPeg.get().credentials.userId}
creatorUserId={MatrixClientPeg.get().credentials.userId}
waitForIframeLoad={true}
show={true}
showMenubar={false}
/>
</div>;
}
}}
>
<AppTile
id={stickerpackWidget.id}
url={stickerpackWidget.content.url}
name={stickerpackWidget.content.name}
room={this.props.room}
type={stickerpackWidget.content.type}
fullWidth={true}
userId={stickerpackWidget.sender || MatrixClientPeg.get().credentials.userId}
creatorUserId={MatrixClientPeg.get().credentials.userId}
waitForIframeLoad={true}
show={true}
showMenubar={false}
/>
</div>;
} else {
// Default content to show if stickerpack widget not added
this.state.stickersContent = <p>Click here to add your first sitckerpack</p>;
}


hideStickersButton =
if (this.state.showStickers) {
// Show hide-stickers button
stickersButton =
<div
id='stickersButton'
key="controls_hide_stickers"
className="mx_MessageComposer_stickers"
onClick={this.onHideStickersClick}
ref='target'
title={_t("Hide Stickers")}>
<TintableSvg src="img/icons-hide-stickers.svg" width="35" height="35" />
<Popover
placement='top'
container={this.refs.messageComposerInput}
target={this.refs.stickersContainer}
show={this.state.showStickers}
onHide={this.onHideStickersClick}
containerStyle={{
zIndex: 1000,
}}
style={{
borderRadius: '5px',
padding: 0,
overflow: 'hidden',
height: popoverHeight,
width: popoverWidth,
}}
children={stickersContent}
/>
</div>;
} else {
showStickersButton =
// Show show-stickers button
stickersButton =
<div
id='stickersButton'
key="constrols_show_stickers"
className="mx_MessageComposer_stickers"
onClick={this.onShowStickersClick}
title={_t("Show Stickers")}>
<TintableSvg src="img/icons-show-stickers.svg" width="35" height="35" />
</div>;
}
const stickersContainer = <div ref='stickersContainer' key='stickers'>
{ showStickersButton }
{ hideStickersButton }
</div>;

const stickers = <Popover
isOpen={this.state.showStickers}
position={'top'}
padding={1}
content={({ position, targetRect, popoverRect }) => (
<ArrowContainer
position={position}
targetRect={targetRect}
popoverRect={popoverRect}
arrowColor={'#76CFA6'}
arrowSize={20}
arrowStyle={{ opacity: 0.7 }}
>
<div
className='mx_PopoverOuterContainer'
style={{
backgroundColor: '#76CFA6', // '#d3efe1',
opacity: 0.7,
overflow: 'hidden',
// border: '1px solid #666',
}}
>
{ this.state.stickersContent }
</div>
</ArrowContainer>
)}
>
<div id='popoverTarget'>
{ stickersButton }
</div>
</Popover>;

const canSendMessages = this.props.room.currentState.maySendMessage(
MatrixClientPeg.get().credentials.userId);
@@ -398,7 +427,7 @@ export default class MessageComposer extends React.Component {
hangupButton,
callButton,
videoCallButton,
stickersContainer,
stickers,
);
} else {
controls.push(