|
7 | 7 | </div> |
8 | 8 | <div class="search-box flex-none" v-if="$route.name !== 'dashboard'"> |
9 | 9 | <input type="text" class="search-input" id="searchInput" placeholder="Search..." |
10 | | - :class="{ 'has-search-results': servers.length > 0 && searchActive }" |
| 10 | + :class="{ 'has-search-results': (servers.length > 0 || loadingResults) && searchActive }" |
11 | 11 | v-on:focus="searchActive = true" |
12 | 12 | v-on:blur="searchActive = false" |
13 | 13 | v-on:input="search" |
14 | 14 | v-model="searchTerm" |
15 | 15 | /> |
16 | | - <div class="search-results select-none" :class="{ 'hidden': servers.length === 0 || !searchActive }"> |
17 | | - <router-link |
18 | | - v-for="server in servers" |
19 | | - :key="server.identifier" |
20 | | - :to="{ name: 'server', params: { id: server.identifier } }" |
21 | | - > |
22 | | - <div class="flex items-center"> |
23 | | - <div class="flex-1"> |
24 | | - <span class="font-bold text-grey-darkest">{{ server.name }}</span><br /> |
25 | | - <span class="font-light text-grey-dark text-sm" v-if="server.description.length > 0">{{ server.description }}</span> |
| 16 | + <div class="search-results select-none" :class="{ 'hidden': (servers.length === 0 && !loadingResults) || !searchActive }"> |
| 17 | + <div v-if="loadingResults"> |
| 18 | + <a href="#"> |
| 19 | + <div class="flex items-center"> |
| 20 | + <div class="flex-1"> |
| 21 | + <span class="text-sm text-grey-darker">Loading...</span> |
| 22 | + </div> |
| 23 | + <div class="flex-none"> |
| 24 | + <span class="spinner spinner-relative"></span> |
| 25 | + </div> |
26 | 26 | </div> |
27 | | - <div class="flex-none"> |
28 | | - <span class="pillbox bg-indigo">{{ server.node }}</span> |
| 27 | + </a> |
| 28 | + </div> |
| 29 | + <div v-else> |
| 30 | + <router-link |
| 31 | + v-for="server in servers" |
| 32 | + :key="server.identifier" |
| 33 | + :to="{ name: 'server', params: { id: server.identifier } }" |
| 34 | + > |
| 35 | + <div class="flex items-center"> |
| 36 | + <div class="flex-1"> |
| 37 | + <span class="font-bold text-grey-darkest">{{ server.name }}</span><br /> |
| 38 | + <span class="font-light text-grey-dark text-sm" v-if="server.description.length > 0">{{ server.description }}</span> |
| 39 | + </div> |
| 40 | + <div class="flex-none"> |
| 41 | + <span class="pillbox bg-indigo">{{ server.node }}</span> |
| 42 | + </div> |
29 | 43 | </div> |
30 | | - </div> |
31 | | - </router-link> |
| 44 | + </router-link> |
| 45 | + </div> |
32 | 46 | </div> |
33 | 47 | </div> |
34 | 48 | <div class="menu flex-none"> |
|
69 | 83 |
|
70 | 84 | data: function () { |
71 | 85 | return { |
| 86 | + loadingResults: false, |
72 | 87 | searchActive: false, |
73 | 88 | }; |
74 | 89 | }, |
|
88 | 103 | methods: { |
89 | 104 | search: debounce(function () { |
90 | 105 | if (this.searchTerm.length > 3) { |
| 106 | + this.loadingResults = true; |
91 | 107 | this.gatherSearchResults(this.searchTerm); |
92 | 108 | } |
93 | 109 | }, 500), |
|
106 | 122 | this.error(error.detail); |
107 | 123 | }); |
108 | 124 | } |
| 125 | + }) |
| 126 | + .then(() => { |
| 127 | + this.loadingResults = false; |
109 | 128 | }); |
110 | 129 | }, |
111 | 130 |
|
|
0 commit comments