From e25e0cc1374a83b86a9585c9a38b754243f66c4d Mon Sep 17 00:00:00 2001 From: liuycy Date: Mon, 25 Mar 2024 23:00:04 +0800 Subject: [PATCH] feat: better action of checkbox on mobile phone (#161) * feat: better action of checkbox on mobile phone * fix: z-index of gallery should higher than overlay --- src/app/theme.ts | 8 ++++++++ src/lang/en/home.json | 1 + src/pages/home/folder/Folder.tsx | 1 + src/pages/home/folder/GridItem.tsx | 10 +++++++--- src/pages/home/folder/ImageItem.tsx | 10 +++++++--- src/pages/home/folder/List.tsx | 6 +++--- src/pages/home/folder/ListItem.tsx | 10 +++++++--- src/pages/home/folder/helper.ts | 22 ++++++++++++++++++++-- src/pages/home/toolbar/LocalSettings.tsx | 10 ++++++++-- src/store/local_settings.ts | 6 +++++- 10 files changed, 67 insertions(+), 17 deletions(-) diff --git a/src/app/theme.ts b/src/app/theme.ts index 6c775ff906..a46121cd05 100644 --- a/src/app/theme.ts +++ b/src/app/theme.ts @@ -176,6 +176,14 @@ export const globalStyles = globalCss({ flexWrap: "wrap", rowGap: "0 !important", }, + ".lightgallery-container": { + "& .lg-backdrop": { + zIndex: "$popover", + }, + "& .lg-outer": { + zIndex: "calc($popover + 10)", + }, + }, ".viselect-selection-area": { background: "rgba(46, 115, 252, 0.11)", border: "2px solid rgba(98, 155, 255, 0.81)", diff --git a/src/lang/en/home.json b/src/lang/en/home.json index a29a3fe3a7..82e570d889 100644 --- a/src/lang/en/home.json +++ b/src/lang/en/home.json @@ -132,6 +132,7 @@ "open_item_on_checkbox": "Open item on Checkbox", "open_item_on_checkbox_options": { "direct": "Direct", + "disable_while_checked": "Disable while checked", "with_ctrl": "With Ctrl/Command hold", "with_alt": "With Alt/Option hold" }, diff --git a/src/pages/home/folder/Folder.tsx b/src/pages/home/folder/Folder.tsx index 6236ec6d0d..d556716bbe 100644 --- a/src/pages/home/folder/Folder.tsx +++ b/src/pages/home/folder/Folder.tsx @@ -39,6 +39,7 @@ const Folder = () => { let dynamicGallery: LightGallery | undefined const initGallery = () => { dynamicGallery = lightGallery(document.createElement("div"), { + addClass: "lightgallery-container", dynamic: true, thumbnail: true, plugins: [lgZoom, lgThumbnail, lgRotate, lgAutoplay, lgFullscreen], diff --git a/src/pages/home/folder/GridItem.tsx b/src/pages/home/folder/GridItem.tsx index a4ad5d5f5f..d0c02446b5 100644 --- a/src/pages/home/folder/GridItem.tsx +++ b/src/pages/home/folder/GridItem.tsx @@ -1,4 +1,4 @@ -import { Center, VStack, Icon, Text, Checkbox } from "@hope-ui/solid" +import { Center, VStack, Icon, Text } from "@hope-ui/solid" import { Motion } from "@motionone/solid" import { useContextMenu } from "solid-contextmenu" import { batch, createMemo, createSignal, Show } from "solid-js" @@ -14,7 +14,11 @@ import { import { ObjType, StoreObj } from "~/types" import { bus, hoverColor } from "~/utils" import { getIconByObj } from "~/utils/icon" -import { useOpenItemWithCheckbox, useSelectWithMouse } from "./helper" +import { + ItemCheckbox, + useOpenItemWithCheckbox, + useSelectWithMouse, +} from "./helper" export const GridItem = (props: { obj: StoreObj; index: number }) => { const { isHide } = useUtil() @@ -124,7 +128,7 @@ export const GridItem = (props: { obj: StoreObj; index: number }) => { pos="relative" > - { const { isHide } = useUtil() @@ -68,7 +72,7 @@ export const ImageItem = (props: { obj: StoreObj; index: number }) => { - { const t = useT() @@ -55,7 +55,7 @@ const ListLayout = () => { - { diff --git a/src/pages/home/folder/ListItem.tsx b/src/pages/home/folder/ListItem.tsx index e7279033c2..7fc5578ab3 100644 --- a/src/pages/home/folder/ListItem.tsx +++ b/src/pages/home/folder/ListItem.tsx @@ -1,4 +1,4 @@ -import { Checkbox, HStack, Icon, Text } from "@hope-ui/solid" +import { HStack, Icon, Text } from "@hope-ui/solid" import { Motion } from "@motionone/solid" import { useContextMenu } from "solid-contextmenu" import { batch, Show } from "solid-js" @@ -15,7 +15,11 @@ import { import { ObjType, StoreObj } from "~/types" import { bus, formatDate, getFileSize, hoverColor } from "~/utils" import { getIconByObj } from "~/utils/icon" -import { useOpenItemWithCheckbox, useSelectWithMouse } from "./helper" +import { + ItemCheckbox, + useOpenItemWithCheckbox, + useSelectWithMouse, +} from "./helper" export interface Col { name: OrderBy @@ -100,7 +104,7 @@ export const ListItem = (props: { obj: StoreObj; index: number }) => { > - { e.stopPropagation() diff --git a/src/pages/home/folder/helper.ts b/src/pages/home/folder/helper.ts index 16bbfc1da1..67954b8908 100644 --- a/src/pages/home/folder/helper.ts +++ b/src/pages/home/folder/helper.ts @@ -1,5 +1,6 @@ +import { Checkbox, hope } from "@hope-ui/solid" import { createKeyHold } from "@solid-primitives/keyboard" -import { createEffect, createSignal, on, onCleanup } from "solid-js" +import { createEffect, createSignal, onCleanup } from "solid-js" import SelectionArea from "@viselect/vanilla" import { checkboxOpen, @@ -9,7 +10,6 @@ import { oneChecked, selectAll, selectIndex, - selectedObjs, } from "~/store" import { isMac, isMobile } from "~/utils/compatibility" import { useContextMenu } from "solid-contextmenu" @@ -29,6 +29,10 @@ export function useOpenItemWithCheckbox() { setShouldOpen(true) break } + case "disable_while_checked": { + setShouldOpen(!haveSelected()) + break + } case "with_ctrl": { // FYI why should use metaKey on a Mac // https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/ctrlKey @@ -107,3 +111,17 @@ export function useSelectWithMouse() { return { isMouseSupported, registerSelectContainer, captureContentMenu } } + +export const ItemCheckbox = hope(Checkbox, { + baseStyle: { + // expand the range of click + _before: { + content: "", + pos: "absolute", + top: -10, + right: -2, + bottom: -10, + left: -10, + }, + }, +}) diff --git a/src/pages/home/toolbar/LocalSettings.tsx b/src/pages/home/toolbar/LocalSettings.tsx index fe5f4f3f1f..3834a745f3 100644 --- a/src/pages/home/toolbar/LocalSettings.tsx +++ b/src/pages/home/toolbar/LocalSettings.tsx @@ -58,7 +58,13 @@ function LocalSettingEdit(props: LocalSetting) { - + {(item) => ( @@ -107,7 +113,7 @@ export const LocalSettings = () => { - + !s.hidden)}> {(setting) => } diff --git a/src/store/local_settings.ts b/src/store/local_settings.ts index af0974a59a..e95186399b 100644 --- a/src/store/local_settings.ts +++ b/src/store/local_settings.ts @@ -57,13 +57,17 @@ export const initialLocalSettings = [ key: "open_item_on_checkbox", default: "direct", type: "select", - options: ["direct", "with_alt", "with_ctrl"], + options: () => + isMobile + ? ["direct", "disable_while_checked"] + : ["direct", "disable_while_checked", "with_alt", "with_ctrl"], }, { key: "select_with_mouse", default: "disabled", type: "select", options: ["disabled", "open_item_with_dblclick"], + hidden: isMobile, }, ] export type LocalSetting = (typeof initialLocalSettings)[number]