Files
oa/documentation/plugins/multiselect/multiselect-select-slot-icons-documentation.md
2025-05-24 01:49:48 +09:00

5.7 KiB

selectSlotIconOptions, selectSlotIconValue
selectSlotIconOptions selectSlotIconValue
value name icon
logistics Logistics fas fa-box
value name icon
business Business fas fa-briefcase
value name icon
relaxation Relaxation fas fa-couch
value name icon
development Development fas fa-code
value name icon
travel Travel fas fa-compass
value name icon
discussions Discussions fas fa-comment-alt
value name icon
shopping Shopping fas fa-shopping-bag

The <Multiselect /> component can be used with a custom template to show icons for options and selected option. Supports searching the values.

<script setup lang="ts">
const selectSlotIconValue
const selectSlotIconOptions = [
  {
    name: 'Logistics',
    value: 'logistics',
    icon: 'fas fa-box',
  },
  {
    name: 'Business',
    value: 'business',
    icon: 'fas fa-briefcase',
  },
  {
    name: 'Relaxation',
    value: 'relaxation',
    icon: 'fas fa-couch',
  },
  {
    name: 'Development',
    value: 'development',
    icon: 'fas fa-code',
  },
  {
    name: 'Travel',
    value: 'travel',
    icon: 'fas fa-compass',
  },
  {
    name: 'Discussions',
    value: 'discussions',
    icon: 'fas fa-comment-alt',
  },
  {
    name: 'Shopping',
    value: 'shopping',
    icon: 'fas fa-shopping-bag',
  },
]
</script>

<template>
  <VField v-slot="{ id }" class="is-icon-select">
    <VControl>
      <Multiselect
        v-model="selectSlotIconValue"
        :attrs="{ id }"
        placeholder="Select a member"
        label="name"
        :options="selectSlotIconOptions"
        :searchable="true"
        track-by="name"
        :max-height="145"
      >
        <template #singlelabel="{ value }">
          <div class="multiselect-single-label">
            <div class="select-label-icon-wrap">
              <i :class="value.icon" />
            </div>
            <span class="select-label-text">
              {{ value.name }}
            </span>
          </div>
        </template>
        <template #option="{ option }">
          <div class="select-option-icon-wrap">
            <i :class="option.icon" />
          </div>
          <span class="select-option-text">
            {{ option.name }}
          </span>
        </template>
      </Multiselect>
    </VControl>
  </VField>
</template>
{{ value.name }}
{{ option.name }}
{{ value.name }}
{{ option.name }}
{{ value.name }}
{{ option.name }}