Skip to content

Commit

Permalink
Merge branch 'dev'
Browse files Browse the repository at this point in the history
  • Loading branch information
frostime committed Dec 29, 2024
2 parents 33e7cd5 + fdf374e commit a833e12
Show file tree
Hide file tree
Showing 17 changed files with 393 additions and 294 deletions.
3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "sy-bookmark-plus",
"version": "1.4.1",
"version": "1.5.0",
"type": "module",
"description": "A more powerful bookmark",
"repository": "",
Expand Down Expand Up @@ -33,6 +33,7 @@
"vite-plugin-zip-pack": "^1.2.2"
},
"dependencies": {
"@frostime/siyuan-plugin-kits": "^1.3.6",
"@frostime/solid-signal-ref": "^2.0.0",
"solid-transition-group": "^0.2.3"
}
Expand Down
2 changes: 1 addition & 1 deletion plugin.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"name": "sy-bookmark-plus",
"author": "frostime",
"url": "https://github.com/frostime/sy-bookmark-plus",
"version": "1.4.1",
"version": "1.5.0",
"minAppVersion": "3.0.12",
"backends": [
"all"
Expand Down
205 changes: 108 additions & 97 deletions public/i18n/en_US.yaml
Original file line number Diff line number Diff line change
@@ -1,130 +1,141 @@
---
msg:
ruleFailed: 'Failed to correctly parse the configuration rule: {0}'
ruleInvalid: 'The format of the group rule input is incorrect: {0}'
itemHasInGroup: The item is already in the target group
itemNotFoundInGroup: The item was not found in the source group
groupNameEmpty: The name of the bookmark group cannot be empty!
itemErr:
closed: 'The notebook "{0}" is already closed'
deleted: 'Content block not found, it may have been deleted! Old block content: [{0}]'
setting:
replaceDefault:
title: Replace Built-in Bookmarks
description: 'If enabled, the default bookmarks will be blocked, and bookmark shortcut keys (default is Alt+3) will be bound;<br/>Takes effect after restart; Notice: not appliable in mobile devices!'
viewMode:
title: Display Mode
description: Select the style of the bookmark bar display
hideClosed:
title: Hide Closed Items
description: When enabled, hide items from closed notebooks
hideDeleted:
title: Hide Invalid Items
description: When enabled, hide items that have been deleted
grouplist:
title: Bookmark Groups
description: Set up bookmark groups
autoRefreshOnExpand:
title: Auto Refresh on Expand
description: Automatically refreshes the items within a dynamic group when it is expanded from a collapsed state.
ariaLabel:
title: Display Hover Box
description: Display full title of the bookmark item in a hover box when the mouse hovers
viewMode:
bookmark: Bookmark Style
card: Card Style
bookmark:
new: Create New Bookmark Group
cache: Cache Current Bookmarks
delete:
title: Delete the bookmark group {0}[{1}]?
desc: ⚠️ Cannot be recovered after deletion! Are you sure you want to delete?
cache: Cache Current Bookmarks
title: Delete the bookmark group {0}[{1}]?
logo:
name: Bookmark
setting: Settings
add: Add Bookmark Group
refresh: Refresh
expand: Expand Ctrl+↓
collapse: Collapse Ctrl+↑
expand: Expand Ctrl+↓
min: Minimize Ctrl+W
name: Bookmark
refresh: Refresh
setting: Settings
new: Create New Bookmark Group
bookmarktype:
composed: Composite Bookmark
dynamic: Dynamic Bookmark
normal: Normal Bookmark
group:
msgexist: 'Cannot add: Block with ID [{0}] already exists in the bookmark group'
msg404: 'Cannot add: Block with ID [{0}] not found'
refresh: Refresh
copyref: Copy as Reference List
bottom: Move to Bottom
copylink: Copy as Link List
msgcopy: Copy Successful
copyref: Copy as Reference List
currentdoc: Add Current Document Block
delete: Delete Bookmark Group
docflow: Document Flow
rename: Rename Bookmark Group
down: Move Down
edit: Edit Rule Value
delete: Delete Bookmark Group
fromclipboard: Insert Block from Clipboard
move: Move
msg404: 'Cannot add: Block with ID [{0}] not found'
msgcopy: Copy Successful
msgdelconfirm:
- Delete bookmark item {0}?
- ⚠️ Cannot be recovered after deletion! Are you sure you want to delete?
msgexist: 'Cannot add: Block with ID [{0}] already exists in the bookmark group'
msgparse: Unable to parse block from [{0}]
refresh: Refresh
rename: Rename Bookmark Group
top: Move to Top
up: Move Up
down: Move Down
bottom: Move to Bottom
fromclipboard: Insert Block from Clipboard
msgparse: Unable to parse block from [{0}]
currentdoc: Add Current Document Block
msgdelconfirm:
- Delete bookmark item {0}?
- ⚠️ Cannot be recovered after deletion! Are you sure you want to delete?
item:
copyref: Copy as Reference
bottom: Move to Bottom
checkerritem: Check detail
copyitem: Copy to
copylink: Copy as Link
copyref: Copy as Reference
del: Delete Bookmark
move: Move
msgcopy: Copy Successful
style: Style
transfer: Move to
move: Move
top: Move to Top
bottom: Move to Bottom
del: Delete Bookmark
checkerritem: Check detail
copyitem: Copy to
transfer: Move to
itemErr:
closed: The notebook "{0}" is already closed
deleted: 'Content block not found, it may have been deleted! Old block content:
[{0}]'
msg:
groupNameEmpty: The name of the bookmark group cannot be empty!
itemHasInGroup: The item is already in the target group
itemNotFoundInGroup: The item was not found in the source group
ruleFailed: 'Failed to correctly parse the configuration rule: {0}'
ruleInvalid: 'The format of the group rule input is incorrect: {0}'
newgroup:
name:
- Bookmark Group Name
- Please enter the name of the new bookmark group
type:
- Bookmark Group Type
- Select Bookmark Group Type
rtype:
- Rule Type
- Select Dynamic Rule Type
rinput: Rule Value
choosetemplate: Template
desc:
sql: Please enter the SQL query below
attr: Please enter the attribute to search for; You can fill in [attribute name],
or [attribute name][= or like][attribute value]
backlinks: Please enter the block ID of the backlink
attr: Please enter the attribute to search for; You can fill in [attribute name], or [attribute name][= or like][attribute value]
choosetemplate: Template
sql: Please enter the SQL query below
icondesc: Select the icon for the group; if not set, the plugin will assign a default
icon based on the group type.
icontitle: Group Icon
name:
- Bookmark Group Name
- Please enter the name of the new bookmark group
postprocess:
ariaLabel: '<b>First child of container: </b>Display the full container block when the referenced block is the first child of a list item or quote block.<br/><b>Display as document block: </b>Display the document containing the referenced block, rather than the referenced block itself.<br/><b>See README for details</b>'
ariaLabel: '<b>First child of container: </b>Display the full container block
when the referenced block is the first child of a list item or quote block.<br/><b>Display
as document block: </b>Display the document containing the referenced block,
rather than the referenced block itself.<br/><b>See README for details</b>'
b2doc: Display as document block
fb2p: First child of container
name: Post-process
omit: No Process
fb2p: First child of container
b2doc: Display as document block
icontitle: Group Icon
# icondesc: 可以手动选择分组的图标;如果不设置,插件会根据分组类型分配默认的图标。
icondesc: Select the icon for the group; if not set, the plugin will assign a default icon based on the group type.

bookmarktype:
normal: 'Normal Bookmark'
dynamic: 'Dynamic Bookmark'
composed: 'Composite Bookmark'
rinput: Rule Value
rtype:
- Rule Type
- Select Dynamic Rule Type
type:
- Bookmark Group Type
- Select Bookmark Group Type
ruletype:
sql: SQL
backlinks: Backlinks
attr: Block Attributes
backlinks: Backlinks
js: Javascript
sql: SQL
selecticon:
h3: Please select an icon
reset: Reset
title: Change Group Icon
setting:
ariaLabel:
description: Display full title of the bookmark item in a hover box when the mouse
hovers
title: Display Hover Box
autoRefreshOnExpand:
description: Automatically refreshes the items within a dynamic group when it
is expanded from a collapsed state.
title: Auto Refresh on Expand
grouplist:
description: Set up bookmark groups
title: Bookmark Groups
hideClosed:
description: When enabled, hide items from closed notebooks
title: Hide Closed Items
hideDeleted:
description: When enabled, hide items that have been deleted
title: Hide Invalid Items
replaceDefault:
description: 'If enabled, the default bookmarks will be blocked, and bookmark
shortcut keys (default is Alt+3) will be bound;<br/>Takes effect after restart;
Notice: not appliable in mobile devices!'
title: Replace Built-in Bookmarks
viewMode:
description: Select the style of the bookmark bar display
title: Display Mode
zoomInWhenClick:
description: When clicking on the bookmark item and opening the content block
in the tab, automatically enter the focus mode
title: Enter focus mode after jumping to the block
template:
attr:
dailynote: Daily Note
sql:
random: Random Roam
updated: Recently Updated
thisday: On this day
todo: Unsolved Task
attr:
dailynote: Daily Note
selecticon:
title: Change Group Icon
h3: Please select an icon
reset: Reset
updated: Recently Updated
viewMode:
bookmark: Bookmark Style
card: Card Style
3 changes: 3 additions & 0 deletions public/i18n/zh_CN.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,9 @@ setting:
ariaLabel:
title: 显示悬浮框
description: 鼠标悬停在书签项目上时,在悬浮框中显示书签项目的完整标题
zoomInWhenClick:
title: 跳转到块后进入聚焦
description: 当点击书签项目,在标签页中打开内容块的时候,自动进入聚焦模式
viewMode:
bookmark: 书签样式
card: 卡片样式
Expand Down
27 changes: 16 additions & 11 deletions src/components/group.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,9 @@ const Group: Component<Props> = (props) => {

if (configs['autoRefreshOnExpand'] && isDynamicGroup() && expand === false) {
// console.log('auto refresh', props.group.name);
model.updateDynamicGroup(props.group);
model.updateDynamicGroup(props.group).then(() => {
model.updateGroupStaticItemsDebounced(props.group);
});
}

setGroups((g) => g.id === props.group.id, 'expand', expand);
Expand Down Expand Up @@ -167,16 +169,17 @@ const Group: Component<Props> = (props) => {
const showGroupContextMenu = (e: MouseEvent) => {
e.stopPropagation();
const menu = new Menu();
if (props.group.type === 'dynamic') {
menu.addItem({
label: i18n_.refresh,
icon: 'iconRefresh',
click: () => {
model.updateDynamicGroup(props.group);
menu.addItem({
label: i18n_.refresh,
icon: 'iconRefresh',
click: async () => {
if (props.group.type === 'dynamic') {
await model.updateDynamicGroup(props.group);
}
});
menu.addSeparator();
}
await model.updateGroupStaticItemsDebounced(props.group);
}
});
menu.addSeparator();
menu.addItem({
label: i18n_.copyref,
icon: "iconRef",
Expand Down Expand Up @@ -498,7 +501,9 @@ const Group: Component<Props> = (props) => {
class="b3-list-item__action"
onClick={(e) => {
e.stopPropagation();
model.updateDynamicGroup(props.group);
model.updateDynamicGroup(props.group).then(() => {
model.updateGroupStaticItemsDebounced(props.group);
});
}}
>
<svg>
Expand Down
17 changes: 14 additions & 3 deletions src/components/item.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,16 @@ import { render } from "solid-js/web";
import { Menu, openTab, showMessage, openMobileFileById } from "siyuan";
import { buildItemDetail } from "../libs/dom";

import { itemInfo, setGroups, groupMap, configs } from "../model";
import { itemInfo, setGroups, groupMap, configs, configRef } from "../model";

import { BookmarkContext, itemMoving, setItemMoving } from "./context";

import { i18n, renderI18n } from "@/utils/i18n";
import { simpleDialog } from "@/libs/dialog";
// import { simpleDialog } from "@/libs/dialog";
import { simpleDialog } from "@frostime/siyuan-plugin-kits";
import Typography from "@/libs/components/typography";
import { getNotebook, isMobile } from "@/utils";
import { getBlockByID } from "@/api";

interface IProps {
group: TBookmarkGroupId;
Expand Down Expand Up @@ -267,11 +269,20 @@ const Item: Component<IProps> = (props) => {
if (isMobile()) {
openMobileFileById(plugin.app, item().id);
} else {
let zoomIn = configRef().zoomInWhenClick;
// if (item().type === 'd') {
// zoomIn = false;
// } else {
// let block = await getBlockByID(item().id);
// let root_id = block.root_id;
// let protyle = document.querySelector(`.protyle-title[data-node-id="${root_id}"]`);
// if (protyle) zoomIn = false; //如果文档已经打开了,就直接调整不聚焦
// }
openTab({
app: plugin.app,
doc: {
id: item().id,
zoomIn: item().type === 'd' ? false : true,
zoomIn: zoomIn,
},
});
}
Expand Down
4 changes: 2 additions & 2 deletions src/components/select-icon.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { createSignal, For, Show } from "solid-js";
import Icon from "./icon";
import { inject } from "@/libs/inject";
// import { inject } from "@/libs/inject";
import { solidDialog } from "@/libs/dialog";

import { i18n } from "@/utils/i18n";
Expand All @@ -20,7 +20,7 @@ const SelectIcons = (props: IProps) => {
const [activeTab, setActiveTab] = createSignal<'symbols' | 'emojis'>('symbols');
const symbols = Array.from(document.querySelectorAll('symbol'));

const i18n = inject<I18n>('i18n');
// const i18n = inject<I18n>('i18n');

const ALLOWED_EMOJI_GROUP = ['activity', 'travel', 'people', 'nature', 'food', 'symbols', 'object', 'flags'];
let EmojisGroups = (window.siyuan.emojis as ImojiGroup[]).filter(emoji => ALLOWED_EMOJI_GROUP.includes(emoji.id));
Expand Down
11 changes: 6 additions & 5 deletions src/components/setting/group-list.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -56,12 +56,13 @@ const App = () => {

return (
<section
class="fn__flex fn__flex-1 fn__flex-column bookmark-config-group-list"
class="fn__flex fn__flex-1 bookmark-config-group-list"
style={{
border: '2px solid var(--b3-theme-primary-lighter)',
'border-radius': '5px',
padding: '15px 10px',
gap: '10px'
padding: '20px 10px',
gap: '10px',
display: 'flex',
flex: 1,
'flex-direction': 'column'
}}
>
<For each={groups}>
Expand Down
Loading

0 comments on commit a833e12

Please sign in to comment.