signal-desktop/ts/components/conversation/EmbeddedContact.md
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
2018-07-17 15:58:07 -07:00

9.3 KiB

With a contact

Including all data types

const contact = {
  name: {
    displayName: 'Someone Somewhere',
  },
  number: [
    {
      value: '(202) 555-0000',
      type: 1,
    },
  ],
  avatar: {
    avatar: {
      path: util.gifObjectUrl,
    },
  },
  onClick: () => console.log('onClick'),
  onSendMessage: () => console.log('onSendMessage'),
  hasSignalAccount: true,
};
<util.ConversationContext theme={util.theme}>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      collapseMetadata
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      collapseMetadata
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
</util.ConversationContext>;

Really long data

const contact = {
  name: {
    displayName: 'Dr. First Middle Last Junior Senior and all that and a bag of chips',
  },
  number: [
    {
      value: '(202) 555-0000 0000 0000 0000 0000 0000 0000 0000 0000 0000',
      type: 1,
    },
  ],
  avatar: {
    avatar: {
      path: util.gifObjectUrl,
    },
  },
  hasSignalAccount: true,
};
<util.ConversationContext theme={util.theme}>
  <li><Message
    authorColor="green"
    direction="incoming"
    i18n={util.i18n}
    contact={contact}/></li>
  <li><Message
    direction="outgoing"
    status="delivered"
    i18n={util.i18n}
    contact={contact}/></li>
</util.ConversationContext>;

In group conversation

const contact = {
  name: {
    displayName: 'Someone Somewhere',
  },
  number: [
    {
      value: '(202) 555-0000',
      type: 1,
    },
  ],
  avatar: {
    avatar: {
      path: util.gifObjectUrl,
    },
  },
  hasSignalAccount: true,
};
<util.ConversationContext theme={util.theme} type="group">
  <li>
    <Message
      authorColor="green"
      conversationType="group"
      authorName="Mr. Fire"
      authorAvatarPath={util.gifObjectUrl}
      direction="incoming"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      authorName="Mr. Fire"
      conversationType="group"
      collapseMetadata
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      conversationType="group"
      authorName="Mr. Fire"
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
</util.ConversationContext>;

If contact has no signal account

const contact = {
  name: {
    displayName: 'Someone Somewhere',
  },
  number: [
    {
      value: '(202) 555-0000',
      type: 1,
    },
  ],
  avatar: {
    avatar: {
      path: util.gifObjectUrl,
    },
  },
  hasSignalAccount: false,
};
<util.ConversationContext theme={util.theme}>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      collapseMetadata
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      collapseMetadata
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
</util.ConversationContext>;

With organization name instead of name

const contact = {
  organization: 'United Somewheres, Inc.',
  email: [
    {
      value: 'someone@somewheres.com',
      type: 2,
    },
  ],
  avatar: {
    avatar: {
      path: util.gifObjectUrl,
    },
  },
  hasSignalAccount: false,
};
<util.ConversationContext theme={util.theme}>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      collapseMetadata
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      collapseMetadata
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
</util.ConversationContext>;

No displayName or organization

const contact = {
  name: {
    givenName: 'Someone',
  },
  number: [
    {
      value: '(202) 555-1000',
      type: 1,
    },
  ],
  avatar: {
    avatar: {
      path: util.gifObjectUrl,
    },
  },
  hasSignalAccount: false,
};
<util.ConversationContext theme={util.theme}>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      collapseMetadata
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      collapseMetadata
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
</util.ConversationContext>;

Default avatar

const contact = {
  name: {
    displayName: 'Someone Somewhere',
  },
  number: [
    {
      value: '(202) 555-1001',
      type: 1,
    },
  ],
  hasSignalAccount: true,
};
<util.ConversationContext theme={util.theme}>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      collapseMetadata
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      collapseMetadata
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
</util.ConversationContext>;

Empty contact

const contact = {};
<util.ConversationContext theme={util.theme}>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      authorColor="green"
      direction="incoming"
      collapseMetadata
      i18n={util.i18n}
      contact={contact}
    />
  </li>
  <li>
    <Message
      direction="outgoing"
      collapseMetadata
      status="delivered"
      i18n={util.i18n}
      contact={contact}
    />
  </li>
</util.ConversationContext>;

Contact with caption (cannot currently be sent)

const contactWithAccount = {
  name: {
    displayName: 'Someone Somewhere',
  },
  number: [
    {
      value: '(202) 555-0000',
      type: 1,
    },
  ],
  avatar: {
    avatar: {
      path: util.gifObjectUrl,
    },
  },
  hasSignalAccount: true,
};
const contactWithoutAccount = {
  name: {
    displayName: 'Someone Somewhere',
  },
  number: [
    {
      value: '(202) 555-0000',
      type: 1,
    },
  ],
  avatar: {
    avatar: {
      path: util.gifObjectUrl,
    },
  },
  hasSignalAccount: false,
};
<util.ConversationContext theme={util.theme}>
  <li>
    <Message
      text="I want to introduce you to Someone..."
      authorColor="green"
      direction="incoming"
      i18n={util.i18n}
      contact={contactWithAccount}
    />
  </li>
  <li>
    <Message
      text="I want to introduce you to Someone..."
      direction="outgoing"
      status="delivered"
      i18n={util.i18n}
      contact={contactWithAccount}
    />
  </li>
  <li>
    <Message
      text="I want to introduce you to Someone..."
      authorColor="green"
      direction="incoming"
      i18n={util.i18n}
      contact={contactWithAccount}
    />
  </li>
  <li>
    <Message
      text="I want to introduce you to Someone..."
      direction="outgoing"
      status="delivered"
      i18n={util.i18n}
      contact={contactWithAccount}
    />
  </li>
  <li>
    <Message
      text="I want to introduce you to Someone..."
      authorColor="green"
      direction="incoming"
      collapseMetadata
      i18n={util.i18n}
      contact={contactWithoutAccount}
    />
  </li>
  <li>
    <Message
      text="I want to introduce you to Someone..."
      direction="outgoing"
      collapseMetadata
      status="delivered"
      i18n={util.i18n}
      contact={contactWithoutAccount}
    />
  </li>
  <li>
    <Message
      text="I want to introduce you to Someone..."
      authorColor="green"
      direction="incoming"
      collapseMetadata
      i18n={util.i18n}
      contact={contactWithoutAccount}
    />
  </li>
  <li>
    <Message
      text="I want to introduce you to Someone..."
      direction="outgoing"
      collapseMetadata
      status="delivered"
      i18n={util.i18n}
      contact={contactWithoutAccount}
    />
  </li>
</util.ConversationContext>;