Personalization Semantics Explainer 1.0

W3C Working Draft

This version:
https://www.w3.org/TR/2020/WD-personalization-semantics-1.0-20200127/
Latest published version:
https://www.w3.org/TR/personalization-semantics-1.0/
Latest editor's draft:
https://w3c.github.io/personalization-semantics/
Previous version:
https://www.w3.org/TR/2019/WD-personalization-semantics-1.0-20190711/
Editors:
(Benetech)
(W3C)
(W3C)
Richard Schwerdtfeger (Knowbility) (Editor until October 2017)

Abstract

Personalization involves tailoring aspects of the user experience to meet the needs and preferences of the individual user. For example, having familiar terms and symbols is key to many users being able to use the web. However, what is familiar for one user may not be familiar to another, requiring them to learn new symbols. The challenge has been the ability to identify the types of content in a document that should be adapted to the preferred user experience. The introduction of standardized semantics allows web applications to customize the presentation of that content to one that is familiar to individuals based on their specific needs and preferences. This specification defines standard semantics to enable user driven personalization. For example, the association of user-preferred symbols with elements having those semantics. This ensures that users can quickly find familiar icons, for example, a help icon, within the context of user interface elements.

This document is an explanation for understanding how to use Personalization properties to personalize an accessible web site.

Status of This Document

This section describes the status of this document at the time of its publication. Other documents may supersede this document. A list of current W3C publications and the latest revision of this technical report can be found in the W3C technical reports index at https://www.w3.org/TR/.

This document was published by the Accessible Platform Architectures Working Group as a Working Draft.

This is a Working Draft of Personalization Semantics Explainer 1.0 by the Accessible Platform Architectures Working Group. This specification changes from the previous version to introduce personalization semantics modules. This explainer introduces standard semantics to enable user-driven personalization, such as the association of a user-preferred symbols to elements having those semantics. The modules define features for specific categories of personalization, including Adaptable Content, Adaptable Help and Support and Adaptable Tools. This version has accepted the name and values of all attributes for the Content module and this document will support content module to Wide Review.

To comment, file an issue in the W3C personalization semantics GitHub repository. If this is not feasible, send email to public-personalization-tf@w3.org (archives). Comments are requested by 10 March 2020. In-progress updates to the document may be viewed in the publicly visible editors' draft.

Publication as a Working Draft does not imply endorsement by the W3C Membership. This is a draft document and may be updated, replaced or obsoleted by other documents at any time. It is inappropriate to cite this document as other than work in progress.

This document was produced by a group operating under the W3C Patent Policy. The group does not expect this document to become a W3C Recommendation. W3C maintains a public list of any patent disclosures made in connection with the deliverables of the group; that page also includes instructions for disclosing a patent. An individual who has actual knowledge of a patent which the individual believes contains Essential Claim(s) must disclose the information in accordance with section 6 of the W3C Patent Policy.

This document is governed by the 1 March 2019 W3C Process Document.

1. Introduction

This section is non-normative.

The goals of this specification include:

This is a proposal for defining syntax for adaptable content such as: links, buttons, symbols, help and keyboard. The proposed syntax will start by using the data-* mechanism provided by HTML5.

Technology holds the promise of being extremely flexible and the design of many systems includes the expectation that users will be able to optimize their interaction experience according to their personal preferences or accessibility needs.

1.1 Why We Need Personalization

We need personalization because:

Some users need extra support. This can include:

To achieve this, we need standardized terms and supportive syntax. These can be linked to associated symbols, terms, translations and explanations. They are then provided to an individual based on personal preferences.

1.2 Use Cases

Requirements for Personalization Semantics elaborates many use cases that further contextualize the above summary of user needs. These use cases form the basis of requirements for this technology.

Examples include:

Assuming an author can make it programmatically known that a button sends an email, and based on user preference settings:

In addition, the button could be identified as important and always rendered or rendered in an emphasized form.

Another use-case is the use of Symbols. Some users might have a severe speech and/or physical impairment and communicate using symbols, rather than written text, as part of an Augmentative and Alternative Communication (AAC) system. The use of symbols to represent words is their primary means of communication for both consuming and producing information.

Symbol users face a wide variety of barriers to accessing web content, but one of the main challenges is a lack of standard interoperability between different symbol-sets, or a mechanism for translating how a concept is represented in one symbol-set to how it may be represented in another symbol-set.

It should be noted that users who depend on symbols for daily communication needs often also struggle the most with mistranslations, as they have severe language disabilities. Inferring what was meant by using an incorrect symbol will not be achievable for many users. This rules out relying on machine learning until it is almost error free.

In another use-case, a user has dyscalculia and has difficulty understanding numbers. They struggle with understanding websites that use numbers to convey information. For this reason, the numeric information must also be provided in an alternative format that the user can understand.

It is important to note that people with dyscalculia are often very good with words, so long text can be better than short numbers.

Finally, consider someone with autistic spectrum disorder and with a learning disability. They may be a slow reader but find numbers clear and precise. They may go to the same website and find all the word and images unclear and the animations cause cognitive overload. They want the same information with more numbers and less words.

