Skip to content

Commit

Permalink
fix: xls upload child table ids and orguids
Browse files Browse the repository at this point in the history
  • Loading branch information
MichaelTaylor3D committed Dec 9, 2022
1 parent aceb436 commit 88c8575
Showing 1 changed file with 14 additions and 181 deletions.
195 changes: 14 additions & 181 deletions src/utils/xls.js
Original file line number Diff line number Diff line change
Expand Up @@ -287,184 +287,6 @@ function buildObjectXlsData({
return aggregatedData;
}

export const createXlsFromSequelizeResults_old = ({
rows,
model,
toStructuredCsv = false,
excludeOrgUid = false,
isUserFriendlyFormat = true,
}) => {
rows = JSON.parse(JSON.stringify(rows)); // Sadly this is the best way to simplify sequelize's return shape

let columnsInResults = [];
const associationColumnsMap = new Map();

if (rows.length > 0) {
columnsInResults = Object.keys(rows[0]);

rows.forEach((row, index) => {
if (index === 0) {
return;
}

Object.keys(row).forEach((key) => {
if (!columnsInResults.includes(key)) columnsInResults.push(key);
});
});
}

const associations = model.getAssociatedModels();
const associationNames = associations.map(
(association) => `${association.model.name}s`,
);

const columnsInMainSheet = columnsInResults.filter(
(column) =>
!associationNames.includes(column) &&
(!excludeOrgUid || column !== 'orgUid'),
);

const associatedModelColumns = columnsInResults.filter((column) =>
associations
.map((association) => `${association.model.name}s`)
.includes(column),
);

// Create a map with the union of all keys of each association item on any row (the columns may differ, e.g. one item added, one updated)
if (rows.length > 0) {
associatedModelColumns.forEach((column) => {
rows.forEach((row) => {
if (row[column] == null || typeof row[column] !== 'object') {
return;
}

if (Array.isArray(row[column])) {
row[column].forEach((item) => {
if (item != null && typeof item === 'object') {
getObjectColumns(item, column, associationColumnsMap);
}
});
} else {
getObjectColumns(row[column], column, associationColumnsMap);
}
});
});
}

const initialReduceValue = {};
initialReduceValue[model.name] = {
name: model.name + 's',
data: [
columnsInMainSheet.map((colName) =>
colName === 'issuance' ? 'issuanceId' : colName,
), // todo make this generic
],
};

const xlsData = rows.reduce((sheets, row) => {
let mainXlsRow = [];

// Populate main sheet values
columnsInMainSheet.forEach((columnName) => {
const rowValue =
isUserFriendlyFormat && row[columnName] == null
? 'null'
: row[columnName];

if (rowValue != null && Object.keys(rowValue).includes('id')) {
if (!Object.keys(sheets).includes(columnName + 's')) {
sheets[columnName + 's'] = {
name: columnName + 's',
data: [
Object.keys(rowValue).concat([
model.name.split('_').join('') + 'Id',
]),
],
};
}
sheets[columnName + 's'].data.push(
Object.values(rowValue)
.map((val1) => val1)
.concat([rowValue.id]),
);
}

mainXlsRow.push(rowValue);
});

if (mainXlsRow.length) {
sheets[model.name].data.push(mainXlsRow);
}

// Populate associated data sheets
associatedModelColumns.forEach((column) => {
if (!Array.isArray(row[column])) {
return;
}

row[column].forEach((value) => {
const xlsRow = [];

if (!Object.keys(sheets).includes(column)) {
sheets[column] = {
name: column,
data: [Object.keys(value).concat([model.name + 'Id'])],
};
}

(associationColumnsMap.get(column) ?? Object.keys(value)).forEach(
(column) => {
const rowValue =
isUserFriendlyFormat && value[column] == null
? 'null'
: value[column];

if (rowValue != null && typeof rowValue === 'object') {
if (!Object.keys(sheets).includes(column + 's')) {
const columns =
associationColumnsMap.get(column) ?? Object.keys(rowValue);

sheets[column + 's'] = {
name: column + 's',
data: [columns.concat([column.split('_').join('') + 'Id'])],
};
}

if (rowValue != null) {
const columns =
associationColumnsMap.get(column) ?? Object.keys(rowValue);
sheets[column + 's'].data.push(
columns
.map((currentCol) => rowValue[currentCol])
.concat([value.id]),
);
}
}

xlsRow.push(rowValue);
},
);

if (xlsRow.length > 0) {
if ((model.primaryKeyAttributes?.length ?? 0) > 0) {
xlsRow.push(row[model.primaryKeyAttributes[0]]);
}

sheets[column].data.push(xlsRow);
}
});
});

return sheets;
}, initialReduceValue);

if (!toStructuredCsv) {
return xlsx.build(Object.values(xlsData));
} else {
return xlsData;
}
};

export const tableDataFromXlsx = (xlsx, model) => {
// Todo recursion
const modelAssociations = [...associations(model), model];
Expand Down Expand Up @@ -598,6 +420,8 @@ export const collapseTablesData = (tableData, model) => {
return;
}

// console.log('!!!!', data);

const tableUnitData = tableData['label_unit']?.data?.find((row) => {
if (tableData[model.name]?.data == null) {
return false;
Expand Down Expand Up @@ -650,13 +474,15 @@ export const collapseTablesData = (tableData, model) => {
* @param model - The model used
* @param setKey - Whether to set the model key to children or to delete them (false = delete)
*/
function updateModelChildIds(
async function updateModelChildIds(
modelAssociations,
item,
removeModelKeyInChildren,
model,
setKey,
) {
const homeOrg = await Organization.getHomeOrg();

modelAssociations.forEach((association) => {
if (!association.pluralize) return;

Expand All @@ -666,6 +492,13 @@ function updateModelChildIds(
item[key] = [item[key]];
}

if (setKey) {
item[key].forEach((childData) => {
childData.id = uuidv4();
childData.orgUid = homeOrg.orgUid;
});
}

if (removeModelKeyInChildren.includes(key)) {
item[key].forEach((childData) => {
if (setKey) {
Expand Down Expand Up @@ -726,7 +559,7 @@ export const updateTableWithData = async (tableData, model) => {
delete row['issuanceId'];
}

updateModelChildIds(
await updateModelChildIds(
modelAssociations,
row,
removeModelKeyInChildren,
Expand All @@ -736,7 +569,7 @@ export const updateTableWithData = async (tableData, model) => {

const validation = data.model.validateImport?.validate(row);

updateModelChildIds(
await updateModelChildIds(
modelAssociations,
row,
removeModelKeyInChildren,
Expand Down

0 comments on commit 88c8575

Please sign in to comment.