mirror of
https://github.com/overte-org/overte.git
synced 2025-08-10 12:12:32 +02:00
Merge pull request #14198 from dback2/entityListTypeFilter
Entity list type filter and X to clear search
This commit is contained in:
commit
5729d35c48
3 changed files with 274 additions and 65 deletions
|
@ -198,7 +198,7 @@ td.url {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
input[type="text"], input[type="number"], textarea {
|
input[type="text"], input[type="search"], input[type="number"], textarea {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0 12px;
|
padding: 0 12px;
|
||||||
color: #afafaf;
|
color: #afafaf;
|
||||||
|
@ -257,12 +257,22 @@ input[type="text"] {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
input[type="search"] {
|
||||||
|
height: 28px;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
input[type="search"]::-webkit-search-cancel-button {
|
||||||
|
-webkit-appearance: none;
|
||||||
|
height: 20px;
|
||||||
|
width: 20px;
|
||||||
|
background-image: url('')
|
||||||
|
}
|
||||||
|
|
||||||
input[type="number"] {
|
input[type="number"] {
|
||||||
position: relative;
|
position: relative;
|
||||||
height: 28px;
|
height: 28px;
|
||||||
width: 124px;
|
width: 124px;
|
||||||
}
|
}
|
||||||
|
|
||||||
input[type=number] {
|
input[type=number] {
|
||||||
padding-right: 3px;
|
padding-right: 3px;
|
||||||
}
|
}
|
||||||
|
@ -1045,31 +1055,123 @@ textarea:enabled[scrolling="true"]::-webkit-resizer {
|
||||||
padding-top: 9px;
|
padding-top: 9px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#search-area {
|
#filter-area {
|
||||||
padding-right: 168px;
|
padding-right: 168px;
|
||||||
padding-bottom: 24px;
|
padding-bottom: 24px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#filter {
|
.multiselect {
|
||||||
width: 98%;
|
position: relative;
|
||||||
|
}
|
||||||
|
.select-box {
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
.select-box select {
|
||||||
|
font-family: FiraSans-SemiBold;
|
||||||
|
font-size: 15px;
|
||||||
|
color: #afafaf;
|
||||||
|
background-color: #252525;
|
||||||
|
border: none;
|
||||||
|
height: 28px;
|
||||||
|
width: 107px;
|
||||||
|
text-align-last: center;
|
||||||
|
}
|
||||||
|
.over-select {
|
||||||
|
position: absolute;
|
||||||
|
left: 0;
|
||||||
|
right: 0;
|
||||||
|
top: 0;
|
||||||
|
bottom: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#in-view {
|
#filter-type-select-box select {
|
||||||
|
border-radius: 14.5px;
|
||||||
|
}
|
||||||
|
#filter-type-checkboxes {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
|
z-index: 2;
|
||||||
|
top: 48px;
|
||||||
|
display: none;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
#filter-type-checkboxes div {
|
||||||
|
position: relative;
|
||||||
|
height: 22px;
|
||||||
|
}
|
||||||
|
#filter-type-checkboxes span {
|
||||||
|
position: relative;
|
||||||
|
top: 3px;
|
||||||
|
font-family: hifi-glyphs;
|
||||||
|
font-size: 13px;
|
||||||
|
color: #000000;
|
||||||
|
padding-left: 6px;
|
||||||
|
padding-right: 4px;
|
||||||
|
}
|
||||||
|
#filter-type-checkboxes label {
|
||||||
|
position: absolute;
|
||||||
|
top: -20px;
|
||||||
|
z-index: 2;
|
||||||
|
display: block;
|
||||||
|
font-family: FiraSans-SemiBold;
|
||||||
|
font-size: 11px;
|
||||||
|
color: #000000;
|
||||||
|
background-color: #afafaf;
|
||||||
|
width: 200px;
|
||||||
|
height: 22px;
|
||||||
|
padding-top: 1px;
|
||||||
|
}
|
||||||
|
#filter-type-checkboxes label:hover {
|
||||||
|
background-color: #1e90ff;
|
||||||
|
}
|
||||||
|
#filter-type-checkboxes input[type=checkbox] + label {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 11px 11px;
|
||||||
|
background-position: top 5px left 14px;
|
||||||
|
}
|
||||||
|
#filter-type-checkboxes input[type=checkbox]:checked + label {
|
||||||
|
background-image: url('');
|
||||||
|
background-size: 11px 11px;
|
||||||
|
background-position: top 5px left 14px;
|
||||||
|
}
|
||||||
|
#filter-type-checkboxes input[type=checkbox]:hover + label {
|
||||||
|
background-color: #1e90ff;
|
||||||
|
}
|
||||||
|
|
||||||
|
#filter-search-and-icon {
|
||||||
|
position: relative;
|
||||||
|
left: 118px;
|
||||||
|
width: calc(100% - 126px);
|
||||||
|
}
|
||||||
|
|
||||||
|
#filter-in-view {
|
||||||
|
position: absolute;
|
||||||
|
top: 0px;
|
||||||
right: 126px;
|
right: 126px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#radius-and-unit {
|
#filter-radius-and-unit {
|
||||||
|
position: relative;
|
||||||
float: right;
|
float: right;
|
||||||
margin-right: -168px;
|
margin-right: -168px;
|
||||||
position: relative;
|
top: -45px;
|
||||||
top: -17px;
|
|
||||||
}
|
}
|
||||||
#radius-and-unit label {
|
#filter-radius-and-unit label {
|
||||||
margin-left: 2px;
|
margin-left: 2px;
|
||||||
}
|
}
|
||||||
#radius-and-unit input {
|
#filter-radius-and-unit span {
|
||||||
|
position: relative;
|
||||||
|
top: 25px;
|
||||||
|
right: 9px;
|
||||||
|
z-index: 2;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
#filter-radius-and-unit input {
|
||||||
width: 120px;
|
width: 120px;
|
||||||
|
border-radius: 14.5px;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
#filter-radius-and-unit input[type=number]::-webkit-inner-spin-button {
|
||||||
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
#entity-table-scroll {
|
#entity-table-scroll {
|
||||||
|
|
|
@ -30,12 +30,25 @@
|
||||||
<input type="button" class="red" id="delete" value="Delete" />
|
<input type="button" class="red" id="delete" value="Delete" />
|
||||||
</div>
|
</div>
|
||||||
<div id="entity-list">
|
<div id="entity-list">
|
||||||
<div id="search-area">
|
<div id="filter-area">
|
||||||
<span class="icon-input"><input type="text" class="search" id="filter" placeholder="Filter" /><span>Y</span></span>
|
<div class="multiselect">
|
||||||
<input type="button" id="in-view" class="glyph" value="" />
|
<div class="select-box" id="filter-type-select-box">
|
||||||
<div id="radius-and-unit" class="number">
|
<select>
|
||||||
|
<option id="filter-type-text">All Types</option>
|
||||||
|
</select>
|
||||||
|
<div class="over-select"></div>
|
||||||
|
</div>
|
||||||
|
<div id="filter-type-checkboxes">
|
||||||
|
<!-- type options with checkbox, icon, and label are added at runtime in entityList -->
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="filter-search-and-icon">
|
||||||
|
<span class="icon-input"><input type="search" class="search" id="filter-search" placeholder="Search" /><span>Y</span></span>
|
||||||
|
</div>
|
||||||
|
<input type="button" id="filter-in-view" class="glyph" value="" />
|
||||||
|
<div id="filter-radius-and-unit" class="number">
|
||||||
<label for="radius">Search radius <span class="unit">m</span></label>
|
<label for="radius">Search radius <span class="unit">m</span></label>
|
||||||
<input type="number" id="radius" value="100" />
|
<input type="text" id="filter-radius" maxlength="9" value="100" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div id="entity-table-scroll">
|
<div id="entity-table-scroll">
|
||||||
|
@ -88,9 +101,8 @@
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
<div id="no-entities">
|
<div id="no-entities">
|
||||||
No entities found <span id="no-entities-in-view">in view</span> within a <span id="no-entities-radius">100</span> meter radius. Try moving to a different location and refreshing.
|
There are no entities to display. Please check your filters or create an entity to begin.
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -23,6 +23,7 @@ const FILTER_IN_VIEW_ATTRIBUTE = "pressed";
|
||||||
const WINDOW_NONVARIABLE_HEIGHT = 227;
|
const WINDOW_NONVARIABLE_HEIGHT = 227;
|
||||||
const NUM_COLUMNS = 12;
|
const NUM_COLUMNS = 12;
|
||||||
const EMPTY_ENTITY_ID = "0";
|
const EMPTY_ENTITY_ID = "0";
|
||||||
|
const MAX_LENGTH_RADIUS = 9;
|
||||||
const DELETE = 46; // Key code for the delete key.
|
const DELETE = 46; // Key code for the delete key.
|
||||||
const KEY_P = 80; // Key code for letter p used for Parenting hotkey.
|
const KEY_P = 80; // Key code for letter p used for Parenting hotkey.
|
||||||
|
|
||||||
|
@ -59,6 +60,30 @@ const COMPARE_DESCENDING = function(a, b) {
|
||||||
return COMPARE_ASCENDING(b, a);
|
return COMPARE_ASCENDING(b, a);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const FILTER_TYPES = [
|
||||||
|
"Shape",
|
||||||
|
"Model",
|
||||||
|
"Image",
|
||||||
|
"Light",
|
||||||
|
"Zone",
|
||||||
|
"Web",
|
||||||
|
"Material",
|
||||||
|
"ParticleEffect",
|
||||||
|
"Text",
|
||||||
|
];
|
||||||
|
|
||||||
|
const ICON_FOR_TYPE = {
|
||||||
|
Shape: "n",
|
||||||
|
Model: "",
|
||||||
|
Image: "",
|
||||||
|
Light: "p",
|
||||||
|
Zone: "o",
|
||||||
|
Web: "q",
|
||||||
|
Material: "",
|
||||||
|
ParticleEffect: "",
|
||||||
|
Text: "l",
|
||||||
|
};
|
||||||
|
|
||||||
// List of all entities
|
// List of all entities
|
||||||
var entities = [];
|
var entities = [];
|
||||||
// List of all entities, indexed by Entity ID
|
// List of all entities, indexed by Entity ID
|
||||||
|
@ -77,6 +102,7 @@ var entityListContextMenu = null;
|
||||||
|
|
||||||
var currentSortColumn = 'type';
|
var currentSortColumn = 'type';
|
||||||
var currentSortOrder = ASCENDING_SORT;
|
var currentSortOrder = ASCENDING_SORT;
|
||||||
|
var typeFilters = [];
|
||||||
var isFilterInView = false;
|
var isFilterInView = false;
|
||||||
var showExtraInfo = false;
|
var showExtraInfo = false;
|
||||||
|
|
||||||
|
@ -110,9 +136,12 @@ function loaded() {
|
||||||
elToggleLocked = document.getElementById("locked");
|
elToggleLocked = document.getElementById("locked");
|
||||||
elToggleVisible = document.getElementById("visible");
|
elToggleVisible = document.getElementById("visible");
|
||||||
elDelete = document.getElementById("delete");
|
elDelete = document.getElementById("delete");
|
||||||
elFilter = document.getElementById("filter");
|
elFilterTypeSelectBox = document.getElementById("filter-type-select-box");
|
||||||
elInView = document.getElementById("in-view")
|
elFilterTypeText = document.getElementById("filter-type-text");
|
||||||
elRadius = document.getElementById("radius");
|
elFilterTypeCheckboxes = document.getElementById("filter-type-checkboxes");
|
||||||
|
elFilterSearch = document.getElementById("filter-search");
|
||||||
|
elFilterInView = document.getElementById("filter-in-view")
|
||||||
|
elFilterRadius = document.getElementById("filter-radius");
|
||||||
elExport = document.getElementById("export");
|
elExport = document.getElementById("export");
|
||||||
elPal = document.getElementById("pal");
|
elPal = document.getElementById("pal");
|
||||||
elInfoToggle = document.getElementById("info-toggle");
|
elInfoToggle = document.getElementById("info-toggle");
|
||||||
|
@ -120,9 +149,8 @@ function loaded() {
|
||||||
elSelectedEntitiesCount = document.getElementById("selected-entities-count");
|
elSelectedEntitiesCount = document.getElementById("selected-entities-count");
|
||||||
elVisibleEntitiesCount = document.getElementById("visible-entities-count");
|
elVisibleEntitiesCount = document.getElementById("visible-entities-count");
|
||||||
elNoEntitiesMessage = document.getElementById("no-entities");
|
elNoEntitiesMessage = document.getElementById("no-entities");
|
||||||
elNoEntitiesInView = document.getElementById("no-entities-in-view");
|
|
||||||
elNoEntitiesRadius = document.getElementById("no-entities-radius");
|
|
||||||
|
|
||||||
|
document.body.onclick = onBodyClick;
|
||||||
document.getElementById("entity-name").onclick = function() {
|
document.getElementById("entity-name").onclick = function() {
|
||||||
setSortColumn('name');
|
setSortColumn('name');
|
||||||
};
|
};
|
||||||
|
@ -132,31 +160,31 @@ function loaded() {
|
||||||
document.getElementById("entity-url").onclick = function() {
|
document.getElementById("entity-url").onclick = function() {
|
||||||
setSortColumn('url');
|
setSortColumn('url');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-locked").onclick = function () {
|
document.getElementById("entity-locked").onclick = function() {
|
||||||
setSortColumn('locked');
|
setSortColumn('locked');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-visible").onclick = function () {
|
document.getElementById("entity-visible").onclick = function() {
|
||||||
setSortColumn('visible');
|
setSortColumn('visible');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-verticesCount").onclick = function () {
|
document.getElementById("entity-verticesCount").onclick = function() {
|
||||||
setSortColumn('verticesCount');
|
setSortColumn('verticesCount');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-texturesCount").onclick = function () {
|
document.getElementById("entity-texturesCount").onclick = function() {
|
||||||
setSortColumn('texturesCount');
|
setSortColumn('texturesCount');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-texturesSize").onclick = function () {
|
document.getElementById("entity-texturesSize").onclick = function() {
|
||||||
setSortColumn('texturesSize');
|
setSortColumn('texturesSize');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-hasTransparent").onclick = function () {
|
document.getElementById("entity-hasTransparent").onclick = function() {
|
||||||
setSortColumn('hasTransparent');
|
setSortColumn('hasTransparent');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-isBaked").onclick = function () {
|
document.getElementById("entity-isBaked").onclick = function() {
|
||||||
setSortColumn('isBaked');
|
setSortColumn('isBaked');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-drawCalls").onclick = function () {
|
document.getElementById("entity-drawCalls").onclick = function() {
|
||||||
setSortColumn('drawCalls');
|
setSortColumn('drawCalls');
|
||||||
};
|
};
|
||||||
document.getElementById("entity-hasScript").onclick = function () {
|
document.getElementById("entity-hasScript").onclick = function() {
|
||||||
setSortColumn('hasScript');
|
setSortColumn('hasScript');
|
||||||
};
|
};
|
||||||
elRefresh.onclick = function() {
|
elRefresh.onclick = function() {
|
||||||
|
@ -177,15 +205,38 @@ function loaded() {
|
||||||
elDelete.onclick = function() {
|
elDelete.onclick = function() {
|
||||||
EventBridge.emitWebEvent(JSON.stringify({ type: 'delete' }));
|
EventBridge.emitWebEvent(JSON.stringify({ type: 'delete' }));
|
||||||
};
|
};
|
||||||
elFilter.onkeyup = refreshEntityList;
|
elFilterTypeSelectBox.onclick = onToggleTypeDropdown;
|
||||||
elFilter.onpaste = refreshEntityList;
|
elFilterSearch.onkeyup = refreshEntityList;
|
||||||
elFilter.onchange = onFilterChange;
|
elFilterSearch.onsearch = refreshEntityList;
|
||||||
elFilter.onblur = refreshFooter;
|
elFilterInView.onclick = toggleFilterInView;
|
||||||
elInView.onclick = toggleFilterInView;
|
elFilterRadius.onkeyup = onRadiusChange;
|
||||||
elRadius.onchange = onRadiusChange;
|
elFilterRadius.onchange = onRadiusChange;
|
||||||
|
elFilterRadius.onclick = onRadiusChange;
|
||||||
elInfoToggle.onclick = toggleInfo;
|
elInfoToggle.onclick = toggleInfo;
|
||||||
|
|
||||||
elNoEntitiesInView.style.display = "none";
|
// create filter type dropdown checkboxes with label and icon for each type
|
||||||
|
for (let i = 0; i < FILTER_TYPES.length; ++i) {
|
||||||
|
let type = FILTER_TYPES[i];
|
||||||
|
let typeFilterID = "filter-type-" + type;
|
||||||
|
let elDiv = document.createElement('div');
|
||||||
|
let elLabel = document.createElement('label');
|
||||||
|
elLabel.setAttribute("for", typeFilterID);
|
||||||
|
elLabel.innerText = type;
|
||||||
|
let elSpan = document.createElement('span');
|
||||||
|
elSpan.setAttribute("class", "typeIcon");
|
||||||
|
elSpan.innerHTML = ICON_FOR_TYPE[type];
|
||||||
|
let elInput = document.createElement('input');
|
||||||
|
elInput.setAttribute("type", "checkbox");
|
||||||
|
elInput.setAttribute("id", typeFilterID);
|
||||||
|
elInput.setAttribute("filterType", type);
|
||||||
|
elInput.checked = true; // all types are checked initially
|
||||||
|
toggleTypeFilter(elInput, false); // add all types to the initial types filter
|
||||||
|
elDiv.appendChild(elInput);
|
||||||
|
elLabel.insertBefore(elSpan, elLabel.childNodes[0]);
|
||||||
|
elDiv.appendChild(elLabel);
|
||||||
|
elFilterTypeCheckboxes.appendChild(elDiv);
|
||||||
|
elDiv.onclick = onToggleTypeFilter;
|
||||||
|
}
|
||||||
|
|
||||||
entityList = new ListView(elEntityTableBody, elEntityTableScroll, elEntityTableHeaderRow,
|
entityList = new ListView(elEntityTableBody, elEntityTableScroll, elEntityTableHeaderRow,
|
||||||
createRow, updateRow, clearRow, WINDOW_NONVARIABLE_HEIGHT);
|
createRow, updateRow, clearRow, WINDOW_NONVARIABLE_HEIGHT);
|
||||||
|
@ -396,17 +447,16 @@ function loaded() {
|
||||||
function refreshEntityList() {
|
function refreshEntityList() {
|
||||||
PROFILE("refresh-entity-list", function() {
|
PROFILE("refresh-entity-list", function() {
|
||||||
PROFILE("filter", function() {
|
PROFILE("filter", function() {
|
||||||
let searchTerm = elFilter.value.toLowerCase();
|
let searchTerm = elFilterSearch.value.toLowerCase();
|
||||||
if (searchTerm === '') {
|
visibleEntities = entities.filter(function(e) {
|
||||||
visibleEntities = entities.slice(0);
|
let type = e.type === "Box" || e.type === "Sphere" ? "Shape" : e.type;
|
||||||
} else {
|
let typeFilter = typeFilters.indexOf(type) > -1;
|
||||||
visibleEntities = entities.filter(function(e) {
|
let searchFilter = searchTerm === '' || (e.name.toLowerCase().indexOf(searchTerm) > -1 ||
|
||||||
return e.name.toLowerCase().indexOf(searchTerm) > -1
|
e.type.toLowerCase().indexOf(searchTerm) > -1 ||
|
||||||
|| e.type.toLowerCase().indexOf(searchTerm) > -1
|
e.fullUrl.toLowerCase().indexOf(searchTerm) > -1 ||
|
||||||
|| e.fullUrl.toLowerCase().indexOf(searchTerm) > -1
|
e.id.toLowerCase().indexOf(searchTerm) > -1);
|
||||||
|| e.id.toLowerCase().indexOf(searchTerm) > -1;
|
return typeFilter && searchFilter;
|
||||||
});
|
});
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
PROFILE("sort", function() {
|
PROFILE("sort", function() {
|
||||||
|
@ -697,29 +747,74 @@ function loaded() {
|
||||||
function toggleFilterInView() {
|
function toggleFilterInView() {
|
||||||
isFilterInView = !isFilterInView;
|
isFilterInView = !isFilterInView;
|
||||||
if (isFilterInView) {
|
if (isFilterInView) {
|
||||||
elInView.setAttribute(FILTER_IN_VIEW_ATTRIBUTE, FILTER_IN_VIEW_ATTRIBUTE);
|
elFilterInView.setAttribute(FILTER_IN_VIEW_ATTRIBUTE, FILTER_IN_VIEW_ATTRIBUTE);
|
||||||
elNoEntitiesInView.style.display = "inline";
|
|
||||||
} else {
|
} else {
|
||||||
elInView.removeAttribute(FILTER_IN_VIEW_ATTRIBUTE);
|
elFilterInView.removeAttribute(FILTER_IN_VIEW_ATTRIBUTE);
|
||||||
elNoEntitiesInView.style.display = "none";
|
|
||||||
}
|
}
|
||||||
EventBridge.emitWebEvent(JSON.stringify({ type: "filterInView", filterInView: isFilterInView }));
|
EventBridge.emitWebEvent(JSON.stringify({ type: "filterInView", filterInView: isFilterInView }));
|
||||||
refreshEntities();
|
refreshEntities();
|
||||||
}
|
}
|
||||||
|
|
||||||
function onFilterChange() {
|
|
||||||
refreshEntityList();
|
|
||||||
entityList.resize();
|
|
||||||
}
|
|
||||||
|
|
||||||
function onRadiusChange() {
|
function onRadiusChange() {
|
||||||
elRadius.value = Math.max(elRadius.value, 0);
|
elFilterRadius.value = elFilterRadius.value.replace(/[^0-9]/g, '');
|
||||||
elNoEntitiesRadius.firstChild.nodeValue = elRadius.value;
|
elFilterRadius.value = Math.max(elFilterRadius.value, 0);
|
||||||
elNoEntitiesMessage.style.display = "none";
|
EventBridge.emitWebEvent(JSON.stringify({ type: 'radius', radius: elFilterRadius.value }));
|
||||||
EventBridge.emitWebEvent(JSON.stringify({ type: 'radius', radius: elRadius.value }));
|
|
||||||
refreshEntities();
|
refreshEntities();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function isTypeDropdownVisible() {
|
||||||
|
return elFilterTypeCheckboxes.style.display === "block";
|
||||||
|
}
|
||||||
|
|
||||||
|
function toggleTypeDropdown() {
|
||||||
|
elFilterTypeCheckboxes.style.display = isTypeDropdownVisible() ? "none" : "block";
|
||||||
|
}
|
||||||
|
|
||||||
|
function onToggleTypeDropdown(event) {
|
||||||
|
toggleTypeDropdown();
|
||||||
|
event.stopPropagation();
|
||||||
|
}
|
||||||
|
|
||||||
|
function toggleTypeFilter(elInput, refresh) {
|
||||||
|
let type = elInput.getAttribute("filterType");
|
||||||
|
let typeChecked = elInput.checked;
|
||||||
|
|
||||||
|
let typeFilterIndex = typeFilters.indexOf(type);
|
||||||
|
if (!typeChecked && typeFilterIndex > -1) {
|
||||||
|
typeFilters.splice(typeFilterIndex, 1);
|
||||||
|
} else if (typeChecked && typeFilterIndex === -1) {
|
||||||
|
typeFilters.push(type);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeFilters.length === 0) {
|
||||||
|
elFilterTypeText.innerText = "No Types";
|
||||||
|
} else if (typeFilters.length === FILTER_TYPES.length) {
|
||||||
|
elFilterTypeText.innerText = "All Types";
|
||||||
|
} else {
|
||||||
|
elFilterTypeText.innerText = "Types...";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (refresh) {
|
||||||
|
refreshEntityList();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function onToggleTypeFilter(event) {
|
||||||
|
let elTarget = event.target;
|
||||||
|
if (elTarget instanceof HTMLInputElement) {
|
||||||
|
toggleTypeFilter(elTarget, true);
|
||||||
|
}
|
||||||
|
event.stopPropagation();
|
||||||
|
}
|
||||||
|
|
||||||
|
function onBodyClick(event) {
|
||||||
|
// if clicking anywhere outside of the type filter dropdown (since click event bubbled up to onBodyClick and
|
||||||
|
// propagation wasn't stopped by onToggleTypeFilter or onToggleTypeDropdown) and the dropdown is open then close it
|
||||||
|
if (isTypeDropdownVisible()) {
|
||||||
|
toggleTypeDropdown();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
function toggleInfo(event) {
|
function toggleInfo(event) {
|
||||||
showExtraInfo = !showExtraInfo;
|
showExtraInfo = !showExtraInfo;
|
||||||
if (showExtraInfo) {
|
if (showExtraInfo) {
|
||||||
|
@ -732,7 +827,7 @@ function loaded() {
|
||||||
entityList.resize();
|
entityList.resize();
|
||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
}
|
}
|
||||||
|
|
||||||
document.addEventListener("keydown", function (keyDownEvent) {
|
document.addEventListener("keydown", function (keyDownEvent) {
|
||||||
if (keyDownEvent.target.nodeName === "INPUT") {
|
if (keyDownEvent.target.nodeName === "INPUT") {
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in a new issue