Commit Graph

260 Commits (712afef8e236f531873b7f7ffe636f649564c0eb)

Author SHA1 Message Date
Scott Nonnenberg fedfbed304 Copy quoted message contents into quote on receipt
Also:
  - visually distinguish any reference we couldn't verify on receipt
  - show toast on quote click if we can't scroll to message
  - toast visuals redesigned to match rest of app
7 years ago
Scott Nonnenberg a247ffe5cf When iOS device has been linked, use iOS color scheme 7 years ago
Scott Nonnenberg 727925a266 Clean up old messages, better handle errors from sending 7 years ago
Scott Nonnenberg b0b1e9b8e3 Message: video/image attachment borders inline, on top of image
Otherwise, its transparency will result in a distracting line between it
and its attached message bubble
7 years ago
Scott Nonnenberg 3b7ee3e2ce A couple copy changes: Show -> View, New Number -> Safety Number 7 years ago
Scott Nonnenberg 19ff050b3a Show 'Off' text when disappearing messages are turned off 7 years ago
Scott Nonnenberg 3105b77475 Migrate to SQLCipher for messages/cache
Quite a few other fixes, including:
  - Sending to contact with no avatar yet (not synced from mobile)
  - Left pane doesn't update quickly or at all on new message
  - Left pane doesn't show sent or error status

Also:
 - Contributing.md: Ensure set of linux dev dependencies is complete
