let p = console.log import all_links from '../assets/community_links' import fzi from 'fzi' import api from '../api' tag app-community-links 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 def close active = no def increment_selection_index selection_index = Math.min(links.length - 1, selection_index + 1) def decrement_selection_index selection_index = Math.max(0, selection_index - 1) 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 @hotkey("esc").force=close > <.tip-hotkey> "Esc" <.tip-content> "Exit Community Links" result.push <> <.tip @click=add_community_link @hotkey("shift+return").force=add_community_link > <.tip-hotkey> "Shift + Return Or Click" <.tip-content> "Add To Your Links" result.push <> <.tip.noclick @hotkey('down').capture.if(!state.loading)=increment_selection_index @hotkey('up').capture.if(!state.loading)=decrement_selection_index > <.tip-hotkey> "Up/Down Arrow" <.tip-content> "Move Selection" result def render css d:flex fld:column jc:start gap:15px fl:1 w:100% ofy:hidden
<.links> css ofy:auto for link, index in sorted_links <.link .selected=(selection_index == index) @pointerover=(selection_index = index) @click=add_community_link > css d:flex fld:row jc:space-between ai:center px:16px py:2px rd:5px cursor:pointer c:$text-c min-height:35px if link.is_bang css c:$bang-c <.link-left> link.name css fl:1 link.url css fl:1 c:inherit