More examples can be found on Use-cases Wiki page.

More information on persona and user needs can be found in Coga usable document.

1.3 Out of Scope

While the intention of this work is to introduce a new set of attributes to support Personalization, the following work items are out of scope:

We encourage a the development of these items and a list of implementations can be found on our wiki.

1.4 Technology Comparison Summary

The task force reviewed various vocabulary options before deciding upon the use of the data- HTML attribute syntax. The list of technologies included:

The details of our research and discussion is documented on the Comparison of ways to use vocabulary in content and Prototypes with data dash pages in our Wiki.

We presented some of these options at the TPAC 2018 Personalization Plenary Day presentation and provided a working example using the data- attribute to add personalization features. The data- solution was recommended by representatives of several working groups attending our presentation and discussions. See the Vocabulary Implementations section in the Explainer document for further details on the use of data- attributes.

2. Modules

This section is non-normative.

This specification has been divided into modules.

Each module has use cases and vocabularies:

3. Vocabulary Structure

This section is non-normative.

Personalization Semantics is made of a vocabulary of properties and their values. This generic structure makes it possible to apply Personalization Semantics in a variety of contexts by adapting how the vocabulary is instantiated. The Vocabulary Implementations section below describes current ways to use the vocabulary.

3.1 Properties

Properties are the main units of personalization types supported by the vocabulary. A given property supports a specific type of personalization. That property would only be used once on a given piece of content, but multiple different properties could be used on the same piece of content to address different needs.

3.2 Values

Values provide the specific personalization information for the property. The possible values for each property are elaborated in the definition of the property in the modules. Some properties require the value to come from a predefined list of possible values, others can accept arbitrary strings, and some may accept multiple values. The value may be one of the following types:

true/false
Value representing either true or false, with a default "false" value.
true/false/undefined
Value representing true or false, with a default "undefined" value indicating the state or property is not relevant.
ID reference
Reference to the ID of another element in the same document
ID reference list
A list of one or more ID references.
integer
A numerical value without a fractional component.
number
Any real numerical value.
string
Unconstrained value type.
token
One of a limited set of allowed values.
token list
A list of one or more tokens.
URI
A Uniform Resource Identifier as defined by RFC 3986 [RFC3986]. It may reference a separate document, or a content fragment identifier in a separate document, or a content fragment identifier within the same document.

4. Vocabulary Implementations

This section is non-normative.

At the present stage of development, the Personalization Semantics vocabulary can be used in HTML content using data- attributes [html5]. Attributes in this form can be used in valid HTML to implement features recognized by browser extensions or other special processors. Personalization Semantics is using this approach to gain early implementation experience of the features in a way that is simple and likely to be accepted within the web ecosystem as an interim approach.

For this publication of Personalization Semantics, the task force has accepted the name and values for the Content module.

Other properties in the vocabulary published here are not yet mature enough to suggest using them in production HTML with data- attributes. Examples of those properties in the modules are published to facilitate review and indicate our development direction, not to suggest implementation at this time. See the discussion Prototypes with data dash.

Note

The HTML data- attribute syntax is not intended to be used for long-term wide-scale features. The task force is using this approach at the moment to gain implementation experience and demonstrate the usefulness of Personalization Semantics in practice. Content authors and user agent implementers should be aware that the recommended approach to use the vocabulary is expected to change, and structure their implementation in a manner that will facilitate the transition to a new syntax.

5. Stakeholders

This section is non-normative.

This document is useful for:

For early implementations of content we suggest including a link to an extension an implementation that can maximize the benefit for users.

A. A. Change Log

This section is non-normative.

The full commit history to personalization semantics is available.

A.1 A.1 Significant editorial changes since the First Public Working Draft

B. Acknowledgments

This section is non-normative.

The following people contributed to the development of this document.

B.1 Participants active in the Personalization TF at the time of publication

B.2 Other Personalization TF contributors, commenters, and previously active participants

B.3 Enabling funders

This publication has been funded in part with U.S. Federal funds from the Health and Human Services, National Institute on Disability, Independent Living, and Rehabilitation Research (NIDILRR) under contract number HHSP23301500054C. The content of this publication does not necessarily reflect the views or policies of the U.S. Department of Health and Human Services, nor does mention of trade names, commercial products, or organizations imply endorsement by the U.S. Government. Some of the work on this project has also received funding from the European Union’s Horizon 2020 research and innovation programme under grant agreement No.780529 and 643399.

C. References

C.1 Informative references

[html5]
HTML5. Ian Hickson; Robin Berjon; Steve Faulkner; Travis Leithead; Erika Doyle Navara; Theresa O'Connor; Silvia Pfeiffer. W3C. 27 March 2018. W3C Recommendation. URL: https://www.w3.org/TR/html5/
[RFC3986]
Uniform Resource Identifier (URI): Generic Syntax. T. Berners-Lee; R. Fielding; L. Masinter. IETF. January 2005. Internet Standard. URL: https://tools.ietf.org/html/rfc3986