7 years ago
Scott Nonnenberg 8b92e6112c Add dir='auto' to Message and Quote body for RTL languages 7 years ago
Scott Nonnenberg f38647dfa5 ContactListItem: Add spacing above and below (for 'show members') 7 years ago
Scott Nonnenberg e80857562a Disappearing messages: show 'disabled' instead of 'set to off' 7 years ago
Scott Nonnenberg 7dd931fb7e ConversationHeader: centered title, ConvoListItem: unbold name 7 years ago
Scott Nonnenberg 5933a34a18 Use window.log in browser context, turn on console eslint rule 7 years ago
Scott Nonnenberg 643739f65d
Responding to feedback on the updated visuals (#2549)
* Conversation List Item: timestamp bold only when convo has unread

* Preserve the positioning of overlays on re-entry into convo

* ConversationListItem: Handle missing and broken thumbnails

* Shorten timestamp in left pane for better Android consistency

* Update convo last updated if last was expire timer change

But not if it was from a sync instead of from you or from a contact.

* Make links in quotes the same color as the text

* MediaGridItem: Update placeholder icon colors for dark theme

* Ensure turning off timer shows 'Timer set to off' in left pane

* ConversationListItem: Show unread count in blue circle

* Add one pixel margin to blue indicator for text alignment

* Ensure replies to voice message can bet sent successfully
7 years ago
Scott Nonnenberg 2384988b0a ConversationHeader: Ensure that profile has tilde before it 7 years ago
Scott Nonnenberg fa18e2ba77 LightBox: tslint exception for play() call which returns promise 7 years ago
Scott Nonnenberg 4fa6a785f4 Remove unused code 7 years ago
Scott Nonnenberg e90355dab5 Lightbox: Play video on open, play/pause on click of video itself 7 years ago
Scott Nonnenberg 66bd6c826d Fix MediaGallery handling of videos - show thumbnail and overlay 7 years ago
Scott Nonnenberg 95976b10e7 Timestamp: Eliminate 'Invalid date' from potential output 7 years ago
Scott Nonnenberg 675e34fc8d New React component: ConversationListItem, installed in left pane
When collecting a conversation's last message, we grab that message's
status as well (if outgoing) and show it.
7 years ago
Scott Nonnenberg 7e2d7b5e60 Media Gallery: Support for dark theme 7 years ago
Scott Nonnenberg 3c69886320 Finish new Message component, integrate into application
Also:
- New schema version 8 with video/image thumbnails, screenshots, sizes
- Upgrade messages not at current schema version when loading messages
  to show in conversation
- New MessageDetail react component
- New ConversationHeader react component
7 years ago
Scott Nonnenberg 43a44793c5 Remove jshint - move everything over to eslint
Also removed all hints of previous linters
7 years ago
Scott Nonnenberg dc11db92f9 New React component: Message
Also: Use react to render contects on the 'show group members' screen
7 years ago
Scott Nonnenberg 445839770b
Fix width of message detail screen (#2478) 7 years ago
Scott Nonnenberg 9dedda84e2 Add style guide examples for ContactName and ConversationTitle 8 years ago
Scott Nonnenberg 2988da0981 Turn on all of Microsoft's recommend lint rules
Biggest changes forced by this: alt tags for all images, resulting in
new strings added to messages.json, and a new i18n paramter/prop added
in a plot of places.

Another change of note is that there are two new tslint.json files under
ts/test and ts/styleguide to relax our rules a bit there. This required
a change to our package.json script, as manually specifying the config
file there made it ignore our tslint.json files in subdirectories
8 years ago
Scott Nonnenberg 23586be6b0 Add emojification to contact names shown in quotes 8 years ago
Scott Nonnenberg 548c8e69cf Emojification now all done with react via a few new components
Three locations were changed:
  1. a group update, which lists a set of contacts
  2. the contact name in the left pane
  3. the conversation title

Three new components were added to window.Signal.Components to support
these scenarios, respectively:
  1. Emojify
  2. ContactName
  3. ConversationTitle

Note that there are a number of other places in the app that should be
emojified, but never have been before. Essentially any place that a
contact name might be shown. A non-exhaustive list:
  - Show group members
  - Show safety number
  - Verified change notification
  - Disappearing timer change notification
  - Contact verification notification
  - Quote contact name
8 years ago
Scott Nonnenberg d9e5338dff Refactor link/emoji/newline components for composability 8 years ago
Scott Nonnenberg a5416e42c4 Refactor all emoji utility methods into window.Signal.Emoji 8 years ago
Scott Nonnenberg a328a70ba2
Update React-based emoji handling to fix skin tone modifiers (#2399) 8 years ago
Scott Nonnenberg 4e5c8965ff Move to react for newlines, emoji, and links in message body 8 years ago
Scott Nonnenberg 8f934251ae Fix a few types: relax contact, Email->Phone 8 years ago
Scott Nonnenberg 8cb1f1f532 Fall back on givenName/familyName if no displayName/organization 8 years ago
Scott Nonnenberg eafa038ba4 Use backup labels if custom contact type labels are missing 8 years ago
Daniel Gasienica d349dd903d Add `AttachmentSection` to style guide 8 years ago
Daniel Gasienica 121bb0ecef Style guide: Fix empty state 8 years ago
Daniel Gasienica f19e6ea93d Wrap JSX siblings in container 8 years ago
Daniel Gasienica a8cd0b782e Rename `DocumentListItem::isLast` to `shouldShowSeparator` 8 years ago
Daniel Gasienica 05f67dc04a Hide separator for last document list entry 8 years ago
Daniel Gasienica fd883b2896 Fix `LightboxGallery` style guide entry 8 years ago
Daniel Gasienica bfe7eb7d5e Consolidate styles 8 years ago
Daniel Gasienica 90329a2764 Display icon for unsupported file formats
Still allows users to download media.
8 years ago
Scott Nonnenberg 1918a88722 Drop ifTruthy suffix 8 years ago
Scott Nonnenberg 1fd487be3f Refactor to remove duplicated code, lint/prettier fixes 8 years ago
Scott Nonnenberg f628df1035 Eliminate arrows in the standalone Lightbox component examples 8 years ago
Scott Nonnenberg 8beeef4d10 Show contact name when you reply to message with a contact 8 years ago
Scott Nonnenberg 30cb673405 Fix style guide for LightboxGallery component 8 years ago
Scott Nonnenberg 37821e5a1b Wire up all contact behaviors, refactor Contact type/selector 8 years ago
Scott Nonnenberg 41be7f126b Visuals for embedded contacts as well as contact detail screen 8 years ago
Daniel Gasienica 38f3ad6518 Use `SignalService` vs `textsecure` for protobuf 8 years ago
Daniel Gasienica 5789b3eb75 Add `Attachment.isVoiceMessage` 8 years ago
Scott Nonnenberg 322d307655 Turn on prettier support for markdown files, update all files 8 years ago
Daniel Gasienica 87d374ea78 Remove `@prettier` pragmas 8 years ago
Daniel Gasienica 1dd87ad197 Format all source code using Prettier 8 years ago
Scott Nonnenberg 82e2fe93a5
Show 'You' in Android theme quotes instead of contact name (#2312)
Show 'You' in Android theme quotes instead of contact name
8 years ago
Scott Nonnenberg c5935eef5d Show 'You' in Android theme quotes instead of contact name 8 years ago
Daniel Gasienica fccbf70d57 Pre-process media for `LightboxGallery` 8 years ago
Daniel Gasienica c6599d2e14 Add another permutation of `EmptyState` 8 years ago
Daniel Gasienica 9ca6fd6498 Center lightbox navigation controls 8 years ago
Daniel Gasienica fa45656e8e Wire up media gallery empty state 8 years ago
Daniel Gasienica 4d01264c09 Fix layout of media gallery 8 years ago
Daniel Gasienica 78f15b654d Add `EmptyState` component 8 years ago
Daniel Gasienica ea49f7a3b6 Implement keyboard navigation for `Lightbox` 8 years ago
Daniel Gasienica e1b620602d Display attachments from disk 8 years ago
Daniel Gasienica 407c77395b Add explicit boolean 8 years ago
Daniel Gasienica 4c0c55082f Move navigation controls to the bottom 8 years ago
Daniel Gasienica fb8d4e2421 Implement basic lightbox with gallery support 8 years ago
Daniel Gasienica 43e19f3b06 Prevent default event on icon button clicks 8 years ago
Daniel Gasienica b3d0438537 Show hand cursor on media grid items 8 years ago
Daniel Gasienica 45d6c7a5a8 Implement video support in lightbox 8 years ago
Daniel Gasienica b74b761255 Implement click to save for document list 8 years ago
Daniel Gasienica b27fdd1559 Use `pointer` cursor for `DocumentListItem` 8 years ago
Daniel Gasienica f8119be97b Include videos in media gallery 8 years ago
Daniel Gasienica 37d73accde Show ‘Documents’ tab 8 years ago
Daniel Gasienica b65370c8d7 Prefer `GoogleChrome.is*` over `MIME.is*` 8 years ago
Daniel Gasienica 64c3d604aa Fix type errors 8 years ago
Daniel Gasienica cd6912f0dd 🎨 Autoformat code 8 years ago
Daniel Gasienica 823a58f98a Prevent NPE 8 years ago
Daniel Gasienica 96be0df8c7 Show lightbox controls based on presence of handlers 8 years ago
Daniel Gasienica 59650035ec Use 🇺🇸 spelling 8 years ago
Daniel Gasienica feff820cd4 Prefer custom styles over `strong` 8 years ago
Daniel Gasienica fca8de16c8 Add required `Message.id: string` 8 years ago
Daniel Gasienica dd7e51e697 🎨 Fix formatting 8 years ago
Daniel Gasienica 6330a8d9f3 Simplify expression 8 years ago
Daniel Gasienica f99e6306c3 Simplify `withSection` 8 years ago
Daniel Gasienica d98d08a7e0 Remove obsolete TODO 8 years ago
Daniel Gasienica e97b078088 Use `componentWillUnmount` 8 years ago
Daniel Gasienica 2e121310e4 🎨 Fix lint error 8 years ago
Daniel Gasienica 4d04638358 Document changes for MVP 8 years ago
Daniel Gasienica c3e04ecf87 Remove use of `LoadingIndicator` 8 years ago
Daniel Gasienica 6d5d0df1c0 🎨 Fix TSLint errors 8 years ago
Daniel Gasienica f240269d7b MVP: Only show images in media gallery 8 years ago
Daniel Gasienica b4e3749c88 MVP: Only show media tab
Until we support showing documents.
8 years ago
Daniel Gasienica 60ed82b728 Show all lightbox controls in style guide 8 years ago
Daniel Gasienica a7ed21a811 Add `shouldShowSaveAsButton` option 8 years ago
Daniel Gasienica 0d676a65b8 Open media gallery item in lightbox 8 years ago
Daniel Gasienica a9f7f18721 Add `ItemClickEvent` 8 years ago
Daniel Gasienica d634a414c3 Make visibility of previous/next buttons opt-in 8 years ago
Daniel Gasienica 142236640e Click lightbox to close 8 years ago
Daniel Gasienica ce825fbd66 Rename `save` to `onSave` 8 years ago
Daniel Gasienica 1b9e581e90 Show lightbox image as large as possible 8 years ago
Daniel Gasienica 2cb0b0aeb1 Add arrow controls 8 years ago
Daniel Gasienica 246e0ca87b Add note about inline styles 8 years ago
Daniel Gasienica d797ede791 Close lightbox on escape key press 8 years ago
Daniel Gasienica 86da80fd23 Wire up attachment saving 8 years ago
Daniel Gasienica 2474b42198 Port lightbox icon buttons 8 years ago
Daniel Gasienica 4a5a2cb5c1 Replace Backbone with React lightbox 8 years ago
Daniel Gasienica cb94d09ef9 Rename media gallery items 8 years ago
Daniel Gasienica 5d0469adef Skip loading videos into memory for performance 8 years ago
Daniel Gasienica 0a4be2e0f4 Remove unused `i18n` 8 years ago
Daniel Gasienica 4ce0472b9f Extract `Message.loadWithObjectURL` 8 years ago
Daniel Gasienica 45d89d1e44 Create `UserMessage` type
Describes user visible messages that can have attachments.
8 years ago
Daniel Gasienica 648a7ab1bb Autoformat using Prettier 8 years ago
Daniel Gasienica c46e1a1519 Move top-level functions to `Signal.Util` 8 years ago
Daniel Gasienica a609c31a57 Style attachment section headers 8 years ago
Daniel Gasienica b0fefdbb98 Implementing grouping messages by date 8 years ago
Daniel Gasienica 424965f876 🎨 Autoformat code 8 years ago
Daniel Gasienica f367a9b059 Move `private` method below `public` ones 8 years ago
Daniel Gasienica 3d70e46aea Calculate dates in UTC 8 years ago
Daniel Gasienica d7b21ef5dc Render attachments grouped by date 8 years ago
Daniel Gasienica e34347f290 Add `groupMessagesByDate` 8 years ago
Daniel Gasienica 9053b6acfc Remove unused style 8 years ago
Daniel Gasienica 66516fd36a Use short format for dates 8 years ago
Daniel Gasienica fc1c3aabf5 Add scaffolding for media gallery 8 years ago
Daniel Gasienica 32a3ef518b Render media gallery placeholder panel 8 years ago
Daniel Gasienica df2e6e7864 Port `MIME` module to TypeScript 8 years ago
Scott Nonnenberg ef1d568a80
Restore rendering of group update and end session messages
The previous work to refactor bubbles broke rendering for these message
types. :0/
8 years ago
Scott Nonnenberg fdc13d0af3
Fix some tslint errors
I really need to get it running in my editor!
8 years ago
Scott Nonnenberg bd88407b78
iOS theme: Permanant background to attachment part of bubble
(this is to handle a quote making bubble wider, but a narrow image)
8 years ago
Scott Nonnenberg 21713cbce7
Update quotes to render emoji just like normal messages 8 years ago
Scott Nonnenberg 37cac717cb
Use fit: cover for non-square thumbnails, better movie icon
Also: Match Android's X button in the quote composition area
8 years ago
Scott Nonnenberg 12257e1560
MessageView: Show menu w/ 'reply to message' on triple-dot click 8 years ago
Scott Nonnenberg f4d9ab8ba0
Put quote preview in text box for Android, above it in iOS 8 years ago
Scott Nonnenberg c71dcf0139
Show current quoted message above composition field
Note that substantial changes will be required for the updated Android
mockups, putting the quotation into the text box next to the attachment
preview.
8 years ago
Scott Nonnenberg d29162f3b6
CSS Refactor: Pull quote CSS out from parent classes
This is to prepare for it to be shown in the message composition area.
8 years ago
Scott Nonnenberg 26e4e97592
Tighten up CSS
- Remove extra padding at top of Android bubbles, via sibling selector
- Don't include .attachments, .quote-wrapper, .content in bubble unless
  we actually need them. This allows for sibling selectors.
- This is a different technique for adding the ReactWrapperView for
  quotes - it is now appended to the DOM instead of attaching to
  something already in the DOM. This allows us to use .remove(), so it's
  a bit cleaner.
- Users of ReactWrapperView can now specify tagName and className
8 years ago
Scott Nonnenberg a563dc8b37
Style Guide: Additional message examples, a few fixes to enable 8 years ago
Scott Nonnenberg 5af5bbdb0f
Add style guide examples for portrait/landscape images 8 years ago
Scott Nonnenberg e3d15d80f6
Quote.md: Fix image example, add examples for attachment + reply 8 years ago
Scott Nonnenberg 7bd747a796
ConversationContext: conversationType => type
And a group conversation example to messages.md
8 years ago
Scott Nonnenberg 3bbbf65a6b
Fix iOS: tail, blue partial border, extra attachment space
Turns out that display: inline on the img tag resulted in a mysterious
3px of space added below it.
8 years ago
Scott Nonnenberg c283ba1a12
Remove pointer cursor when clicking on quote won't do anything 8 years ago
Scott Nonnenberg d91f40177e
Quote.tsx: Fix tslint errors
I really need to get tslint editor integration in place.
8 years ago
Scott Nonnenberg a0b1dea693
Introduce a bit of color to the message/attachment style guide 8 years ago
Scott Nonnenberg b458c7d449
android-dark: Constrain light play icon to with peer image 8 years ago
Scott Nonnenberg bdaebc24ae
A few tweaks for the android-dark theme 8 years ago
Scott Nonnenberg 087dd0f758
Support for iOS theme 8 years ago
Scott Nonnenberg 644bc9e6fb
Fix problem of squished quote icons and images 8 years ago