How do I set the text color for individual blocks? Or even subsets of words? Is that even possible right now?
I don’t want to highlight the text. I want to customize the actual text color itself. Like I want to be able to be able to decide on the fly that <font color="red">this text should be red</font> or for a different line, <font color="#fcb103">this text color should be set by the hex code</font>. That kind of thing.
Edit: The only problem is that it stops working if I have to type a comma anywhere in the text. I tried putting the text in quotation marks, and that allows it to continue past the comma, but I don’t particularly want the quotation marks to show up.
Just tried this edit after typing out the example, and it looks like it’s fixed it! Thanks again!
Edit: Err, actually, this one works unless I want the text to contain quotation marks. I can get by with using single ones, I guess, but if I want to include quotation marks, it doesn’t process it as a macro.
I also have to put the whole text in quotation marks this way, or it removes all the…spaces? I don’t know what’s going on @mentaloid
But now also the entire thing needs to be written in quotation marks? So, for example, in my block, I have to type: {{light-yellow "Here is the text."}} instead of {{light-yellow Here is the text.}} like I was doing before?
I can’t tag things within the required quotes, though. It doesn’t process them as block links. I can’t make words italic or bold, either.
Is there a way to go back to the original solution and just fix the comma thing? That was working a lot better, with that one really significant exception. Is there some other way to escape the comma? The forward slash doesn’t work to do it, but is there some other way? (If there’s some resource where I can read about the type of syntax that does or doesn’t work in these contexts, I’m happy to do some reading on it. I’m just completely unfamiliar with the implementation of “macros” here.)
Multiple macros or even the same macro can be applied multiple times for different parts of a block. Leave the special parts outside the macros (e.g. for tags) or even define their own macros (e.g. for colored text that is also italic and/or bold). If you have a specific example, could provide specific code.
Basically I want a block to function totally like it normally does, just with the text in something other than the default color.
I want to be able to write a paragraph like:
Today I went out for a walk. I ran into my friend and he was telling me about this “novel” idea he had invented, but it was just peanut butter and jelly sandwiches. Can you believe that? [[Joe]] is such a doofus.
But have it in, say, blue. Or red. Or yellow. I want the commas to render and the quotation marks to render and the italics to render and the block link to work.
I’m fine with having the whole block in one color. I don’t need to be able to change the color in the middle of the block (though that would also be fine). I just want to be able to set the color of the text for a block without changing anything else about how the block functions.
Hello, thanks for this solution so far. Do you have any idea, why my block always has some line break after the color-changed words?
Some colors do work normal, but especially after red text there’s always a line break (doesn’t matter if I use the solution in :macros {} or just write the span-command in my text)…
these are my words in the block
{{red "this is a test"}} for line break
this is what I wrote in :macros {}
:red "[:span {:style \"color: red\"} $1]"
and this is what it almost always looks like
Long question short: How can I avoid the line break while changing the color of my text (usually only a few words of the block)
Such approaches don’t scale very well. I would rather use a logseq.css-class:: property that applies the passed class(es) to the block’s element, enabling users to style any block however they want.
I think both things are compatible, but just because I think that text-color is as important as the already existing background-color property. Nevertheless, It is true that adding more than a couple of properties would not hold up in the long term…
If/when my proposal is merged, I’ll make another one adding logseq.css-class::
is it possible to do it in bulk for all the children blocks of a specific block?
and after we color them, is it possible to search for them using query or any other methods?
And generally we want to consider all the blocks, not only the currently rendered ones.
But could search for the string (relatively slow) of the macro of the parent, e.g.:
"{{colored-block #d9d898}}"
"{{light-yellow-block}}"
Then can return either:
the children
the parent with its children
This is a file inside folder logseq of each graph (unless modified in file config.edn of the same folder). If it is not there, simply create it as a text-file with that exact name.