Commit Graph

1009 Commits (9441fa98fd55793a15663638ff25e76f12eedf5c)
 

Author SHA1 Message Date
lilia f1309b71c1 Don't scale or compress gifs
If a gif is too large, it's too large.

Fixes #196
11 years ago
lilia 8e54aa1401 Plumb contact avatars into conversations 11 years ago
lilia 019a9d1fbc Unread counts
Update unreadCounts per-conversation on incoming messages. Render unread
conversations with font-weigh: bold in the inbox view.

To ensure that the inbox and conversation views remain in sync, the
background page now ensures that the same models objects are used for
both views.
11 years ago
lilia b9969b14b6 Always reconnect the socket except when there is an error
Turns out we can get ABNORMAL_CODE (1006) for disconnects where (for
instance) we pause the background page too long. However, in these cases
there is no preceeding ErrorEvent. In contrast, when we have bad
authentication credentials, there is an ErrorEvent. Thus, this change
ensures that we only reconnect if there was no Error.
11 years ago
lilia 5becd80fe9 Show an error if a conversation window fails to init
I saw this happen once. Seems to be a race condition.
11 years ago
lilia 0cbad730ce Don't send keepalive if socket has closed
Also shorten the timeout to see if it improves websocket connection
reliability.
11 years ago
lilia 2b073f3365 Reset keepalive timer if we're about to send
No sense in sending more keepalives than necessary.
11 years ago
lilia ed707db4ba Support :emoji_name: syntax for emoji text input 11 years ago
lilia 01092075ac Add js-emoji as a component 11 years ago
lilia 254131488e Render emoji in conversation and inbox views. 11 years ago
lilia 99d599e008 Add twemoji as a component 11 years ago
lilia 7e5e558ad5 Bump keepalive to 60s 11 years ago
James Firth cd91a47a3a Updated Registration Instructions
Documents the changes made in commit
8ee282b1aa
11 years ago
lilia c73f4d71a7 DRY up scrollable pattern
Switch to using gutter class instead of id since there is potentially
more than one usage on the page.
11 years ago
lilia a72ea7966d Clean up inbox/compose view rendering and swapping
Templatize the inbox view and use the same pattern for in-window view
switching as is now used with the conversation/message detail views.
This means doing more with markup and less jquery manipulation of
individual subelements of the inbox view.
11 years ago
lilia fd6e2954f7 Curtail over-zealous websocket reconnects
Closes #173

Previously, in the event of a failed websocket auth, we would attempt to
reconnect once a second ad infinitum. This changeset ensures that we
only reconnect automatically if the socket closed 'normally' as
indicated by the code on the socket's CloseEvent. Otherwise, show a
'Websocket closed' error on the inbox view.

Ideally we would show a more contextual error (ie, 'Unauthorized'), but
unfortunately the actual server response code is not available to our
code. It can be observed in the console output from the background page,
but programmatically, we only receive the WebSocket CloseEvent codes
listed here:
https://developer.mozilla.org/en-US/docs/Web/API/CloseEvent#Status_codes

The websocket error message is displayed by a normally-hidden but ever
present socket status element. Clicking this element will immediately
refresh the background page, which will try again to open the websocket
connection.
11 years ago
lilia 1321a90667 Rename Whisper.View#attributes
Avoid colliding with Backbone.View attributes, which is a list of attrs
to set on the html element for a view.
11 years ago
lilia dc1b09f59d Auto-link urls in message bodies
And watch out for xss.

Closes #187
11 years ago
lilia 8ee282b1aa Restyle registration page
When first intalling, users will no longer be presented with the option
to register as a standalone client.

For developer convenience, the standalone form can still be found at
chrome-extension://.../register.html

