Revert "fix group badges for weird badge strings"

This reverts commit 629bb9b111
This commit is contained in:
skeletor 2022-03-28 06:59:02 +00:00
parent 1e0334b14a
commit 26e625a851

View File

@ -173,37 +173,19 @@ export class BadgeImageManager implements IDisposable
for(const partMatch of partMatches) for(const partMatch of partMatches)
{ {
const partCode = partMatch[0]; const partCode = partMatch[0];
const part = this.parsePartString(partCode); const shortMethod = (partCode.length === 6);
const partType = partCode[0];
const partId = parseInt(partCode.slice(1, shortMethod ? 3 : 4));
const partColor = parseInt(partCode.slice(shortMethod ? 3 : 4, shortMethod ? 5 : 6));
const partPosition = partCode.length < 6 ? 0 : parseInt(partCode.slice(shortMethod ? 5 : 6, shortMethod ? 6 : 7)); // sometimes position is ommitted
const part = new GroupBadgePart(partType, partId, partColor, partPosition);
if(part) groupBadge.parts.push(part); groupBadge.parts.push(part);
} }
this.renderGroupBadge(groupBadge); this.renderGroupBadge(groupBadge);
} }
/**
* Returns a badge part based on the part string.
* This is ugly but it is not my fault. I blame emulators for
* different ways of implementing group badges wrong
* @param partCode (for example b08010)
* @returns badge part object
*/
private parsePartString(partCode: string) : GroupBadgePart
{
const arr = partCode.split('');
const partType = arr.splice(0, 1).join('');
const isSymbol = partType !== 'b';
const partId = parseInt(arr.splice(0, (partCode.length == 7 || (!isSymbol && partCode.length == 6 && arr[0] == '0')) ? 3 : 2).join(''));
const partColor = parseInt(arr.splice(0, 2).join(''));
const partPosition = arr.length ? parseInt(arr[0]) : 0; // sometimes position is ommitted
return new GroupBadgePart(partType, partId, partColor, partPosition);
}
private renderGroupBadge(groupBadge: GroupBadge): void private renderGroupBadge(groupBadge: GroupBadge): void
{ {
const container = new NitroContainer(); const container = new NitroContainer();