logseqadvancedquerybuilder

An Experimental online tool to help Logseq Users build advanced queries from simple commands.

News Flash 3rd March 2023 Logseq plugin (logseq-query-builder-plugin) now officially in the Logseq Marketplace

News Flash 30th Dec 2022 Logseq plugin with same functionality now developed. You can get it here and see it in action here

Updated 14th Dec 2022 to v0.4 see Releases section below SITE HAS BEEN COMPLETELY REWRITTEN IN JAVASCRIPT FOR STABILITY

You can run this tool online at https://adxsoft.github.io/logseqadvancedquerybuilder/

To include this tool in a logseq page use this line

<iframe src="https://adxsoft.github.io/logseqadvancedquerybuilder/" allow="clipboard-read; clipboard-write" style="width: 100%; height: 1000px"></iframe>

See the FAQ for instructions and examples of how to use the tool

Also see https://github.com/adxsoft/buildlogseqtestgraph for building a test graph to checkout the advanced queries you build with this tool

Technical information

The tool is built in javascript.

To test locally set the mode variable to 'local'. Once this is set you can use Jest Testing Library with the included index.tests.js file.

To deploy to the web set the mode to 'website'

  1. To input a set of simple commands to generate an advanced query, add the following code at the end of logseqquerybuilder.py
testQueryBuild("""yourcommands""")

Where yourcommands could be for example

testQueryBuild("""title: blocktags and pages command combined - test 3
- pages
    - test*
    - *2
    - not *age1
- blocktags
    - tag1
    - not tag2
    - tag3
    - not tag4
""")

which will print the following advanced query that you can copy and paste (using Cmd/Ctrl Shift V) directly into Logseq

#+BEGIN_QUERY
{
:title [:b "blocktags and pages command combined - test 3"]
:query [:find (pull ?block [*])
:where
[?block :block/content ?blockcontent]
[?block :block/page ?page]
[?page :block/name ?pagename]
( or 
[(clojure.string/starts-with? ?pagename "test")]
[(clojure.string/ends-with? ?pagename "2")]
)
(not [(clojure.string/ends-with? ?pagename "age1")])
( or 
(page-ref ?block "tag1")
(page-ref ?block "tag3")
)
(not (page-ref ?block "tag2"))
(not (page-ref ?block "tag4"))
]
}
#+END_QUERY
  1. To run the unit tests you must do step 1 above and then run test.py

Releases

Version 0.1

  • Original release Oct 2022

Version 0.2

  • clarify pages retrieval vs blocks retrieval in FAQ, Simple Commands
  • Added 'and' and 'or' keywords in arguments for a command, For example can now say
- tagA
- or tagA

and also

- property category, "fiction"
- and property category, "western"
  • Added a logseq test graph download button to help user test advanced queries
  • Force user to choose either pages or block retrieval, Default to block retrieval
  • improved error messaging
  • improved descriptions for the generated advanced query lines
  • bug fixes

Version 0.3 Dec 8th 2022

  • added the pagelinks command which will select blocks that have links to specific pages or journals

Example: To select blocks referring to page1 OR page 2

- blocks
  - *
- pagelinks
  - page1
  - page2

Example: To select blocks referring to page1 AND page 2

- blocks
  - *
- pagelinks
  - page1
  - and page2

Example: To select blocks referring to Xmas day journal (assumes your date format is the default format)

- blocks
  - *
- pagelinks
  - Dec 25th, 2022

If you use a different date format use that in the journal reference

Version 0.4 Dec 14th 2022 Redeveloped in Javascript for speed and stability

  • pyscript is still in alpha and early days so changes are happening all the time
  • javascript is stable
  • code base has been changed so that the core functions can operate in one of three ways (mode variable controls which operation is chosen website,local,logseq-plugin
    • as this website,
    • locally for testing
    • as a logseq plugin (distributed to a separate repository)