diff --git a/app/api.imba b/app/api.imba
index edd8957..6df2695 100644
--- a/app/api.imba
+++ b/app/api.imba
@@ -80,10 +80,14 @@ export default new class api
def sort_links
if state.query.trim!.length <= 0
- return state.sorted_links = orderBy(state.links, ['is_pinned', 'frequency'], ['desc', 'desc'])
- if config.data.enable_effective_names
- return state.sorted_links = fzi state.links, state.query
- state.sorted_links = fzi state.links, state.query, "display_name"
+ state.sorted_links = orderBy(state.links, ['is_pinned', 'frequency'], ['desc', 'desc'])
+ elif config.data.enable_effective_names
+ state.sorted_links = fzi.sort state.query, state.links, do |x| x.name
+ else
+ state.sorted_links = fzi.sort state.query, state.links, do |x| x.display_name
+
+ def name_exists new_name
+ state.links.some! do |{name}| new_name is name
def add_initial_links
let initial_links = [
@@ -102,7 +106,7 @@ export default new class api
catch e
err "adding link", e
- def create_link_from_text text
+ def create_link_from_text text, get_icon=yes
text = text.trim!
throw "Text is empty." if text is ''
let split_text = text.split(/\s+/)
@@ -110,7 +114,6 @@ export default new class api
let url = split_text.pop!
let host
{ href:url, host } = parse_url url
- let icon = await fetch_image_as_base_64 host
let name
if split_text[-1].startsWith "`"
name = split_text.pop!.slice(1)
@@ -121,7 +124,10 @@ export default new class api
is_bang = yes
display_name = display_name.slice(1)
name ||= display_name
- { name, display_name, is_bang, is_pinned, url, frequency:0, icon }
+ let link = { name, display_name, is_bang, is_pinned, url, frequency:0 }
+ if get_icon
+ link.icon = await fetch_image_as_base_64 host
+ return link
def fetch_image_as_base_64 host
let fallback = ''
diff --git a/app/components/app-community-links.imba b/app/components/app-community-links.imba
index 0f1b07d..a73a934 100644
--- a/app/components/app-community-links.imba
+++ b/app/components/app-community-links.imba
@@ -1,14 +1,37 @@
let p = console.log
-import links from '../assets/community_links'
+import all_links from '../assets/community_links'
import fzi from 'fzi'
+import api from '../api'
tag app-community-links
- active = yes
+ active = no
selection_index = 0
+ query = ""
+
+ get render? do mounted?
def mount
$cli.focus!
+ links = await get_links!
+ render!
+
+ def get_links
+ let result = []
+ for link_text in all_links
+ let link = await api.create_link_from_text(link_text, no)
+ link.link_text = link_text
+ result.push link
+ result
+
+ get filtered_links
+ links.filter! do |link| !api.name_exists(link.name)
+
+ get sorted_links
+ fzi.sort query, filtered_links, do |x| x.name
+
+ get selected_link
+ sorted_links[selection_index]
def open
active = yes
@@ -22,27 +45,31 @@ tag app-community-links
def decrement_selection_index
selection_index = Math.max(0, selection_index - 1)
- def get_link_obj link_text
- let split_text = link_text.trim!.split /\s+/
- let url = split_text.pop!
- let rest = split_text.join " "
- { url, rest }
-
- def add_community_link link
- await db.links.add link
- await api.reload_db!
- imba.commit!
+ def add_community_link
+ return if state.loading
+ state.loading = yes
+ try
+ await api.add_link selected_link.link_text
+ catch e
+ err "adding link", e
+ state.loading = no
get tips
let result = []
result.push <>
- <.tip @click=close>
+ <.tip
+ @click=close
+ @hotkey("esc").force=close
+ >
<.tip-hotkey> "Esc"
<.tip-content> "Exit Community Links"
result.push <>
- <.tip @click=handle_shift_return>
+ <.tip
+ @click=add_community_link
+ @hotkey("shift+return").force=add_community_link
+ >
<.tip-hotkey> "Shift + Return Or Click"
<.tip-content> "Add To Your Links"
@@ -62,28 +89,30 @@ tag app-community-links
css d:flex fld:column jc:start gap:15px fl:1 w:100% ofy:hidden
-
+
<.links>
css ofy:auto
- for link_text, index in links
+ for link, index in sorted_links
<.link
.selected=(selection_index == index)
@pointerover=(selection_index = index)
- @click=(add_community_link(link_text))
+ @click=add_community_link
>
css d:flex fld:row jc:space-between ai:center px:16px
- py:11px rd:5px cursor:pointer c:blue3 min-height:35px
+ py:2px rd:5px cursor:pointer c:blue3 min-height:35px
- let { url, rest } = get_link_obj link_text
+ if link.is_bang
+ css c:#FAD4AB
- <.link-left> rest
+ <.link-left> link.name
css fl:1
- if rest.startsWith("!")
- css c:#FAD4AB
- <.link-right> url
- css fl:1 overflow-wrap:anywhere word-break:break-all
+ link.url
+ css fl:1 c:inherit
diff --git a/app/components/app-settings.imba b/app/components/app-settings.imba
index d7a2741..cd4fbc7 100644
--- a/app/components/app-settings.imba
+++ b/app/components/app-settings.imba
@@ -35,9 +35,6 @@ tag app-settings
def handle_click_import e
- def name_exists new_name
- state.links.some! do |{name}| new_name is name
-
def handle_import
let errors = []
try
@@ -48,7 +45,7 @@ tag app-settings
for link_text in links
try
let link = await api.create_link_from_text link_text
- if name_exists link.name
+ if api.name_exists link.name
throw "Name already exists, add manually if you don't mind duplicates."
api.add_link link_text
catch e
diff --git a/package-lock.json b/package-lock.json
index 3fe66fa..3fcc6b7 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -11,8 +11,8 @@
"dexie": "^3.2.2",
"dexie-export-import": "^1.0.3",
"downloadjs": "^1.4.7",
- "fzi": "^1.0.0",
- "imba": "^2.0.0-alpha.219",
+ "fzi": "^1.1.0",
+ "imba": "^2.0.0-alpha.220",
"lodash": "^4.17.21",
"mathjs": "^11.1.0",
"nanoid": "^4.0.0"
@@ -516,9 +516,9 @@
}
},
"node_modules/fzi": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/fzi/-/fzi-1.0.0.tgz",
- "integrity": "sha512-ZsF/SPkQVWrVPvhkKRivf7pM8LC1kMQmWPXPlbHIdQPL10a6Q9eiVbCJfmEVRFbZafd66DQMC8brfpORxSaKKA=="
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/fzi/-/fzi-1.1.0.tgz",
+ "integrity": "sha512-5bqCChh+i3RQ2Acl+FGg7JnxONXLaWDl4g/JLbRJE+zV5zX0GI0ScpKr/MzgDqzRnhkqy58J6kVy+GfDv2QSFw=="
},
"node_modules/glob-parent": {
"version": "5.1.2",
@@ -532,9 +532,9 @@
}
},
"node_modules/imba": {
- "version": "2.0.0-alpha.219",
- "resolved": "https://registry.npmjs.org/imba/-/imba-2.0.0-alpha.219.tgz",
- "integrity": "sha512-5BIUK9DBNDvprJ/hPezfg4dk6w96j/yOCWU35O/CKpLx8ce+k/u534HYrdQNGZqfTY7ImSA5uRduVbp1zKi9Wg==",
+ "version": "2.0.0-alpha.220",
+ "resolved": "https://registry.npmjs.org/imba/-/imba-2.0.0-alpha.220.tgz",
+ "integrity": "sha512-Q2Kiqb7kLKfVZ19kje0PWgWR4K+0Nt3RmY2RD13AkhEz2Wksdr3Sj1PGJazy2gW/xC18ILB2MgPplXxzGr3dWQ==",
"dependencies": {
"chokidar": "^3.4.3",
"esbuild": "^0.15.2"
@@ -945,9 +945,9 @@
"optional": true
},
"fzi": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/fzi/-/fzi-1.0.0.tgz",
- "integrity": "sha512-ZsF/SPkQVWrVPvhkKRivf7pM8LC1kMQmWPXPlbHIdQPL10a6Q9eiVbCJfmEVRFbZafd66DQMC8brfpORxSaKKA=="
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/fzi/-/fzi-1.1.0.tgz",
+ "integrity": "sha512-5bqCChh+i3RQ2Acl+FGg7JnxONXLaWDl4g/JLbRJE+zV5zX0GI0ScpKr/MzgDqzRnhkqy58J6kVy+GfDv2QSFw=="
},
"glob-parent": {
"version": "5.1.2",
@@ -958,9 +958,9 @@
}
},
"imba": {
- "version": "2.0.0-alpha.219",
- "resolved": "https://registry.npmjs.org/imba/-/imba-2.0.0-alpha.219.tgz",
- "integrity": "sha512-5BIUK9DBNDvprJ/hPezfg4dk6w96j/yOCWU35O/CKpLx8ce+k/u534HYrdQNGZqfTY7ImSA5uRduVbp1zKi9Wg==",
+ "version": "2.0.0-alpha.220",
+ "resolved": "https://registry.npmjs.org/imba/-/imba-2.0.0-alpha.220.tgz",
+ "integrity": "sha512-Q2Kiqb7kLKfVZ19kje0PWgWR4K+0Nt3RmY2RD13AkhEz2Wksdr3Sj1PGJazy2gW/xC18ILB2MgPplXxzGr3dWQ==",
"requires": {
"chokidar": "^3.4.3",
"esbuild": "^0.15.2"
diff --git a/package.json b/package.json
index a55888d..5a1ecba 100644
--- a/package.json
+++ b/package.json
@@ -14,8 +14,8 @@
"dexie": "^3.2.2",
"dexie-export-import": "^1.0.3",
"downloadjs": "^1.4.7",
- "fzi": "^1.0.0",
- "imba": "^2.0.0-alpha.219",
+ "fzi": "^1.1.0",
+ "imba": "^2.0.0-alpha.220",
"lodash": "^4.17.21",
"mathjs": "^11.1.0",
"nanoid": "^4.0.0"