Skip to content

Commit

Permalink
flags
Browse files Browse the repository at this point in the history
  • Loading branch information
taylorhelene authored and svrnm committed Nov 11, 2024
1 parent eb958bd commit dc12484
Show file tree
Hide file tree
Showing 3 changed files with 102 additions and 18 deletions.
67 changes: 50 additions & 17 deletions assets/js/registrySearch.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@ let pathName = window.location.pathname;
let searchQuery = '';
let selectedLanguage = 'all';
let selectedComponent = 'all';
let selectedFlag = 'all'; // Added selectedFlag


parseUrlParams();

Expand All @@ -49,22 +51,24 @@ if (pathName.includes('registry')) {
showBody();
}

if (selectedLanguage !== 'all' || selectedComponent !== 'all') {
// Set the dropdown values from query params
if (selectedLanguage !== 'all' || selectedComponent !== 'all' || selectedFlag !== 'all') {
if (selectedLanguage !== 'all') {
document.getElementById('languageDropdown').textContent =
document.getElementById(
`language-item-${selectedLanguage}`,
).textContent;
document.getElementById(`language-item-${selectedLanguage}`).textContent;
}
if (selectedComponent !== 'all') {
document.getElementById('componentDropdown').textContent =
document.getElementById(
`component-item-${selectedComponent}`,
).textContent;
document.getElementById(`component-item-${selectedComponent}`).textContent;
}
if (selectedFlag !== 'all') {
document.getElementById('flagsDropdown').textContent =
document.getElementById(`flag-item-${selectedFlag}`).textContent;
}
updateFilters();
}


document.addEventListener('DOMContentLoaded', (event) => {
let searchForm = document.getElementById('searchForm');
searchForm.addEventListener('submit', function (evt) {
Expand Down Expand Up @@ -106,6 +110,23 @@ if (pathName.includes('registry')) {
updateFilters();
}),
);
// Flags dropdown event listener

let flagList = document
.getElementById('flagsFilter')
.querySelectorAll('.dropdown-item');

flagList.forEach((element) =>
element.addEventListener('click', function (evt) {
let val = evt.target.getAttribute('value');
selectedFlag = val;
document.getElementById('flagsDropdown').textContent = evt.target.textContent;
setInput('flag', val);
updateFilters();
})
);


});
}

Expand Down Expand Up @@ -208,34 +229,46 @@ function setInput(key, value) {
history.replaceState(null, null, '?' + queryParams.toString());
}

