Compare commits
14 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f958310d91 | ||
|
|
d00cbebcc4 | ||
|
|
3619dfa7f2 | ||
|
|
c844bc668f | ||
|
|
32dec05e0b | ||
|
|
5394d7fceb | ||
|
|
8dea4c7b7f | ||
|
|
b8a595275d | ||
|
|
a7b3ecde63 | ||
|
|
8bcfc225ce | ||
|
|
1d608db223 | ||
|
|
c1cb5d9bc2 | ||
|
|
66f51474cd | ||
|
|
af0b16bc10 |
62
.github/labeler.yml
vendored
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
# For changed dependencies
|
||||||
|
📦 dependencies:
|
||||||
|
- pnpm-lock.yaml
|
||||||
|
|
||||||
|
# For changes in documentation
|
||||||
|
📖 documentation:
|
||||||
|
- docs/*.md
|
||||||
|
- docs/**/*.md
|
||||||
|
|
||||||
|
# For changes in the site, but not markdown files
|
||||||
|
🌍 site:
|
||||||
|
- 'docs/**'
|
||||||
|
|
||||||
|
# For changes in the metadata
|
||||||
|
🫧 metadata:
|
||||||
|
- 'icons/*.json'
|
||||||
|
- categories/*
|
||||||
|
|
||||||
|
# For changes or added icons
|
||||||
|
🎨 icon:
|
||||||
|
- 'icons/*.svg'
|
||||||
|
|
||||||
|
# For changes in the lucide package
|
||||||
|
🧳 lucide package:
|
||||||
|
- 'packages/lucide/*'
|
||||||
|
|
||||||
|
# For changes in the lucide React package
|
||||||
|
⚛️ react package:
|
||||||
|
- 'packages/lucide-react/*'
|
||||||
|
|
||||||
|
# For changes in the lucide React Native package
|
||||||
|
⚛️ react native package:
|
||||||
|
- 'packages/lucide-react-native/*'
|
||||||
|
|
||||||
|
# For changes in the lucide vue packages
|
||||||
|
💎 vue package:
|
||||||
|
- 'packages/lucide-vue/*'
|
||||||
|
- 'packages/lucide-vue-next/*'
|
||||||
|
|
||||||
|
# For changes in the lucide angular package
|
||||||
|
🅰️ angular package:
|
||||||
|
- 'packages/lucide-angular/*'
|
||||||
|
|
||||||
|
# For changes in the lucide preact package
|
||||||
|
⚛️ preact package:
|
||||||
|
- 'packages/lucide-preact/*'
|
||||||
|
|
||||||
|
# For changes in the lucide svelte package
|
||||||
|
🧣 svelte package:
|
||||||
|
- 'packages/lucide-svelte/*'
|
||||||
|
|
||||||
|
# For changes in the lucide solid package
|
||||||
|
🪝 solid package:
|
||||||
|
- 'packages/lucide-solid/*'
|
||||||
|
|
||||||
|
# For changes in the lucide static package
|
||||||
|
🪨 static package:
|
||||||
|
- 'packages/lucide-static/*'
|
||||||
|
|
||||||
|
# For changes in the lucide flutter package
|
||||||
|
🏹 flutter package:
|
||||||
|
- 'packages/lucide-flutter/*'
|
||||||
12
.github/workflows/labeler.yml
vendored
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
name: "Pull Request Labeler"
|
||||||
|
on:
|
||||||
|
- pull_request_target
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
triage:
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
pull-requests: write
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/labeler@v4
|
||||||
95
.vscode/svg.code-snippets
vendored
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
{
|
||||||
|
"Lucide SVG": {
|
||||||
|
"scope": "xml",
|
||||||
|
"description": "Base SVG with Lucide attributes.",
|
||||||
|
"prefix": [
|
||||||
|
"svg",
|
||||||
|
"lucide"
|
||||||
|
],
|
||||||
|
"body": [
|
||||||
|
"<svg",
|
||||||
|
" xmlns=\"http://www.w3.org/2000/svg\"",
|
||||||
|
" width=\"24\"",
|
||||||
|
" height=\"24\"",
|
||||||
|
" viewBox=\"0 0 24 24\"",
|
||||||
|
" fill=\"none\"",
|
||||||
|
" stroke=\"currentColor\"",
|
||||||
|
" stroke-width=\"2\"",
|
||||||
|
" stroke-linecap=\"round\"",
|
||||||
|
" stroke-linejoin=\"round\"",
|
||||||
|
">",
|
||||||
|
" $0",
|
||||||
|
"</svg>"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"Rectangle": {
|
||||||
|
"scope": "xml",
|
||||||
|
"description": "SVG `rect`angle, with Lucide defaults.",
|
||||||
|
"prefix": [
|
||||||
|
"rect",
|
||||||
|
"<rect"
|
||||||
|
],
|
||||||
|
"body": "<rect width=\"${1:20}\" height=\"${2:12}\" x=\"${3:2}\" y=\"${4:6}\" rx=\"${5|2,1|}\"/>"
|
||||||
|
},
|
||||||
|
"Square": {
|
||||||
|
"scope": "xml",
|
||||||
|
"description": "SVG square `rect`angle, with Lucide defaults.",
|
||||||
|
"prefix": [
|
||||||
|
"square",
|
||||||
|
"rect",
|
||||||
|
"<rect",
|
||||||
|
"tile"
|
||||||
|
],
|
||||||
|
"body": "<rect width=\"${1:18}\" height=\"$1\" x=\"${2:3}\" y=\"${3:$2}\" rx=\"${4|2,1|}\" />"
|
||||||
|
},
|
||||||
|
"Circle": {
|
||||||
|
"scope": "xml",
|
||||||
|
"description": "SVG `circle`, with Lucide defaults.",
|
||||||
|
"prefix": [
|
||||||
|
"circle",
|
||||||
|
"<circle"
|
||||||
|
],
|
||||||
|
"body": "<circle cx=\"${2:12}\" cy=\"${3:$2}\" r=\"${1|10,2,.5|}\" />"
|
||||||
|
},
|
||||||
|
"Ellipse": {
|
||||||
|
"scope": "xml",
|
||||||
|
"description": "SVG `ellipse`.",
|
||||||
|
"prefix": [
|
||||||
|
"ellipse",
|
||||||
|
"<ellipse"
|
||||||
|
],
|
||||||
|
"body": "<ellipse cx=\"${3:12}\" cy=\"${4:$3}\" rx=\"${1:10}\" ry=\"${2:$1}\" />"
|
||||||
|
},
|
||||||
|
"Path": {
|
||||||
|
"scope": "xml",
|
||||||
|
"description": "SVG custom `path`.",
|
||||||
|
"prefix": [
|
||||||
|
"path",
|
||||||
|
"<path",
|
||||||
|
"polyline",
|
||||||
|
"<polyline",
|
||||||
|
"polygon",
|
||||||
|
"<polygon"
|
||||||
|
],
|
||||||
|
"body": "<path d=\"${1|M,m|}$0\" />"
|
||||||
|
},
|
||||||
|
"Line": {
|
||||||
|
"scope": "xml",
|
||||||
|
"description": "SVG `path`, preffered to `line` in Lucide.",
|
||||||
|
"prefix": [
|
||||||
|
"line",
|
||||||
|
"<line",
|
||||||
|
"minus"
|
||||||
|
],
|
||||||
|
"body": "<path d=\"M${3:5} ${4:12}${1|h,v|}${2:14}\" />"
|
||||||
|
},
|
||||||
|
"Dot": {
|
||||||
|
"scope": "xml",
|
||||||
|
"description": "SVG small dot, within the Lucide guidelines.",
|
||||||
|
"prefix": [
|
||||||
|
"dot",
|
||||||
|
"."
|
||||||
|
],
|
||||||
|
"body": "<path d=\"M ${1:12} ${2:$1}h.01\" />"
|
||||||
|
}
|
||||||
|
}
|
||||||
55
docs/.vitepress/theme/components/base/Tooltip.vue
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import {onMounted, ref} from 'vue';
|
||||||
|
import {useFloating, offset, shift} from '@floating-ui/vue';
|
||||||
|
|
||||||
|
const reference = ref(null);
|
||||||
|
const tooltip = ref(null);
|
||||||
|
const middleware = ref([shift(), offset(8)]);
|
||||||
|
const { floatingStyles, update } = useFloating(reference, tooltip, {
|
||||||
|
middleware,
|
||||||
|
transform: false
|
||||||
|
});
|
||||||
|
|
||||||
|
defineProps<{
|
||||||
|
title: string
|
||||||
|
}>()
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
update()
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<span ref="reference" class="reference">
|
||||||
|
<slot/>
|
||||||
|
</span>
|
||||||
|
<div ref="tooltip" class="tooltip" :style="floatingStyles">
|
||||||
|
{{title}}
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.reference:hover + .tooltip{
|
||||||
|
opacity: 1;
|
||||||
|
transform: scale(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
.tooltip {
|
||||||
|
display: block;
|
||||||
|
font-size: 12px;
|
||||||
|
line-height: 20px;
|
||||||
|
transform: scale(0.9);
|
||||||
|
font-weight: 400;
|
||||||
|
background: var(--vp-c-brand-dark);
|
||||||
|
color: white;
|
||||||
|
z-index: 10;
|
||||||
|
white-space: nowrap;
|
||||||
|
padding: 2px 8px;
|
||||||
|
border-radius: 4px;
|
||||||
|
box-shadow: var(--vp-shadow-1);
|
||||||
|
opacity: 0;
|
||||||
|
pointer-events: none;
|
||||||
|
transition: cubic-bezier(0.19, 1, 0.22, 1) .2s;
|
||||||
|
transition-property: opacity, transform;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
@@ -3,19 +3,9 @@ import { ref } from 'vue';
|
|||||||
import ButtonMenu from '../base/ButtonMenu.vue'
|
import ButtonMenu from '../base/ButtonMenu.vue'
|
||||||
import { useIconStyleContext } from '../../composables/useIconStyle';
|
import { useIconStyleContext } from '../../composables/useIconStyle';
|
||||||
import useConfetti from '../../composables/useConfetti';
|
import useConfetti from '../../composables/useConfetti';
|
||||||
|
import getSVGIcon from '../../utils/getSVGIcon';
|
||||||
|
import downloadData from '../../utils/downloadData';
|
||||||
|
|
||||||
const allowedAttrs = [
|
|
||||||
'xmlns',
|
|
||||||
'width',
|
|
||||||
'height',
|
|
||||||
'viewBox',
|
|
||||||
'fill',
|
|
||||||
'stroke',
|
|
||||||
'stroke-width',
|
|
||||||
'stroke-linecap',
|
|
||||||
'stroke-linejoin',
|
|
||||||
'class',
|
|
||||||
]
|
|
||||||
const downloadText = 'Download!'
|
const downloadText = 'Download!'
|
||||||
const copiedText = 'Copied!'
|
const copiedText = 'Copied!'
|
||||||
const confettiText = ref(copiedText)
|
const confettiText = ref(copiedText)
|
||||||
@@ -28,24 +18,6 @@ const { size } = useIconStyleContext()
|
|||||||
|
|
||||||
const { animate, confetti } = useConfetti()
|
const { animate, confetti } = useConfetti()
|
||||||
|
|
||||||
function getSVGIcon() {
|
|
||||||
const svg = document.querySelector('#previewer svg')
|
|
||||||
if (!svg) return
|
|
||||||
|
|
||||||
const clonedSvg = svg.cloneNode(true) as SVGElement
|
|
||||||
|
|
||||||
// Filter out attributes that are not allowed in SVGs
|
|
||||||
for (const attr of Array.from(clonedSvg.attributes)) {
|
|
||||||
if (!allowedAttrs.includes(attr.name)) {
|
|
||||||
clonedSvg.removeAttribute(attr.name)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const svgString = new XMLSerializer().serializeToString(clonedSvg)
|
|
||||||
|
|
||||||
return svgString
|
|
||||||
}
|
|
||||||
|
|
||||||
function copySVG() {
|
function copySVG() {
|
||||||
confettiText.value = copiedText
|
confettiText.value = copiedText
|
||||||
const svgString = getSVGIcon()
|
const svgString = getSVGIcon()
|
||||||
@@ -70,11 +42,7 @@ function downloadSVG() {
|
|||||||
confettiText.value = downloadText
|
confettiText.value = downloadText
|
||||||
const svgString = getSVGIcon()
|
const svgString = getSVGIcon()
|
||||||
|
|
||||||
const link = document.createElement('a');
|
downloadData(`${props.name}.svg`, `data:image/svg+xml;base64,${btoa(svgString)}`)
|
||||||
link.download = `${props.name}.svg`;
|
|
||||||
link.href = `data:image/svg+xml;base64,${btoa(svgString)}`
|
|
||||||
link.click();
|
|
||||||
|
|
||||||
confetti()
|
confetti()
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -91,12 +59,7 @@ function downloadPNG() {
|
|||||||
image.src = `data:image/svg+xml;base64,${btoa(svgString)}`;
|
image.src = `data:image/svg+xml;base64,${btoa(svgString)}`;
|
||||||
image.onload = function() {
|
image.onload = function() {
|
||||||
ctx.drawImage(image, 0, 0);
|
ctx.drawImage(image, 0, 0);
|
||||||
|
downloadData(`${props.name}.png`, canvas.toDataURL('image/png'))
|
||||||
const link = document.createElement('a');
|
|
||||||
link.download = `${props.name}.png`;
|
|
||||||
link.href = canvas.toDataURL('image/png')
|
|
||||||
link.click();
|
|
||||||
|
|
||||||
confetti()
|
confetti()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -43,5 +43,6 @@ function setActiveIcon(name: string) {
|
|||||||
|
|
||||||
.icon {
|
.icon {
|
||||||
aspect-ratio: 1/1;
|
aspect-ratio: 1/1;
|
||||||
|
position: relative;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -2,13 +2,17 @@
|
|||||||
import createLucideIcon from 'lucide-vue-next/src/createLucideIcon';
|
import createLucideIcon from 'lucide-vue-next/src/createLucideIcon';
|
||||||
import { useMediaQuery } from '@vueuse/core';
|
import { useMediaQuery } from '@vueuse/core';
|
||||||
import { useRouter } from 'vitepress';
|
import { useRouter } from 'vitepress';
|
||||||
|
import getSVGIcon from '../../utils/getSVGIcon';
|
||||||
|
import useConfetti from '../../composables/useConfetti';
|
||||||
|
import Tooltip from '../base/Tooltip.vue';
|
||||||
|
|
||||||
|
const downloadText = 'Download!'
|
||||||
|
const copiedText = 'Copied!'
|
||||||
|
|
||||||
export type IconNode = [elementName: string, attrs: Record<string, string>][]
|
export type IconNode = [elementName: string, attrs: Record<string, string>][]
|
||||||
|
|
||||||
const props = defineProps<{
|
const props = defineProps<{
|
||||||
name: string;
|
name: string;
|
||||||
// tags: string[];
|
|
||||||
// categories: string[];
|
|
||||||
iconNode: IconNode;
|
iconNode: IconNode;
|
||||||
active: boolean;
|
active: boolean;
|
||||||
customizable?: boolean;
|
customizable?: boolean;
|
||||||
@@ -20,40 +24,65 @@ const emit = defineEmits(['setActiveIcon'])
|
|||||||
|
|
||||||
const { go } = useRouter()
|
const { go } = useRouter()
|
||||||
const showOverlay = useMediaQuery('(min-width: 860px)');
|
const showOverlay = useMediaQuery('(min-width: 860px)');
|
||||||
|
const { animate, confetti, confettiText } = useConfetti()
|
||||||
|
|
||||||
|
|
||||||
const icon = createLucideIcon(props.name, props.iconNode)
|
const icon = createLucideIcon(props.name, props.iconNode)
|
||||||
|
|
||||||
function navigateToIcon() {
|
async function navigateToIcon(event) {
|
||||||
|
|
||||||
|
if (event.shiftKey) {
|
||||||
|
event.preventDefault()
|
||||||
|
const svgString = getSVGIcon(event.target.firstChild, {
|
||||||
|
class: `lucide lucide-${props.name}`,
|
||||||
|
})
|
||||||
|
|
||||||
|
await navigator.clipboard.writeText(svgString)
|
||||||
|
|
||||||
|
confettiText.value = copiedText
|
||||||
|
confetti()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
if(props.overlayMode && showOverlay.value) {
|
if(props.overlayMode && showOverlay.value) {
|
||||||
|
event.preventDefault()
|
||||||
window.history.pushState({}, '', `/icons/${props.name}`)
|
window.history.pushState({}, '', `/icons/${props.name}`)
|
||||||
emit('setActiveIcon', props.name)
|
emit('setActiveIcon', props.name)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
event.preventDefault()
|
||||||
go(`/icons/${props.name}`)
|
go(`/icons/${props.name}`)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<button
|
<Tooltip :title="name">
|
||||||
class="icon-button"
|
<a
|
||||||
@click="navigateToIcon"
|
class="icon-button confetti-button vp-raw"
|
||||||
:class="{ 'active' : active }"
|
@click="navigateToIcon"
|
||||||
:data-title="name"
|
:class="{ active, animate }"
|
||||||
:aria-label="name"
|
:aria-label="name"
|
||||||
:href="`/icons/${props.name}`"
|
:href="`/icons/${props.name}`"
|
||||||
>
|
:data-confetti-text="confettiText"
|
||||||
<KeepAlive>
|
ref="ref"
|
||||||
<component
|
>
|
||||||
v-if="!hideIcon"
|
<KeepAlive>
|
||||||
:is="icon"
|
<component
|
||||||
class="lucide-icon"
|
v-if="!hideIcon"
|
||||||
:class="{ customizable }"
|
:is="icon"
|
||||||
/>
|
class="lucide-icon"
|
||||||
</KeepAlive>
|
:class="{
|
||||||
</button>
|
customizable,
|
||||||
|
}"
|
||||||
|
/>
|
||||||
|
</KeepAlive>
|
||||||
|
</a>
|
||||||
|
</Tooltip>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
<style src="./confetti.css" />
|
||||||
|
|
||||||
<style scoped>
|
<style scoped>
|
||||||
.icon-button {
|
.icon-button {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
@@ -72,35 +101,13 @@ function navigateToIcon() {
|
|||||||
color: var(--vp-c-text-1);
|
color: var(--vp-c-text-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
.icon-button:hover:before {
|
.confetti-button:before,
|
||||||
opacity: 1;
|
.confetti-button:after {
|
||||||
transform: translate(-50%, 48px) scale(1);
|
z-index: 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
.icon-button:before {
|
.confetti-button:before {
|
||||||
content: attr(data-title);
|
line-height: 80px;
|
||||||
display: block;
|
|
||||||
font-size: 12px;
|
|
||||||
line-height: 20px;
|
|
||||||
margin-left: 27px;
|
|
||||||
transform: translate(-50%, 48px) scale(0.9);
|
|
||||||
font-weight: 400;
|
|
||||||
position: absolute;
|
|
||||||
background: var(--vp-c-brand-dark);
|
|
||||||
color: white;
|
|
||||||
z-index: 10;
|
|
||||||
white-space: nowrap;
|
|
||||||
padding: 2px 8px;
|
|
||||||
border-radius: 4px;
|
|
||||||
box-shadow: var(--vp-shadow-1);
|
|
||||||
opacity: 0;
|
|
||||||
pointer-events: none;
|
|
||||||
transition: cubic-bezier(0.19, 1, 0.22, 1) .2s;
|
|
||||||
transition-property: opacity, transform;
|
|
||||||
/* max-width: calc((32px * 2) + 56px); */
|
|
||||||
overflow: hidden;
|
|
||||||
white-space: pre-wrap;
|
|
||||||
word-break: break-word;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.icon-button:active {
|
.icon-button:active {
|
||||||
@@ -139,6 +146,7 @@ function navigateToIcon() {
|
|||||||
|
|
||||||
.lucide-icon {
|
.lucide-icon {
|
||||||
margin: auto;
|
margin: auto;
|
||||||
|
pointer-events: none;
|
||||||
}
|
}
|
||||||
.lucide-icon.customizable {
|
.lucide-icon.customizable {
|
||||||
will-change: width, height, stroke-width, stroke;
|
will-change: width, height, stroke-width, stroke;
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import { ref } from "vue";
|
|||||||
|
|
||||||
export default function useConfetti() {
|
export default function useConfetti() {
|
||||||
const animate = ref(false)
|
const animate = ref(false)
|
||||||
|
const confettiText = ref('confetti!')
|
||||||
|
|
||||||
function confetti() {
|
function confetti() {
|
||||||
animate.value = true;
|
animate.value = true;
|
||||||
@@ -13,6 +14,7 @@ export default function useConfetti() {
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
animate,
|
animate,
|
||||||
confetti
|
confetti,
|
||||||
|
confettiText
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
6
docs/.vitepress/theme/utils/downloadData.ts
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
export default function downloadData(filename:string, data:string) {
|
||||||
|
const link = document.createElement('a');
|
||||||
|
link.download = filename;
|
||||||
|
link.href = data
|
||||||
|
link.click();
|
||||||
|
}
|
||||||
34
docs/.vitepress/theme/utils/getSVGIcon.ts
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
const allowedAttrs = [
|
||||||
|
'xmlns',
|
||||||
|
'width',
|
||||||
|
'height',
|
||||||
|
'viewBox',
|
||||||
|
'fill',
|
||||||
|
'stroke',
|
||||||
|
'stroke-width',
|
||||||
|
'stroke-linecap',
|
||||||
|
'stroke-linejoin',
|
||||||
|
'class',
|
||||||
|
]
|
||||||
|
|
||||||
|
export default function getSVGIcon(element?: HTMLElement, attrs?: Record<string, string>) {
|
||||||
|
const svg = element ?? document.querySelector('#previewer svg')
|
||||||
|
if (!svg) return
|
||||||
|
|
||||||
|
const clonedSvg = svg.cloneNode(true) as SVGElement
|
||||||
|
|
||||||
|
// Filter out attributes that are not allowed in SVGs
|
||||||
|
for (const attr of Array.from(clonedSvg.attributes)) {
|
||||||
|
if (!allowedAttrs.includes(attr.name)) {
|
||||||
|
clonedSvg.removeAttribute(attr.name)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (const [key, value] of Object.entries(attrs ?? {})) {
|
||||||
|
clonedSvg.setAttribute(key, value)
|
||||||
|
}
|
||||||
|
|
||||||
|
const svgString = new XMLSerializer().serializeToString(clonedSvg)
|
||||||
|
|
||||||
|
return svgString
|
||||||
|
}
|
||||||
@@ -89,7 +89,7 @@ export default Icon;
|
|||||||
import Icon from './Icon';
|
import Icon from './Icon';
|
||||||
|
|
||||||
const App = () => {
|
const App = () => {
|
||||||
return <Icon name="home" />;
|
return <Icon name="Home" />;
|
||||||
};
|
};
|
||||||
|
|
||||||
export default App;
|
export default App;
|
||||||
|
|||||||
@@ -30,6 +30,7 @@
|
|||||||
"vitepress": "1.0.0-beta.1"
|
"vitepress": "1.0.0-beta.1"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@floating-ui/vue": "^1.0.1",
|
||||||
"@headlessui/vue": "^1.7.13",
|
"@headlessui/vue": "^1.7.13",
|
||||||
"@vueuse/components": "^10.1.0",
|
"@vueuse/components": "^10.1.0",
|
||||||
"@vueuse/core": "^10.1.0",
|
"@vueuse/core": "^10.1.0",
|
||||||
|
|||||||
15
icons/area-chart.json
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"nstokoe"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"statistics",
|
||||||
|
"diagram",
|
||||||
|
"graph",
|
||||||
|
"area"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"charts"
|
||||||
|
]
|
||||||
|
}
|
||||||
14
icons/area-chart.svg
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M3 3v18h18" />
|
||||||
|
<path d="M7 12v5h12V8l-5 5-4-4Z" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 272 B |
23
icons/arrows-up-from-line.json
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley",
|
||||||
|
"ericfennis"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"direction",
|
||||||
|
"orientation",
|
||||||
|
"this way up",
|
||||||
|
"vertical",
|
||||||
|
"package",
|
||||||
|
"box",
|
||||||
|
"fragile",
|
||||||
|
"postage",
|
||||||
|
"shipping"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"arrows",
|
||||||
|
"transportation",
|
||||||
|
"mail"
|
||||||
|
]
|
||||||
|
}
|
||||||
17
icons/arrows-up-from-line.svg
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="m4 6 3-3 3 3" />
|
||||||
|
<path d="M7 17V3" />
|
||||||
|
<path d="m14 6 3-3 3 3" />
|
||||||
|
<path d="M17 17V3" />
|
||||||
|
<path d="M4 21h16" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 336 B |
@@ -11,7 +11,8 @@
|
|||||||
"square",
|
"square",
|
||||||
"rectangular",
|
"rectangular",
|
||||||
"marquee",
|
"marquee",
|
||||||
"tool"
|
"tool",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"text",
|
"text",
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
"calculating machine"
|
"calculating machine"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"maths"
|
"maths",
|
||||||
|
"devices"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
19
icons/container.json
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"tags": [
|
||||||
|
"storage",
|
||||||
|
"shipping",
|
||||||
|
"freight",
|
||||||
|
"supply chain",
|
||||||
|
"docker",
|
||||||
|
"environment",
|
||||||
|
"devops",
|
||||||
|
"code",
|
||||||
|
"coding"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"development",
|
||||||
|
"transportation",
|
||||||
|
"mail"
|
||||||
|
]
|
||||||
|
}
|
||||||
17
icons/container.svg
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M22 7.7c0-.6-.4-1.2-.8-1.5l-6.3-3.9a1.72 1.72 0 0 0-1.7 0l-10.3 6c-.5.2-.9.8-.9 1.4v6.6c0 .5.4 1.2.8 1.5l6.3 3.9a1.72 1.72 0 0 0 1.7 0l10.3-6c.5-.3.9-1 .9-1.5Z" />
|
||||||
|
<path d="M10 21.9V14L2.1 9.1" />
|
||||||
|
<path d="m10 14 11.9-6.9" />
|
||||||
|
<path d="M14 19.8v-8.1" />
|
||||||
|
<path d="M18 17.5V9.4" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 506 B |
@@ -7,7 +7,8 @@
|
|||||||
"tags": [
|
"tags": [
|
||||||
"reflect",
|
"reflect",
|
||||||
"mirror",
|
"mirror",
|
||||||
"alignment"
|
"alignment",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"design",
|
"design",
|
||||||
|
|||||||
@@ -7,7 +7,8 @@
|
|||||||
"tags": [
|
"tags": [
|
||||||
"reflect",
|
"reflect",
|
||||||
"mirror",
|
"mirror",
|
||||||
"alignment"
|
"alignment",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"design",
|
"design",
|
||||||
|
|||||||
@@ -8,7 +8,8 @@
|
|||||||
"tags": [
|
"tags": [
|
||||||
"reflect",
|
"reflect",
|
||||||
"mirror",
|
"mirror",
|
||||||
"alignment"
|
"alignment",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"design",
|
"design",
|
||||||
|
|||||||
@@ -7,7 +7,8 @@
|
|||||||
"tags": [
|
"tags": [
|
||||||
"reflect",
|
"reflect",
|
||||||
"mirror",
|
"mirror",
|
||||||
"alignment"
|
"alignment",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"design",
|
"design",
|
||||||
|
|||||||
@@ -9,7 +9,8 @@
|
|||||||
"tags": [
|
"tags": [
|
||||||
"camera",
|
"camera",
|
||||||
"lens",
|
"lens",
|
||||||
"photo"
|
"photo",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"photography"
|
"photography"
|
||||||
|
|||||||
27
icons/gallery-horizontal-end.json
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"carousel",
|
||||||
|
"pictures",
|
||||||
|
"images",
|
||||||
|
"scroll",
|
||||||
|
"swipe",
|
||||||
|
"album",
|
||||||
|
"portfolio",
|
||||||
|
"history",
|
||||||
|
"versions",
|
||||||
|
"backup",
|
||||||
|
"time machine"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"layout",
|
||||||
|
"design",
|
||||||
|
"development",
|
||||||
|
"photography",
|
||||||
|
"multimedia",
|
||||||
|
"files"
|
||||||
|
]
|
||||||
|
}
|
||||||
15
icons/gallery-horizontal-end.svg
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M2 7v10" />
|
||||||
|
<path d="M6 5v14" />
|
||||||
|
<rect width="12" height="18" x="10" y="3" rx="2" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 308 B |
22
icons/gallery-horizontal.json
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"carousel",
|
||||||
|
"pictures",
|
||||||
|
"images",
|
||||||
|
"scroll",
|
||||||
|
"swipe",
|
||||||
|
"album",
|
||||||
|
"portfolio"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"layout",
|
||||||
|
"design",
|
||||||
|
"development",
|
||||||
|
"photography",
|
||||||
|
"multimedia"
|
||||||
|
]
|
||||||
|
}
|
||||||
15
icons/gallery-horizontal.svg
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M2 3v18" />
|
||||||
|
<rect width="12" height="18" x="6" y="3" rx="2" />
|
||||||
|
<path d="M22 3v18" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 308 B |
21
icons/gallery-thumbnails.json
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"carousel",
|
||||||
|
"pictures",
|
||||||
|
"images",
|
||||||
|
"album",
|
||||||
|
"portfolio",
|
||||||
|
"preview"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"layout",
|
||||||
|
"design",
|
||||||
|
"development",
|
||||||
|
"photography",
|
||||||
|
"multimedia"
|
||||||
|
]
|
||||||
|
}
|
||||||
17
icons/gallery-thumbnails.svg
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<rect width="18" height="14" x="3" y="3" rx="2" />
|
||||||
|
<path d="M4 21h1" />
|
||||||
|
<path d="M9 21h1" />
|
||||||
|
<path d="M14 21h1" />
|
||||||
|
<path d="M19 21h1" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 355 B |
27
icons/gallery-vertical-end.json
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"carousel",
|
||||||
|
"pictures",
|
||||||
|
"images",
|
||||||
|
"scroll",
|
||||||
|
"swipe",
|
||||||
|
"album",
|
||||||
|
"portfolio",
|
||||||
|
"history",
|
||||||
|
"versions",
|
||||||
|
"backup",
|
||||||
|
"time machine"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"layout",
|
||||||
|
"design",
|
||||||
|
"development",
|
||||||
|
"photography",
|
||||||
|
"multimedia",
|
||||||
|
"files"
|
||||||
|
]
|
||||||
|
}
|
||||||
15
icons/gallery-vertical-end.svg
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M7 2h10" />
|
||||||
|
<path d="M5 6h14" />
|
||||||
|
<rect width="18" height="12" x="3" y="10" rx="2" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 308 B |
22
icons/gallery-vertical.json
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"carousel",
|
||||||
|
"pictures",
|
||||||
|
"images",
|
||||||
|
"scroll",
|
||||||
|
"swipe",
|
||||||
|
"album",
|
||||||
|
"portfolio"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"layout",
|
||||||
|
"design",
|
||||||
|
"development",
|
||||||
|
"photography",
|
||||||
|
"multimedia"
|
||||||
|
]
|
||||||
|
}
|
||||||
15
icons/gallery-vertical.svg
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M3 2h18" />
|
||||||
|
<rect width="18" height="12" x="3" y="6" rx="2" />
|
||||||
|
<path d="M3 22h18" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 308 B |
@@ -6,12 +6,22 @@
|
|||||||
],
|
],
|
||||||
"tags": [
|
"tags": [
|
||||||
"diamond",
|
"diamond",
|
||||||
|
"crystal",
|
||||||
|
"ruby",
|
||||||
|
"jewellery",
|
||||||
"price",
|
"price",
|
||||||
"special",
|
"special",
|
||||||
"present"
|
"present",
|
||||||
|
"gift",
|
||||||
|
"ring",
|
||||||
|
"wedding",
|
||||||
|
"proposal",
|
||||||
|
"marriage",
|
||||||
|
"rubygems"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"gaming",
|
"gaming",
|
||||||
"money"
|
"money",
|
||||||
|
"development"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@@ -9,8 +9,7 @@
|
|||||||
stroke-linecap="round"
|
stroke-linecap="round"
|
||||||
stroke-linejoin="round"
|
stroke-linejoin="round"
|
||||||
>
|
>
|
||||||
<polygon points="6 3 18 3 22 9 12 22 2 9" />
|
<path d="M6 3h12l4 6-10 13L2 9Z" />
|
||||||
<path d="m12 22 4-13-3-6" />
|
<path d="M11 3 8 9l4 13 4-13-3-6" />
|
||||||
<path d="M12 22 8 9l3-6" />
|
|
||||||
<path d="M2 9h20" />
|
<path d="M2 9h20" />
|
||||||
</svg>
|
</svg>
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 339 B After Width: | Height: | Size: 308 B |
@@ -10,7 +10,8 @@
|
|||||||
"units",
|
"units",
|
||||||
"collection",
|
"collection",
|
||||||
"cluster",
|
"cluster",
|
||||||
"gather"
|
"gather",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"shapes",
|
"shapes",
|
||||||
|
|||||||
@@ -8,7 +8,8 @@
|
|||||||
],
|
],
|
||||||
"tags": [
|
"tags": [
|
||||||
"fullscreen",
|
"fullscreen",
|
||||||
"expand"
|
"expand",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"layout",
|
"layout",
|
||||||
|
|||||||
@@ -11,8 +11,7 @@
|
|||||||
"issue",
|
"issue",
|
||||||
"code",
|
"code",
|
||||||
"coding",
|
"coding",
|
||||||
"version control",
|
"version control"
|
||||||
"dashed"
|
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"arrows",
|
"arrows",
|
||||||
|
|||||||
@@ -7,7 +7,8 @@
|
|||||||
"face",
|
"face",
|
||||||
"biometric",
|
"biometric",
|
||||||
"authentication",
|
"authentication",
|
||||||
"2fa"
|
"2fa",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"devices",
|
"devices",
|
||||||
|
|||||||
@@ -5,7 +5,8 @@
|
|||||||
"ericfennis"
|
"ericfennis"
|
||||||
],
|
],
|
||||||
"tags": [
|
"tags": [
|
||||||
"qr-code"
|
"qr-code",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"devices",
|
"devices",
|
||||||
|
|||||||
@@ -5,7 +5,8 @@
|
|||||||
"ericfennis"
|
"ericfennis"
|
||||||
],
|
],
|
||||||
"tags": [
|
"tags": [
|
||||||
"qr-code"
|
"qr-code",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"devices",
|
"devices",
|
||||||
|
|||||||
@@ -8,11 +8,14 @@
|
|||||||
"log",
|
"log",
|
||||||
"scripture",
|
"scripture",
|
||||||
"document",
|
"document",
|
||||||
|
"notes",
|
||||||
"parchment",
|
"parchment",
|
||||||
"list",
|
"list",
|
||||||
"long",
|
"long",
|
||||||
"script",
|
"script",
|
||||||
"code"
|
"story",
|
||||||
|
"code",
|
||||||
|
"coding"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"gaming",
|
"gaming",
|
||||||
|
|||||||
@@ -10,11 +10,14 @@
|
|||||||
"log",
|
"log",
|
||||||
"scripture",
|
"scripture",
|
||||||
"document",
|
"document",
|
||||||
|
"notes",
|
||||||
"parchment",
|
"parchment",
|
||||||
"list",
|
"list",
|
||||||
"long",
|
"long",
|
||||||
"script",
|
"script",
|
||||||
"code"
|
"story",
|
||||||
|
"code",
|
||||||
|
"coding"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"gaming",
|
"gaming",
|
||||||
|
|||||||
@@ -6,9 +6,8 @@
|
|||||||
"ericfennis"
|
"ericfennis"
|
||||||
],
|
],
|
||||||
"tags": [
|
"tags": [
|
||||||
"sheet",
|
"spreadsheet",
|
||||||
"grid",
|
"grid"
|
||||||
"spreadsheet"
|
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"text",
|
"text",
|
||||||
|
|||||||
20
icons/table-properties.json
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"property list",
|
||||||
|
"plist",
|
||||||
|
"spreadsheet",
|
||||||
|
"grid",
|
||||||
|
"dictionary",
|
||||||
|
"object",
|
||||||
|
"hash"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"text",
|
||||||
|
"development",
|
||||||
|
"files"
|
||||||
|
]
|
||||||
|
}
|
||||||
16
icons/table-properties.svg
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M15 3v18" />
|
||||||
|
<rect width="18" height="18" x="3" y="3" rx="2" />
|
||||||
|
<path d="M21 9H3" />
|
||||||
|
<path d="M21 15H3" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 332 B |
@@ -8,9 +8,8 @@
|
|||||||
"mittalyashu"
|
"mittalyashu"
|
||||||
],
|
],
|
||||||
"tags": [
|
"tags": [
|
||||||
"sheet",
|
"spreadsheet",
|
||||||
"grid",
|
"grid"
|
||||||
"spreadsheet"
|
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"text",
|
"text",
|
||||||
|
|||||||
@@ -9,8 +9,8 @@
|
|||||||
stroke-linecap="round"
|
stroke-linecap="round"
|
||||||
stroke-linejoin="round"
|
stroke-linejoin="round"
|
||||||
>
|
>
|
||||||
<rect width="18" height="18" x="3" y="3" rx="2" ry="2" />
|
<path d="M12 3v18" />
|
||||||
<line x1="3" x2="21" y1="9" y2="9" />
|
<rect width="18" height="18" x="3" y="3" rx="2" />
|
||||||
<line x1="3" x2="21" y1="15" y2="15" />
|
<path d="M3 9h18" />
|
||||||
<line x1="12" x2="12" y1="3" y2="21" />
|
<path d="M3 15h18" />
|
||||||
</svg>
|
</svg>
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 392 B After Width: | Height: | Size: 332 B |
20
icons/tally-1.json
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"tags": [
|
||||||
|
"count",
|
||||||
|
"score",
|
||||||
|
"enumerate",
|
||||||
|
"days",
|
||||||
|
"one",
|
||||||
|
"1",
|
||||||
|
"first",
|
||||||
|
"bar",
|
||||||
|
"prison",
|
||||||
|
"cell",
|
||||||
|
"sentence"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"maths",
|
||||||
|
"gaming"
|
||||||
|
]
|
||||||
|
}
|
||||||
13
icons/tally-1.svg
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M4 4v16" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 231 B |
21
icons/tally-2.json
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"tags": [
|
||||||
|
"count",
|
||||||
|
"score",
|
||||||
|
"enumerate",
|
||||||
|
"days",
|
||||||
|
"two",
|
||||||
|
"2",
|
||||||
|
"second",
|
||||||
|
"double",
|
||||||
|
"bars",
|
||||||
|
"prison",
|
||||||
|
"cell",
|
||||||
|
"sentence"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"maths",
|
||||||
|
"gaming"
|
||||||
|
]
|
||||||
|
}
|
||||||
14
icons/tally-2.svg
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M4 4v16" />
|
||||||
|
<path d="M9 4v16" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 254 B |
21
icons/tally-3.json
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"tags": [
|
||||||
|
"count",
|
||||||
|
"score",
|
||||||
|
"enumerate",
|
||||||
|
"days",
|
||||||
|
"three",
|
||||||
|
"3",
|
||||||
|
"third",
|
||||||
|
"triple",
|
||||||
|
"bars",
|
||||||
|
"prison",
|
||||||
|
"cell",
|
||||||
|
"sentence"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"maths",
|
||||||
|
"gaming"
|
||||||
|
]
|
||||||
|
}
|
||||||
15
icons/tally-3.svg
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M4 4v16" />
|
||||||
|
<path d="M9 4v16" />
|
||||||
|
<path d="M14 4v16" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 278 B |
20
icons/tally-4.json
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"tags": [
|
||||||
|
"count",
|
||||||
|
"score",
|
||||||
|
"enumerate",
|
||||||
|
"days",
|
||||||
|
"4",
|
||||||
|
"fourth",
|
||||||
|
"quadruple",
|
||||||
|
"bars",
|
||||||
|
"prison",
|
||||||
|
"cell",
|
||||||
|
"sentence"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"maths",
|
||||||
|
"gaming"
|
||||||
|
]
|
||||||
|
}
|
||||||
16
icons/tally-4.svg
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M4 4v16" />
|
||||||
|
<path d="M9 4v16" />
|
||||||
|
<path d="M14 4v16" />
|
||||||
|
<path d="M19 4v16" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 302 B |
22
icons/tally-5.json
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"tags": [
|
||||||
|
"count",
|
||||||
|
"score",
|
||||||
|
"enumerate",
|
||||||
|
"days",
|
||||||
|
"five",
|
||||||
|
"5",
|
||||||
|
"fifth",
|
||||||
|
"bars",
|
||||||
|
"prison",
|
||||||
|
"cell",
|
||||||
|
"sentence",
|
||||||
|
"slash",
|
||||||
|
"/"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"maths",
|
||||||
|
"gaming"
|
||||||
|
]
|
||||||
|
}
|
||||||
17
icons/tally-5.svg
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M4 4v16" />
|
||||||
|
<path d="M9 4v16" />
|
||||||
|
<path d="M14 4v16" />
|
||||||
|
<path d="M19 4v16" />
|
||||||
|
<path d="M22 6 2 18" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 328 B |
@@ -3,14 +3,17 @@
|
|||||||
"contributors": [
|
"contributors": [
|
||||||
"danielbayley"
|
"danielbayley"
|
||||||
],
|
],
|
||||||
"aliases": ["text-selection"],
|
|
||||||
"tags": [
|
"tags": [
|
||||||
"find",
|
"find",
|
||||||
"search",
|
"search",
|
||||||
"selection"
|
"selection",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"text",
|
"text",
|
||||||
"cursors"
|
"cursors"
|
||||||
|
],
|
||||||
|
"aliases": [
|
||||||
|
"text-selection"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@@ -8,7 +8,9 @@
|
|||||||
"tags": [
|
"tags": [
|
||||||
"entry",
|
"entry",
|
||||||
"pass",
|
"pass",
|
||||||
"voucher"
|
"voucher",
|
||||||
|
"perforated",
|
||||||
|
"dashed"
|
||||||
],
|
],
|
||||||
"categories": [
|
"categories": [
|
||||||
"account",
|
"account",
|
||||||
|
|||||||
14
icons/wallet-2.json
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"finance",
|
||||||
|
"pocket"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"account",
|
||||||
|
"money"
|
||||||
|
]
|
||||||
|
}
|
||||||
14
icons/wallet-2.svg
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<path d="M17 14h.01" />
|
||||||
|
<path d="M7 7h12a2 2 0 0 1 2 2v10a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h14" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 323 B |
22
icons/wallet-cards.json
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
{
|
||||||
|
"$schema": "../icon.schema.json",
|
||||||
|
"contributors": [
|
||||||
|
"danielbayley"
|
||||||
|
],
|
||||||
|
"tags": [
|
||||||
|
"money",
|
||||||
|
"finance",
|
||||||
|
"pocket",
|
||||||
|
"credit",
|
||||||
|
"purchase",
|
||||||
|
"payment",
|
||||||
|
"shopping",
|
||||||
|
"retail",
|
||||||
|
"consumer",
|
||||||
|
"cc"
|
||||||
|
],
|
||||||
|
"categories": [
|
||||||
|
"account",
|
||||||
|
"money"
|
||||||
|
]
|
||||||
|
}
|
||||||
15
icons/wallet-cards.svg
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<svg
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
width="24"
|
||||||
|
height="24"
|
||||||
|
viewBox="0 0 24 24"
|
||||||
|
fill="none"
|
||||||
|
stroke="currentColor"
|
||||||
|
stroke-width="2"
|
||||||
|
stroke-linecap="round"
|
||||||
|
stroke-linejoin="round"
|
||||||
|
>
|
||||||
|
<rect width="18" height="18" x="3" y="3" rx="2" />
|
||||||
|
<path d="M3 9a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2" />
|
||||||
|
<path d="M3 11h3c.8 0 1.6.3 2.1.9l1.1.9c1.6 1.6 4.1 1.6 5.7 0l1.1-.9c.5-.5 1.3-.9 2.1-.9H21" />
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 410 B |
@@ -9,7 +9,7 @@
|
|||||||
stroke-linecap="round"
|
stroke-linecap="round"
|
||||||
stroke-linejoin="round"
|
stroke-linejoin="round"
|
||||||
>
|
>
|
||||||
<path d="M20 12V8H6a2 2 0 0 1-2-2c0-1.1.9-2 2-2h12v4" />
|
<path d="M21 12V7H5a2 2 0 0 1 0-4h14v4" />
|
||||||
<path d="M4 6v12c0 1.1.9 2 2 2h14v-4" />
|
<path d="M3 5v14a2 2 0 0 0 2 2h16v-5" />
|
||||||
<path d="M18 12a2 2 0 0 0-2 2c0 1.1.9 2 2 2h4v-4h-4z" />
|
<path d="M18 12a2 2 0 0 0 0 4h4v-4Z" />
|
||||||
</svg>
|
</svg>
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 369 B After Width: | Height: | Size: 338 B |
10
package.json
@@ -32,20 +32,20 @@
|
|||||||
"gi": "node ./scripts/generate/generateIcons.mjs"
|
"gi": "node ./scripts/generate/generateIcons.mjs"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@octokit/rest": "^19.0.7",
|
"@octokit/rest": "^19.0.13",
|
||||||
"eslint": "^8.36.0",
|
"eslint": "^8.43.0",
|
||||||
"eslint-config-airbnb-base": "^15.0.0",
|
"eslint-config-airbnb-base": "^15.0.0",
|
||||||
"eslint-config-prettier": "^8.8.0",
|
"eslint-config-prettier": "^8.8.0",
|
||||||
"eslint-plugin-import": "^2.27.5",
|
"eslint-plugin-import": "^2.27.5",
|
||||||
"eslint-plugin-prettier": "^4.2.1",
|
"eslint-plugin-prettier": "^4.2.1",
|
||||||
"husky": "^8.0.3",
|
"husky": "^8.0.3",
|
||||||
"lint-staged": "^13.2.0",
|
"lint-staged": "^13.2.3",
|
||||||
"minimist": "^1.2.8",
|
"minimist": "^1.2.8",
|
||||||
"node-fetch": "^3.3.1",
|
"node-fetch": "^3.3.1",
|
||||||
"p-memoize": "^7.1.1",
|
"p-memoize": "^7.1.1",
|
||||||
"prettier": "2.7.1",
|
"prettier": "2.7.1",
|
||||||
"semver": "^7.5.0",
|
"semver": "^7.5.3",
|
||||||
"simple-git": "^3.18.0",
|
"simple-git": "^3.19.1",
|
||||||
"svgo": "^3.0.2",
|
"svgo": "^3.0.2",
|
||||||
"svgson": "^5.2.1"
|
"svgson": "^5.2.1"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -23,7 +23,8 @@
|
|||||||
"@types/react-dom": "^17.0.0",
|
"@types/react-dom": "^17.0.0",
|
||||||
"@vitejs/plugin-react": "^1.0.0",
|
"@vitejs/plugin-react": "^1.0.0",
|
||||||
"typescript": "^4.3.2",
|
"typescript": "^4.3.2",
|
||||||
"vite": "^2.6.4",
|
"vite": "^4.3.9",
|
||||||
|
"vitest": "^0.32.2",
|
||||||
"vite-plugin-singlefile": "^0.5.1"
|
"vite-plugin-singlefile": "^0.5.1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,8 +40,8 @@
|
|||||||
"preact": "^10.11.2",
|
"preact": "^10.11.2",
|
||||||
"rollup": "^3.5.1",
|
"rollup": "^3.5.1",
|
||||||
"typescript": "^4.8.4",
|
"typescript": "^4.8.4",
|
||||||
"vite": "^3.1.0",
|
"vite": "^4.3.9",
|
||||||
"vitest": "^0.24.3"
|
"vitest": "^0.32.2"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"preact": "^10.5.13"
|
"preact": "^10.5.13"
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Vitest Snapshot v1
|
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
||||||
|
|
||||||
exports[`Using lucide icon components > should adjust the size, stroke color and stroke width 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"48\\" height=\\"48\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"red\\" stroke-width=\\"4\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" class=\\"lucide lucide-grid\\" data-testid=\\"grid-icon\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\"></line></svg>"`;
|
exports[`Using lucide icon components > should adjust the size, stroke color and stroke width 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"48\\" height=\\"48\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"red\\" stroke-width=\\"4\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" class=\\"lucide lucide-grid\\" data-testid=\\"grid-icon\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\"></line></svg>"`;
|
||||||
|
|
||||||
|
|||||||
@@ -47,8 +47,8 @@
|
|||||||
"react-native-svg": "^13.0.0",
|
"react-native-svg": "^13.0.0",
|
||||||
"rollup": "^3.5.1",
|
"rollup": "^3.5.1",
|
||||||
"typescript": "^4.8.4",
|
"typescript": "^4.8.4",
|
||||||
"vite": "^3.1.0",
|
"vite": "^4.3.9",
|
||||||
"vitest": "^0.24.3"
|
"vitest": "^0.32.2"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"prop-types": "^15.7.2",
|
"prop-types": "^15.7.2",
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Vitest Snapshot v1
|
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
||||||
|
|
||||||
exports[`Using lucide icon components > should adjust the size, stroke color and stroke width 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"48\\" height=\\"48\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"red\\" stroke-width=\\"4\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" data-testid=\\"grid-icon\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\"></line></svg>"`;
|
exports[`Using lucide icon components > should adjust the size, stroke color and stroke width 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"48\\" height=\\"48\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"red\\" stroke-width=\\"4\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" data-testid=\\"grid-icon\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\"></line></svg>"`;
|
||||||
|
|
||||||
|
|||||||
@@ -45,8 +45,8 @@
|
|||||||
"react-dom": "17.0.2",
|
"react-dom": "17.0.2",
|
||||||
"rollup": "^3.5.1",
|
"rollup": "^3.5.1",
|
||||||
"typescript": "^4.8.4",
|
"typescript": "^4.8.4",
|
||||||
"vite": "^3.1.0",
|
"vite": "^4.3.9",
|
||||||
"vitest": "^0.24.3"
|
"vitest": "^0.32.2"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"react": "^16.5.1 || ^17.0.0 || ^18.0.0"
|
"react": "^16.5.1 || ^17.0.0 || ^18.0.0"
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Vitest Snapshot v1
|
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
||||||
|
|
||||||
exports[`Using lucide icon components > should adjust the size, stroke color and stroke width 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"48\\" height=\\"48\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"red\\" stroke-width=\\"4\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" class=\\"lucide lucide-grid\\" data-testid=\\"grid-icon\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\"></line></svg>"`;
|
exports[`Using lucide icon components > should adjust the size, stroke color and stroke width 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"48\\" height=\\"48\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"red\\" stroke-width=\\"4\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" class=\\"lucide lucide-grid\\" data-testid=\\"grid-icon\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\"></line></svg>"`;
|
||||||
|
|
||||||
|
|||||||
@@ -46,12 +46,12 @@
|
|||||||
"jsdom": "^20.0.0",
|
"jsdom": "^20.0.0",
|
||||||
"rollup": "^3.5.1",
|
"rollup": "^3.5.1",
|
||||||
"rollup-preset-solid": "^2.0.1",
|
"rollup-preset-solid": "^2.0.1",
|
||||||
"solid-js": "^1.4.7",
|
"solid-js": "^1.7.7",
|
||||||
"solid-testing-library": "^0.3.0",
|
"solid-testing-library": "^0.5.1",
|
||||||
"typescript": "^4.9.4",
|
"typescript": "^4.9.4",
|
||||||
"vite": "^3.2.4",
|
"vite": "^4.3.9",
|
||||||
"vite-plugin-solid": "^2.3.0",
|
"vitest": "^0.32.2",
|
||||||
"vitest": "^0.23.2"
|
"vite-plugin-solid": "^2.7.0"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"solid-js": "^1.4.7"
|
"solid-js": "^1.4.7"
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
// Vitest Snapshot v1
|
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
||||||
|
|
||||||
exports[`Using lucide icon components > should adjust the size, stroke color and stroke width 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"48\\" height=\\"48\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"red\\" stroke-width=\\"4\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" class=\\"lucide lucide-grid \\" data-testid=\\"grid-icon\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\" key=\\"1m3agn\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\" key=\\"1vqk6q\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\" key=\\"o2sbyz\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\" key=\\"13tij5\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\" key=\\"1hpv9i\\"></line></svg>"`;
|
exports[`Using lucide icon components > should adjust the size, stroke color and stroke width 1`] = `"<svg data-testid=\\"grid-icon\\" width=\\"48\\" height=\\"48\\" stroke=\\"red\\" stroke-width=\\"4\\" class=\\"lucide lucide-grid \\" xmlns=\\"http://www.w3.org/2000/svg\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\" key=\\"1m3agn\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\" key=\\"1vqk6q\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\" key=\\"o2sbyz\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\" key=\\"13tij5\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\" key=\\"1hpv9i\\"></line></svg>"`;
|
||||||
|
|
||||||
exports[`Using lucide icon components > should not scale the strokeWidth when absoluteStrokeWidth is set 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"48\\" height=\\"48\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"red\\" stroke-width=\\"1\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" class=\\"lucide lucide-grid \\" data-testid=\\"grid-icon\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\" key=\\"1m3agn\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\" key=\\"1vqk6q\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\" key=\\"o2sbyz\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\" key=\\"13tij5\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\" key=\\"1hpv9i\\"></line></svg>"`;
|
exports[`Using lucide icon components > should not scale the strokeWidth when absoluteStrokeWidth is set 1`] = `"<svg data-testid=\\"grid-icon\\" width=\\"48\\" height=\\"48\\" stroke=\\"red\\" stroke-width=\\"1\\" class=\\"lucide lucide-grid \\" xmlns=\\"http://www.w3.org/2000/svg\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\" key=\\"1m3agn\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\" key=\\"1vqk6q\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\" key=\\"o2sbyz\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\" key=\\"13tij5\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\" key=\\"1hpv9i\\"></line></svg>"`;
|
||||||
|
|
||||||
exports[`Using lucide icon components > should render an component 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"24\\" height=\\"24\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke=\\"currentColor\\" stroke-width=\\"2\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" class=\\"lucide lucide-grid \\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\" key=\\"1m3agn\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\" key=\\"1vqk6q\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\" key=\\"o2sbyz\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\" key=\\"13tij5\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\" key=\\"1hpv9i\\"></line></svg>"`;
|
exports[`Using lucide icon components > should render an component 1`] = `"<svg width=\\"24\\" height=\\"24\\" stroke=\\"currentColor\\" stroke-width=\\"2\\" class=\\"lucide lucide-grid \\" xmlns=\\"http://www.w3.org/2000/svg\\" viewBox=\\"0 0 24 24\\" fill=\\"none\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\"><rect width=\\"18\\" height=\\"18\\" x=\\"3\\" y=\\"3\\" rx=\\"2\\" ry=\\"2\\" key=\\"1m3agn\\"></rect><line x1=\\"3\\" x2=\\"21\\" y1=\\"9\\" y2=\\"9\\" key=\\"1vqk6q\\"></line><line x1=\\"3\\" x2=\\"21\\" y1=\\"15\\" y2=\\"15\\" key=\\"o2sbyz\\"></line><line x1=\\"9\\" x2=\\"9\\" y1=\\"3\\" y2=\\"21\\" key=\\"13tij5\\"></line><line x1=\\"15\\" x2=\\"15\\" y1=\\"3\\" y2=\\"21\\" key=\\"1hpv9i\\"></line></svg>"`;
|
||||||
|
|||||||
@@ -7,12 +7,12 @@ export default defineConfig({
|
|||||||
globals: true,
|
globals: true,
|
||||||
environment: 'jsdom',
|
environment: 'jsdom',
|
||||||
transformMode: {
|
transformMode: {
|
||||||
web: [/\.jsx?$/],
|
web: [/\.[jt]sx?$/]
|
||||||
},
|
},
|
||||||
setupFiles: './tests/setupVitest.js',
|
setupFiles: './tests/setupVitest.js',
|
||||||
threads: false,
|
// threads: false,
|
||||||
isolate: false,
|
// isolate: false,
|
||||||
watch: false,
|
// watch: false,
|
||||||
},
|
},
|
||||||
resolve: {
|
resolve: {
|
||||||
conditions: ['development', 'browser'],
|
conditions: ['development', 'browser'],
|
||||||
|
|||||||
@@ -33,25 +33,25 @@
|
|||||||
"version": "pnpm version --git-tag-version=false"
|
"version": "pnpm version --git-tag-version=false"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@lucide/rollup-plugins": "workspace:*",
|
|
||||||
"@lucide/build-icons": "workspace:*",
|
"@lucide/build-icons": "workspace:*",
|
||||||
"@rollup/plugin-node-resolve": "^15.0.1",
|
"@lucide/rollup-plugins": "workspace:*",
|
||||||
"@sveltejs/vite-plugin-svelte": "^1.2.0",
|
"@rollup/plugin-node-resolve": "^15.1.0",
|
||||||
"@testing-library/jest-dom": "^5.16.2",
|
"@sveltejs/vite-plugin-svelte": "^2.4.2",
|
||||||
"@testing-library/svelte": "^3.0.3",
|
"@testing-library/jest-dom": "^5.16.5",
|
||||||
"@tsconfig/svelte": "^3.0.0",
|
"@testing-library/svelte": "^4.0.2",
|
||||||
|
"@tsconfig/svelte": "^5.0.0",
|
||||||
"jsdom": "^20.0.3",
|
"jsdom": "^20.0.3",
|
||||||
"rollup": "^3.5.1",
|
"rollup": "^3.25.3",
|
||||||
"rollup-plugin-svelte": "^7.1.0",
|
"rollup-plugin-svelte": "^7.1.6",
|
||||||
"svelte": "^3.53.1",
|
"svelte": "^4.0.1",
|
||||||
"svelte-check": "^2.9.2",
|
"svelte-check": "^3.4.4",
|
||||||
"svelte-preprocess": "^4.10.7",
|
"svelte-preprocess": "^5.0.4",
|
||||||
"svelte-strip": "^1.0.3",
|
"svelte-strip": "^2.0.0",
|
||||||
"typescript": "^4.9.3",
|
"typescript": "^5.1.6",
|
||||||
"vite": "^3.1.0",
|
"vite": "^4.3.9",
|
||||||
"vitest": "^0.23.2"
|
"vitest": "^0.32.2"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"svelte": "^3.49.0"
|
"svelte": ">=3 <5"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Vitest Snapshot v1
|
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
||||||
|
|
||||||
exports[`Using lucide icon components > should add a class to the element 1`] = `
|
exports[`Using lucide icon components > should add a class to the element 1`] = `
|
||||||
<svg
|
<svg
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import { describe, it, expect, afterEach } from 'vitest';
|
import { describe, it, expect, afterEach } from 'vitest';
|
||||||
import { render, cleanup, logDOM } from '@testing-library/svelte';
|
import { render, cleanup } from '@testing-library/svelte';
|
||||||
import { Smile, Pen, Edit2 } from '../src/lucide-svelte'
|
import { Smile, Pen, Edit2 } from '../src/lucide-svelte'
|
||||||
import TestSlots from './TestSlots.svelte'
|
import TestSlots from './TestSlots.svelte'
|
||||||
|
|
||||||
|
|||||||
@@ -2,12 +2,17 @@ import { defineConfig } from 'vitest/config'
|
|||||||
import { svelte } from '@sveltejs/vite-plugin-svelte'
|
import { svelte } from '@sveltejs/vite-plugin-svelte'
|
||||||
|
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
plugins: [svelte({ hot: false })],
|
plugins: [
|
||||||
|
svelte({
|
||||||
|
hot: false,
|
||||||
|
})
|
||||||
|
],
|
||||||
test: {
|
test: {
|
||||||
globals: true,
|
globals: true,
|
||||||
environment: 'jsdom',
|
environment: 'jsdom',
|
||||||
setupFiles: './tests/setupVitest.ts',
|
setupFiles: './tests/setupVitest.ts',
|
||||||
threads: false,
|
alias: [
|
||||||
isolate: false,
|
{ find: /^svelte$/, replacement: "svelte/internal" }
|
||||||
|
]
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -42,8 +42,8 @@
|
|||||||
"@vue/test-utils": "2.2.4",
|
"@vue/test-utils": "2.2.4",
|
||||||
"@vitejs/plugin-vue": "^3.2.0",
|
"@vitejs/plugin-vue": "^3.2.0",
|
||||||
"rollup": "^3.5.1",
|
"rollup": "^3.5.1",
|
||||||
"vite": "^3.1.0",
|
"vite": "^4.3.9",
|
||||||
"vitest": "^0.24.3",
|
"vitest": "^0.32.2",
|
||||||
"vue": "3.2.45",
|
"vue": "3.2.45",
|
||||||
"jsdom": "^20.0.3"
|
"jsdom": "^20.0.3"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -40,8 +40,8 @@
|
|||||||
"@vue/test-utils": "1.3.0",
|
"@vue/test-utils": "1.3.0",
|
||||||
"rollup": "^3.23.0",
|
"rollup": "^3.23.0",
|
||||||
"typescript": "^4.9.5",
|
"typescript": "^4.9.5",
|
||||||
"vite": "^3.2.7",
|
"vite": "^4.3.9",
|
||||||
"vitest": "^0.24.5",
|
"vitest": "^0.32.2",
|
||||||
"vue": "2.7.14",
|
"vue": "2.7.14",
|
||||||
"vue-template-compiler": "2.7.14"
|
"vue-template-compiler": "2.7.14"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -39,7 +39,7 @@
|
|||||||
"rollup": "^3.5.1",
|
"rollup": "^3.5.1",
|
||||||
"rollup-plugin-dts": "^5.0.0",
|
"rollup-plugin-dts": "^5.0.0",
|
||||||
"typescript": "^4.9.3",
|
"typescript": "^4.9.3",
|
||||||
"vite": "^3.1.0",
|
"vite": "^4.3.9",
|
||||||
"vitest": "^0.24.3"
|
"vitest": "^0.32.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
// Vitest Snapshot v1
|
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
||||||
|
|
||||||
exports[`createIcons > should add custom attributes 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"24\\" height=\\"24\\" viewBox=\\"0 0 24 24\\" fill=\\"black\\" stroke=\\"currentColor\\" stroke-width=\\"2\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" data-lucide=\\"volume-2\\" class=\\"lucide lucide-volume-2 icon custom-class\\"><polygon points=\\"11 5 6 9 2 9 2 15 6 15 11 19 11 5\\"></polygon><path d=\\"M15.54 8.46a5 5 0 0 1 0 7.07\\"></path><path d=\\"M19.07 4.93a10 10 0 0 1 0 14.14\\"></path></svg>"`;
|
exports[`createIcons > should add custom attributes 1`] = `"<svg xmlns=\\"http://www.w3.org/2000/svg\\" width=\\"24\\" height=\\"24\\" viewBox=\\"0 0 24 24\\" fill=\\"black\\" stroke=\\"currentColor\\" stroke-width=\\"2\\" stroke-linecap=\\"round\\" stroke-linejoin=\\"round\\" data-lucide=\\"volume-2\\" class=\\"lucide lucide-volume-2 icon custom-class\\"><polygon points=\\"11 5 6 9 2 9 2 15 6 15 11 19 11 5\\"></polygon><path d=\\"M15.54 8.46a5 5 0 0 1 0 7.07\\"></path><path d=\\"M19.07 4.93a10 10 0 0 1 0 14.14\\"></path></svg>"`;
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
// Vitest Snapshot v1
|
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
|
||||||
|
|
||||||
exports[`combineClassNames > should retuns a string of classNames 1`] = `"item item1 item2 item3 item4 item5 item6 item7 item8 item9"`;
|
exports[`combineClassNames > should retuns a string of classNames 1`] = `"item item1 item2 item3 item4 item5 item6 item7 item8 item9"`;
|
||||||
|
|||||||