mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 14:47:53 +01:00
Fix XML Data Export Error by Modifying XML Format (#13942)
* Added XML code to parse json + convert formatting before exporting as XML + XML Marshall tests * Add linting fixes linting errors still present in xmlMarshaller.test.js but, certain keys starting with digits (for example '800ed0') must be enclosed in quotes , so to maintain consistency within the test file I kept all keys enclosed by single quotes. * fix(lint): unquote, EOF Co-authored-by: SabreCat <sabe@habitica.com>
This commit is contained in:
@@ -23,7 +23,33 @@ export function marshallUserData (userData) {
|
||||
type: i.type,
|
||||
}));
|
||||
|
||||
return js2xml.parse('user', userData, {
|
||||
const copyUserData = JSON.parse(JSON.stringify(userData));
|
||||
|
||||
const newPurchased = {};
|
||||
if (userData.purchased != null) {
|
||||
for (const itemType in userData.purchased) {
|
||||
if (userData.purchased[itemType] != null) {
|
||||
if (typeof userData.purchased[itemType] === 'object') {
|
||||
const fixedData = [];
|
||||
for (const item in userData.purchased[itemType]) {
|
||||
if (item != null) {
|
||||
if (typeof userData.purchased[itemType][item] === 'object') {
|
||||
fixedData.push({ item: userData.purchased[itemType][item] });
|
||||
} else {
|
||||
fixedData.push(item);
|
||||
}
|
||||
}
|
||||
}
|
||||
newPurchased[itemType] = fixedData;
|
||||
} else {
|
||||
newPurchased[itemType] = userData.purchased[itemType];
|
||||
}
|
||||
}
|
||||
}
|
||||
copyUserData.purchased = newPurchased;
|
||||
}
|
||||
|
||||
return js2xml.parse('user', copyUserData, {
|
||||
cdataInvalidChars: true,
|
||||
replaceInvalidChars: true,
|
||||
declaration: {
|
||||
|
||||
Reference in New Issue
Block a user