2021-09-23 17:19:31 +02:00
|
|
|
const errors = require("./errors.js");
|
|
|
|
import { DatasRenders, DatasRendersSettings } from "./freeDatas2HTMLInterfaces";
|
|
|
|
import { FreeDatas2HTML } from "./freeDatas2HTML";
|
|
|
|
|
|
|
|
export class Render implements DatasRenders
|
|
|
|
{
|
|
|
|
private _converter: FreeDatas2HTML;
|
|
|
|
public settings: DatasRendersSettings;
|
|
|
|
static readonly defaultSettings =
|
|
|
|
{
|
|
|
|
allBegining:"<table>",
|
|
|
|
allEnding:"</table>",
|
|
|
|
fieldsBegining:"<thead><tr>",
|
2021-09-27 16:03:05 +02:00
|
|
|
fieldsEnding:"</tr></thead>",
|
2021-09-23 17:19:31 +02:00
|
|
|
fieldDisplaying:"<th>#FIELDNAME</th>",
|
|
|
|
linesBegining:"<tbody>",
|
|
|
|
linesEnding:"</tbody>",
|
|
|
|
lineBegining:"<tr>",
|
|
|
|
lineEnding:"</tr>",
|
|
|
|
dataDisplaying:"<td>#VALUE</td>",
|
|
|
|
};
|
|
|
|
|
|
|
|
// Injection de la classe principale
|
|
|
|
constructor(converter: FreeDatas2HTML, settings:DatasRendersSettings=Render.defaultSettings)
|
|
|
|
{
|
|
|
|
this._converter=converter;
|
|
|
|
this.settings=settings;
|
|
|
|
}
|
|
|
|
|
2021-09-27 12:11:05 +02:00
|
|
|
// Reçoit les données à afficher et retourne le HTML correspondant.
|
2021-09-23 17:19:31 +02:00
|
|
|
public rend2HTML(datas: any[]) : string
|
|
|
|
{
|
2021-09-27 12:11:05 +02:00
|
|
|
// Il peut n'y avoir aucune donnée (filtres...), mais les noms des champs doivent être connus.
|
2021-09-23 17:19:31 +02:00
|
|
|
if(this._converter.parseMetas === undefined || this._converter.parseMetas.fields === undefined)
|
|
|
|
throw new Error(errors.renderNeedDatas);
|
|
|
|
else
|
|
|
|
{
|
|
|
|
let datasHTML=this.settings.allBegining;
|
2021-09-27 12:11:05 +02:00
|
|
|
// On ne souhaite pas nécessairement afficher les noms des champs
|
|
|
|
if(this.settings.fieldsBegining !== undefined && this.settings.fieldDisplaying !== undefined && this.settings.fieldsEnding !== undefined )
|
2021-09-23 17:19:31 +02:00
|
|
|
{
|
|
|
|
datasHTML+=this.settings.fieldsBegining;
|
2021-09-27 12:17:14 +02:00
|
|
|
for (let i in this._converter.parseMetas.fields)
|
2021-09-23 17:19:31 +02:00
|
|
|
datasHTML+=this.settings.fieldDisplaying.replace("#FIELDNAME", this._converter.parseMetas.fields[Number(i)]);
|
|
|
|
datasHTML+=this.settings.fieldsEnding;
|
|
|
|
}
|
|
|
|
datasHTML+=this.settings.linesBegining;
|
|
|
|
for (let row in datas)
|
|
|
|
{
|
|
|
|
datasHTML+=this.settings.lineBegining;
|
|
|
|
for(let field in datas[row])
|
|
|
|
{
|
2021-09-27 12:11:05 +02:00
|
|
|
// On n'affiche que les champs attendus et signale les erreurs dans la console
|
2021-09-23 17:19:31 +02:00
|
|
|
if(this._converter.parseMetas.fields.indexOf(field) !== -1)
|
|
|
|
datasHTML+=this.settings.dataDisplaying.replace("#VALUE" , datas[row][field]).replace("#FIELDNAME" , field);
|
2021-09-27 12:11:05 +02:00
|
|
|
else
|
|
|
|
console.log(errors.renderUnknownField+field);
|
2021-09-23 17:19:31 +02:00
|
|
|
}
|
|
|
|
datasHTML+=this.settings.lineEnding;
|
|
|
|
}
|
|
|
|
datasHTML+=this.settings.linesEnding+this.settings.allEnding;
|
|
|
|
return datasHTML;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|