2015-09-16 23:51:28 +00:00
|
|
|
/*****************************************************************************
|
2016-07-12 23:21:58 +00:00
|
|
|
* Open MCT, Copyright (c) 2014-2016, United States Government
|
2015-09-16 23:51:28 +00:00
|
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
|
|
* Administration. All rights reserved.
|
|
|
|
*
|
2016-07-12 23:21:58 +00:00
|
|
|
* Open MCT is licensed under the Apache License, Version 2.0 (the
|
2015-09-16 23:51:28 +00:00
|
|
|
* "License"); you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*
|
2016-07-12 23:21:58 +00:00
|
|
|
* Open MCT includes source code licensed under additional open source
|
2015-09-16 23:51:28 +00:00
|
|
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
|
|
|
* this source code distribution or the Licensing information page available
|
|
|
|
* at runtime from the About dialog for additional information.
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
define(
|
|
|
|
["../../src/directives/MCTClickElsewhere"],
|
|
|
|
function (MCTClickElsewhere) {
|
|
|
|
|
2016-05-19 18:29:13 +00:00
|
|
|
var JQLITE_METHODS = ["on", "off", "find", "parent"];
|
2015-09-16 23:51:28 +00:00
|
|
|
|
|
|
|
describe("The mct-click-elsewhere directive", function () {
|
|
|
|
var mockDocument,
|
|
|
|
mockScope,
|
|
|
|
mockElement,
|
|
|
|
testAttrs,
|
|
|
|
mockBody,
|
2015-12-29 23:37:09 +00:00
|
|
|
mockPlainEl,
|
2015-09-16 23:51:28 +00:00
|
|
|
testRect,
|
|
|
|
mctClickElsewhere;
|
|
|
|
|
|
|
|
function testEvent(x, y) {
|
|
|
|
return {
|
2015-12-29 23:37:09 +00:00
|
|
|
clientX: x,
|
|
|
|
clientY: y,
|
2015-09-16 23:51:28 +00:00
|
|
|
preventDefault: jasmine.createSpy("preventDefault")
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
mockDocument =
|
|
|
|
jasmine.createSpyObj("$document", JQLITE_METHODS);
|
|
|
|
mockScope =
|
2016-05-19 18:29:13 +00:00
|
|
|
jasmine.createSpyObj("$scope", ["$eval", "$apply", "$on"]);
|
2015-09-16 23:51:28 +00:00
|
|
|
mockElement =
|
|
|
|
jasmine.createSpyObj("element", JQLITE_METHODS);
|
|
|
|
mockBody =
|
|
|
|
jasmine.createSpyObj("body", JQLITE_METHODS);
|
2015-12-29 23:37:09 +00:00
|
|
|
mockPlainEl =
|
|
|
|
jasmine.createSpyObj("htmlElement", ["getBoundingClientRect"]);
|
2015-09-16 23:51:28 +00:00
|
|
|
|
|
|
|
testAttrs = {
|
|
|
|
mctClickElsewhere: "some Angular expression"
|
|
|
|
};
|
|
|
|
testRect = {
|
|
|
|
left: 20,
|
|
|
|
top: 42,
|
|
|
|
width: 60,
|
|
|
|
height: 75
|
|
|
|
};
|
2015-12-29 23:37:09 +00:00
|
|
|
mockElement[0] = mockPlainEl;
|
|
|
|
mockPlainEl.getBoundingClientRect.andReturn(testRect);
|
2015-09-16 23:51:28 +00:00
|
|
|
|
|
|
|
mockDocument.find.andReturn(mockBody);
|
|
|
|
|
|
|
|
mctClickElsewhere = new MCTClickElsewhere(mockDocument);
|
|
|
|
mctClickElsewhere.link(mockScope, mockElement, testAttrs);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("is valid as an attribute", function () {
|
|
|
|
expect(mctClickElsewhere.restrict).toEqual("A");
|
|
|
|
});
|
|
|
|
|
2015-12-29 23:37:09 +00:00
|
|
|
it("detaches listeners when destroyed", function () {
|
|
|
|
expect(mockBody.off).not.toHaveBeenCalled();
|
|
|
|
mockScope.$on.calls.forEach(function (call) {
|
|
|
|
if (call.args[0] === '$destroy') {
|
|
|
|
call.args[1]();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
expect(mockBody.off).toHaveBeenCalled();
|
|
|
|
expect(mockBody.off.mostRecentCall.args)
|
|
|
|
.toEqual(mockBody.on.mostRecentCall.args);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("listens for mousedown on the document's body", function () {
|
|
|
|
expect(mockBody.on)
|
|
|
|
.toHaveBeenCalledWith('mousedown', jasmine.any(Function));
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("when a click occurs outside the element's bounds", function () {
|
|
|
|
beforeEach(function () {
|
|
|
|
mockBody.on.mostRecentCall.args[1](testEvent(
|
|
|
|
testRect.left + testRect.width + 10,
|
|
|
|
testRect.top + testRect.height + 10
|
|
|
|
));
|
|
|
|
});
|
|
|
|
|
|
|
|
it("triggers an evaluation of its related Angular expression", function () {
|
2016-06-08 12:32:21 +00:00
|
|
|
expect(mockScope.$apply).toHaveBeenCalled();
|
|
|
|
mockScope.$apply.mostRecentCall.args[0]();
|
2015-12-29 23:37:09 +00:00
|
|
|
expect(mockScope.$eval)
|
|
|
|
.toHaveBeenCalledWith(testAttrs.mctClickElsewhere);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("when a click occurs within the element's bounds", function () {
|
|
|
|
beforeEach(function () {
|
|
|
|
mockBody.on.mostRecentCall.args[1](testEvent(
|
|
|
|
testRect.left + testRect.width / 2,
|
|
|
|
testRect.top + testRect.height / 2
|
|
|
|
));
|
|
|
|
});
|
|
|
|
|
|
|
|
it("triggers no evaluation", function () {
|
|
|
|
expect(mockScope.$eval).not.toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|
2015-09-16 23:51:28 +00:00
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|