思源笔记 v3.1.11 支持了动态图标:Add internal kernel API `/api/icon/getDynamicIcon` by Achuan-2 · Pull Request #12939 · siyuan-note/siyuan
这篇帖子分享下如何用链接传参的方式使用动态图标,选择图标样式、颜色等。v3.1.11 版本还不支持文档图标设置动态图标,可以期待下之后能支持这个功能(见文档图标支持使用动态图标 · Issue #12943 · siyuan-note/siyuan)
参数
目前有 8 种 color 和 8 种 type
-
type
:图标类型,默认为 1type=1
:显示年月日星期type=2
:显示年月日type=3
:仅显示年月type=4
:仅显示年type=5
:当前周数type=6
:仅返回星期type=7
:倒数日type=8
:文字图标
-
lang
:默认为当前思源笔记使用的语言,仅在 type=1、2、3、5、6、7 时有效lang=zh_CN
:显示中文简体lang=zh_CHT
:显示中文繁体lang=en_US
/lang=en_ES
:显示英文- 其他语言用英文显示
-
color
:设置配色,一共八种配色color=red
color=blue
color=yellow
color=green
color=purple
color=pink
color=orange
color=grey
支持通过
color=FE3427
或color=%23FE3427
设置自定义颜色(注意:直接输出color=#FE3427
,会由于#
是 URL 特殊符号,导致 URL 被截断,会使得参数不起作用)data:image/s3,"s3://crabby-images/90953/90953f7dea138c08f19537597e01d32d7d972dd5" alt=""
-
date
: 设置日期,默认为当前日期,日期设置格式为yyyy-mm-dd
,仅在 type=1-7 时有效 -
weekdayType
: 设置星期格式,默认为第一种类型,仅在 type=1、6 时有效-
中文
weekdayType=1
:"周日", "周一", "周二", "周三", "周四", "周五", "周六"
weekdayType=2
:"周天", "周一", "周二", "周三", "周四", "周五", "周六"
weekdayType=3
:"星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"
weekdayType=4
:"星期天", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六
-
英文
weekdayType=1
:"Sun","Mon","Tue","Wed","Thu","Fri","Sat"
weekdayType=2
:"SUN","MON","TUE","WED","THU","FRI","SAT"
weekdayType=3
:"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"
weekdayType=4
:"SUNDAY","MONDAY","TUESDAY","WEDNESDAY","THURSDAY","FRIDAY","SATURDAY"
-
-
content
:设置文字图标的内容,默认为空,仅在 type=8 时有效注意 content 输入下面特殊符号,需要用 URL 编码替代,否则导致解析参数失败或丢失
%
:%25
+
:%2B
#
:%23
使用
如果是在思源笔记内部使用(不用外部软件打开),可以直接用 api/icon/getDynamicIcon
后添加 type、color、lang、date/content 等参数,例如 api/icon/getDynamicIcon?color=red&type=7&lang=zh_CN
外部使用需要添加 ip 地址和端口,如 http://127.0.0.1:6806/api/icon/getDynamicIcon
示例
type=1:显示年月日星期
默认显示今天的日期。
可通过 date=2024-10-27
指定显示的日期
data:image/s3,"s3://crabby-images/00f65/00f65a5b0b3b284d1826a75059ff3883cf92ccab" alt=""
data:image/s3,"s3://crabby-images/81784/81784727f5be43a43e533df30fdf1a7180074680" alt=""
type=2:显示年月日
data:image/s3,"s3://crabby-images/8c771/8c7715338b95c36a2b44e921ccd6c8ac4c36077b" alt=""
data:image/s3,"s3://crabby-images/e987e/e987e6b25a75fc82b53a4dbdc60bfdcc46cc0ea0" alt=""
type=3:仅显示年月
data:image/s3,"s3://crabby-images/d893c/d893c3b252180b762687750d18235879ad4950df" alt=""
data:image/s3,"s3://crabby-images/8a885/8a885040c01dfa9d719729d0fc8fc1f7e6560df9" alt=""
type=4:仅显示年
data:image/s3,"s3://crabby-images/8b58b/8b58b1eeae91f2109d8f13e0170f9cd803e6457f" alt=""
type=5:当前周数
data:image/s3,"s3://crabby-images/d81c8/d81c89b78ff8e7dba0cab694a361f3ceece309ee" alt=""
data:image/s3,"s3://crabby-images/cf296/cf296a4b6c45c7cb2291c03abace79c33f184dd6" alt=""
type=6:仅返回星期
不输入 color 的话,默认星期一到星期五为红色,星期六和星期日为蓝色
data:image/s3,"s3://crabby-images/2c486/2c486566c98e79ec57ef7c9827d90bd3bd945731" alt=""
data:image/s3,"s3://crabby-images/12125/121258c3d62e223a7f23f5130e52544f36bbda77" alt=""
data:image/s3,"s3://crabby-images/a7ce7/a7ce7ece340fb59692e12055fc421ebc29850584" alt=""
data:image/s3,"s3://crabby-images/cf29d/cf29d12003731aac10fcf7046f703b943099a40e" alt=""
data:image/s3,"s3://crabby-images/4c3a2/4c3a2010ecfdf83e7a554d94d50d129c49f7e73b" alt=""
data:image/s3,"s3://crabby-images/9956a/9956a82ea91d0aa26e0b817dc832c62ab9802a72" alt=""
data:image/s3,"s3://crabby-images/917aa/917aab1807452557694944125d20c7cd67d7fc4a" alt=""
指定 color
data:image/s3,"s3://crabby-images/c7659/c7659cd66e32ddccaf39287999a5aac29192a5e8" alt=""
data:image/s3,"s3://crabby-images/d30ac/d30ac103954278be234791f9e5d4d373c76d808e" alt=""
data:image/s3,"s3://crabby-images/2f0ae/2f0aed85f4aba4a4b87e689a4e7651c828f7a054" alt=""
data:image/s3,"s3://crabby-images/02231/022319c030e0dc9237d4678b227e4ffc18d8ba50" alt=""
data:image/s3,"s3://crabby-images/4b333/4b333ef9d2033bcd124ad5451529ee20aa6dc4b7" alt=""
data:image/s3,"s3://crabby-images/03151/03151e4d6436079978c64778afe855df3836b0a5" alt=""
data:image/s3,"s3://crabby-images/d0702/d070283b841e0e64c3fb5c8f85f2b7755cf6d733" alt=""
type=7:倒数日
该图标会显示当前日期与指定日期之间的天数。
支持 lang=en_US
修改为英文:
已过
用Past
表示。还有
用Left
表示。
data:image/s3,"s3://crabby-images/216cb/216cb22ce50bb139fb3412c7c56dadec9a171169" alt=""
data:image/s3,"s3://crabby-images/80946/809462880a31afd7e996dd992f97cfff4c21ce6c" alt=""
data:image/s3,"s3://crabby-images/d20e4/d20e47367688bcbc83cc8707abd81589d51c551a" alt=""
data:image/s3,"s3://crabby-images/8f01d/8f01d68e8d258fe7fd5776e24d19243ebbb55c92" alt=""
data:image/s3,"s3://crabby-images/25f50/25f5041d312165bd8f4665490b77e8fb695187ea" alt=""
data:image/s3,"s3://crabby-images/367d1/367d1506b1b4ceb5b33eff4986303fe9bec405d5" alt=""
type=8:文字图标
该图标可以显示文字。
data:image/s3,"s3://crabby-images/d5c76/d5c76e3df72044d3ddf7c06b2d78820ff0bb8da4" alt=""
data:image/s3,"s3://crabby-images/1f7eb/1f7ebe1e08073b578d0d45eb613caf0c4eb9294f" alt=""
如何在 dailynote 模板中设置动态图标,创建 dailynote 自动添加图标?
v3.1.11 还不支持文档图标支持使用动态图标
之后等这个功能实现了,就可以在 dailynote 模板后面添加下面这段代码,应该就能让 dailynote 自动添加上指定的动态文档图标了。
.action{/* 获取今天日期和星期 */}
.action{$today := now | date "2006-01-02" }
.action{$weekday := now | date "Mon" }
.action{/* 工作日用红色图标,周末用蓝色图标 */}
.action{$color := "red"}
.action{if or (eq $weekday "Sat") (eq $weekday "Sun") }
.action{$color = "blue"}
.action{else}
.action{$color = "red"}
.action{end}
.action{/* 设置文档图标:选择type6,仅返回星期样式 */}
{: icon="api/icon/getDynamicIcon?type=6&date=.action{$today}&color=.action{$color}" type="doc"}
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于