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.
 
 

78 lines
1.3 KiB

tag app-edit
active = no
def mount
$dn.setSelectionRange 0, 0
$dn.focus!
def open data
link = data
new_link_text = value=api.construct_link_text(link)
active = yes
def close
active = no
def handle_click_set_default_bang
config.set_default_bang link
close!
def handle_delete
try
await api.delete_link link
close!
catch e
err "deleting link", e
def save
try
api.update_link link, new_link_text
close!
catch e
err "saving link", e
get tips
let result = []
result.push <>
<.tip
@click=handle_delete
@hotkey('shift+backspace').capture.if(!state.loading)=handle_delete
>
<.tip-hotkey> "Shift + Backspace"
<.tip-content> "Delete Link"
result.push <>
<.tip
@click=save
@hotkey('return').capture.if(!state.loading)=save
>
<.tip-hotkey> "Return"
<.tip-content> "Update Link"
if link.is_bang
result.push <>
<.tip @click=handle_click_set_default_bang>
<.tip-hotkey> "Click"
<.tip-content> "Set Default Bang"
result.push <>
<.tip
@click=close
@hotkey('esc').capture.if(!state.loading)=close
>
<.tip-hotkey> "Esc"
<.tip-content> "Cancel"
result
def render
<self>
css d:flex fld:column gap:20px w:100%
<div>
<input$dn autofocus bind=new_link_text>
<app-tips tips=tips>