mirror of
https://github.com/lucide-icons/lucide.git
synced 2026-05-18 12:55:55 +02:00
* Update images * Adjust color * update accessebility * Add matrix hero * Add typescript documentation * Add basics section to vue pages * Add svelte docs * Fix dynamic sidebar * Add animation? * Some adjustments * Adjust animation * Updates docs * Add scaledown animation * Add docs for vue types * Fix layout accessibility page * fix framework select * adjust easing home animation * Write docs for Vue * Adjust animation home * Adjust home hero animation * Finish svelte docs * Add solid pages * remove spiral animation component * Add group icons * Added solid docs * update preact docs * Adjust examples preact docs * Add snackplayer * Get new editor * Save this * Add examples * Adjust styling * setup custom sandpack * Add script * Format files * Make sandpack plugin work * migrate react docs * Fix svelte and solid examples * Migrate to solid packages * Add darkmode package logos * Fix bug in selector * migrate vue examples * migrate advanced vue items * migrate preact and svelte examples * Add astro docs * adding more docs on guide for lucide library * Fix home animation * Cleanup * Added resources page, with more details and content * Add hero badge for Version 1 * Fix vercel json * Update missing paths * Fix build? * Replace lucide-vue-next * Fix build * Add some docs * update markdown * Setup angular docs * Add basic angular docs * Adjust code examples * Update title and descriptions * Update accessibility link * Update title and description * Add og image * Fix alignment * Add migration guides * Adjust version 1 markdown file * Add migration guide to the main list * Minor fixes * Update docs * Apply feedback * Select icons * Add pointer events none * Fix package links homepage * Format code * Fix types * Fix focus * Fix build * Fix focus * Apply feedback * Adjust imports * Adjust imports * Fix search * Apply feedback * Fix import in font docs * Small fixes * docs(guide): added easter egg icon. stay tuned, guys 😉 * Add llm txt plugin * Adjust logo top * docs(version-1): upgraded @lucide/angular guide for v1 website (#4144) * docs(guide/angular): rewrite some angular documentation * docs(guide/angular): extens angular guide with combining icons & icon provider guides * docs(guide/angular): fix angular sandbox, still needs @lucide/angular release tho * docs(guide/angular): rework the getting started page a bit more, refactor some more prop=>input occurences * docs(guide/angular): context provider => provideLucideConfig * Update docs/guide/angular/migration.md Co-authored-by: Eric Fennis <eric.fennis@gmail.com> * Update docs/guide/angular/advanced/combining-icons.md Co-authored-by: Eric Fennis <eric.fennis@gmail.com> * Apply suggestions from code review Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com> * docs(guide/angular): rework a11y for better flow & pacing * docs(guide/angular): salvage original phrase, it has better flow * docs(guide/angular): some more a11y nitpicking * docs(guide/angular): reduce llm fatigue * docs(guides/angular): fix app component selector * docs(guides/angular): fix angular sandpacks * Add sandpack angular to improve tree-shakable stack * Update docs/guide/angular/getting-started.md * docs(guides/angular): fix user import in combinding icons guide * docs(guides/angular): fix nested SVG phrasing * Update docs/guide/angular/advanced/with-lucide-lab.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update docs/guide/angular/advanced/filled-icons.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * docs(guides/angular): fix createLucideIcon guide * docs(guides/angular): upgrade all relevant angular sandpack demos --------- Co-authored-by: Eric Fennis <eric.fennis@gmail.com> Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com> * fix(docs): add autogenerated OG images to gitignore * fix(docs): unify the case of "Lucide" & "Lucide Lab" over all docs and readmes * Fix build * Add next tag to all installation guides * Add top bar notification * Minor fixes * Update text * Add todos * Update og image * Adjust install command * Color top bar * fix(docs): ignore all OG images, expect general.png * fix(docs): fix the package list, hide @lucide/icons, downgrade angular logo, link to v0 guide, fix package title alignment * Update docs/.vitepress/theme/components/base/LayoutTop.vue Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update docs/guide/react/advanced/dynamic-icon-component.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update CONTRIBUTING.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update docs/.vitepress/sidebar/resources.ts Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Fix code example * fix(docs): version 1 => Version 1 * feat(docs): add angular to new features in v1 * Fix next line issue * feat(docs): fix typo (code example_s_) * Fix deadlink * feat(docs): fix some more typos and irky grammar * feat(docs): fix lowercase lucide in sidebar 😅 * feat(docs): add dark mode icon support for framework select * fix(docs): revert incorrect merge --------- Co-authored-by: Eric Fennis <eric.fennis@gmail.com> Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>
218 lines
4.4 KiB
Vue
218 lines
4.4 KiB
Vue
<script setup lang="ts">
|
|
import { Listbox, ListboxButton, ListboxOptions, ListboxOption } from '@headlessui/vue';
|
|
import Icon from '@lucide/vue/src/Icon';
|
|
import { chevronsUpDown, check } from '../../../data/iconNodes';
|
|
import SelectIcon from './SelectIcon.vue';
|
|
|
|
defineProps<{
|
|
id?: string;
|
|
items?: { name: string; route: string; icon: string; iconDark?: string }[];
|
|
}>();
|
|
|
|
const selected = defineModel<{ name: string; icon: string; iconDark?: string }>();
|
|
</script>
|
|
|
|
<template>
|
|
<Listbox v-model="selected">
|
|
<div class="select-wrapper">
|
|
<ListboxButton
|
|
class="select-button"
|
|
:id="id"
|
|
>
|
|
<SelectIcon :item="selected" />
|
|
<span class="select-text">{{ selected.name }}</span>
|
|
<span class="select-icon">
|
|
<Icon
|
|
:iconNode="chevronsUpDown"
|
|
class="chevron-icon"
|
|
aria-hidden="true"
|
|
/>
|
|
</span>
|
|
</ListboxButton>
|
|
|
|
<transition
|
|
leave-active-class="transition-leave"
|
|
leave-from-class="transition-leave-from"
|
|
leave-to-class="transition-leave-to"
|
|
>
|
|
<ListboxOptions class="select-options">
|
|
<ListboxOption
|
|
v-slot="{ active, selected }"
|
|
v-for="item in items"
|
|
:key="item.name"
|
|
:value="item"
|
|
as="template"
|
|
>
|
|
<li :class="['select-option', { active, selected }]">
|
|
<SelectIcon :item="item" />
|
|
<span :class="['option-text', { selected }]">{{ item.name }}</span>
|
|
<span
|
|
v-if="selected"
|
|
class="check-icon"
|
|
>
|
|
<Icon
|
|
:iconNode="check"
|
|
class="check"
|
|
aria-hidden="true"
|
|
/>
|
|
</span>
|
|
</li>
|
|
</ListboxOption>
|
|
</ListboxOptions>
|
|
</transition>
|
|
</div>
|
|
</Listbox>
|
|
</template>
|
|
|
|
<style scoped>
|
|
.select-wrapper {
|
|
position: relative;
|
|
}
|
|
|
|
.select-button {
|
|
background: var(--vp-sidebar-input);
|
|
border-radius: 8px;
|
|
color: var(--vp-c-text-1);
|
|
padding: 7px 14px;
|
|
height: auto;
|
|
font-size: 14px;
|
|
border: 1px solid transparent;
|
|
cursor: text;
|
|
display: flex;
|
|
gap: 12px;
|
|
transition:
|
|
color 0.25s,
|
|
border-color 0.25s,
|
|
background-color 0.25s;
|
|
width: 100%;
|
|
align-items: center;
|
|
}
|
|
|
|
.select-button:focus {
|
|
border-color: var(--vp-c-brand);
|
|
}
|
|
|
|
.select-text {
|
|
display: block;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.select-icon {
|
|
pointer-events: none;
|
|
position: absolute;
|
|
top: 0;
|
|
bottom: 0;
|
|
right: 0;
|
|
display: flex;
|
|
align-items: center;
|
|
padding-right: 0.5rem;
|
|
}
|
|
|
|
.chevron-icon {
|
|
height: 1.25rem;
|
|
width: 1.25rem;
|
|
color: #9ca3af;
|
|
}
|
|
|
|
.transition-leave {
|
|
transition: opacity 100ms ease-in;
|
|
}
|
|
|
|
.transition-leave-from {
|
|
opacity: 1;
|
|
}
|
|
|
|
.transition-leave-to {
|
|
opacity: 0;
|
|
}
|
|
|
|
.select-options {
|
|
position: absolute;
|
|
display: flex;
|
|
flex-direction: column;
|
|
border-radius: 12px;
|
|
padding: 12px;
|
|
min-width: 128px;
|
|
border: 1px solid var(--vp-c-divider);
|
|
background-color: var(--vp-c-bg-elv);
|
|
box-shadow: var(--vp-shadow-3);
|
|
transition: background-color 0.5s;
|
|
max-height: calc(100vh - var(--vp-nav-height));
|
|
overflow-y: auto;
|
|
width: 100%;
|
|
z-index: 90;
|
|
right: 0;
|
|
top: 44px;
|
|
}
|
|
|
|
.select-option {
|
|
position: relative;
|
|
cursor: default;
|
|
user-select: none;
|
|
padding: 0px 4px;
|
|
text-align: left;
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 12px;
|
|
border-radius: 6px;
|
|
line-height: 32px;
|
|
font-size: 14px;
|
|
font-weight: 500;
|
|
color: var(--vp-c-text-1);
|
|
white-space: nowrap;
|
|
transition:
|
|
background-color 0.25s,
|
|
color 0.25s;
|
|
list-style: none;
|
|
}
|
|
|
|
.select-option:hover,
|
|
.select-option.active {
|
|
color: var(--vp-c-brand);
|
|
background-color: var(--vp-c-default-soft);
|
|
}
|
|
|
|
.select-option:active {
|
|
color: var(--vp-c-brand);
|
|
background-color: var(--vp-c-bg-elv);
|
|
}
|
|
|
|
.option-text {
|
|
display: block;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
white-space: nowrap;
|
|
font-weight: normal;
|
|
}
|
|
|
|
.option-text.selected {
|
|
font-weight: 500;
|
|
}
|
|
|
|
.check-icon {
|
|
position: absolute;
|
|
top: 0;
|
|
bottom: 0;
|
|
right: 12px;
|
|
display: flex;
|
|
align-items: center;
|
|
padding-left: 0.75rem;
|
|
color: var(--vp-c-brand);
|
|
}
|
|
|
|
.check {
|
|
height: 1.25rem;
|
|
width: 1.25rem;
|
|
}
|
|
|
|
@media (min-width: 640px) {
|
|
.select-button,
|
|
.select-options {
|
|
font-size: 0.875rem;
|
|
line-height: 1.25rem;
|
|
}
|
|
}
|
|
</style>
|