2023-03-14 13:18:55 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) HashiCorp, Inc.
|
2023-08-11 13:12:13 +00:00
|
|
|
* SPDX-License-Identifier: BUSL-1.1
|
2023-03-14 13:18:55 +00:00
|
|
|
*/
|
|
|
|
|
2019-12-17 18:47:37 +00:00
|
|
|
import domIsOutside from 'consul-ui/utils/dom/is-outside';
|
|
|
|
import { module, test } from 'qunit';
|
|
|
|
|
2022-09-15 08:43:17 +00:00
|
|
|
module('Unit | Utility | dom/is-outside', function () {
|
|
|
|
test('it is outside when its in the document but not in the element', function (assert) {
|
2019-12-17 18:47:37 +00:00
|
|
|
// is in the document
|
|
|
|
const doc = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return true;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
// is NOT in the element
|
|
|
|
const el = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return false;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
const target = {};
|
|
|
|
const result = domIsOutside(el, target, doc);
|
|
|
|
assert.ok(result);
|
|
|
|
});
|
2022-09-15 08:43:17 +00:00
|
|
|
test('it is not outside when its not in the document', function (assert) {
|
2019-12-17 18:47:37 +00:00
|
|
|
// is NOT in the document
|
|
|
|
const doc = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return false;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
// is NOT in the element
|
|
|
|
const el = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return false;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
const target = {};
|
|
|
|
const result = domIsOutside(el, target, doc);
|
|
|
|
assert.notOk(result);
|
|
|
|
});
|
2022-09-15 08:43:17 +00:00
|
|
|
test('it is not outside when its in the document but in the element', function (assert) {
|
2019-12-17 18:47:37 +00:00
|
|
|
// is in the document
|
|
|
|
const doc = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return true;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
// is in the element
|
|
|
|
const el = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return true;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
const target = {};
|
|
|
|
const result = domIsOutside(el, target, doc);
|
|
|
|
assert.notOk(result);
|
|
|
|
});
|
2023-02-10 21:32:19 +00:00
|
|
|
test('it is not outside when its in the document but not in the element', function (assert) {
|
2019-12-17 18:47:37 +00:00
|
|
|
// is in the document
|
|
|
|
const doc = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return true;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
// is NOT in the element
|
|
|
|
const el = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return false;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
// is element
|
|
|
|
const target = el;
|
|
|
|
const result = domIsOutside(el, target, doc);
|
|
|
|
assert.notOk(result);
|
|
|
|
});
|
2022-09-15 08:43:17 +00:00
|
|
|
test('it is not outside when target is nullish', function (assert) {
|
2019-12-17 18:47:37 +00:00
|
|
|
// is in the document
|
|
|
|
const doc = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return true;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
// is NOT in the element
|
|
|
|
const el = {
|
2022-09-15 08:43:17 +00:00
|
|
|
contains: function (el) {
|
2019-12-17 18:47:37 +00:00
|
|
|
return false;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
//
|
|
|
|
let target = null;
|
|
|
|
let result = domIsOutside(el, target, doc);
|
|
|
|
assert.notOk(result);
|
|
|
|
target = undefined;
|
|
|
|
result = domIsOutside(el, target, doc);
|
|
|
|
assert.notOk(result);
|
|
|
|
});
|
|
|
|
});
|