espanso / espanso

Cross-platform Text Expander written in Rust
https://espanso.org
GNU General Public License v3.0
9.85k stars 271 forks source link

Text and image #676

Closed Duckbilled closed 3 years ago

Duckbilled commented 3 years ago

Is it possible to have a result where I both get a string of text and an image? For example:

Best regards, path/to/signature.png

federico-terzi commented 3 years ago

Hey @Duckbilled,

Is it possible to have a result where I both get a string of text and an image?

In theory, it can be done with the Rich text feature (available since version 0.7.3), but from my own testing, not every application accepts it.

Firstly, you will need to get the DATA URL for your image, for example using this website: https://ezgif.com/image-to-datauri

Then, with a little bit of HTML magic:

  - trigger: ":sig"
    html: |
      <p>Best regards, </p>
      <img src="" alt="" />

I can do:

rich_image

Let me know if that helps

Cheers :)

thewilli commented 2 years ago

@federico-terzi is there any documentation about the html configuration? Something maybe as simple as a JSON Schema to understand all the possibilities like the one mentioned here (and have editor support) while the docs are being updates for v2?

federico-terzi commented 2 years ago

@thewilli The html property is actually pretty dumb :) Espanso just sends the HTML you specified to the target application (such as Word, Google Docs, etc), without doing any particular processing on it. It's the target application that decides how to interpret the HTML. For that reason, some HTML replacements might work on some applications but not with others. Hope that helps :)

PS: The docs for the v2 are 95% complete, today I made the v2 the stable version :) Docs can be found at https://espanso.org/docs/get-started/

thewilli commented 2 years ago

@federico-terzi is there any place in the documentation where I can find a summary of all possible match scenarios?

I'd like to create a JSON Schema for it, so I get syntax completion and validation in VSCode and Neovim, when working on the match definition YAML files - for example suggest the different options for uppercase_style and give a short overview on what the options mean when writing the configuration.

Would you be interested in including this file in this repository once it's finished? IMO it would serve as a technical documentation as well.

federico-terzi commented 2 years ago

Hey @thewilli,

Thanks for the feedback! Currently, there is no exhaustive documentation for the possible match options, but I definitely agree that having a Schema for it would be very useful. For now, your best bet is to read the matches docs and the source code

Cheers :)

smeech commented 5 months ago

For future reference, the syntax I found to work is:

  - trigger: image2
    html: |
      some text
      <img src="file:///path/to/image.png">
      some more text

  - trigger: :image1
    markdown: |
      some text
      ![](file:///path/to/image.png)
      some more text