github-readme-stats
github-readme-stats copied to clipboard
fix: Fix multiline text wrapping for foreign languages
Thank you for this project! I found a problem with wrapping text in the repo card and decided to fix it. The problem is that foreign language text is not wrapped properly because it's first encodes in HTML, and because of it certain foreign characters increases the line length, and it's not wrappes properly. See the PR code for more info. Sorry for my JavaScript ;)
Before:
After:
@ZhymabekRoman is attempting to deploy a commit to the github readme stats Team on Vercel.
A member of the Team first needs to authorize it.
@rickstaa wasn't this already fixed with a PR? Or am I mistaken?
@rickstaa wasn't this already fixed with a PR? Or am I mistaken?
Do you mean https://github.com/anuraghazra/github-readme-stats/pull/206? If I understand it correctly, this PR fixes problems people encounter when the description is not written in English. 🤔
Not sure about other languages, but with russian its broken. For example: https://github-readme-stats.vercel.app/api/pin/?username=TTATPuOT&repo=cdek-sdk2.0
Its split into three lines but can fit at one. So, please, marge it PR if possible.
@rickstaa, is there an update?
@rickstaa, is there an update?
Sorry, I didn't have time yet to review this. If you could send me multiple examples of languages and repos where the problem exists, that would make it easier to study since I need more examples to understand the situation in depth 👍🏻. You can put them like so:
[data:image/s3,"s3://crabby-images/aab92/aab92bd1caba7d70c45b35b12a31e9c1419079da" alt="Readme Card"](https://github.com/anuraghazra/github-readme-stats)
I collected more examples. Sometimes, text not splits into multiline, but overflow of image (chinese, korean).
Russian:
https://github-readme-stats.vercel.app/api/pin/?username=TTATPuOT&repo=cdek-sdk2.0
Chinese:
https://github-readme-stats.vercel.app/api/pin/?username=modood&repo=Administrative-divisions-of-China
Japanese:
https://github-readme-stats.vercel.app/api/pin/?username=oreilly-japan&repo=deep-learning-from-scratch
Arab:
https://github-readme-stats.vercel.app/api/pin/?username=Hussain-Alsalman&repo=Arabian_Analyst_Blog
Ukrainian:
https://github-readme-stats.vercel.app/api/pin/?username=reactjs&repo=uk.react.dev
Hindi:
https://github-readme-stats.vercel.app/api/pin/?username=gopalindians&repo=awesome-hinduism
Korean:
https://github-readme-stats.vercel.app/api/pin/?username=ClintJang&repo=awesome-swift-korean-lecture
After this fix:
Russian (Correct)
data:image/s3,"s3://crabby-images/8dd59/8dd59e41bb50d3a8058301838af9bf27d611d588" alt="Card"
Another Russian (My own repo with big description) (Overflow problem)
Before:
After:
data:image/s3,"s3://crabby-images/5cff3/5cff37946c17dadd61ec15cf5ff314a022b3331b" alt="Card"
Chinese (Overflow problem)
data:image/s3,"s3://crabby-images/1f44f/1f44f122b1d929574020364240b876fcec6732a1" alt="Card"
Arab (Correct)
data:image/s3,"s3://crabby-images/60031/600318e93bb5fae9610a2cf6850b391dbd4d524f" alt="Card"
Ukrainian (Correct)
data:image/s3,"s3://crabby-images/87eb4/87eb407e006ec01abb8bc6bca7c5cfc4aa1d98c6" alt="Card"
Hindi (Correct)
data:image/s3,"s3://crabby-images/01a8c/01a8ce5efc30763c7a1df2b6144156d710deadd9" alt="Card"
Korean (Overflow problem (???)):
data:image/s3,"s3://crabby-images/43c64/43c64e1313517183f721478cc4385cf7c6fcbc6b" alt="Card"
@ZhymabekRoman and @TTATPuOT, thanks for the examples. When the overflow problem is fixed, we can merge this pull request 👍🏻.
To fix the overflow, I have only two ideas:
- Somehow calculate the maximum line width of the text and reduce the char length. But how do we know that a text line is overflowing?
- Manually set max line char by user in
text_width
property. I have some implementation of this in custom branch:
[SimMarketBot](https://github-readme-stats-git-dev2-zhymabekroman.vercel.app/api/pin/?username=ZhymabekRoman&repo=SimMarketBot&text_width=54)
I found some libraries to calculate text width
- https://github.com/schickling/calculate-size - Only for browser environment
import calculateSize from "calculate-size";
export function getTextWidth(text) {
const size = calculateSize(text, {
font: '"Montserrat", sans-serif',
fontSize: "14px"
});
return size.width;
}
- https://github.com/adambisek/string-pixel-width - doesn't require a browser, can be run in backend. Need to add custom fonts to library. May produce non-perceptible results.
- https://github.com/Evgenus/js-server-text-width - doesn't require a browser, can be run in backend. Need to add custom fonts to library. May produce non-perceptible results.
I found some libraries to calculate text width
- https://github.com/schickling/calculate-size - Only browser for environment
import calculateSize from "calculate-size"; export function getTextWidth(text) { const size = calculateSize(text, { font: '"Montserrat", sans-serif', fontSize: "14px" }); return size.width; }
- https://github.com/adambisek/string-pixel-width - doesn't require a browser, can be run in backend. Need to add custom fonts to library. May produce non-perceptible results.
- https://github.com/Evgenus/js-server-text-width - doesn't require a browser, can be run in backend. Need to add custom fonts to library. May produce non-perceptible results.
@ZhymabekRoman, thanks for looking into this! We already have a function that calculates the text width to adjust the card to the title length. I didn't write this code but since we have yet to offer a way to set different fonts, it might already be sufficient.
https://github.com/anuraghazra/github-readme-stats/blob/0d74d5a25d7e522a7aa50a54863e9b2833290f5e/src/common/utils.js#L357-L389
As alternative way we can use some JS code to properly wrap text since SVG specification officially doesn't support text wrapping: https://codepen.io/techniq/pen/MeNoQQ
As alternative way we can use some JS code to properly wrap text since SVG specification officially doesn't support text wrapping: https://codepen.io/techniq/pen/MeNoQQ
Looks good!