Skip to content
Snippets Groups Projects
Verified Commit 897d8d54 authored by Luke "Jared" Bennett's avatar Luke "Jared" Bennett
Browse files

Further review changes

parent b72e18b0
No related branches found
No related tags found
1 merge request!10564Initial balsamiq support
/* global Flash */ /* global Flash */
   
import sqljs from 'sql.js'; import sqljs from 'sql.js';
import _ from 'underscore';
import Spinner from '../../spinner'; import Spinner from '../../spinner';
   
class BalsamiqViewer { class BalsamiqViewer {
Loading
@@ -52,6 +53,10 @@ class BalsamiqViewer {
Loading
@@ -52,6 +53,10 @@ class BalsamiqViewer {
return thumbnails[0].values.map(BalsamiqViewer.parsePreview); return thumbnails[0].values.map(BalsamiqViewer.parsePreview);
} }
   
getTitle(resourceID) {
return this.database.exec(`SELECT * FROM resources WHERE id = '${resourceID}'`);
}
renderPreview(preview) { renderPreview(preview) {
const previewElement = document.createElement('li'); const previewElement = document.createElement('li');
   
Loading
@@ -62,13 +67,14 @@ class BalsamiqViewer {
Loading
@@ -62,13 +67,14 @@ class BalsamiqViewer {
} }
   
renderTemplate(preview) { renderTemplate(preview) {
let template = BalsamiqViewer.PREVIEW_TEMPLATE; const title = this.getTitle(preview.resourceID);
const name = BalsamiqViewer.parseTitle(title);
const title = this.database.exec(`SELECT * FROM resources WHERE id = '${preview.resourceID}'`);
const name = JSON.parse(title[0].values[0][2]).name;
const image = preview.image; const image = preview.image;
   
template = template.replace(/{{name}}/g, name).replace(/{{image}}/g, image); const template = BalsamiqViewer.PREVIEW_TEMPLATE({
name,
image,
});
   
return template; return template;
} }
Loading
@@ -77,6 +83,10 @@ class BalsamiqViewer {
Loading
@@ -77,6 +83,10 @@ class BalsamiqViewer {
return JSON.parse(preview[1]); return JSON.parse(preview[1]);
} }
   
static parseTitle(title) {
return JSON.parse(title[0].values[0][2]).name;
}
static onError() { static onError() {
const flash = new Flash('Balsamiq file could not be loaded.'); const flash = new Flash('Balsamiq file could not be loaded.');
   
Loading
@@ -84,13 +94,13 @@ class BalsamiqViewer {
Loading
@@ -84,13 +94,13 @@ class BalsamiqViewer {
} }
} }
   
BalsamiqViewer.PREVIEW_TEMPLATE = ` BalsamiqViewer.PREVIEW_TEMPLATE = _.template(`
<div class="panel panel-default"> <div class="panel panel-default">
<div class="panel-heading">{{name}}</div> <div class="panel-heading"><%- name %></div>
<div class="panel-body"> <div class="panel-body">
<img class="img-thumbnail" src="data:image/png;base64,{{image}}"/> <img class="img-thumbnail" src="data:image/png;base64,<%- image %>"/>
</div> </div>
</div> </div>
`; `);
   
export default BalsamiqViewer; export default BalsamiqViewer;
Loading
@@ -216,6 +216,35 @@ describe('BalsamiqViewer', () => {
Loading
@@ -216,6 +216,35 @@ describe('BalsamiqViewer', () => {
}); });
}); });
   
