2015-04-22 17:12:45 +02:00
|
|
|
(function () {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var ID = 'view/viewmode';
|
2015-05-10 16:09:11 +02:00
|
|
|
var DEPS = ['_', '$', 'core/event', 'core/resource', 'core/settings', 'view/sidebar', 'view/topbar', 'view/view'];
|
2015-04-22 17:12:45 +02:00
|
|
|
|
2015-04-22 23:21:48 +02:00
|
|
|
describe('module \'' + ID + '\'', function () {
|
2015-04-22 17:12:45 +02:00
|
|
|
|
|
|
|
before(function () {
|
|
|
|
|
|
|
|
this.definition = modulejs._private.definitions[ID];
|
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xEvent = {
|
|
|
|
sub: sinon.stub(),
|
|
|
|
pub: sinon.stub()
|
|
|
|
};
|
2015-04-22 17:12:45 +02:00
|
|
|
this.xResource = {
|
2015-04-22 19:34:35 +02:00
|
|
|
image: sinon.stub().returns(util.uniqPath('-image.png'))
|
2015-04-22 17:12:45 +02:00
|
|
|
};
|
2015-05-10 16:09:11 +02:00
|
|
|
this.xSettings = {view: {
|
|
|
|
viewmodeToggle: false
|
|
|
|
}};
|
2015-04-25 13:24:34 +02:00
|
|
|
this.xSidebar = {$el: null};
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xTopbar = {$el: null};
|
|
|
|
this.xView = {
|
|
|
|
$el: null,
|
|
|
|
getModes: sinon.stub().returns(['details', 'grid', 'icons']),
|
|
|
|
getMode: sinon.stub(),
|
|
|
|
setMode: sinon.stub(),
|
2015-05-10 16:10:03 +02:00
|
|
|
getSizes: sinon.stub().returns([20, 30, 40]),
|
2015-05-10 10:58:18 +02:00
|
|
|
getSize: sinon.stub(),
|
|
|
|
setSize: sinon.stub()
|
|
|
|
};
|
2015-04-25 13:24:34 +02:00
|
|
|
|
2015-04-22 17:12:45 +02:00
|
|
|
this.applyFn = function () {
|
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xEvent.sub.reset();
|
|
|
|
this.xEvent.pub.reset();
|
2015-04-22 17:12:45 +02:00
|
|
|
this.xResource.image.reset();
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xView.getModes.reset();
|
|
|
|
this.xView.getMode.reset();
|
|
|
|
this.xView.setMode.reset();
|
|
|
|
this.xView.getSizes.reset();
|
|
|
|
this.xView.getSize.reset();
|
|
|
|
this.xView.setSize.reset();
|
|
|
|
|
2015-05-10 16:09:11 +02:00
|
|
|
return this.definition.fn(_, $, this.xEvent, this.xResource, this.xSettings, this.xSidebar, this.xTopbar, this.xView);
|
2015-04-22 17:12:45 +02:00
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
after(function () {
|
|
|
|
|
|
|
|
util.restoreHtml();
|
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
|
|
|
|
util.restoreHtml();
|
2015-04-25 13:24:34 +02:00
|
|
|
this.xSidebar.$el = $('<div id="sidebar"/>').appendTo('body');
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xTopbar.$el = $('<div id="topbar"/>').appendTo('body');
|
2015-04-29 23:08:38 +02:00
|
|
|
this.xView.$el = $('<div id="view"/>').appendTo('body');
|
2015-04-22 17:12:45 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('definition', function () {
|
|
|
|
|
|
|
|
it('is defined', function () {
|
|
|
|
|
|
|
|
assert.isPlainObject(this.definition);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('has correct id', function () {
|
|
|
|
|
|
|
|
assert.strictEqual(this.definition.id, ID);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('requires correct', function () {
|
|
|
|
|
|
|
|
assert.deepEqual(this.definition.deps, DEPS);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('args for each request', function () {
|
|
|
|
|
|
|
|
assert.strictEqual(this.definition.deps.length, this.definition.fn.length);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('has no instance', function () {
|
|
|
|
|
|
|
|
assert.notProperty(modulejs._private.instances, ID);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('inits without errors', function () {
|
|
|
|
|
|
|
|
this.applyFn();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('application', function () {
|
|
|
|
|
|
|
|
it('returns undefined', function () {
|
|
|
|
|
|
|
|
var instance = this.applyFn();
|
|
|
|
assert.isUndefined(instance);
|
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('adds HTML #viewmode-settings to #sidebar', function () {
|
2015-04-22 17:12:45 +02:00
|
|
|
|
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
assert.lengthOf($('#sidebar > #viewmode-settings'), 1);
|
2015-04-22 17:12:45 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('adds HTML #viewmode-details to #viewmode-settings', function () {
|
2015-04-29 14:54:59 +02:00
|
|
|
|
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
assert.lengthOf($('#viewmode-settings > #viewmode-details'), 1);
|
2015-04-29 14:54:59 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('adds HTML #viewmode-grid to #viewmode-settings', function () {
|
2015-04-29 14:54:59 +02:00
|
|
|
|
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
assert.lengthOf($('#viewmode-settings > #viewmode-grid'), 1);
|
2015-04-29 14:54:59 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('adds HTML #viewmode-icons to #viewmode-settings', function () {
|
2015-04-29 14:54:59 +02:00
|
|
|
|
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
assert.lengthOf($('#viewmode-settings > #viewmode-icons'), 1);
|
2015-04-29 14:54:59 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('adds HTML #viewmode-size to #viewmode-settings', function () {
|
2015-04-29 14:54:59 +02:00
|
|
|
|
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
assert.lengthOf($('#viewmode-settings > #viewmode-size'), 1);
|
2015-04-29 14:54:59 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('does not add HTML #viewmode-details, #viewmode-grid, #viewmode-icons when only one mode', function () {
|
2015-04-30 00:32:43 +02:00
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xView.getModes.returns(['details']);
|
2015-04-30 00:32:43 +02:00
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
assert.lengthOf($('#viewmode-details'), 0);
|
|
|
|
assert.lengthOf($('#viewmode-grid'), 0);
|
|
|
|
assert.lengthOf($('#viewmode-icons'), 0);
|
2015-04-30 00:32:43 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('does not add HTML #viewmode-size when only one size', function () {
|
2015-04-30 00:32:43 +02:00
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xView.getSizes.returns([20]);
|
2015-04-30 00:32:43 +02:00
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
assert.lengthOf($('#viewmode-size'), 0);
|
2015-04-29 16:23:24 +02:00
|
|
|
});
|
2015-04-22 17:12:45 +02:00
|
|
|
});
|
2015-04-29 14:54:59 +02:00
|
|
|
|
|
|
|
describe('works', function () {
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('clicking #viewmode-details triggers view.setMode(\'details\')', function () {
|
2015-04-29 14:54:59 +02:00
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xView.getModes.returns(['details', 'grid', 'icons']);
|
2015-04-29 14:54:59 +02:00
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-details').trigger('click');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setMode.calledOnce);
|
|
|
|
assert.deepEqual(this.xView.setMode.lastCall.args, ['details']);
|
2015-04-29 14:54:59 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('clicking #viewmode-grid triggers view.setMode(\'grid\')', function () {
|
2015-04-29 14:54:59 +02:00
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xView.getModes.returns(['details', 'grid', 'icons']);
|
2015-04-29 14:54:59 +02:00
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-grid').trigger('click');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setMode.calledOnce);
|
|
|
|
assert.deepEqual(this.xView.setMode.lastCall.args, ['grid']);
|
2015-04-29 14:54:59 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('clicking #viewmode-icons triggers view.setMode(\'icons\')', function () {
|
2015-04-29 14:54:59 +02:00
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xView.getModes.returns(['details', 'grid', 'icons']);
|
2015-04-29 14:54:59 +02:00
|
|
|
this.applyFn();
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-icons').trigger('click');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setMode.calledOnce);
|
|
|
|
assert.deepEqual(this.xView.setMode.lastCall.args, ['icons']);
|
2015-04-29 14:54:59 +02:00
|
|
|
});
|
2015-04-30 00:15:09 +02:00
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('changing #viewmode-size triggers view.setSize(*)', function () {
|
2015-04-30 00:15:09 +02:00
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xView.getSizes.returns([20, 40, 60]);
|
2015-04-30 00:15:09 +02:00
|
|
|
this.applyFn();
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-size').val(0).trigger('change');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setSize.calledOnce);
|
|
|
|
assert.deepEqual(this.xView.setSize.lastCall.args, [20]);
|
2015-04-30 00:18:14 +02:00
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-size').val(1).trigger('change');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setSize.calledTwice);
|
|
|
|
assert.deepEqual(this.xView.setSize.lastCall.args, [40]);
|
2015-04-30 00:18:14 +02:00
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-size').val(2).trigger('change');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setSize.calledThrice);
|
|
|
|
assert.deepEqual(this.xView.setSize.lastCall.args, [60]);
|
2015-04-30 00:15:09 +02:00
|
|
|
});
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
it('inputing #viewmode-size triggers view.setSize(*)', function () {
|
2015-04-30 00:15:09 +02:00
|
|
|
|
2015-05-10 10:58:18 +02:00
|
|
|
this.xView.getSizes.returns([20, 40, 60]);
|
2015-04-30 00:15:09 +02:00
|
|
|
this.applyFn();
|
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-size').val(0).trigger('input');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setSize.calledOnce);
|
|
|
|
assert.deepEqual(this.xView.setSize.lastCall.args, [20]);
|
2015-04-30 00:18:14 +02:00
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-size').val(1).trigger('input');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setSize.calledTwice);
|
|
|
|
assert.deepEqual(this.xView.setSize.lastCall.args, [40]);
|
2015-04-30 00:18:14 +02:00
|
|
|
|
2015-05-10 13:05:39 +02:00
|
|
|
$('#viewmode-size').val(2).trigger('input');
|
2015-05-10 10:58:18 +02:00
|
|
|
assert.isTrue(this.xView.setSize.calledThrice);
|
|
|
|
assert.deepEqual(this.xView.setSize.lastCall.args, [60]);
|
2015-04-30 00:15:09 +02:00
|
|
|
});
|
2015-04-29 14:54:59 +02:00
|
|
|
});
|
2015-04-22 17:12:45 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
}());
|