diff options
author | Michael Kozono <mkozono@gmail.com> | 2019-08-12 22:02:28 +0000 |
---|---|---|
committer | Michael Kozono <mkozono@gmail.com> | 2019-08-12 22:02:28 +0000 |
commit | 4254f5dc0ea4c226690d0d9abd20d1c9822fefcb (patch) | |
tree | 3cd94454d455b99ae3dd192633fc0942441c46d6 /app/assets/javascripts/pages/search/show/refresh_counts.js | |
parent | 4ce6d2b9db680b7c8563ee65fe25ee4d38a329e9 (diff) | |
parent | 2f8709fb53137c2f53409f2400cd85083b06d6f6 (diff) | |
download | gitlab-ce-4254f5dc0ea4c226690d0d9abd20d1c9822fefcb.tar.gz |
Merge branch 'ce-12547-load-search-counts-async' into 'master'
Load search result counts asynchronously (CE)
See merge request gitlab-org/gitlab-ce!31663
Diffstat (limited to 'app/assets/javascripts/pages/search/show/refresh_counts.js')
-rw-r--r-- | app/assets/javascripts/pages/search/show/refresh_counts.js | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/app/assets/javascripts/pages/search/show/refresh_counts.js b/app/assets/javascripts/pages/search/show/refresh_counts.js new file mode 100644 index 00000000000..fa75ee6075d --- /dev/null +++ b/app/assets/javascripts/pages/search/show/refresh_counts.js @@ -0,0 +1,24 @@ +import axios from '~/lib/utils/axios_utils'; + +function showCount(el, count) { + el.textContent = count; + el.classList.remove('hidden'); +} + +function refreshCount(el) { + const { url } = el.dataset; + + return axios + .get(url) + .then(({ data }) => showCount(el, data.count)) + .catch(e => { + // eslint-disable-next-line no-console + console.error(`Failed to fetch search count from '${url}'.`, e); + }); +} + +export default function refreshCounts() { + const elements = Array.from(document.querySelectorAll('.js-search-count')); + + return Promise.all(elements.map(refreshCount)); +} |