Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add OrientationLock parameter to BitSwipeTrap (#9662) #9663

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@
Throttle="10"
OnMove="HandleOnSwipeMove"
OnEnd="HandleOnSwipeEnd"
OnTrigger="HandleOnSwipeTrigger">
OnTrigger="HandleOnSwipeTrigger"
OrientationLock="BitSwipeOrientation.Horizontal">
<div style="@Styles?.Container" class="bit-npn-cnt @Classes?.Container">
@if (Header is not null)
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -194,22 +194,12 @@ private void SearchNavItems(string? searchText)
_filteredNavItems = [.. mainItems, .. subItems];
}

private decimal _oldDiffY = 0;
private void HandleOnSwipeMove(BitSwipeTrapEventArgs args)
{
if (IsOpen is false) return;

if (Math.Abs(args.DiffX) > Math.Abs(args.DiffY))
{
diffXPanel = args.DiffX;
StateHasChanged();
}
else
{
var diff = args.DiffY - _oldDiffY;
_js.BitExtrasScrollBy(RootElement, 0, diff > 0 ? -20 : 20);
_oldDiffY = args.DiffY;
}
diffXPanel = args.DiffX;
StateHasChanged();

}
private void HandleOnSwipeEnd(BitSwipeTrapEventArgs args)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
namespace Bit.BlazorUI;

/// <summary>
/// The lock orientation of the swipe trap component.
/// </summary>
public enum BitSwipeOrientation
{
/// <summary>
/// Not orientation lock for swipe trap.
/// </summary>
None,

/// <summary>
/// Horizontal orientation lock of trapping the swipe action.
/// </summary>
Horizontal,

/// <summary>
/// Vertical orientation lock of trapping the swipe action.
/// </summary>
Vertical
}
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,11 @@ public partial class BitSwipeTrap : BitComponentBase, IAsyncDisposable
/// </summary>
[Parameter] public EventCallback<BitSwipeTrapTriggerArgs> OnTrigger { get; set; }

/// <summary>
/// Specifies the orientation lock in which the swipe trap allows to trap the swipe actions.
/// </summary>
[Parameter] public BitSwipeOrientation? OrientationLock { get; set; }

/// <summary>
/// The threshold in pixel for swiping distance that starts the swipe process process which stops the default behavior.
/// </summary>
Expand Down Expand Up @@ -96,7 +101,14 @@ protected override async Task OnAfterRenderAsync(bool firstRender)
if (firstRender)
{
var dotnetObj = DotNetObjectReference.Create(this);
await _js.BitSwipeTrapSetup(UniqueId, RootElement, Trigger ?? 0.25m, Threshold ?? 0, Throttle ?? 0, dotnetObj);
await _js.BitSwipeTrapSetup(
UniqueId,
RootElement,
Trigger ?? 0.25m,
Threshold ?? 0,
Throttle ?? 0,
OrientationLock ?? BitSwipeOrientation.None,
dotnetObj);
}

await base.OnAfterRenderAsync(firstRender);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,13 +8,15 @@
trigger: number,
threshold: number,
throttle: number,
orientationLock: BitSwipeOrientation,
dotnetObj: DotNetObject) {
const bcr = element.getBoundingClientRect();

let diffX = 0;
let diffY = 0;
let startX = -1;
let startY = -1;
let orientation = BitSwipeOrientation.None;
const isTouchDevice = Utils.isTouchDevice();
const throttledMove = Utils.throttle((sx: number, sy: number, dx: number, dy: number) => dotnetObj.invokeMethodAsync('OnMove', sx, sy, dx, dy), throttle);

Expand All @@ -34,12 +36,46 @@
diffX = getX(e) - startX;
diffY = getY(e) - startY;

if ((Math.abs(diffX) > threshold || Math.abs(diffY) > threshold) && e.cancelable) {
e.preventDefault();
e.stopPropagation();
const absX = Math.abs(diffX);
const absY = Math.abs(diffY);
const thresX = absX > threshold;
const thresY = absY > threshold;


if (orientation === BitSwipeOrientation.None) {
if (thresX && !thresY) {
orientation = BitSwipeOrientation.Horizontal;
} else if (!thresX && thresY) {
orientation = BitSwipeOrientation.Vertical;
}
}

if (orientationLock === BitSwipeOrientation.Horizontal) {
if (orientation === BitSwipeOrientation.Horizontal) {
cancel();
diffY = 0;
} else {
diffX = 0;
}
} else if (orientationLock === BitSwipeOrientation.Vertical) {
if (orientation === BitSwipeOrientation.Vertical && absY > threshold) {
cancel();
diffX = 0;
} else {
diffY = 0;
}
} else if ((thresX || thresY)) {
cancel();
}

throttledMove(startX, startY, diffX, diffY);

function cancel() {
if (e.cancelable) {
e.preventDefault();
e.stopPropagation();
}
}
};

const onEnd = async (e: TouchEvent | PointerEvent): Promise<void> => {
Expand All @@ -59,6 +95,7 @@
} finally {
await dotnetObj.invokeMethodAsync('OnEnd', sX, sY, diffX, diffY);
diffX = diffY = 0;
orientation = BitSwipeOrientation.None;
msynk marked this conversation as resolved.
Show resolved Hide resolved
}
};

