|
|
@ -6,6 +6,7 @@ import { |
|
|
|
SqliteUi, |
|
|
|
SqliteUi, |
|
|
|
SqlUiFactory |
|
|
|
SqlUiFactory |
|
|
|
} from '../sqlUi'; |
|
|
|
} from '../sqlUi'; |
|
|
|
|
|
|
|
import UITypes from '../sqlUi/UITypes'; |
|
|
|
|
|
|
|
|
|
|
|
export default class NcTemplateParser { |
|
|
|
export default class NcTemplateParser { |
|
|
|
sqlUi: |
|
|
|
sqlUi: |
|
|
@ -15,18 +16,24 @@ export default class NcTemplateParser { |
|
|
|
| typeof OracleUi |
|
|
|
| typeof OracleUi |
|
|
|
| typeof SqliteUi; |
|
|
|
| typeof SqliteUi; |
|
|
|
|
|
|
|
|
|
|
|
constructor(client) { |
|
|
|
private _tables: any[]; |
|
|
|
|
|
|
|
private _relations: any[]; |
|
|
|
|
|
|
|
private template: any; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
constructor({ client, template }) { |
|
|
|
this.sqlUi = SqlUiFactory.create({ client }); |
|
|
|
this.sqlUi = SqlUiFactory.create({ client }); |
|
|
|
|
|
|
|
this.template = template; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
public parse(template: any): any { |
|
|
|
public parse(template?: any): any { |
|
|
|
const tables = []; |
|
|
|
const tables = []; |
|
|
|
for (const tableTemplate of template.tables) { |
|
|
|
this.template = template || this.template; |
|
|
|
|
|
|
|
for (const tableTemplate of this.template._tables) { |
|
|
|
const table = this.extractTable(tableTemplate); |
|
|
|
const table = this.extractTable(tableTemplate); |
|
|
|
tables.push(table); |
|
|
|
tables.push(table); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return { tables }; |
|
|
|
this._tables = tables; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private extractTable(tableTemplate) { |
|
|
|
private extractTable(tableTemplate) { |
|
|
@ -58,6 +65,13 @@ export default class NcTemplateParser { |
|
|
|
if (!tableColumn?.cn) { |
|
|
|
if (!tableColumn?.cn) { |
|
|
|
throw Error('Missing column name in template'); |
|
|
|
throw Error('Missing column name in template'); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ( |
|
|
|
|
|
|
|
tableColumn.uidt === UITypes.LinkToAnotherRecord || |
|
|
|
|
|
|
|
tableColumn.uidt === UITypes.ForeignKey |
|
|
|
|
|
|
|
) { |
|
|
|
|
|
|
|
// todo :
|
|
|
|
|
|
|
|
} else { |
|
|
|
const column = { |
|
|
|
const column = { |
|
|
|
...this.sqlUi.getNewColumn(''), |
|
|
|
...this.sqlUi.getNewColumn(''), |
|
|
|
cn: tableColumn.cn, |
|
|
|
cn: tableColumn.cn, |
|
|
@ -67,8 +81,19 @@ export default class NcTemplateParser { |
|
|
|
}; |
|
|
|
}; |
|
|
|
columns.push(column); |
|
|
|
columns.push(column); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
return columns; |
|
|
|
return columns; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private ex; |
|
|
|
protected extractRelations(_columnTemplate) { |
|
|
|
|
|
|
|
if (!this._relations) this._relations = []; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
get tables(): any[] { |
|
|
|
|
|
|
|
return this._tables; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
get relations(): any[] { |
|
|
|
|
|
|
|
return this._relations; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|