mirror of
https://github.com/netbox-community/netbox.git
synced 2024-05-10 07:54:54 +00:00
add javascript
This commit is contained in:
37
netbox/project-static/src/search.ts
Normal file
37
netbox/project-static/src/search.ts
Normal file
@ -0,0 +1,37 @@
|
||||
interface SearchFilterButton extends EventTarget {
|
||||
dataset: { searchValue: string };
|
||||
}
|
||||
|
||||
function isSearchButton(el: any): el is SearchFilterButton {
|
||||
return el?.dataset?.searchValue ?? null !== null;
|
||||
}
|
||||
|
||||
export function initSearchBar() {
|
||||
const dropdown = document.getElementById('object-type-selector');
|
||||
const selectedValue = document.getElementById('selected-value') as HTMLSpanElement;
|
||||
const selectedType = document.getElementById('search-obj-type') as HTMLInputElement;
|
||||
let selected = '';
|
||||
|
||||
if (dropdown !== null) {
|
||||
const buttons = dropdown.querySelectorAll('li > button.dropdown-item');
|
||||
for (const button of buttons) {
|
||||
if (button !== null) {
|
||||
function handleClick(event: Event) {
|
||||
if (isSearchButton(event.target)) {
|
||||
const objectType = event.target.dataset.searchValue;
|
||||
if (objectType !== '' && selected !== objectType) {
|
||||
selected = objectType;
|
||||
selectedValue.innerHTML = button.textContent ?? 'Error';
|
||||
selectedType.value = objectType;
|
||||
} else {
|
||||
selected = '';
|
||||
selectedType.innerHTML = 'All Objects';
|
||||
selectedType.value = '';
|
||||
}
|
||||
}
|
||||
}
|
||||
button.addEventListener('click', handleClick);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user