// Filters items based on language and component filters
// Filters items based on language, component, and flags
function updateFilters() {
let allItems = [...document.getElementsByClassName('registry-entry')];
if (selectedComponent === 'all' && selectedLanguage === 'all') {
if (selectedComponent === 'all' && selectedLanguage === 'all' && selectedFlag === 'all') {
// Show all items if all filters are set to 'all'
allItems.forEach((element) => element.classList.remove('d-none'));
} else {
// Apply the filters
allItems.forEach((element) => {
const dc = element.dataset.registrytype;
const dl = element.dataset.registrylanguage;
if (
(dc === selectedComponent || selectedComponent === 'all') &&
(dl === selectedLanguage || selectedLanguage === 'all')
) {
const df = element.dataset.registryflags ? element.dataset.registryflags.split(' ').map(f => f.toLowerCase()) : [];

const componentMatches = (dc === selectedComponent || selectedComponent === 'all');
const languageMatches = (dl === selectedLanguage || selectedLanguage === 'all');
const flagMatches = (selectedFlag === 'all' || df.includes(selectedFlag.toLowerCase()));

console.log('Selected Flag:', selectedFlag);
console.log('Registry Flags:', df);

if (flagMatches) {
console.log('Flag matches:', df);
}


if (componentMatches && languageMatches && flagMatches) { // Changed
element.classList.remove('d-none');
} else if (dc === selectedComponent && dl !== selectedLanguage) {
element.classList.add('d-none');
} else if (dl === selectedLanguage && dc !== selectedComponent) {
element.classList.add('d-none');
} else {
element.classList.add('d-none');
}
});
}
}


// Parse URL parameters and update variables
function parseUrlParams() {
let urlParams = new URLSearchParams(window.location.search);
searchQuery = urlParams.get('s');
selectedLanguage = urlParams.get('language') || 'all';
selectedComponent = urlParams.get('component') || 'all';
selectedFlag = urlParams.get('flag') || 'all'; // Added
}
12 changes: 11 additions & 1 deletion layouts/partials/ecosystem/registry/entry.html
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,17 @@
{{ errorf "The %q registry entry requires a repo or website URL." .title }}
{{ end -}}
{{ $primaryHref := printf "href=%q" $primaryUrl | safeHTMLAttr -}}
<li class="card my-3 registry-entry {{ $highlightStyle }}" data-registry-id="{{ ._key }}" data-registrytype="{{ .registryType }}" data-registrylanguage="{{ .language }}">
{{ $flags := slice -}} <!-- Initialize flags slice -->
{{ if $isNative -}}
{{ $flags = $flags | append "native" -}}
{{ end -}}
{{ if $isFirstParty -}}
{{ $flags = $flags | append "first party" -}}
{{ end -}}
{{ if $deprecated -}}
{{ $flags = $flags | append "deprecated" -}}
{{ end -}}
<li class="card my-3 registry-entry {{ $highlightStyle }}" data-registry-id="{{ ._key }}" data-registrytype="{{ .registryType }}" data-registrylanguage="{{ .language }}" data-registryflags="{{- range $index, $flag := $flags -}}{{ if $index }} {{ end }}{{ $flag }}{{- end }}">
<div class="card-body container">
<h4 class="card-title mb-0 d-flex flex-row">
<a {{ $primaryHref }} target="_blank" rel="noopener" class="me-auto">
Expand Down
41 changes: 41 additions & 0 deletions layouts/shortcodes/ecosystem/registry/search-form.html
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,35 @@
{{ end -}}
{{ $types = $types | uniq | sort -}}

{{ $counter := 0 -}}
{{ $entries := slice -}}
{{ range $key, $entry := .Site.Data.registry -}}
{{ $flags := slice -}}
{{ if .isNative -}}
{{ $flags = $flags | append "native" -}}
{{ end -}}
{{ if .isFirstParty -}}
{{ $flags = $flags | append "first party" -}}
{{ end -}}
{{ if .deprecated -}}
{{ $flags = $flags | append "deprecated" -}}
{{ end -}}
{{ $entry = merge $entry (dict "_key" $key "id" $counter "flags" $flags) -}}
{{ $entries = $entries | append $entry -}}
{{ $counter = add $counter 1 }}
{{ end -}}



{{ $allFlags := slice -}}
{{ range $entry := $entries -}}
{{ range $flag := $entry.flags -}}
{{ $allFlags = $allFlags | append $flag }}
{{ end -}}
{{ end -}}
{{ $uniqueFlags := $allFlags | uniq | sort }}


<div class="alert alert-info">
The OpenTelemetry Registry allows you to search for instrumentation libraries,
collector components, utilities, and other useful projects in the OpenTelemetry
Expand All @@ -51,6 +80,8 @@

<input type="hidden" name="component" id="input-component" value="" />
<input type="hidden" name="language" id="input-language" value="" />
<input type="hidden" name="flag" id="input-flag" value="all" />


<button type="button" class="btn btn-outline-success"
onclick="document.getElementById('searchForm').submit();">Submit</button>
Expand Down Expand Up @@ -88,6 +119,16 @@
{{ end -}}
</div>

<!-- Flags Filter Dropdown -->
<button class="btn btn-outline-secondary dropdown-toggle" id="flagsDropdown" type="button"
data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Flags</button>
<div class="dropdown-menu" id="flagsFilter">
<a value="all" class="dropdown-item">Any Flag</a>
{{ range $flag := $uniqueFlags -}}
<a value="{{ $flag }}" id="flag-item-{{ $flag }}" class="dropdown-item">{{ humanize $flag }}</a>
{{ end -}}
</div>

</div>
</form>
</div>
Expand Down

0 comments on commit dc12484

Please sign in to comment.