Browse Source

Merge pull request #7076 from nocodb/fix/at-select

fix: various at-import issues
pull/7071/head
Raju Udava 1 year ago committed by GitHub
parent
commit
c4b26e87a3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 104
      packages/nocodb/src/modules/jobs/jobs/at-import/at-import.processor.ts
  2. 3
      packages/nocodb/src/modules/jobs/jobs/at-import/helpers/readAndProcessData.ts

104
packages/nocodb/src/modules/jobs/jobs/at-import/at-import.processor.ts

@ -302,54 +302,19 @@ export class AtImportProcessor {
// aTbl helper routines // aTbl helper routines
// //
const nc_getSanitizedColumnName = (table, name) => { const nc_getSanitizedColumnName = (name, table_name) => {
let col_name = sanitizeColumnName(name); const uniqueColNameGen = getUniqueNameGenerator('column', table_name);
const uniqueFieldNameGen = getUniqueNameGenerator('field', table_name);
// truncate to 50 chars if character if exceeds above 50 // truncate to 50 chars if character if exceeds above 50
col_name = col_name?.slice(0, 50); const col_name = sanitizeColumnName(name)?.slice(0, 50);
// for knex, replace . with _ // for knex, replace . with _
let col_alias = name.trim().replace(/\./g, '_'); const col_alias = name.trim().replace(/\./g, '_');
// check if already a column exists with same name?
const duplicateTitle = table.columns.find(
(x) => x.title?.toLowerCase() === col_alias?.toLowerCase(),
);
const duplicateColumn = table.columns.find(
(x) => x.column_name?.toLowerCase() === col_name?.toLowerCase(),
);
if (duplicateTitle) {
let tempAlias = col_alias;
let suffix = 1;
while (
table.columns.find(
(x) => x.title?.toLowerCase() === tempAlias?.toLowerCase(),
)
) {
tempAlias = col_alias;
tempAlias += `_${suffix++}`;
}
col_alias = tempAlias;
}
if (duplicateColumn) {
let tempName = col_name;
let suffix = 1;
while (
table.columns.find(
(x) => x.column_name?.toLowerCase() === tempName?.toLowerCase(),
)
) {
tempName = col_name;
tempName += `_${suffix++}`;
}
col_name = tempName;
}
return { return {
title: col_alias, title: uniqueFieldNameGen(col_alias),
column_name: col_name, column_name: uniqueColNameGen(col_name),
}; };
}; };
@ -379,7 +344,7 @@ export class AtImportProcessor {
const ncColId = await sMap.getNcIdFromAtId(aTblFieldId); const ncColId = await sMap.getNcIdFromAtId(aTblFieldId);
// not migrated column, skip // not migrated column, skip
if (ncColId === undefined || ncTblId === undefined) return 0; if (!ncColId || !ncTblId) return 0;
return ncSchema.tablesById[ncTblId].columns.find((x) => x.id === ncColId); return ncSchema.tablesById[ncTblId].columns.find((x) => x.id === ncColId);
}; };
@ -453,6 +418,10 @@ export class AtImportProcessor {
const options = []; const options = [];
let order = 1; let order = 1;
for (const [, value] of Object.entries(col.typeOptions.choices)) { for (const [, value] of Object.entries(col.typeOptions.choices)) {
// max length of option is 255 chars
// truncate to 255 chars if character if exceeds above 255
(value as any).name = (value as any).name?.slice(0, 255);
// replace commas with dot for multiselect // replace commas with dot for multiselect
if (col.type === 'multiSelect') { if (col.type === 'multiSelect') {
(value as any).name = (value as any).name.replace(/,/g, '.'); (value as any).name = (value as any).name.replace(/,/g, '.');
@ -526,7 +495,6 @@ export class AtImportProcessor {
// check for duplicate and populate a unique name if already exist // check for duplicate and populate a unique name if already exist
table.table_name = uniqueTableNameGen(sanitizedName); table.table_name = uniqueTableNameGen(sanitizedName);
const uniqueColNameGen = getUniqueNameGenerator('field');
table.columns = []; table.columns = [];
const sysColumns = [ const sysColumns = [
{ {
@ -554,11 +522,14 @@ export class AtImportProcessor {
} }
// base column schema // base column schema
const ncName: any = nc_getSanitizedColumnName(table, col.name); const ncName: any = nc_getSanitizedColumnName(
col.name,
table.table_name,
);
const ncCol: any = { const ncCol: any = {
// Enable to use aTbl identifiers as is: id: col.id, // Enable to use aTbl identifiers as is: id: col.id,
title: ncName.title, title: ncName.title,
column_name: uniqueColNameGen(ncName.column_name), column_name: ncName.column_name,
uidt: getNocoType(col), uidt: getNocoType(col),
}; };
@ -753,8 +724,8 @@ export class AtImportProcessor {
// create link // create link
const ncName = nc_getSanitizedColumnName( const ncName = nc_getSanitizedColumnName(
srcTbl,
aTblLinkColumns[i].name, aTblLinkColumns[i].name,
srcTbl.table_name,
); );
// LTAR alias ref to AT // LTAR alias ref to AT
@ -907,8 +878,8 @@ export class AtImportProcessor {
// note that: current rename API requires us to send all parameters, // note that: current rename API requires us to send all parameters,
// not just title being renamed // not just title being renamed
const ncName = nc_getSanitizedColumnName( const ncName = nc_getSanitizedColumnName(
childTblSchema,
aTblLinkColumns[i].name, aTblLinkColumns[i].name,
childTblSchema.table_name,
); );
logDetailed( logDetailed(
@ -987,18 +958,15 @@ export class AtImportProcessor {
aTblColumns[i].typeOptions.foreignTableRollupColumnId, aTblColumns[i].typeOptions.foreignTableRollupColumnId,
); );
if ( if (!ncLookupColumnId || !ncRelationColumnId) {
ncLookupColumnId === undefined ||
ncRelationColumnId === undefined
) {
aTblColumns[i]['srcTableId'] = srcTableId; aTblColumns[i]['srcTableId'] = srcTableId;
nestedLookupTbl.push(aTblColumns[i]); nestedLookupTbl.push(aTblColumns[i]);
continue; continue;
} }
const ncName = nc_getSanitizedColumnName( const ncName = nc_getSanitizedColumnName(
srcTableSchema,
aTblColumns[i].name, aTblColumns[i].name,
srcTableSchema.table_name,
); );
logDetailed(`NC API: dbTableColumn.create LOOKUP ${ncName.title}`); logDetailed(`NC API: dbTableColumn.create LOOKUP ${ncName.title}`);
@ -1062,6 +1030,7 @@ export class AtImportProcessor {
nestedCnt = nestedLookupTbl.length; nestedCnt = nestedLookupTbl.length;
for (let i = 0; i < nestedLookupTbl.length; i++) { for (let i = 0; i < nestedLookupTbl.length; i++) {
const srcTableId = nestedLookupTbl[0].srcTableId; const srcTableId = nestedLookupTbl[0].srcTableId;
const srcTableSchema = ncSchema.tablesById[srcTableId]; const srcTableSchema = ncSchema.tablesById[srcTableId];
const ncRelationColumnId = await sMap.getNcIdFromAtId( const ncRelationColumnId = await sMap.getNcIdFromAtId(
@ -1071,16 +1040,13 @@ export class AtImportProcessor {
nestedLookupTbl[0].typeOptions.foreignTableRollupColumnId, nestedLookupTbl[0].typeOptions.foreignTableRollupColumnId,
); );
if ( if (!ncLookupColumnId || !ncRelationColumnId) {
ncLookupColumnId === undefined ||
ncRelationColumnId === undefined
) {
continue; continue;
} }
const ncName = nc_getSanitizedColumnName( const ncName = nc_getSanitizedColumnName(
srcTableSchema,
nestedLookupTbl[0].name, nestedLookupTbl[0].name,
srcTableSchema.table_name,
); );
logDetailed( logDetailed(
@ -1208,7 +1174,7 @@ export class AtImportProcessor {
aTblColumns[i].typeOptions.foreignTableRollupColumnId, aTblColumns[i].typeOptions.foreignTableRollupColumnId,
); );
if (ncRollupColumnId === undefined) { if (!ncRollupColumnId) {
aTblColumns[i]['srcTableId'] = srcTableId; aTblColumns[i]['srcTableId'] = srcTableId;
nestedRollupTbl.push(aTblColumns[i]); nestedRollupTbl.push(aTblColumns[i]);
continue; continue;
@ -1234,8 +1200,8 @@ export class AtImportProcessor {
} }
const ncName = nc_getSanitizedColumnName( const ncName = nc_getSanitizedColumnName(
srcTableSchema,
aTblColumns[i].name, aTblColumns[i].name,
srcTableSchema.table_name,
); );
logDetailed(`NC API: dbTableColumn.create ROLLUP ${ncName.title}`); logDetailed(`NC API: dbTableColumn.create ROLLUP ${ncName.title}`);
@ -1279,6 +1245,7 @@ export class AtImportProcessor {
const nestedCnt = nestedLookupTbl.length; const nestedCnt = nestedLookupTbl.length;
for (let i = 0; i < nestedLookupTbl.length; i++) { for (let i = 0; i < nestedLookupTbl.length; i++) {
const srcTableId = nestedLookupTbl[0].srcTableId; const srcTableId = nestedLookupTbl[0].srcTableId;
const srcTableSchema = ncSchema.tablesById[srcTableId]; const srcTableSchema = ncSchema.tablesById[srcTableId];
const ncRelationColumnId = await sMap.getNcIdFromAtId( const ncRelationColumnId = await sMap.getNcIdFromAtId(
@ -1288,16 +1255,13 @@ export class AtImportProcessor {
nestedLookupTbl[0].typeOptions.foreignTableRollupColumnId, nestedLookupTbl[0].typeOptions.foreignTableRollupColumnId,
); );
if ( if (!ncLookupColumnId || !ncRelationColumnId) {
ncLookupColumnId === undefined ||
ncRelationColumnId === undefined
) {
continue; continue;
} }
const ncName = nc_getSanitizedColumnName( const ncName = nc_getSanitizedColumnName(
srcTableSchema,
nestedLookupTbl[0].name, nestedLookupTbl[0].name,
srcTableSchema.table_name,
); );
logDetailed( logDetailed(
@ -2553,16 +2517,18 @@ export class AtImportProcessor {
} }
} }
export const getUniqueNameGenerator = (defaultName = 'name') => { const namesRef = {};
const namesRef = {};
const getUniqueNameGenerator = (defaultName = 'name', context = 'default') => {
const finalContext = `${context}_${defaultName}}`;
if (!namesRef[finalContext]) namesRef[finalContext] = {};
return (initName: string = defaultName): string => { return (initName: string = defaultName): string => {
let name = initName === '_' ? defaultName : initName; let name = initName === '_' ? defaultName : initName;
let c = 0; let c = 0;
while (name in namesRef) { while (name in namesRef[finalContext]) {
name = `${initName}_${++c}`; name = `${initName}_${++c}`;
} }
namesRef[name] = true; namesRef[finalContext][name] = true;
return name; return name;
}; };
}; };

3
packages/nocodb/src/modules/jobs/jobs/at-import/helpers/readAndProcessData.ts

@ -212,8 +212,7 @@ export async function importData({
return records; return records;
} catch (e) { } catch (e) {
console.log(e); throw e;
return null;
} }
} }

Loading…
Cancel
Save