-
Notifications
You must be signed in to change notification settings - Fork 28
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Talks with non-Latin titles generate empty slugs #479
Comments
Crashing on an empty slug is something we should fix. We also should do something better with unicode talk titles. I'm not sure what the best approach is though. People can add arbitrary unicode characters in the talk title anyway, so I don't think transliterate is a good solution here, given it's design goals. We could use django.text.utls allow_unicode option and create urls with unicode characters - that should work, although the percent-encoded url isn't going to be particularly readable Something more like text-unidecode is an alternative, which will produce more ascii friendly urls, although that will also produce not particularly meaningful character strings for many languages. |
Why do you think transliteration isn’t a good solution? A lot of CMS do exactly that. |
I mean that the "transliterate" module isn't a good solution (https://pypi.org/project/transliterate/) - it supports a very limited set of languages, requires knowing the language of the title ahead of time to get good results and doesn't support arbitary non-language unicode characters sensibly. Nothing prevents someone from creating a talk titled "♠♡♢", for example, and we need to handle that with whatever solution we come up with. |
Well, you need to know the language to get good results since languages
with same alphabets often have different rules of transliteration. E.g. my
first name transliterated from Russian is Andrey but it's Andrej if
transliterated from Belarusian.
But maybe potentially bad transliteration is better than none. I don't
know, I'm not sure.
|
What if we added a hook so that each site could override the slug function
if needed? There could be a set of default functions based on site language.
|
Talks now have a language attribute. We could transliterate from that language. |
When I create a talk with a non-Latin title, for example
Тестовый доклад
, the generated slug is an empty string, which prevents the user submitting the talk from saving it:You may want to use e.g.
transliterate
module to transliterate the title for the purpose of generating the slug.Alternatively the pattern can be modified to allow an empty slug.
The text was updated successfully, but these errors were encountered: