You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
106 lines
2.6 KiB
106 lines
2.6 KiB
tag app-bang
|
|
|
|
get bang
|
|
return active_bang if state.active_bang
|
|
config.data.default_bang
|
|
|
|
get encoded_bang_query
|
|
"{bang.url}{window.encodeURIComponent(state.query)}"
|
|
|
|
def handle_bang
|
|
await api.increment_link_frequency bang
|
|
window.location.href = encoded_bang_query
|
|
|
|
def render
|
|
|
|
<self>
|
|
css w:100% d:flex fld:column gap:10px
|
|
|
|
|
|
<app-tips>
|
|
|
|
<.tip-row>
|
|
|
|
<.tip
|
|
@click=(state.active_bang = no)
|
|
@hotkey('esc').capture.if(!state.loading)=(state.active_bang = no)
|
|
>
|
|
<.tip-hotkey> "Return"
|
|
<.tip-content> "Search"
|
|
|
|
<.tip
|
|
@click=api.handle_add_link
|
|
@hotkey('shift+return').capture.if(!state.loading)=api.handle_add_link
|
|
>
|
|
<.tip-hotkey> "Shift + Return"
|
|
<.tip-content.ellipsis>
|
|
<span[ws:pre]> "Create Link "
|
|
let sq = state.query.trim!.split /\s+/
|
|
if sq.length >= 2
|
|
let url = sq.pop!
|
|
<span> '"'
|
|
<span> sq.join " "
|
|
<span[c:blue3 ws:pre]> " {url}"
|
|
<span> '"'
|
|
else
|
|
<span> "\"{sq.join " "}\""
|
|
|
|
if state.active_bang
|
|
<.tip
|
|
@click=(state.active_bang = no)
|
|
@hotkey('esc').capture.if(!state.loading)=(state.active_bang = no)
|
|
>
|
|
<.tip-hotkey> "Esc"
|
|
<.tip-content> "Back"
|
|
else
|
|
<.tip
|
|
@click.if(!state.loading)=refs.settings.open
|
|
@hotkey('esc').capture.if(!state.loading)=refs.settings.open
|
|
>
|
|
<.tip-hotkey> "Esc"
|
|
<.tip-content> "Toggle Settings"
|
|
|
|
<app-tips-more$tips-more>
|
|
|
|
<.tip-row>
|
|
|
|
<.tip
|
|
@click.if(!state.loading)=api.toggle_effective_names
|
|
@hotkey('tab').capture.if(!state.loading)=api.toggle_effective_names
|
|
>
|
|
<.tip-hotkey> "Tab"
|
|
<.tip-content> "Toggle Effective Names"
|
|
|
|
<.tip
|
|
@click.if(!loading)=api.handle_cut
|
|
>
|
|
if math_result
|
|
<.tip-hotkey> "Cut (Math, If No Selection)"
|
|
<.tip-content> "Cut Math Result"
|
|
else
|
|
<.tip-hotkey> "Cut (If No Selection)"
|
|
<.tip-content> "Cut All Text"
|
|
|
|
<.tip.noclick>
|
|
<.tip-hotkey> "Paste (If Input Empty)"
|
|
<.tip-content> "Instant Search"
|
|
|
|
unless $tips-more.active
|
|
<.bang.selected@click=handle_bang>
|
|
css d:flex fld:row jc:space-between ai:center
|
|
px:16px py:11px rd:5px cursor:pointer c:blue3
|
|
|
|
<.link-left>
|
|
css d:flex fl:1
|
|
|
|
<img.link-icon src=bang.icon>
|
|
css w:20px h:20px mr:10px rd:3px
|
|
|
|
<.display-name> encoded_bang_query
|
|
css c:#FAD4AB fs:20px word-break:break-all
|
|
|
|
<.link-right>
|
|
css d:flex fld:row jc:space-between ai:center
|
|
|
|
<.frequency> bang.frequency
|
|
css fs:15px ml:7px
|
|
|