Display vectors in models directory if available (see #1457)

This commit is contained in:
ines 2017-10-25 16:15:37 +02:00
parent 11e3f19764
commit 70de2dd035
2 changed files with 10 additions and 3 deletions

View File

@ -38,7 +38,7 @@ for id in CURRENT_MODELS
+cell #[+label Size] +cell #[+label Size]
+cell #[+tag=comps.size] #[span(data-tpl=id data-tpl-key="size") #[em n/a]] +cell #[+tag=comps.size] #[span(data-tpl=id data-tpl-key="size") #[em n/a]]
each label in ["Pipeline", "Sources", "Author", "License"] each label in ["Pipeline", "Vectors", "Sources", "Author", "License"]
- var field = label.toLowerCase() - var field = label.toLowerCase()
+row +row
+cell.u-nowrap +cell.u-nowrap

View File

@ -140,6 +140,10 @@ class ModelLoader {
else return ({ ok: res.ok }) else return ({ ok: res.ok })
} }
convertNumber(num, separator = ',') {
return num.toString().replace(/\B(?=(\d{3})+(?!\d))/g, separator);
}
getModels(compat) { getModels(compat) {
this.compat = compat; this.compat = compat;
for (let modelId of this.modelIds) { for (let modelId of this.modelIds) {
@ -159,7 +163,7 @@ class ModelLoader {
const template = new Templater(modelId); const template = new Templater(modelId);
template.get('table').removeAttribute('data-loading'); template.get('table').removeAttribute('data-loading');
template.get('error').style.display = 'block'; template.get('error').style.display = 'block';
for (let key of ['sources', 'pipeline', 'author', 'license']) { for (let key of ['sources', 'pipeline', 'vectors', 'author', 'license']) {
template.get(key).parentElement.parentElement.style.display = 'none'; template.get(key).parentElement.parentElement.style.display = 'none';
} }
} }
@ -167,13 +171,14 @@ class ModelLoader {
/** /**
* Update model details in tables. Currently quite hacky :( * Update model details in tables. Currently quite hacky :(
*/ */
render({ lang, name, version, sources, pipeline, url, author, license, accuracy, size, description, notes }) { render({ lang, name, version, sources, pipeline, vectors, url, author, license, accuracy, size, description, notes }) {
const modelId = `${lang}_${name}`; const modelId = `${lang}_${name}`;
const model = `${modelId}-${version}`; const model = `${modelId}-${version}`;
const template = new Templater(modelId); const template = new Templater(modelId);
const getSources = s => (s instanceof Array) ? s.join(', ') : s; const getSources = s => (s instanceof Array) ? s.join(', ') : s;
const getPipeline = p => p.map(comp => `<code>${comp}</code>`).join(', '); const getPipeline = p => p.map(comp => `<code>${comp}</code>`).join(', ');
const getVectors = v => `${this.convertNumber(v.entries)} (${v.width} dimensions)`;
const getLink = (t, l) => `<a href="${l}" target="_blank">${t}</a>`; const getLink = (t, l) => `<a href="${l}" target="_blank">${t}</a>`;
const keys = { version, size, description, notes } const keys = { version, size, description, notes }
@ -182,6 +187,8 @@ class ModelLoader {
if (sources) template.fill('sources', getSources(sources)); if (sources) template.fill('sources', getSources(sources));
if (pipeline && pipeline.length) template.fill('pipeline', getPipeline(pipeline), true); if (pipeline && pipeline.length) template.fill('pipeline', getPipeline(pipeline), true);
else template.get('pipeline').parentElement.parentElement.style.display = 'none'; else template.get('pipeline').parentElement.parentElement.style.display = 'none';
if (vectors) template.fill('vectors', getVectors(vectors));
else template.get('vectors').parentElement.parentElement.style.display = 'none';
if (author) template.fill('author', url ? getLink(author, url) : author, true); if (author) template.fill('author', url ? getLink(author, url) : author, true);
if (license) template.fill('license', this.licenses[license] ? getLink(license, this.licenses[license]) : license, true); if (license) template.fill('license', this.licenses[license] ? getLink(license, this.licenses[license]) : license, true);