mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-10 01:10:28 +00:00
8b60cab6a2
* Update tag-picker.tid * rework kb-driven-input macro to procedures + new syntax * rework change-input-tab to procedure * fix * remove console log :) * replace defines with procedures * fix link-dropdown * fix focus-selector in new-field dropdown * revert changing the footpring of change-input-tab + make it work as procedure * update change-input-tab procedure * refactor change-input-tab procedure and keep tags/Macro tag * simplify complicated filter * add tags/Global tag * remove tags/Global tag * rename variable
142 lines
6.4 KiB
Plaintext
142 lines
6.4 KiB
Plaintext
title: $:/core/macros/keyboard-driven-input
|
|
tags: $:/tags/Macro
|
|
|
|
\procedure prefix.bracket() [
|
|
\procedure suffix.bracket() ]
|
|
|
|
\function tf.change-input-tab.next-tab() [[all]addprefix<prefix.bracket>addsuffix<prefix.bracket>addsuffix[shadows+tiddlers]addsuffix<suffix.bracket>addsuffix[tag<tag>!has]addsuffix<prefix.bracket>addsuffix[draft.of]addsuffix<suffix.bracket>addsuffix<beforeafter>addsuffix[<currentState>]addsuffix<suffix.bracket>addsuffix[ :else]addsuffix<prefix.bracket>addsuffix<prefix.bracket>addsuffix<beforeafter>addsuffix<suffix.bracket>addsuffix[match]addsuffix<prefix.bracket>addsuffix[after]addsuffix<suffix.bracket>addsuffix[then<firstTab>]addsuffix<suffix.bracket>addsuffix[ :else]addsuffix<prefix.bracket>addsuffix<prefix.bracket>addsuffix<beforeafter>addsuffix<suffix.bracket>addsuffix[match]addsuffix<prefix.bracket>addsuffix[before]addsuffix<suffix.bracket>addsuffix[then<lastTab>]addsuffix<suffix.bracket>]
|
|
|
|
\procedure change-input-tab(stateTitle,tag,beforeafter,defaultState,actions)
|
|
\whitespace trim
|
|
<$set name="tabsList" filter="[<explicitTabList>!is[blank]enlist-input[]] :else[all[shadows+tiddlers]tag<tag>!has[draft.of]]">
|
|
<$let
|
|
currentState={{{ [<stateTitle>!is[missing]get[text]] :else[<defaultState>] }}}
|
|
firstTab={{{ [enlist<tabsList>nth[1]] }}}
|
|
lastTab={{{ [enlist<tabsList>last[]] }}}
|
|
nextTabSubFilter=<<tf.change-input-tab.next-tab>>
|
|
nextTab={{{ [subfilter<nextTabSubFilter>] }}}
|
|
>
|
|
<$action-setfield $tiddler=<<stateTitle>> text=<<nextTab>>/>
|
|
<<actions>>
|
|
</$let>
|
|
</$set>
|
|
\end
|
|
|
|
\procedure keyboard-input-actions()
|
|
\whitespace trim
|
|
<%if [<index>match[]] %>
|
|
<$action-setfield $tiddler=<<storeTitle>> text={{{ [<tiddler>get<field>] }}}/>
|
|
<% endif %>
|
|
<%if [<index>!match[]] %>
|
|
<$action-setfield $tiddler=<<storeTitle>> text={{{ [<tiddler>getindex<index>] }}}/>
|
|
<% endif %>
|
|
\end
|
|
|
|
\procedure input-next-actions-inner()
|
|
\whitespace trim
|
|
<%if [<nextItem>minlength[1]] %>
|
|
<$action-setfield $tiddler=<<selectionStateTitle>> text=<<nextItem>>/>
|
|
<%if [<index>match[]] %>
|
|
<$action-setfield $tiddler=<<tiddler>> $field=<<field>> $value={{{ [<nextItem>] :and[splitregexp[(?:.(?!-))+$]] }}}/>
|
|
<% endif %>
|
|
<%if [<index>!match[]] %>
|
|
<$action-setfield $tiddler=<<tiddler>> $index=<<index>> $value={{{ [<nextItem>] :and[splitregexp[(?:.(?!-))+$]] }}}/>
|
|
<% endif %>
|
|
<$action-setfield $tiddler=<<refreshTitle>> text="yes"/>
|
|
<% endif %>
|
|
\end
|
|
|
|
\procedure input-next-actions-after()
|
|
\whitespace trim
|
|
<%if [<storeTitle>get[text]minlength<filterMinLength>] [<filterMinLength>match[0]] %>
|
|
<$let
|
|
userInput={{{ [<storeTitle>get[text]] }}}
|
|
selectedItem={{{ [<selectionStateTitle>get[text]] }}}
|
|
configTiddler={{{ [subfilter<configTiddlerFilter>] }}}
|
|
primaryListFilter={{{ [<configTiddler>get<firstSearchFilterField>] }}}
|
|
secondaryListFilter={{{ [<configTiddler>get<secondSearchFilterField>] }}}
|
|
>
|
|
<$set
|
|
name="filteredList"
|
|
filter="[subfilter<primaryListFilter>addsuffix[-primaryList]] :all[subfilter<secondaryListFilter>addsuffix[-secondaryList]]"
|
|
>
|
|
<$let
|
|
nextItem={{{ [enlist<filteredList>after<selectedItem>] :else[enlist<filteredList>nth[1]] }}}
|
|
firstItem={{{ [enlist<filteredList>nth[1]] }}}
|
|
lastItem={{{ [enlist<filteredList>last[]] }}}
|
|
>
|
|
<%if [<selectedItem>match<firstItem>!match<lastItem>] [<selectedItem>!match<firstItem>!match<lastItem>] %>
|
|
<<input-next-actions-inner>>
|
|
<%elseif [<selectedItem>match<lastItem>!match<firstItem>] %>
|
|
<$set name="nextItem" value={{{ [<userInput>addsuffix[-userInput]] }}}>
|
|
<<input-next-actions-inner>>
|
|
</$set>
|
|
<%elseif [<selectedItem>match<firstItem>match<lastItem>] %>
|
|
<$set name="nextItem" value={{{ [<userInput>addsuffix[-userInput]] }}}>
|
|
<<input-next-actions-inner>>
|
|
</$set>
|
|
<% endif %>
|
|
</$let>
|
|
</$set>
|
|
</$let>
|
|
<% endif %>
|
|
\end
|
|
|
|
\procedure input-next-actions-before()
|
|
\whitespace trim
|
|
<%if [<storeTitle>get[text]minlength<filterMinLength>] [<filterMinLength>match[0]] %>
|
|
<$let
|
|
userInput={{{ [<storeTitle>get[text]] }}}
|
|
selectedItem={{{ [<selectionStateTitle>get[text]] }}}
|
|
configTiddler={{{ [subfilter<configTiddlerFilter>] }}}
|
|
primaryListFilter={{{ [<configTiddler>get<firstSearchFilterField>] }}}
|
|
secondaryListFilter={{{ [<configTiddler>get<secondSearchFilterField>] }}}
|
|
>
|
|
<$set
|
|
name="filteredList"
|
|
filter="[subfilter<primaryListFilter>addsuffix[-primaryList]] :all[subfilter<secondaryListFilter>addsuffix[-secondaryList]]"
|
|
>
|
|
<$let
|
|
nextItem={{{ [enlist<filteredList>before<selectedItem>] :else[enlist<filteredList>reverse[]nth[1]] }}}
|
|
firstItem={{{ [enlist<filteredList>nth[1]] }}}
|
|
lastItem={{{ [enlist<filteredList>last[]] }}}
|
|
>
|
|
<%if [<selectedItem>match<firstItem>!match<lastItem>] %>
|
|
<$set name="nextItem" value={{{ [<userInput>addsuffix[-userInput]] }}}>
|
|
<<input-next-actions-inner>>
|
|
</$set>
|
|
<%elseif [<selectedItem>match<lastItem>!match<firstItem>] [<selectedItem>!match<firstItem>!match<lastItem>] %>
|
|
<<input-next-actions-inner>>
|
|
<%elseif [<selectedItem>match<firstItem>match<lastItem>] %>
|
|
<$set name="nextItem" value={{{ [<userInput>addsuffix[-userInput]] }}}>
|
|
<<input-next-actions-inner>>
|
|
</$set>
|
|
<% endif %>
|
|
</$let>
|
|
</$set>
|
|
</$let>
|
|
<% endif %>
|
|
\end
|
|
|
|
\procedure keyboard-driven-input(tiddler,storeTitle,field:"text",index:"",tag:"input",type,focus:"",inputAcceptActions,inputAcceptVariantActions,inputCancelActions,placeholder:"",default:"",class,focusPopup,rows,minHeight,tabindex,size,autoHeight,filterMinLength:"0",refreshTitle,selectionStateTitle,cancelPopups:"",configTiddlerFilter,firstSearchFilterField:"first-search-filter",secondSearchFilterField:"second-search-filter")
|
|
\whitespace trim
|
|
<$keyboard key="((input-accept))" actions=<<inputAcceptActions>>>
|
|
<$keyboard key="((input-accept-variant))" actions=<<inputAcceptVariantActions>>>
|
|
<$keyboard key="((input-up))" actions=<<input-next-actions-before>>>
|
|
<$keyboard key="((input-down))" actions=<<input-next-actions-after>>>
|
|
<$keyboard key="((input-cancel))" actions=<<inputCancelActions>>>
|
|
<$edit-text
|
|
tiddler=<<tiddler>> field=<<field>> index=<<index>>
|
|
inputActions=<<keyboard-input-actions>> tag=<<tag>> class=<<class>>
|
|
placeholder=<<placeholder>> default=<<default>> focusPopup=<<focusPopup>>
|
|
focus=<<focus>> type=<<type>> rows=<<rows>> minHeight=<<minHeight>>
|
|
tabindex=<<tabindex>> size=<<size>> autoHeight=<<autoHeight>>
|
|
refreshTitle=<<refreshTitle>> cancelPopups=<<cancelPopups>>
|
|
/>
|
|
</$keyboard>
|
|
</$keyboard>
|
|
</$keyboard>
|
|
</$keyboard>
|
|
</$keyboard>
|
|
\end
|