-
Notifications
You must be signed in to change notification settings - Fork 24
Specs handling text direction
r12a edited this page Jul 29, 2016
·
25 revisions
- this is JSON
- basic object sent as single item
- structured objects
- only some strings are natural language
- includes a mechanism for localised text
- name property has no markup
- summary and content properties do support HTML markup
- an object can contains several natural language strings, which may have different base directions
- either a summaryMap should become several objects, or FS will need to be used
- the name property admits no markup, so control codes need to be used - otherwise, use markup for inline changes
for the name property (no markup allowed) add control codes at start and end of value for overall base direction and inline control codes for inline changes
Example 133
{
"@context": {
"@value": "http://www.w3.org/ns/activitystreams",
"@language": "he"
},
"name": "\u202Bפעילות הבינאום, W3C\u202C",
"type": "Note",
"summary": "<span dir="rtl">פעילות הבינאום, W3C</span>"
}
for summary and content properties, use markup with dir attributes to establish overall base direction and inline changes
Example 134
{
"@context": {
"@value": "http://www.w3.org/ns/activitystreams",
"@language": "he"
},
"name": "\u202Bפעילות הבינאום, W3C\u202C",
"type": "Note",
"summaryMap": {
"he": "<span dir="rtl">פעילות הבינאום, W3C</span>",
"en": "Internationalization Activity, W3C",
"ar": "<span dir="rtl">نشاط التدويل، W3C</span>"
}
}
- can't expect Arabic/Hebrew/Divehi/Urdu/Persian/etc users to add control characters or markup for default direction for every natural language string
- if name has multiple lines, or summary/content have multiple paragraphs, each line/paragraph needs to be annotated with directional information
- users are expected to use different approaches for notes vs summary/content, which is confusing (and must be correctly done, eg. no control codes before
<p>
, no control codes inside inline markup, etc.) - all the usual problems with control codes (eg. difficult to use, may not be available on keyboard, even harder to edit, etc.)
- specify that the default is LTR
- use one property per object to establish the base direction for RTL text
- user only needs to revert to control codes/markup for exceptional text
- if property value says auto, does FS analysis, which may reduce the need for user intervention even further
- setting a property is possibly more helpful when dealing with input from HTML forms, etc, where the direction information is carried separately from the text (dirname)
Example 133
{
"@context": {
"@value": "http://www.w3.org/ns/activitystreams",
"@language": "he"
},
"direction": "rtl"
"name": "פעילות הבינאום, W3C",
"type": "Note",
"summary": "פעילות הבינאום, W3C"
}
Example 134
{
"@context": {
"@value": "http://www.w3.org/ns/activitystreams",
"@language": "he"
},
"direction": "rtl"
"nameMap": {
"he": "פעילות הבינאום, W3C",
"en": "Internationalization Activity, W3C",
"ar": "نشاط التدويل، W3C"
}
"type": "Note",
"summaryMap": {
"he": "פעילות הבינאום, W3C",
"en": "Internationalization Activity, W3C",
"ar": "نشاط التدويل، W3C"
}
}