aboutsummaryrefslogtreecommitdiff
path: root/src/tools/http-status-codes/http-status-codes.vue
blob: 992fbc1edb595cf9eb35366ae85ab0bd2c2b3536 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
<template>
  <div>
    <n-form-item :show-label="false">
      <n-input
        v-model:value="search"
        placeholder="Search http status..."
        size="large"
        autofocus
        mb-10
        autocomplete="off"
        autocorrect="off"
        autocapitalize="off"
      >
        <template #prefix>
          <n-icon :component="SearchRound" />
        </template>
      </n-input>
    </n-form-item>

    <div v-for="{ codes, category } of codesByCategoryFiltered" :key="category" mb-8>
      <n-h2> {{ category }} </n-h2>

      <c-card v-for="{ code, description, name, type } of codes" :key="code" mb-2>
        <n-space align="center">
          <n-text strong text-lg> {{ code }} {{ name }} </n-text>
        </n-space>
        <n-text depth="3">{{ description }} {{ type !== 'HTTP' ? `For ${type}.` : '' }}</n-text>
      </c-card>
    </div>
  </div>
</template>

<script setup lang="ts">
import { useFuzzySearch } from '@/composable/fuzzySearch';
import { SearchRound } from '@vicons/material';
import { codesByCategories } from './http-status-codes.constants';

const search = ref('');

const { searchResult } = useFuzzySearch({
  search,
  data: codesByCategories.flatMap(({ codes, category }) => codes.map((code) => ({ ...code, category }))),
  options: {
    keys: [{ name: 'code', weight: 3 }, { name: 'name', weight: 2 }, 'description', 'category'],
  },
});

const codesByCategoryFiltered = computed(() => {
  if (!search.value) {
    return codesByCategories;
  }

  return [{ category: 'Search results', codes: searchResult.value }];
});
</script>

<style lang="less" scoped></style>