diff --git a/app/api.imba b/app/api.imba index 6df2695..444d959 100644 --- a/app/api.imba +++ b/app/api.imba @@ -124,7 +124,7 @@ export default new class api is_bang = yes display_name = display_name.slice(1) name ||= display_name - let link = { name, display_name, is_bang, is_pinned, url, frequency:0 } + let link = { name, display_name, is_bang, is_pinned, url, frequency:0, history:[] } if get_icon link.icon = await fetch_image_as_base_64 host return link @@ -235,12 +235,52 @@ export default new class api state.active_bang or config.data.default_bang get encoded_bang_query - "{bang.url}{window.encodeURIComponent(state.query)}" + let history_item = sorted_bang_history[state.bang_selection_index] + "{bang.url}{window.encodeURIComponent(history_item or state.query)}" + + get encoded_bang_query_nourl + let history_item = sorted_bang_history[state.bang_selection_index] + "{window.encodeURIComponent(history_item or state.query)}" + + def update_history bang + let text + if state.bang_selection_index > -1 + text = sorted_bang_history.splice(state.bang_selection_index, 1)[0] + text ||= state.query.trim! + return unless text + let i = bang.history.indexOf(text) + if i > -1 + bang.history.splice(i, 1) + bang.history.unshift text + try + await put_link bang + catch e + err "updating bang history", e + + def delete_bang_history_item text + let i = bang.history.indexOf(text) + return unless i > -1 + bang.history.splice(i, 1) + try + await put_link bang + catch e + err "updating bang history", e def handle_bang await increment_link_frequency bang - window.location.href = encoded_bang_query + let to_navigate = encoded_bang_query + await update_history bang + window.location.href = to_navigate def unset_active_bang state.active_bang = no sort_links! + + def increment_bang_selection_index + state.bang_selection_index = Math.min(sorted_bang_history.length - 1, state.bang_selection_index + 1) + + def decrement_bang_selection_index + state.bang_selection_index = Math.max(-1, state.bang_selection_index - 1) + + get sorted_bang_history + fzi.sort state.query, bang.history diff --git a/app/components/app-bang.imba b/app/components/app-bang.imba index 8775c88..bb3fd70 100644 --- a/app/components/app-bang.imba +++ b/app/components/app-bang.imba @@ -1,18 +1,30 @@ tag app-bang + def unmount + state.bang_selection_index = -1 + get tips let result = [] - result.push <> - <.tip - @click=api.handle_bang - @hotkey('return').capture.if(!state.loading)=api.handle_bang - > - <.tip-hotkey> "Return" - <.tip-content> "Search" + 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" result.push <> - <.tip + <.tip.ellipsis @click=api.handle_add_link @hotkey('shift+return').capture.if(!state.loading)=api.handle_add_link > @@ -42,14 +54,6 @@ tag app-bang <.tip-hotkey> "Paste (If Input Empty)" <.tip-content> "Instant Search" - result.push <> - <.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" - result.push <> <.tip @click.if(!loading)=api.handle_cut> if api.math_result @@ -59,14 +63,6 @@ tag app-bang <.tip-hotkey> "Cut (If No Selection)" <.tip-content> "Cut All Text" - result.push <> - <.tip - @click.if(!state.loading)=refs.settings.open - @hotkey('shift+tab').capture.if(!state.loading)=refs.settings.open - > - <.tip-hotkey> "Shift + Tab" - <.tip-content> "Toggle Settings" - if state.active_bang result.push <> <.tip.noclick> @@ -77,27 +73,43 @@ tag app-bang def render - + css w:100% d:flex fld:column gap:15px unless $tips.show_more - <.bang.selected@click=api.handle_bang> + + <.bang.selected + @click=api.handle_bang + > css d:flex fld:row jc:space-between ai:center px:16px py:11px rd:5px cursor:pointer c:#FAD4AB <.link-left> - css d:flex fl:1 + css d:flex fl:1 ofy:hidden css w:20px h:20px mr:10px rd:3px - <.display-name> api.encoded_bang_query - css fs:20px word-break:break-all + <.display-name> api.encoded_bang_query_nourl + css fs:20px of:hidden text-overflow:ellipsis <.link-right> css d:flex fld:row jc:space-between ai:center <.frequency> api.bang.frequency css fs:15px ml:7px + + <.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 diff --git a/app/components/app-home.imba b/app/components/app-home.imba index a8d15a9..1d7bbfb 100644 --- a/app/components/app-home.imba +++ b/app/components/app-home.imba @@ -21,6 +21,7 @@ tag app-home api.sort_links! def handle_input + state.bang_selection_index = -1 api.set_link_selection_index 0 api.sort_links! diff --git a/app/config.imba b/app/config.imba index 5e1097c..5c48560 100644 --- a/app/config.imba +++ b/app/config.imba @@ -22,6 +22,7 @@ export default new class config this.data.default_bang.frequency ??= 0 this.data.default_bang.icon ??= "" this.data.default_bang.id ??= "FEJbsKLUMwHbazbqW3c4i" + this.data.default_bang.history ??= [] p "config:", this.data diff --git a/app/db.imba b/app/db.imba index bbbbf14..48460c0 100644 --- a/app/db.imba +++ b/app/db.imba @@ -39,6 +39,7 @@ db.version(4).stores({ link.is_bang = no link.icon = link.img link.is_pinned = no + link.history = [] delete link.img export default db diff --git a/app/state.imba b/app/state.imba index bff15e0..1e78b96 100644 --- a/app/state.imba +++ b/app/state.imba @@ -5,4 +5,5 @@ export default { loading: no link_selection_index: 0 active_bang: no + bang_selection_index: -1 }