From b34630cf873f57eac7ba375c0485ea8c7d6f95c3 Mon Sep 17 00:00:00 2001 From: Asva Date: Fri, 4 Jan 2019 18:31:15 +0300 Subject: [PATCH] fix: icon search for multi set icons fix #447 --- src/components/ui/icons/IconSet.vue | 37 ++++++++++++++++------------- 1 file changed, 20 insertions(+), 17 deletions(-) diff --git a/src/components/ui/icons/IconSet.vue b/src/components/ui/icons/IconSet.vue index eb2378b2a..f7a281545 100644 --- a/src/components/ui/icons/IconSet.vue +++ b/src/components/ui/icons/IconSet.vue @@ -13,7 +13,7 @@
export default { - name: 'set', + name: 'vuestic-icon-set', props: { name: { type: String, @@ -84,7 +84,7 @@ export default { }, data () { return { - selector: '', + search: '', iconSize: 30, slider: { formatter: v => `${v}px`, @@ -99,28 +99,31 @@ export default { if (set.href === this.name) return set } }, - - validatedLists () { - if (this.selector === '') { + filteredLists () { + if (!this.search) { + // If nothing is searched - we return all sets return this.set.lists } - let result = [ - { - name: 'Found Icons', - icons: [], - }, - ] - + const foundIcons = [] this.set.lists.forEach(list => { list.icons.forEach(icon => { - if (icon.match(this.selector)) { - result[0].icons.push(icon) + if (!icon.toUpperCase().includes(this.search.toUpperCase())) { + return + } + // Same icon could be included in different sets. + if (foundIcons.includes(icon)) { + return } + foundIcons.push(icon) }) }) - return result + // We return all found icons as a single set. + return [{ + name: 'Found Icons', + icons: foundIcons, + }] }, }, methods: {