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.

125 lines
3.1 KiB

3 years ago
tag app-bang
3 years ago
def unmount
state.bang_selection_index = -1
3 years ago
get tips
3 years ago
let result = []
3 years ago
3 years ago
if state.bang_selection_index > -1
result.push <>
<.tip
@click=api.handle_bang
@hotkey('return').capture.if(!state.loading)=api.handle_bang
>
<.tip-hotkey> "Return"
<.tip-content> "Search History Item"
else
result.push <>
<.tip
@click=api.handle_bang
@hotkey('return').capture.if(!state.loading)=api.handle_bang
>
<.tip-hotkey> "Return"
<.tip-content> "Search"
3 years ago
if state.bang_selection_index > -1
result.push <>
<.tip
@click=api.delete_bang_history_item
@hotkey('shift+backspace').capture.if(!state.loading)=api.delete_bang_history_item
>
<.tip-hotkey> "Shift + Backspace"
<.tip-content> "Delete History Item"
3 years ago
result.push <>
3 years ago
<.tip.ellipsis
3 years ago
@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 " "}\""
3 years ago
result.push <>
3 years ago
if state.active_bang
<.tip
@click=api.unset_active_bang
3 years ago
@hotkey('esc').capture.if(!state.loading)=api.unset_active_bang
3 years ago
>
<.tip-hotkey> "Esc"
<.tip-content> "Back"
else
<.tip.noclick>
<.tip-hotkey> "Paste (If Input Empty)"
<.tip-content> "Instant Search"
3 years ago
result.push <>
3 years ago
<.tip @click.if(!loading)=api.handle_cut>
if api.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"
if state.active_bang
3 years ago
result.push <>
3 years ago
<.tip.noclick>
<.tip-hotkey> "Paste (If Input Empty)"
<.tip-content> "Instant Search"
3 years ago
result
3 years ago
def render
3 years ago
<self
@hotkey("tab").force=api.increment_bang_selection_index
@hotkey("up").force=api.decrement_bang_selection_index
@hotkey("down").force=api.increment_bang_selection_index
@hotkey("shift+tab").force=api.decrement_bang_selection_index
>
3 years ago
css w:100% d:flex fld:column gap:15px
3 years ago
<app-tips$tips tips=tips>
3 years ago
unless $tips.show_more
3 years ago
<.bang.selected
@click=api.handle_bang
>
css d:flex fld:row jc:space-between ai:center
3 years ago
px:16px py:11px rd:5px cursor:pointer c:#FAD4AB
3 years ago
<.link-left>
3 years ago
css d:flex fl:1 ofy:hidden
3 years ago
3 years ago
<img.link-icon src=api.bang.icon>
css w:20px h:20px mr:10px rd:3px
3 years ago
3 years ago
<.display-name> api.encoded_bang_query_nourl
css fs:20px of:hidden text-overflow:ellipsis
3 years ago
<.link-right>
css d:flex fld:row jc:space-between ai:center
3 years ago
3 years ago
<.frequency> api.bang.frequency
css fs:15px ml:7px
3 years ago
<.history>
css d:flex fld:column jc:start ai:center
for item, index in api.sorted_bang_history
<.item [c:#FAD4AB]=(state.bang_selection_index is index)> item
css w:100% fs:17px c:blue3 rd:5px p:10px 10px
box-sizing:border-box