Closes #159
11 years ago
lilia a9cf4bd93e Update test config to run against latest Chrome
Break up some long lines while I'm here.
11 years ago
lilia 01d5881a71 Remove unneeded if-gaurd 11 years ago
lilia 7a03c26849 Adjust message bubble tail position
It should align with the center of the avatar.
11 years ago
lilia fc6c8c0f3e Fix tests 11 years ago
lilia b65190e101 Break a long line 11 years ago
lilia e2bd55c171 Tweak delivery receipt and timestamp display
Checkmark is no longer underlined when hovering over the timestamp.
11 years ago
lilia 99787753a8 Stop re-rendering attachments on delivery receipt
Only re-render a message if the body changed. Re-render only the
delivery receipt checkmark if the delivered property changes.

Fix a bug where attachments flash in and out of existance when a
delivery receipt arrives.
11 years ago
lilia dfe7813e7f Fix multiple from address in message detail 11 years ago
lilia 441167ab35 Tighten up send btn icon size 11 years ago
lilia 2ee34343a8 Use consistent boiler plate throughout js files 11 years ago
lilia f89cf890df Clean up older views, mostly whitespace 11 years ago
lilia 44a31f3ed9 Remove unneeded function 11 years ago
lilia 1bb480f6ea DRY up a common view pattern
Define a Whisper.View base class that automatically parses and renders
templates and attributes defined by the subclass. This saves us a good
number of lines of code as well as some marginal memory overhead, since
we are no longer saving per-instance copies of template strings.
11 years ago
lilia 7c9ad975bb Unravel image processing recursion and fix bugs
Although I find the previous implementation more elegant, it results in
a deeper nesting of Promises than necessary, which can make debugging
more complicated. The canvas scaling and compression apis are actually
synchronous, so the callback structure isn't really recessary here.
Converting to a loop also makes this process easier to understand at
a glance.

Fixed some bugs along the way:
* accidentally scaling small images up to 1920px
* jpeg compressing gifs and other formats even if unnecessary
11 years ago
lilia 0da04632f2 Scale large images even if they are small
Previously we would not scale large resolution images with small file
sizes, but in fact, both resolution and file size constraints should be
enforced.
11 years ago
lilia 567a48e82b Adjust widths of bubbles and chat window
With these changes, message bubbles in the default-sized chat popup are
just wide enough to display the full complement of html5 media player
controls.
11 years ago
lilia 8bc77fa02b Automatically compress and scale large images
Do nothing to other file types. Continue to block files that are too
large even after scaling and compression.
11 years ago
lilia 37d20b986b Add canvas.toBlob polyfill 11 years ago
lilia 68d68e9009 Add blueimp lib for html5's canvas-based image scaling 11 years ago
lilia f89340a4e8 Turn up the volume on README warnings
Closes #185
11 years ago
lilia 258a872ce3 Trigger update events after attachments load
Mostly so we can ensure we're scrolled to the bottom when the
conversation is loaded.
11 years ago
lilia f9ca13a86f DRY up audio and video views 11 years ago
lilia df06499a19 Use blob urls to display attachments
Converting attachment data to base64-encoded data uris takes O(n) and
there's no need! URL.createObjectURL returns a magic link that can be
set as the `src` attribute to `img`, `video`, and `audio` tags to load
blob data directly without copying.

https://developer.mozilla.org/en-US/docs/Web/API/URL/createObjectURL
11 years ago
lilia 4f5d3f0080 s/End Session/Reset Session/
Use the friendlier sounding copy from iOS.
11 years ago
lilia 11bdc58701 Update CONTRIBUTING.md 11 years ago
lilia 4cefd17ac6 Remove unused view 11 years ago
lilia 9d94bce92a After clearing messages, leave conversation open
Fixes #178
11 years ago
lilia ce5f6e41a8 Add missing images 11 years ago
lilia 0778854cc4 Attachments should be in spans, not divs 11 years ago
lilia 88a708ce03 Fix file inputs on inbox view 11 years ago
lilia 1311f7c9ae Fix attachment previews for audio/video files 11 years ago