A few fixes for the emoji bundled with stickers

This commit is contained in:
Scott Nonnenberg 2022-08-08 11:21:00 -07:00 committed by GitHub
parent 7a1686b915
commit fde917c983
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 30 additions and 8 deletions

View file

@ -184,10 +184,17 @@ window.encryptAndUpload = async (
return s;
});
const coverSticker = new Proto.StickerPack.Sticker();
coverSticker.id =
const coverStickerId =
uniqueStickers.length === stickers.length ? 0 : uniqueStickers.length - 1;
const coverStickerData = stickers[coverStickerId];
const coverSticker = new Proto.StickerPack.Sticker();
coverSticker.id = coverStickerId;
if (coverStickerData.emoji) {
coverSticker.emoji = coverStickerData.emoji;
} else {
coverSticker.emoji = '';
}
manifestProto.cover = coverSticker;
const encryptedManifest = await encrypt(

View file

@ -731,11 +731,10 @@ export class MessageModel extends window.Backbone.Model<MessageAttributesType> {
const stickerData = this.get('sticker');
if (stickerData) {
const sticker = Stickers.getSticker(
stickerData.packId,
stickerData.stickerId
);
const { emoji } = sticker || {};
const emoji =
Stickers.getSticker(stickerData.packId, stickerData.stickerId)?.emoji ||
stickerData?.emoji;
if (!emoji) {
log.warn('Unable to get emoji for sticker');
}

View file

@ -299,6 +299,7 @@ describe('processDataMessage', () => {
packId: new Uint8Array([1, 2, 3]),
packKey: new Uint8Array([4, 5, 6]),
stickerId: 1,
emoji: '💯',
data: UNPROCESSED_ATTACHMENT,
},
});
@ -307,6 +308,7 @@ describe('processDataMessage', () => {
packId: '010203',
packKey: 'BAUG',
stickerId: 1,
emoji: '💯',
data: PROCESSED_ATTACHMENT,
});
});

View file

@ -171,6 +171,7 @@ export type ProcessedSticker = {
packId?: string;
packKey?: string;
stickerId?: number;
emoji?: string;
data?: ProcessedAttachment;
};

View file

@ -212,6 +212,7 @@ export function processSticker(
packId: sticker.packId ? Bytes.toHex(sticker.packId) : undefined,
packKey: sticker.packKey ? Bytes.toBase64(sticker.packKey) : undefined,
stickerId: dropNull(sticker.stickerId),
emoji: dropNull(sticker.emoji),
data: processAttachment(sticker.data),
};
}

View file

@ -449,6 +449,12 @@ export async function downloadEphemeralPack(
proto.stickers,
sticker => !isNumber(sticker.id) || sticker.id === coverStickerId
);
const coverSticker = proto.stickers.filter(
sticker => isNumber(sticker.id) && sticker.id === coverStickerId
);
if (coverSticker[0] && !coverProto.emoji) {
coverProto.emoji = coverSticker[0].emoji;
}
const coverIncludedInList = nonCoverStickers.length < stickerCount;
@ -652,6 +658,12 @@ async function doDownloadStickerPack(
proto.stickers,
sticker => !isNumber(sticker.id) || sticker.id === coverStickerId
);
const coverSticker = proto.stickers.filter(
sticker => isNumber(sticker.id) && sticker.id === coverStickerId
);
if (coverSticker[0] && !coverProto.emoji) {
coverProto.emoji = coverSticker[0].emoji;
}
coverIncludedInList = nonCoverStickers.length < stickerCount;