More poll normalization fixes
This commit is contained in:
parent
84a364a7d2
commit
4bd1531056
4 changed files with 39 additions and 10 deletions
Binary file not shown.
Binary file not shown.
|
@ -57,11 +57,12 @@ const PollRecord = ImmutableRecord({
|
||||||
emojis: ImmutableList(),
|
emojis: ImmutableList(),
|
||||||
expired: false,
|
expired: false,
|
||||||
expires_at: new Date(),
|
expires_at: new Date(),
|
||||||
|
id: '',
|
||||||
multiple: false,
|
multiple: false,
|
||||||
options: ImmutableList(),
|
options: ImmutableList(),
|
||||||
voters_count: 0,
|
voters_count: 0,
|
||||||
votes_count: 0,
|
votes_count: 0,
|
||||||
own_votes: ImmutableList(),
|
own_votes: null,
|
||||||
voted: false,
|
voted: false,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -106,14 +107,42 @@ const normalizeMentions = (status: ImmutableMap<string, any>) => {
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
// Normalize poll
|
// Normalize poll options
|
||||||
const normalizePoll = (status: ImmutableMap<string, any>) => {
|
const normalizePollOptions = (poll: ImmutableMap<string, any>) => {
|
||||||
|
return poll.update('options', (options: ImmutableList<ImmutableMap<string, any>>) => {
|
||||||
|
return options.map(PollOptionRecord);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// Normalize own_votes to `null` if empty (like Mastodon)
|
||||||
|
const normalizePollOwnVotes = (poll: ImmutableMap<string, any>) => {
|
||||||
|
return poll.update('own_votes', ownVotes => {
|
||||||
|
return ownVotes?.size > 0 ? ownVotes : null;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// Whether the user voted in the poll
|
||||||
|
const normalizePollVoted = (poll: ImmutableMap<string, any>) => {
|
||||||
|
return poll.update('voted', voted => {
|
||||||
|
return typeof voted === 'boolean' ? voted : poll.get('own_votes')?.size > 0;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// Normalize the actual poll
|
||||||
|
const normalizePoll = (poll: ImmutableMap<string, any>) => {
|
||||||
|
return PollRecord(
|
||||||
|
poll.withMutations((poll: ImmutableMap<string, any>) => {
|
||||||
|
normalizePollOptions(poll);
|
||||||
|
normalizePollOwnVotes(poll);
|
||||||
|
normalizePollVoted(poll);
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
// Normalize the poll in the status, if applicable
|
||||||
|
const normalizeStatusPoll = (status: ImmutableMap<string, any>) => {
|
||||||
if (status.hasIn(['poll', 'options'])) {
|
if (status.hasIn(['poll', 'options'])) {
|
||||||
return status.update('poll', ImmutableMap(), poll => {
|
return status.update('poll', ImmutableMap(), normalizePoll);
|
||||||
return PollRecord(poll).update('options', (options: ImmutableList<ImmutableMap<string, any>>) => {
|
|
||||||
return options.map(PollOptionRecord);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
} else {
|
} else {
|
||||||
return status.set('poll', null);
|
return status.set('poll', null);
|
||||||
}
|
}
|
||||||
|
@ -161,12 +190,12 @@ const fixQuote = (status: ImmutableMap<string, any>) => {
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
export const normalizeStatus = (status: ImmutableMap<any, string>): IStatus => {
|
export const normalizeStatus = (status: ImmutableMap<string, any>): IStatus => {
|
||||||
return StatusRecord(
|
return StatusRecord(
|
||||||
status.withMutations(status => {
|
status.withMutations(status => {
|
||||||
normalizeAttachments(status);
|
normalizeAttachments(status);
|
||||||
normalizeMentions(status);
|
normalizeMentions(status);
|
||||||
normalizePoll(status);
|
normalizeStatusPoll(status);
|
||||||
fixMentionsOrder(status);
|
fixMentionsOrder(status);
|
||||||
addSelfMention(status);
|
addSelfMention(status);
|
||||||
fixQuote(status);
|
fixQuote(status);
|
||||||
|
|
Binary file not shown.
Loading…
Reference in a new issue