describe('getTitle', () => {
let database;
let resourceID;
let resource;
let getTitle;
beforeEach(() => {
database = jasmine.createSpyObj('database', ['exec']);
resourceID = 4;
resource = 'resource';
balsamiqViewer = {
database,
};
database.exec.and.returnValue(resource);
getTitle = BalsamiqViewer.prototype.getTitle.call(balsamiqViewer, resourceID);
});
it('should call database.exec', () => {
expect(database.exec).toHaveBeenCalledWith(`SELECT * FROM resources WHERE id = '${resourceID}'`);
});
it('should return the selected resource', () => {
expect(getTitle).toBe(resource);
});
});
describe('renderPreview', () => { describe('renderPreview', () => {
let previewElement; let previewElement;
let innerHTML; let innerHTML;
Loading
@@ -261,54 +290,50 @@ describe('BalsamiqViewer', () => {
Loading
@@ -261,54 +290,50 @@ describe('BalsamiqViewer', () => {
   
describe('renderTemplate', () => { describe('renderTemplate', () => {
let preview; let preview;
let database; let name;
let title; let title;
let template;
let renderTemplate; let renderTemplate;
   
beforeEach(() => { beforeEach(() => {
preview = { reosourceID: 1, image: 'image' }; preview = { resourceID: 1, image: 'image' };
title = [{ values: [['{}', '{}', '{ "name": "name" }']] }]; name = 'name';
database = jasmine.createSpyObj('database', ['exec']); title = 'title';
template = `
database.exec.and.returnValue(title); <div class="panel panel-default">
<div class="panel-heading">name</div>
<div class="panel-body">
<img class="img-thumbnail" src=""/>
</div>
</div>
`;
   
balsamiqViewer = { balsamiqViewer = jasmine.createSpyObj('balsamiqViewer', ['getTitle']);
database,
};
   
spyOn(JSON, 'parse').and.callThrough(); spyOn(BalsamiqViewer, 'parseTitle').and.returnValue(name);
spyOn(String.prototype, 'replace').and.callThrough(); spyOn(BalsamiqViewer, 'PREVIEW_TEMPLATE').and.returnValue(template);
balsamiqViewer.getTitle.and.returnValue(title);
   
renderTemplate = BalsamiqViewer.prototype.renderTemplate.call(balsamiqViewer, preview); renderTemplate = BalsamiqViewer.prototype.renderTemplate.call(balsamiqViewer, preview);
}); });
   
it('should call database.exec', () => { it('should call .getTitle', () => {
expect(database.exec).toHaveBeenCalledWith(`SELECT * FROM resources WHERE id = '${preview.resourceID}'`); expect(balsamiqViewer.getTitle).toHaveBeenCalledWith(preview.resourceID);
}); });
   
it('should call JSON.parse', () => { it('should call .parseTitle', () => {
expect(JSON.parse).toHaveBeenCalledWith(title[0].values[0][2]); expect(BalsamiqViewer.parseTitle).toHaveBeenCalledWith(title);
}); });
   
it('should call String.prototype.replace', () => { it('should call .PREVIEW_TEMPLATE', () => {
const allArgs = String.prototype.replace.calls.allArgs(); expect(BalsamiqViewer.PREVIEW_TEMPLATE).toHaveBeenCalledWith({
name,
expect(allArgs.length).toBe(2); image: preview.image,
expect(allArgs[0]).toEqual([/{{name}}/g, 'name']); });
expect(allArgs[1]).toEqual([/{{image}}/g, 'image']);
}); });
   
it('should return the template string', function () { it('should return the template string', function () {
const template = ` expect(renderTemplate.trim()).toBe(template.trim());
<div class="panel panel-default">
<div class="panel-heading">name</div>
<div class="panel-body">
<img class="img-thumbnail" src=""/>
</div>
</div>
`;
expect(renderTemplate.replace(/\s/g, '')).toEqual(template.replace(/\s/g, ''));
}); });
}); });
   
Loading
@@ -335,6 +360,29 @@ describe('BalsamiqViewer', () => {
Loading
@@ -335,6 +360,29 @@ describe('BalsamiqViewer', () => {
}); });
}); });
   
describe('parseTitle', () => {
let title;
let parseTitle;
beforeEach(() => {
title = [{ values: [['{}', '{}', '{"name":"name"}']] }];
spyOn(JSON, 'parse').and.callThrough();
parseTitle = BalsamiqViewer.parseTitle(title);
});
ClassSpecHelper.itShouldBeAStaticMethod(BalsamiqViewer, 'parsePreview');
it('should call JSON.parse', () => {
expect(JSON.parse).toHaveBeenCalledWith(title[0].values[0][2]);
});
it('should return the name value', () => {
expect(parseTitle).toBe('name');
});
});
describe('onError', () => { describe('onError', () => {
let onError; let onError;
   
Loading
Loading
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment