Web 2.0 Mashup Accessibility CSUN 2008 IBM Software Group Rich Schwerdtfeger

advertisement
®
IBM Software Group
Web 2.0 Mashup Accessibility
CSUN 2008
Rich Schwerdtfeger
IBM Distinguished Engineer
Peter Parente
Software Engineer
Emerging Technologies
© 2007 IBM Corporation
IBM Software Group
Agenda
 State of Web 2.0 Accessibility
 Quick look WAI-ARIA
 Introduction to the Programmable Web and Mashups
 IBM Mashup Accessibility Analysis
 Short Term Solutions
 Long Term: Flexible, Personalized Web
IBM Software Group
State of Accessibility for Web 2.0
 Tremendous progress on Web 2.0 Application accessibility
 IBM led W3C Accessible Rich Internet Applications (WAI-ARIA)
 Reusable, Accessible RIAs springing up: (Dojo AJAX Toolkit, JQuery)
 IAccessible2, Gnome ATK/ATSPI Allows ATs full access to RIAs through the
browser
 AccProbe Test Tool, (Firefox, Opera, IE) browser support under way
 ATV support: Window-Eyes, JAWS, ZoomText, Orca, NVDA
 WAI ARIA – Allows for
 Full interoperability with ATs
 Keyboard usability of the desktop
 Semantics for content adaptation
 Accessibility of all applications has its limitations
 One size fits all
 Great if you control all the content/code
 The web is becoming programmable and distributed
IBM Software Group
Quick Look at WAI-ARIA
 Extends and fills gaps in (X)HTML to support accessibility
 Uses Meta data found in Rich Desktop Applications to provide for full
interoperability with assistive technologies
 Role, state, property information for widgets
 Identify Drag and Drop information
 Defines relationships between UI components
 Provides information to handle live regions
 Provides navigational landmarks
 Allows Web authors to provide desktop keyboard navigation
 Tab to significant areas and arrow within the widget
 All HTML keyboard accessible
 Allows all items to be focusable without impacting the tab order
 Is cross-cutting and helps all users
IBM Software Group
The programmable web
• Companies making Web 2.0
API public as a service API
– Fragments, data, reusable
widgets
– programmableweb.com
> 660 APIs
• RSS and Atom Data Feeds
made public
• Opportunity for rapid Web 2.0
application development
*RSS – Real Simple Syndication
IBM Software Group
What is a Mashup?
 A mashup is a web application combining data or capabilities from more
than one source into an integrated experience
 Popular on the consumer web - over 3.45 new mashups/day are appearing:
Pageflakes.com
Zillow
SeatSnapper
 What typically characterizes a mashup?
Lightweight integration of applications (enables rapid development)
 “Widgets” that make up a mashup are often developed and deployed independently without
knowledge of each other
 Widgets can be mashed and wired together in the browser
Utilize web technologies like HTTP, **JSON, XML, JavaScript, Atom, RSS
Often incorporates one or more public API and online services
Often, mashups can be customized by the end user
**JSON – JavaScript Object Notaton
IBM Software Group
What is a Widget?
 A widget is a portable chunk of code that can run
in any web application without requiring separate
compilation
 How is a widget different than a portlet?
 Widgets are URL addressable fragments and can be
written in any language (Java, .NET, PHP, etc.).
Portlets are Java code.
 Widgets can be as simple as an HTML fragment, so
they don’t have to involve any server side code (but
they can).
 Simplicity of model enables developers to learn how
to create widgets in a matter of hours versus days.
 Widgets don’t have a complex packaging structure or
require a complex deployment model.
 >> A simple “hello world” widget can be written in a
tool like Dreamweaver, and the file can copied into the
file structure on the server. A “hello world” portlet
would require a Java-based tool and also consists of
multiple files, packaging, and deployment.
 No widget standards and many vendors have created their own names: gadgets, blocks, flakes, etc.
IBM Software Group
Mashups are Catching on in the Enterprise, But Why?
 Lightweight integration enables rapid development and lowers skill set
requirements
Enables the creation of applications that were previously too costly to build (like situational
applications)
Extends web app development beyond IT – out to even knowledge workers
Reduces IT backlog
 Availability of many widgets and gadgets allows organizations to assemble
applications at a lower cost
 Once a component is developed, it can be easily reused across different
applications, regardless of the underlying technology
.NET and J2EE and PHP widgets can communicate together on a page
.NET + PHP widgets can be mashed into a J2EE-based app (and vice versa)
 Wire up for interoperability
Gartner: By 2010, more than 30% of Global 2000 organizations will enter a new
era of end-user computing via user-assembled, composite applications created
with enterprise mashup environments.
IBM Software Group
Examples of Enterprise Mashups
Competition Tracker / Web Site
Data Center Administrator Mashup
Sales – Customer Trip Prep
Collaborative Web App for Project Teams
IBM Software Group
Mashup Example
IBM Software Group
Accessibility/Usability Wild Wild West - issues from content
aggregation are extensive
 Is the resource accessible?
 Will the accessible resource meet my needs (WAI-ARIA is new)?
 Can the resource be adapted to fit my needs?
 If the resource cannot meet my needs is there an equivalent alternative?
 Will the Mashup have consistent keyboard support?
 Is the end solution too cluttered to assist all users?
 Will restructuring the mashup produce a more usable solution?
IBM Software Group
Accessibility Study QED Wiki
 No Accessibility Assessment of Data Feeds (RSS/Atom)
 Keyboard problems
 Conflicting accelerator keys, tab ordering, IDs, etc.
 Content from a remote service traps input focus
 Dynamic content inappropriately grabs focus
 Inaccessible services
 No WAI-ARIA support
 No keyboard support
 Fixed sizes, styles, and layout (Can’t respond to system settings –font/color)
 Interaction inconsistencies
 Different defaults
 Different paradigms
 Disrespect for local user settings
 Invisible relationships
 Missing status indicators for widgets
 Missing controller-controlled by relations among widgets
 Drag/Drop Layout construction problems
IBM Software Group
Near term solutions
 Mashup runtime environment must take responsibility for exposing relations
among widgets.
 Use WAI-ARIA relationships (controls, flowto, labelledby)
 Use WAI-ARIA to mark regional landmarks (main, secondary, contentinfo, etc.)
 Mashup runtime should attempt to repair any problems it can.
 Compute a global tab ordering by inspecting explicit tabindex in widgets.
 Fix overlapping IDs. (Store Widgets in IFrames where possible)
 Override widget styling.
 Mashup designer tooling must support creation of accessible mashups.
 Provide reusable accessible widgets when available
 Prompt user for WAI-ARIA information when possible
 Ultimately, must address the accessibility of the original widget content.
 Services providers must adopt WAI-ARIA
IBM Software Group
Near Term solutions for Mashup construction
 Layout grid templates for widgets
 Allows all users to use keyboard to navigate pre-designed template
 Use WAI-ARIA to apply keyboard navigation/semantics to the grid
 Provide accessible utilities to wire up widgets
 Ensure mashup UI consists of accessible WAI-ARIA enabled
components (Dojo Toolkit)
IBM Software Group
Aggregation issues expose bigger problems which also
create business opportunity

One size fits all approach

Usable access may require equivalent alternatives

Content Aggregators: Unaware if a resource is accessible (Web 2.0 mashups)
IBM Software Group
Problems with one-size fits all

Learning disabilities needs vary greatly
 Managing content density, highlighting specific text, providing different color schemes, use of
symbols, etc.

Complex visualizations may require equivalent alternatives for blind consumers

Use of closed captioning or transcripts depends on the language spoken by the
consumer

Restructuring content may benefit mobility impaired user

Does not adapt to the environment the user is operating in
 High background noise, low light, temporary mobility impairment, etc.
IBM Software Group
Basis for the solution resides in the learning space

IMS Access For All Specifications
(Version 2 under development now)

ISO JTC1 SC36 Standard nearly final
http://www.imsglobal.org/accessibility
*DC –
**LOM – Learning Object Metadata
IBM Software Group
Access for All Standards
 A description of the user’s personal needs and preferences (*ACCLIP)
 A description of a digital resource (**ACCMD)
 Can be used with or without other personal profiles and other resource
metadata
*ACCLIP – Accessibility Learner Information Package
**ACCMD – Accessibility Meta Data
IBM Software Group
Business Value

Personalization
 How much business is lost when people walk away from an online purchase?
 What additional revenue could search companies realize if results were easier to use
(advertising service contracts)?
 Aging workforce, with cash, don’t want to show they have a disability
 Service opportunity for ATVs and accessibility consulting
 Corporations improve effectiveness of e-training
 When does a person’s environment make the IT unusable?

Resource Metadata
 Lawsuits: How does the content aggregator show they did not produce the inaccessible
resource?
 System Admin: What accessibility standards did the resource comply to and can I deploy it?
IBM Software Group
Strategy Moving Forward – Demands Personalization
 Address accessibility of resource content
 Continue to evangelize and drive industry toward WAI-ARIA adoption
 Develop Best Practices for addressing accessibility Merge Issues
 Perform accessibility study of data feeds (RSS, ATOM, others)
 Identify transformations needed (Fluid Project)
 Develop “flexible internet highway infrastructure” map user preferences with the
appropriate resource and adapt the resource where necessary
 Develop standards for resource meta data and user preferences (IMS AccessForAll)
 Work with W3C/**OMA Deliver user preferences over *DPE?
 Deliver Accessibility Preferences from identity brokers?
 Potential – Fluid Project
 Drive Industry Adoption of flexible highway
 Providing resource meta data (catalog of accessibility capabilities and equivalent
resources
 Drive understanding of business value
*DPE – Device Profile Evolution
**OMA – Open Mobile Alliance
IBM Software Group
Take advantage of ability to:

Transform the user interface of resources (display and control)

Re-aggregate resources

Configure tools to meet user needs
IBM Software Group
On-Demand Personalization Broad Network
RSS/Atom
search
Blog
Content and ACCMD
Aggregating server (search, mashup, etc.)
Device, User Agent,
Environment, ACCLIP
*DPE – Device Profile Evolution
*DPE
Server
IBM Software Group
On-Demand Personalization Local Network
RSS/Atom
search
Blog
Content and ACCMD
ACCLIP
Aggregating server (search, mashup, etc.)
ACCLIP
Identity
Broker
IBM Software Group
Summary
 Mashups are in the early stages of addressing accessibility
 Like WAI-ARIA, IBM is leading to get us ahead of the curve
 WAI-ARIA places usable access on equal playing field with desktop
but Mashups could undo the good work
 Reusable WAI-ARIA enabled toolkits, like Dojo, are on the rise – Use them
 The advancement of the Web mandates an Open Accessibility Strategy
 Open architectures
 Open standards
 Open Source
 Leverage social collaboration!
 Proprietary creates barriers!
 The time is now to move to a more flexible, accessible web
 Critical for content aggregation
 Essential for addressing learning and cognitive accessibility
 Addressing broader accessibility issue will generate significant business value
®
IBM Software Group
For a copy of the presentation or more information, contact:
Rich Schwerdtfeger at schwer@us.ibm.com
Questions?
© 2007 IBM Corporation
Download