File size: 1,972 Bytes
8ede856
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
<script setup>
const props = defineProps({
  modelValue: {
    type: String,
    required: true,
  },
  items: {
    type: Array,
    required: true,
  },
  label: {
    type: String,
    required: true,
  },
  order: {
    type: String,
    default: "desc",
  },
  ascendingLabel: {
    type: String,
    default: "Ascending",
  },
  descendingLabel: {
    type: String,
    default: "Descending",
  },
  showOrder: {
    type: Boolean,
    default: false,
  },
});

const emit = defineEmits(["update:modelValue", "update:order"]);

const updateSortBy = (value) => {
  emit("update:modelValue", value);
};

const toggleOrder = () => {
  emit("update:order", props.order === "desc" ? "asc" : "desc");
};
</script>

<template>
  <div class="plugin-sort-control">
    <v-select
      :model-value="modelValue"
      :items="items"
      density="compact"
      variant="outlined"
      hide-details
      :label="label"
      class="plugin-sort-control__select"
      @update:model-value="updateSortBy"
    >
      <template #prepend-inner>
        <v-icon size="small">mdi-sort</v-icon>
      </template>
    </v-select>

    <v-btn
      v-if="showOrder"
      icon
      variant="text"
      density="compact"
      @click="toggleOrder"
    >
      <v-icon>{{
        order === "desc" ? "mdi-arrow-down-thin" : "mdi-arrow-up-thin"
      }}</v-icon>
      <v-tooltip activator="parent" location="top">
        {{ order === "desc" ? descendingLabel : ascendingLabel }}
      </v-tooltip>
    </v-btn>
  </div>
</template>

<style scoped>
.plugin-sort-control {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.plugin-sort-control__select {
  min-width: 180px;
  max-width: 220px;
}

.plugin-sort-control__select :deep(.v-field__input),
.plugin-sort-control__select :deep(.v-field-label),
.plugin-sort-control__select :deep(.v-select__selection-text),
.plugin-sort-control__select :deep(.v-field__prepend-inner) {
  font-size: 0.875rem;
}
</style>