mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-01-25 16:36:52 +00:00
start making it possible to use this universally
This commit is contained in:
parent
a35b9a5d5c
commit
338a3d1646
@ -3,6 +3,10 @@ tags: $:/tags/PageTemplate
|
|||||||
list-after: $:/core/ui/PageTemplate/story
|
list-after: $:/core/ui/PageTemplate/story
|
||||||
|
|
||||||
\import [function[get.base.functions.theme],<get.current.theme>first[]!is[missing]] :else[function[get.base.functions.theme],<get.current.theme>first[]is[shadow]] :else[[$:/themes/tiddlywiki/vanilla/functions]] [[$:/core/procedures/sidebar-resizer]]
|
\import [function[get.base.functions.theme],<get.current.theme>first[]!is[missing]] :else[function[get.base.functions.theme],<get.current.theme>first[]is[shadow]] :else[[$:/themes/tiddlywiki/vanilla/functions]] [[$:/core/procedures/sidebar-resizer]]
|
||||||
|
\function resizer.state.tiddler() $:/state/sidebar/resizing
|
||||||
|
\function resizer.state() [{$:/state/sidebar}]
|
||||||
|
\function resizer.class() tc-main-sidebar-resizer
|
||||||
|
\function set.throttling() yes
|
||||||
\whitespace trim
|
\whitespace trim
|
||||||
|
|
||||||
<%if [<get.theme.explicit.option sidebarresizer>match[show]] %>
|
<%if [<get.theme.explicit.option sidebarresizer>match[show]] %>
|
||||||
|
@ -37,31 +37,35 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
:else[<value>suffix[em]then[em]]
|
:else[<value>suffix[em]then[em]]
|
||||||
\end
|
\end
|
||||||
|
|
||||||
\procedure set_theme_throttling(metric)
|
\function get.sidebar.width.tiddler()
|
||||||
<$set name="metricsTiddler" value={{{ [function[get.theme],<metric>] }}}>
|
[<sidebarWidthTiddler>!is[blank]]
|
||||||
|
:else[get.theme[sidebarwidth]]
|
||||||
|
\end
|
||||||
|
|
||||||
|
\function get.resizer.state()
|
||||||
|
[<resizer.state.tiddler>!is[blank]]
|
||||||
|
:else[<qualify>addsuffix[-]addsuffix<get.sidebar.width.tiddler>addsuffix[-]addsuffix<currentTiddler>sha256[]addprefix[$:/state/resizing-]]
|
||||||
|
\end
|
||||||
|
|
||||||
|
\procedure set_theme_throttling(metric,tiddler)
|
||||||
|
<%if [<set.throttling>match[yes]] %>
|
||||||
|
<$set name="metricsTiddler" value={{{ [<tiddler>getvariable[]!is[blank]] :else[function[get.theme],<metric>] }}}>
|
||||||
<%if [<metricsTiddler>!has[throttle.refresh]] %>
|
<%if [<metricsTiddler>!has[throttle.refresh]] %>
|
||||||
<$action-setfield $tiddler=<<metricsTiddler>> throttle.refresh="yes"/>
|
<$action-setfield $tiddler=<<metricsTiddler>> throttle.refresh="yes"/>
|
||||||
<% endif %>
|
<% endif %>
|
||||||
</$set>
|
</$set>
|
||||||
|
<% endif %>
|
||||||
\end
|
\end
|
||||||
|
|
||||||
\procedure sidebar-resizer-pointerdown-actions()
|
\procedure sidebar-resizer-pointerdown-actions-inner()
|
||||||
<%if [[$:/state/sidebar]get[click-time]subtract<now [UTC]YYYY0MM0DD0hh0mm0ss0XXX>abs[]compare:number:lteq[500]] %>
|
<%if [<get.resizer.state>is[missing]then<event-mousebutton>match[left]] %>
|
||||||
<<sidebar-resizer-pointercancel-actions>>
|
|
||||||
<$action-setfield $tiddler="$:/state/sidebar" text="no"/>
|
|
||||||
<% else %>
|
|
||||||
<%if [[$:/state/sidebar]is[missing]] %>
|
|
||||||
<$action-setfield $tiddler="$:/state/sidebar" text="yes"/>
|
|
||||||
<% endif %>
|
|
||||||
<$action-setfield $tiddler="$:/state/sidebar" click-time=<<now [UTC]YYYY0MM0DD0hh0mm0ss0XXX>>/>
|
|
||||||
<%if [[$:/state/sidebar/resizing]is[missing]then<event-mousebutton>match[left]] %>
|
|
||||||
<$let
|
<$let
|
||||||
startStoryLeft={{{ [<storyLeftTiddler>!is[blank]get[text]] :else[get.theme.metric[storyleft]] }}}
|
startStoryLeft={{{ [<storyLeftTiddler>!is[blank]get[text]] :else[get.theme.metric[storyleft]] }}}
|
||||||
startStoryRight={{{ [<storyRightTiddler>!is[blank]get[text]] :else[get.theme.metric[storyright]] }}}
|
startStoryRight={{{ [<storyRightTiddler>!is[blank]get[text]] :else[get.theme.metric[storyright]] }}}
|
||||||
startSidebarWidth={{{ [<sidebarWidthTiddler>!is[blank]get[text]] :else[get.theme.metric[sidebarwidth]] }}}
|
startSidebarWidth={{{ [<sidebarWidthTiddler>!is[blank]get[text]] :else[get.theme.metric[sidebarwidth]] }}}
|
||||||
startTiddlerWidth={{{ [<tiddlerWidthTiddler>!is[blank]get[text]] :else[get.theme.metric[tiddlerwidth]] }}}
|
startTiddlerWidth={{{ [<tiddlerWidthTiddler>!is[blank]get[text]] :else[get.theme.metric[tiddlerwidth]] }}}
|
||||||
startStoryWidth={{{ [<storyWidthTiddler>!is[blank]get[text]] :else[get.theme.metric[storywidth]] }}}>
|
startStoryWidth={{{ [<storyWidthTiddler>!is[blank]get[text]] :else[get.theme.metric[storywidth]] }}}>
|
||||||
<$action-setfield $tiddler="$:/state/sidebar/resizing"
|
<$action-setfield $tiddler=<<get.resizer.state>>
|
||||||
text="yes"
|
text="yes"
|
||||||
widget-node-width=<<tv-widgetnode-width>>
|
widget-node-width=<<tv-widgetnode-width>>
|
||||||
start-posx=<<event-fromcatcher-posx>>
|
start-posx=<<event-fromcatcher-posx>>
|
||||||
@ -78,11 +82,23 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
/>
|
/>
|
||||||
</$let>
|
</$let>
|
||||||
<% endif %>
|
<% endif %>
|
||||||
|
\end
|
||||||
|
|
||||||
|
\procedure sidebar-resizer-pointerdown-actions()
|
||||||
|
<%if [[$:/state/sidebar]get[click-time]subtract<now [UTC]YYYY0MM0DD0hh0mm0ss0XXX>abs[]compare:number:lteq[500]] %>
|
||||||
|
<<sidebar-resizer-pointercancel-actions>>
|
||||||
|
<$action-setfield $tiddler="$:/state/sidebar" text="no"/>
|
||||||
|
<% else %>
|
||||||
|
<%if [[$:/state/sidebar]is[missing]] %>
|
||||||
|
<$action-setfield $tiddler="$:/state/sidebar" text="yes"/>
|
||||||
|
<% endif %>
|
||||||
|
<$action-setfield $tiddler="$:/state/sidebar" click-time=<<now [UTC]YYYY0MM0DD0hh0mm0ss0XXX>>/>
|
||||||
|
<<sidebar-resizer-pointerdown-actions-inner>>
|
||||||
<% endif %>
|
<% endif %>
|
||||||
\end
|
\end
|
||||||
|
|
||||||
\procedure sidebar-resizer-pointercancel-actions()
|
\procedure sidebar-resizer-pointercancel-actions()
|
||||||
<$action-deletetiddler $tiddler="$:/state/sidebar/resizing"/>
|
<$action-deletetiddler $tiddler=<<get.resizer.state>>/>
|
||||||
\end
|
\end
|
||||||
|
|
||||||
\function get.story-width.result()
|
\function get.story-width.result()
|
||||||
@ -108,8 +124,10 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
|
|
||||||
\procedure set-storywidth-storyright-actions()
|
\procedure set-storywidth-storyright-actions()
|
||||||
<$let
|
<$let
|
||||||
storyRightStart={{{ [convert.to.pixels.locally{$:/state/sidebar/resizing!!start-story-right}] }}}
|
storyRightStart={{{ [<get.resizer.state>get[start-story-right]] }}}
|
||||||
storyWidthStart={{{ [convert.to.pixels.locally{$:/state/sidebar/resizing!!start-story-width}] }}}
|
storyWidthStart={{{ [<get.resizer.state>get[start-story-width]] }}}
|
||||||
|
storyRightStart={{{ [convert.to.pixels.locally<storyRightStart>] }}}
|
||||||
|
storyWidthStart={{{ [convert.to.pixels.locally<storyWidthStart>] }}}
|
||||||
storyMinWidthValue={{{ [<storyMinWidthTiddler>!is[blank]get[text]] :else[<get.theme.metric storyminwidth>] }}}
|
storyMinWidthValue={{{ [<storyMinWidthTiddler>!is[blank]get[text]] :else[<get.theme.metric storyminwidth>] }}}
|
||||||
storyMinWidth={{{ [convert.to.pixels.locally<storyMinWidthValue>] }}}
|
storyMinWidth={{{ [convert.to.pixels.locally<storyMinWidthValue>] }}}
|
||||||
sidebarMinWidthValue={{{ [<sidebarMinWidthTiddler>!is[blank]get[text]] :else[<get.theme.metric sidebarminwidth>] }}}
|
sidebarMinWidthValue={{{ [<sidebarMinWidthTiddler>!is[blank]get[text]] :else[<get.theme.metric sidebarminwidth>] }}}
|
||||||
@ -129,8 +147,8 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
storyMinWidthAddLeft={{{ [<storyMinWidth>add<storyLeft>] }}}
|
storyMinWidthAddLeft={{{ [<storyMinWidth>add<storyLeft>] }}}
|
||||||
storyRiverLimit={{{ [<widgetNodeWidth>subtract<sidebarMinWidth>] }}}
|
storyRiverLimit={{{ [<widgetNodeWidth>subtract<sidebarMinWidth>] }}}
|
||||||
storyMaxWidth={{{ [<storyRiverLimit>subtract<storyLeft>] }}}
|
storyMaxWidth={{{ [<storyRiverLimit>subtract<storyLeft>] }}}
|
||||||
tiddlerWidthMetric={{$:/state/sidebar/resizing!!tiddler-width-metric}}
|
tiddlerWidthMetric={{{ [<get.resizer.state>get[tiddler-width-metric]] }}}
|
||||||
tiddlerWidthStart={{$:/state/sidebar/resizing!!start-tiddler-width}}
|
tiddlerWidthStart={{{ [<get.resizer.state>get[start-tiddler-width]] }}}
|
||||||
tiddlerWidthStartPixels={{{ [<tiddlerWidthMetric>match[%]then<tiddlerWidthStart>multiply<innerStoryWidthStart>divide[100]] :else[convert.to.pixels.locally<tiddlerWidthStart>] }}}
|
tiddlerWidthStartPixels={{{ [<tiddlerWidthMetric>match[%]then<tiddlerWidthStart>multiply<innerStoryWidthStart>divide[100]] :else[convert.to.pixels.locally<tiddlerWidthStart>] }}}
|
||||||
tiddlerWidthClampedDiff={{{ [<tiddlerWidthStartPixels>add<storyPaddingLeft>add<storyPaddingRight>add<storyLeft>add<sidebarMinWidth>subtract<widgetNodeWidth>compare:number:gt[0]] ~0 }}}
|
tiddlerWidthClampedDiff={{{ [<tiddlerWidthStartPixels>add<storyPaddingLeft>add<storyPaddingRight>add<storyLeft>add<sidebarMinWidth>subtract<widgetNodeWidth>compare:number:gt[0]] ~0 }}}
|
||||||
tiddlerWidth={{{ [<tiddlerWidthStartPixels>add<dragDiff>subtract<tiddlerWidthClampedDiff>] }}}
|
tiddlerWidth={{{ [<tiddlerWidthStartPixels>add<dragDiff>subtract<tiddlerWidthClampedDiff>] }}}
|
||||||
@ -140,7 +158,7 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
storyRiverWidth={{{ [<storyRiverWidth>subtract<clampedDiff>] }}}>
|
storyRiverWidth={{{ [<storyRiverWidth>subtract<clampedDiff>] }}}>
|
||||||
|
|
||||||
<$let
|
<$let
|
||||||
storyWidthMetric={{$:/state/sidebar/resizing!!story-width-metric}}
|
storyWidthMetric={{{ [<get.resizer.state>get[story-width-metric]] }}}
|
||||||
storyWidthConverted={{{ [function[convert.to.result],<storyWidth>,<storyWidthMetric>] }}}
|
storyWidthConverted={{{ [function[convert.to.result],<storyWidth>,<storyWidthMetric>] }}}
|
||||||
storyMinWidthConverted={{{ [function[convert.to.result],<storyMinWidth>,<storyWidthMetric>] }}}
|
storyMinWidthConverted={{{ [function[convert.to.result],<storyMinWidth>,<storyWidthMetric>] }}}
|
||||||
storyMaxWidthConverted={{{ [function[convert.to.result],<storyMaxWidth>,<storyWidthMetric>] }}}
|
storyMaxWidthConverted={{{ [function[convert.to.result],<storyMaxWidth>,<storyWidthMetric>] }}}
|
||||||
@ -156,7 +174,7 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
</$let>
|
</$let>
|
||||||
|
|
||||||
<$let
|
<$let
|
||||||
storyRightMetric={{$:/state/sidebar/resizing!!story-right-metric}}
|
storyRightMetric={{{ [<get.resizer.state>get[story-right-metric]] }}}
|
||||||
storyRiverWidthConverted={{{ [function[convert.to.result],<storyRiverWidth>,<storyRightMetric>] }}}
|
storyRiverWidthConverted={{{ [function[convert.to.result],<storyRiverWidth>,<storyRightMetric>] }}}
|
||||||
storyRiverLimitConverted={{{ [function[convert.to.result],<storyRiverLimit>,<storyRightMetric>] }}}
|
storyRiverLimitConverted={{{ [function[convert.to.result],<storyRiverLimit>,<storyRightMetric>] }}}
|
||||||
storyMinWidthAddLeftConverted={{{ [function[convert.to.result],<storyMinWidthAddLeft>,<storyRightMetric>] }}}
|
storyMinWidthAddLeftConverted={{{ [function[convert.to.result],<storyMinWidthAddLeft>,<storyRightMetric>] }}}
|
||||||
@ -178,7 +196,7 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
\procedure set-sidebarwidth-actions()
|
\procedure set-sidebarwidth-actions()
|
||||||
<$let
|
<$let
|
||||||
sidebarMinWidthValue={{{ [<sidebarMinWidthTiddler>!is[blank]get[text]] :else[<get.theme.metric sidebarminwidth>] }}}
|
sidebarMinWidthValue={{{ [<sidebarMinWidthTiddler>!is[blank]get[text]] :else[<get.theme.metric sidebarminwidth>] }}}
|
||||||
sidebarWidthMetric={{$:/state/sidebar/resizing!!sidebar-width-metric}}
|
sidebarWidthMetric={{{ [<get.resizer.state>get[sidebar-width-metric]] }}}
|
||||||
sidebarMinWidth={{{ [convert.to.pixels.locally<sidebarMinWidthValue>] }}}
|
sidebarMinWidth={{{ [convert.to.pixels.locally<sidebarMinWidthValue>] }}}
|
||||||
storyLeftValue={{{ [<storyLeftTiddler>!is[blank]get[text]] :else[<get.theme.metric storyleft>] }}}
|
storyLeftValue={{{ [<storyLeftTiddler>!is[blank]get[text]] :else[<get.theme.metric storyleft>] }}}
|
||||||
storyLeft={{{ [convert.to.pixels.locally<storyLeftValue>] }}}
|
storyLeft={{{ [convert.to.pixels.locally<storyLeftValue>] }}}
|
||||||
@ -195,6 +213,7 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
sidebarWidthSetTiddler={{{ [<sidebarWidthTiddler>!is[blank]] :else[<set.theme.metric sidebarwidth>] }}}>
|
sidebarWidthSetTiddler={{{ [<sidebarWidthTiddler>!is[blank]] :else[<set.theme.metric sidebarwidth>] }}}>
|
||||||
|
|
||||||
<$action-setfield $tiddler=<<sidebarWidthSetTiddler>> text=<<get.sidebar-width.result>>/>
|
<$action-setfield $tiddler=<<sidebarWidthSetTiddler>> text=<<get.sidebar-width.result>>/>
|
||||||
|
|
||||||
</$let>
|
</$let>
|
||||||
</$let>
|
</$let>
|
||||||
\end
|
\end
|
||||||
@ -209,7 +228,8 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
<$let
|
<$let
|
||||||
storyMinWidthValue={{{ [<storyMinWidthTiddler>!is[blank]get[text]] :else[{$:/themes/tiddlywiki/centralised/metrics/storyminwidth}] }}}
|
storyMinWidthValue={{{ [<storyMinWidthTiddler>!is[blank]get[text]] :else[{$:/themes/tiddlywiki/centralised/metrics/storyminwidth}] }}}
|
||||||
storyMinWidth={{{ [convert.to.pixels.locally<storyMinWidthValue>] }}}
|
storyMinWidth={{{ [convert.to.pixels.locally<storyMinWidthValue>] }}}
|
||||||
storyWidthStart={{{ [convert.to.pixels.locally{$:/state/sidebar/resizing!!start-story-width}] }}}
|
storyWidthStart={{{ [<get.resizer.state>get[start-story-width]] }}}
|
||||||
|
storyWidthStart={{{ [convert.to.pixels.locally<storyWidthStart>] }}}
|
||||||
sidebarMinWidthValue={{{ [<sidebarMinWidthTiddler>!is[blank]get[text]] :else[{$:/themes/tiddlywiki/centralised/metrics/sidebarminwidth}] }}}
|
sidebarMinWidthValue={{{ [<sidebarMinWidthTiddler>!is[blank]get[text]] :else[{$:/themes/tiddlywiki/centralised/metrics/sidebarminwidth}] }}}
|
||||||
sidebarMinWidth={{{ [convert.to.pixels.locally<sidebarMinWidthValue>] }}}
|
sidebarMinWidth={{{ [convert.to.pixels.locally<sidebarMinWidthValue>] }}}
|
||||||
storyMaxWidth={{{ [<widgetNodeWidth>subtract<sidebarMinWidth>subtract<sidebarMinWidth>] }}}
|
storyMaxWidth={{{ [<widgetNodeWidth>subtract<sidebarMinWidth>subtract<sidebarMinWidth>] }}}
|
||||||
@ -219,7 +239,7 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
storyWidth={{{ [<storyWidth>subtract<storyWidthClamped>] }}}>
|
storyWidth={{{ [<storyWidth>subtract<storyWidthClamped>] }}}>
|
||||||
|
|
||||||
<$let
|
<$let
|
||||||
storyWidthMetric={{$:/state/sidebar/resizing!!story-width-metric}}
|
storyWidthMetric={{{ [<get.resizer.state>get[story-width-metric]] }}}
|
||||||
storyWidthConverted={{{ [function[convert.to.result],<storyWidth>,<storyWidthMetric>] }}}
|
storyWidthConverted={{{ [function[convert.to.result],<storyWidth>,<storyWidthMetric>] }}}
|
||||||
storyMinWidthConverted={{{ [function[convert.to.result],<storyMinWidth>,<storyWidthMetric>] }}}
|
storyMinWidthConverted={{{ [function[convert.to.result],<storyMinWidth>,<storyWidthMetric>] }}}
|
||||||
storyMaxWidthConverted={{{ [function[convert.to.result],<storyMaxWidth>,<storyWidthMetric>] }}}
|
storyMaxWidthConverted={{{ [function[convert.to.result],<storyMaxWidth>,<storyWidthMetric>] }}}
|
||||||
@ -233,54 +253,72 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
\end
|
\end
|
||||||
|
|
||||||
\function get.drag.diff()
|
\function get.drag.diff()
|
||||||
[<event-fromcatcher-posx>subtract{$:/state/sidebar/resizing!!start-posx}]
|
[<event-fromcatcher-posx>subtract<startPosX>]
|
||||||
:map[<get.theme.option sidebarposition>match[left]then<currentTiddler>multiply[-1]else<currentTiddler>]
|
:map[<get.theme.option sidebarposition>match[left]then<currentTiddler>multiply[-1]else<currentTiddler>]
|
||||||
\end
|
\end
|
||||||
|
|
||||||
\procedure sidebar-resizer-pointermove-actions()
|
\procedure sidebar-resizer-pointermove-actions()
|
||||||
<%if [[$:/state/sidebar/resizing]!is[missing]] %>
|
<%if [<get.resizer.state>!is[missing]] %>
|
||||||
<$let widgetNodeWidth={{$:/state/sidebar/resizing!!widget-node-width}} dragDiff=<<get.drag.diff>> startStoryRight={{{ [convert.to.pixels.locally{$:/state/sidebar/resizing!!start-story-right}] }}} storyRiverWidth={{{ [<startStoryRight>add<dragDiff>] }}} startSidebarWidth={{{ [convert.to.pixels.locally{$:/state/sidebar/resizing!!start-sidebar-width}] }}} sidebarWidth={{{ [<startSidebarWidth>subtract<dragDiff>] }}}>
|
<$let
|
||||||
|
startPosX={{{ [<get.resizer.state>get[start-posx]] }}}
|
||||||
|
widgetNodeWidth={{{ [<get.resizer.state>get[widget-node-width]] }}}
|
||||||
|
dragDiff=<<get.drag.diff>>
|
||||||
|
startStoryRight={{{ [<get.resizer.state>get[start-story-right]] }}}
|
||||||
|
startStoryRight={{{ [convert.to.pixels.locally<startStoryRight>] }}}
|
||||||
|
storyRiverWidth={{{ [<startStoryRight>add<dragDiff>] }}}
|
||||||
|
startSidebarWidth={{{ [<get.resizer.state>get[start-sidebar-width]] }}}
|
||||||
|
startSidebarWidth={{{ [convert.to.pixels.locally<startSidebarWidth>] }}}
|
||||||
|
sidebarWidth={{{ [<startSidebarWidth>subtract<dragDiff>] }}}>
|
||||||
<%if [<tv-set-storywidth-storyright>match[yes]] %>
|
<%if [<tv-set-storywidth-storyright>match[yes]] %>
|
||||||
<<set_theme_throttling storyright>>
|
<<set_theme_throttling storyright storyRightTiddler>>
|
||||||
<<set_theme_throttling tiddlerwidth>>
|
<<set_theme_throttling tiddlerwidth tiddlerWidthTiddler>>
|
||||||
<<set_theme_throttling storywidth>>
|
<<set_theme_throttling storywidth storyWidthTiddler>>
|
||||||
<<set-storywidth-storyright-actions>>
|
<<set-storywidth-storyright-actions>>
|
||||||
<% endif %>
|
<% endif %>
|
||||||
<%if [<tv-set-sidebarwidth>match[yes]] %>
|
<%if [<tv-set-sidebarwidth>match[yes]] %>
|
||||||
<<set_theme_throttling sidebarwidth>>
|
<<set_theme_throttling sidebarwidth sidebarWidthTiddler>>
|
||||||
<<set-sidebarwidth-actions>>
|
<<set-sidebarwidth-actions>>
|
||||||
<% endif %>
|
<% endif %>
|
||||||
<%if [<tv-set-centralised>match[yes]] %>
|
<%if [<tv-set-centralised>match[yes]] %>
|
||||||
<<set_theme_throttling storywidth>>
|
<<set_theme_throttling storywidth storyWidthTiddler>>
|
||||||
<<set-centralised-actions>>
|
<<set-centralised-actions>>
|
||||||
<% endif %>
|
<% endif %>
|
||||||
</$let>
|
</$let>
|
||||||
<% endif %>
|
<% endif %>
|
||||||
\end
|
\end
|
||||||
|
|
||||||
\procedure sidebar-resizer()
|
\function get.sidebar-resizer.class() tc-sidebar-resizer [<get.resizer.state>!is[missing]then[tc-resizer-active]] [resizer.class[]] [<qualify>addsuffix[-]addsuffix<currentTiddler>sha256[]addprefix[tc-sidebar-resizer-]] +[join[ ]]
|
||||||
|
|
||||||
|
\function get.active.class(class) [<class>] [<get.resizer.state>!is[missing]then[tc-resizer-active]] +[join[ ]]
|
||||||
|
|
||||||
|
\function get.sidebar-resizer.pointerdown.actions()
|
||||||
|
[<get.resizer.state>match[$:/state/sidebar/resizing]then<sidebar-resizer-pointerdown-actions>]
|
||||||
|
:else[<sidebar-resizer-pointerdown-actions-inner>]
|
||||||
|
\end
|
||||||
|
|
||||||
|
\procedure sidebar-resizer(templateLeft:"",templateRight:"")
|
||||||
<$eventcatcher
|
<$eventcatcher
|
||||||
tag="div"
|
tag="div"
|
||||||
class="tc-sidebar-resizer-pointerdown-eventcatcher"
|
class=<<get.active.class tc-sidebar-resizer-pointerdown-eventcatcher>>
|
||||||
selector=".tc-sidebar-resizer"
|
selector=".tc-sidebar-resizer"
|
||||||
matchSelector=".tc-sidebar-resizer"
|
matchSelector=".tc-sidebar-resizer"
|
||||||
$pointerdown=<<sidebar-resizer-pointerdown-actions>>
|
$pointerdown=<<get.sidebar-resizer.pointerdown.actions>>
|
||||||
$pointerup=<<sidebar-resizer-pointercancel-actions>>>
|
$pointerup=<<sidebar-resizer-pointercancel-actions>>>
|
||||||
|
|
||||||
<%if [{$:/state/sidebar}!match[no]] %>
|
<%if [<resizer.state>!match[no]] %>
|
||||||
|
|
||||||
<$eventcatcher
|
<$eventcatcher
|
||||||
tag="div"
|
tag="div"
|
||||||
class="tc-sidebar-resizer-pointermove-eventcatcher-wrapper"
|
class=<<get.active.class tc-sidebar-resizer-pointermove-eventcatcher-wrapper>>
|
||||||
selector=".tc-sidebar-resizer"
|
selector=".tc-sidebar-resizer"
|
||||||
matchSelector=".tc-sidebar-resizer"
|
matchSelector=".tc-sidebar-resizer"
|
||||||
$pointerup={{{ [[$:/state/sidebar/resizing]!is[missing]then<sidebar-resizer-pointercancel-actions>] }}}>
|
$pointerup={{{ [<get.resizer.state>!is[missing]then<sidebar-resizer-pointercancel-actions>] }}}>
|
||||||
|
|
||||||
<$eventcatcher
|
<$eventcatcher
|
||||||
tag="div"
|
tag="div"
|
||||||
selector=".tc-sidebar-resizer-pointermove"
|
selector=".tc-sidebar-resizer-pointermove"
|
||||||
matchSelector=".tc-sidebar-resizer-pointermove"
|
matchSelector=".tc-sidebar-resizer-pointermove"
|
||||||
class="tc-sidebar-resizer-pointermove-eventcatcher"
|
class=<<get.active.class tc-sidebar-resizer-pointermove-eventcatcher>>
|
||||||
$pointerup=<<sidebar-resizer-pointercancel-actions>>
|
$pointerup=<<sidebar-resizer-pointercancel-actions>>
|
||||||
$pointerleave=<<sidebar-resizer-pointercancel-actions>>
|
$pointerleave=<<sidebar-resizer-pointercancel-actions>>
|
||||||
$pointerout=<<sidebar-resizer-pointercancel-actions>>
|
$pointerout=<<sidebar-resizer-pointercancel-actions>>
|
||||||
@ -290,11 +328,26 @@ title: $:/core/procedures/sidebar-resizer
|
|||||||
$pointermove=<<sidebar-resizer-pointermove-actions>>
|
$pointermove=<<sidebar-resizer-pointermove-actions>>
|
||||||
$contextmenu=<<sidebar-resizer-pointercancel-actions>>>
|
$contextmenu=<<sidebar-resizer-pointercancel-actions>>>
|
||||||
|
|
||||||
<div class="tc-sidebar-resizer-pointermove"/>
|
<div class=<<get.active.class tc-sidebar-resizer-pointermove>>/>
|
||||||
|
|
||||||
</$eventcatcher>
|
</$eventcatcher>
|
||||||
|
|
||||||
<div class="tc-sidebar-resizer"/>
|
<%if [<templateLeft>!is[blank]] %>
|
||||||
|
|
||||||
|
<$transclude $tiddler=<<templateLeft>> mode="block"/>
|
||||||
|
|
||||||
|
<% endif %>
|
||||||
|
|
||||||
|
<div
|
||||||
|
class=<<get.sidebar-resizer.class>>
|
||||||
|
style.position={{{ [get.style.position[]] }}}
|
||||||
|
style.left={{{ [get.style.left[]] }}}/>
|
||||||
|
|
||||||
|
<%if [<templateRight>!is[blank]] %>
|
||||||
|
|
||||||
|
<$transclude $tiddler=<<templateRight>> mode="block"/>
|
||||||
|
|
||||||
|
<% endif %>
|
||||||
|
|
||||||
</$eventcatcher>
|
</$eventcatcher>
|
||||||
|
|
||||||
|
@ -27,15 +27,19 @@ code-body: yes
|
|||||||
|
|
||||||
@media (pointer: coarse) {
|
@media (pointer: coarse) {
|
||||||
|
|
||||||
.tc-sidebar-resizer {
|
.tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
background: <<colour muted-foreground>>;
|
background: <<colour muted-foreground>>;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tc-sidebar-resizer:hover {
|
.tc-sidebar-resizer.tc-main-sidebar-resizer:hover {
|
||||||
opacity: 0.1;
|
opacity: 0.1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.tc-sidebar-resizer-pointerdown-eventcatcher, .tc-sidebar-resizer-pointermove-eventcatcher-wrapper {
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
.tc-sidebar-resizer-pointermove-eventcatcher, .tc-sidebar-resizer-pointermove {
|
.tc-sidebar-resizer-pointermove-eventcatcher, .tc-sidebar-resizer-pointermove {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 0;
|
top: 0;
|
||||||
@ -52,28 +56,28 @@ code-body: yes
|
|||||||
user-select: none;
|
user-select: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
<%if [[$:/state/sidebar/resizing]!is[missing]] %>
|
.tc-sidebar-resizer-pointermove-eventcatcher-wrapper.tc-resizer-active {
|
||||||
|
|
||||||
.tc-sidebar-resizer-pointermove-eventcatcher-wrapper {
|
|
||||||
z-index: 801;
|
z-index: 801;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tc-sidebar-resizer-pointermove-eventcatcher {
|
.tc-sidebar-resizer-pointermove-eventcatcher.tc-resizer-active {
|
||||||
z-index: 802;
|
z-index: 802;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tc-sidebar-resizer-pointermove {
|
.tc-sidebar-resizer-pointermove.tc-resizer-active {
|
||||||
z-index: 803;
|
z-index: 803;
|
||||||
cursor: ew-resize;
|
cursor: ew-resize;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tc-sidebar-resizer {
|
.tc-sidebar-resizer.tc-resizer-active {
|
||||||
opacity: 0.6;
|
opacity: 0.6;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
<%if [[$:/state/sidebar/resizing]!is[missing]] %>
|
||||||
|
|
||||||
@media (pointer: coarse) {
|
@media (pointer: coarse) {
|
||||||
|
|
||||||
.tc-sidebar-resizer {
|
.tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
opacity: 0.25;
|
opacity: 0.25;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -82,11 +86,11 @@ code-body: yes
|
|||||||
|
|
||||||
<%if [<set.storywidth.storyright>match[yes]] %>
|
<%if [<set.storywidth.storyright>match[yes]] %>
|
||||||
|
|
||||||
.tc-sidebar-resizer {
|
.tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
left: clamp(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storyminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),clamp(calc(<<get.theme.metric storywidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),max(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storywidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),calc(<<get.theme.metric storyright>> - (2 * <<get.theme.metric storypaddingright>> / 3))),max(calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3) + (<<get.theme.metric storyleft>> + <<get.theme.metric storywidth>> - <<get.theme.metric storyright>>)),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)))),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)));
|
left: clamp(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storyminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),clamp(calc(<<get.theme.metric storywidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),max(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storywidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),calc(<<get.theme.metric storyright>> - (2 * <<get.theme.metric storypaddingright>> / 3))),max(calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3) + (<<get.theme.metric storyleft>> + <<get.theme.metric storywidth>> - <<get.theme.metric storyright>>)),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)))),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)));
|
||||||
}
|
}
|
||||||
|
|
||||||
.tc-sidebar-left .tc-sidebar-resizer {
|
.tc-sidebar-left .tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
left: auto;
|
left: auto;
|
||||||
right: clamp(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storyminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),clamp(calc(<<get.theme.metric storywidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),max(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storywidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),calc(<<get.theme.metric storyright>> - (2 * <<get.theme.metric storypaddingright>> / 3))),max(calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3) + (<<get.theme.metric storyleft>> + <<get.theme.metric storywidth>> - <<get.theme.metric storyright>>)),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)))),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)));
|
right: clamp(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storyminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),clamp(calc(<<get.theme.metric storywidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),max(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storywidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)),calc(<<get.theme.metric storyright>> - (2 * <<get.theme.metric storypaddingright>> / 3))),max(calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3) + (<<get.theme.metric storyleft>> + <<get.theme.metric storywidth>> - <<get.theme.metric storyright>>)),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)))),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)));
|
||||||
}
|
}
|
||||||
@ -95,11 +99,11 @@ code-body: yes
|
|||||||
|
|
||||||
<%if [<set.sidebarwidth>match[yes]] %>
|
<%if [<set.sidebarwidth>match[yes]] %>
|
||||||
|
|
||||||
.tc-sidebar-resizer {
|
.tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
left: clamp(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storyminwidth>> + (<<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarwidth>> + (<<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarminwidth>> + (<<get.theme.metric storypaddingright>> / 3)));
|
left: clamp(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storyminwidth>> + (<<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarwidth>> + (<<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarminwidth>> + (<<get.theme.metric storypaddingright>> / 3)));
|
||||||
}
|
}
|
||||||
|
|
||||||
.tc-sidebar-left .tc-sidebar-resizer {
|
.tc-sidebar-left .tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
left: auto;
|
left: auto;
|
||||||
right: clamp(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storyminwidth>> + (<<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarwidth>> + (<<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarminwidth>> + (<<get.theme.metric storypaddingright>> / 3)));
|
right: clamp(calc(<<get.theme.metric storyleft>> + <<get.theme.metric storyminwidth>> + (<<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarwidth>> + (<<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarminwidth>> + (<<get.theme.metric storypaddingright>> / 3)));
|
||||||
}
|
}
|
||||||
@ -108,11 +112,11 @@ code-body: yes
|
|||||||
|
|
||||||
<%if [<set.centralised>match[yes]] %>
|
<%if [<set.centralised>match[yes]] %>
|
||||||
|
|
||||||
.tc-sidebar-resizer {
|
.tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
left: min(calc(50% + (<<get.theme.metric storywidth>> / 2) - (2 * <<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)));
|
left: min(calc(50% + (<<get.theme.metric storywidth>> / 2) - (2 * <<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)));
|
||||||
}
|
}
|
||||||
|
|
||||||
.tc-sidebar-left .tc-sidebar-resizer {
|
.tc-sidebar-left .tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
left: auto;
|
left: auto;
|
||||||
right: min(calc(50% + (<<get.theme.metric storywidth>> / 2) - (2 * <<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)));
|
right: min(calc(50% + (<<get.theme.metric storywidth>> / 2) - (2 * <<get.theme.metric storypaddingright>> / 3)),calc(100% - <<get.theme.metric sidebarminwidth>> - (2 * <<get.theme.metric storypaddingright>> / 3)));
|
||||||
}
|
}
|
||||||
@ -121,7 +125,7 @@ code-body: yes
|
|||||||
|
|
||||||
<%if [{$:/state/sidebar}match[no]] %>
|
<%if [{$:/state/sidebar}match[no]] %>
|
||||||
|
|
||||||
.tc-sidebar-resizer-pointerdown-eventcatcher, .tc-sidebar-resizer-pointermove-eventcatcher-wrapper, .tc-sidebar-resizer-pointermove-eventcatcher, .tc-sidebar-resizer-pointermove, .tc-sidebar-resizer {
|
.tc-sidebar-resizer-pointerdown-eventcatcher, .tc-sidebar-resizer-pointermove-eventcatcher-wrapper, .tc-sidebar-resizer-pointermove-eventcatcher, .tc-sidebar-resizer-pointermove, .tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -131,7 +135,7 @@ code-body: yes
|
|||||||
|
|
||||||
@media (max-width: <<sidebarbreakpoint-minus-one>>) {
|
@media (max-width: <<sidebarbreakpoint-minus-one>>) {
|
||||||
|
|
||||||
.tc-sidebar-resizer-pointerdown-eventcatcher, .tc-sidebar-resizer-pointermove-eventcatcher-wrapper, .tc-sidebar-resizer-pointermove-eventcatcher, .tc-sidebar-resizer-pointermove, .tc-sidebar-resizer {
|
.tc-sidebar-resizer-pointerdown-eventcatcher, .tc-sidebar-resizer-pointermove-eventcatcher-wrapper, .tc-sidebar-resizer-pointermove-eventcatcher, .tc-sidebar-resizer-pointermove, .tc-sidebar-resizer.tc-main-sidebar-resizer {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user