Expand All @@ -67,6 +104,7 @@
dotnetObj.invokeMethodAsync('OnEnd', startX, startY, diffX, diffY);
startX = startY = -1;
diffX = diffY = 0;
orientation = BitSwipeOrientation.None;
}

if (isTouchDevice) {
Expand Down Expand Up @@ -130,4 +168,11 @@
this.dotnetObj.dispose();
}
}

enum BitSwipeOrientation {
None,
Horizontal,
Vertical
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,10 @@ internal static ValueTask BitSwipeTrapSetup(this IJSRuntime js,
decimal trigger,
decimal threshold,
int throttle,
BitSwipeOrientation orientationLock,
DotNetObjectReference<BitSwipeTrap>? dotnetObjectReference)
{
return js.InvokeVoid("BitBlazorUI.SwipeTrap.setup", id, element, trigger, threshold, throttle, dotnetObjectReference);
return js.InvokeVoid("BitBlazorUI.SwipeTrap.setup", id, element, trigger, threshold, throttle, orientationLock, dotnetObjectReference);
}

internal static ValueTask BitSwipeTrapDispose(this IJSRuntime jsRuntime, string id)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -98,49 +98,45 @@
<br />
<div class="mobile-frame">
<div class="screen">
<BitLayout Classes="@(new() { MainContent = "panel-adv-container" })">
<Header>
<BitCard FullWidth>
<BitStack Horizontal HorizontalAlign="BitAlignment.Center" VerticalAlign="BitAlignment.Center">
<BitImage Src="/_content/Bit.BlazorUI.Demo.Client.Core/images/bit-logo.svg" Width="50" />
<BitText Typography="BitTypography.H4" Color="BitColor.Info">
bit BlazorUI
</BitText>
</BitStack>
</BitCard>
</Header>
<Main>
<div class="layout">
<div class="header">
<BitImage Src="/_content/Bit.BlazorUI.Demo.Client.Core/images/bit-logo.svg" Width="50" />
<BitText Typography="BitTypography.H4" Color="BitColor.Info">
bit BlazorUI
</BitText>
</div>
<div class="main">
<BitSwipeTrap Style="width:100%;height:100%"
OnMove="HandleOnMovePanelAdvanced"
OnEnd="HandleOnEndPanelAdvanced"
OnTrigger="HandleOnTriggerPanelAdvanced">
<BitStack HorizontalAlign="BitAlignment.Center" VerticalAlign="BitAlignment.Center">
<div class="main-text">
<BitText Style="user-select:none"
Typography="BitTypography.H4"
Color="BitColor.SecondaryBackground">
Swipe left or right
</BitText>
</BitStack>
</div>

<div class="panel-adv left" style="@GetLeftPanelAdvancedStyle()">
<div class="panel-adv-trap">
<div class="panel left" style="@GetLeftPanelAdvancedStyle()">
<div class="panel-trap">
<h3>Left Menu</h3>
<div>Item1</div>
<div>Item2</div>
<div>Item3</div>
</div>
</div>
<div class="panel-adv right" style="@GetRightPanelAdvancedStyle()">
<div class="panel-adv-trap">
<div class="panel right" style="@GetRightPanelAdvancedStyle()">
<div class="panel-trap">
<h3>Right Menu</h3>
<div>Item1</div>
<div>Item2</div>
<div>Item3</div>
</div>
</div>
</BitSwipeTrap>
</Main>
</BitLayout>
</div>
</div>
</div>
</div>
</ExamplePreview>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,15 @@ public partial class BitSwipeTrapDemo
Href = "#swipetrap-trigger-args",
},
new()
{
Name = "OrientationLock",
Type = "BitSwipeOrientation?",
DefaultValue = "null",
Description = "Specifies the orientation lock in which the swipe trap allows to trap the swipe actions.",
LinkType = LinkType.Link,
Href = "#swipe-orientation",
},
new()
{
Name = "Threshold",
Type = "decimal?",
Expand Down Expand Up @@ -146,6 +155,33 @@ public partial class BitSwipeTrapDemo

private readonly List<ComponentSubEnum> componentSubEnums =
[
new()
{
Id = "swipe-orientation",
Name = "BitSwipeOrientation",
Description = "The lock orientation of the swipe trap component.",
Items =
[
new()
{
Name = "None",
Value = "0",
Description = "Not orientation lock for swipe trap."
},
new()
{
Name = "Horizontal",
Value = "1",
Description = "Horizontal orientation lock of trapping the swipe action."
},
new()
{
Name = "Vertical",
Value = "2",
Description = "Vertical orientation lock of trapping the swipe action."
},
]
},
new()
{
Id = "swipe-direction-enum",
Expand Down
Loading
Loading