user-interface: Difference between revisions
|  (Added Margin Marks) |  (stick with "microformats" terminology until something better. write up some "obvious" what browsers should implement suggestions.) | ||
| Line 20: | Line 20: | ||
| * Andy Mabbett - How can we make them [[accessibility|accessible]] to people with (for instance) visual disabilities? | * Andy Mabbett - How can we make them [[accessibility|accessible]] to people with (for instance) visual disabilities? | ||
| * Alex Faaborg: Mozilla has had inquiries from reporters in the mainstream media (Wired and Business Week) who wanted to cover microformats in stories about the future of the Web browser, but they then later backed out because they felt the term "microformats" would only appeal to developers, and not the average reader.  These types of mainstream stories need to focus on the user experience, and not the underlying technology, but what term should reporters use to describe the overall feature? | * Alex Faaborg: Mozilla has had inquiries from reporters in the mainstream media (Wired and Business Week) who wanted to cover microformats in stories about the future of the Web browser, but they then later backed out because they felt the term "microformats" would only appeal to developers, and not the average reader.  These types of mainstream stories need to focus on the user experience, and not the underlying technology, but what term should reporters use to describe the overall feature? | ||
| ** I think we should stick with the term "microformats" until someone comes up with a better term that doens't "only appeal to developers". Note that we should avoid terms which are either overloaded, or dilute the concepts, or are just another form of made-up jargon. [[User:Tantek|Tantek]] | |||
| == Social Network Portability == | == Social Network Portability == | ||
| Line 26: | Line 27: | ||
| == Browser Integration == | == Browser Integration == | ||
| From screenshot brainstorms to working plugins, there is a lot going on with browser integration of microformats support. | From screenshot brainstorms to working plugins, there is a lot going on with browser integration of microformats support. | ||
| === In General === | |||
| Browser support for microformats consists of three things in general: | |||
| # Automatically detect the presence of microformats on a page | |||
| # Parse them into a set of microformats for that page (preferably maintaining their relative relationships perhaps within a tree structure). | |||
| # Do something useful with them | |||
| === Do something useful === | |||
| Do something useful could be any or all of: | |||
| * User interface: Provide the user with an additional user interface for common actions to take with those microformats | |||
| * API: Provide an API (DOM extensions on "document" object?) to access those microformats for browser extension developers. | |||
| * Cache: cache that set/tree of parsed microformats along with the URL/Title/date-accessed of the page in the browser navigation "History" or even page cache, and then use that set of objects for various auto-complete/auto-fill uses and other enhancements to existing browser features. | |||
| === Additional user interface === | |||
| Some examples of additional user interface for common actions to take with microformats found in pages, grouped by specific microformat: | |||
| * [[hcard|hCard]] - for all at once, or for one at a time: | |||
| ** "Add to Address Book" (convert the hCard to a vCard (.vcf) and pass it onto the OS to automatically open/incorporate into the user's preferred local address book application) | |||
| ** add to Gmail, Yahoo Mail, Hotmail address book (etc.) | |||
| * [[hcalendar|hCalendar]] - for all at once, or for one at a time: | |||
| ** "Add to Calendar" (convert the hCalendar events to iCalendar vevents (.ics) and pass them onto the OS to automatically open/incorporate into the user's preferred local calendaring application). | |||
| ** "Subscribe to Calendar" - construct and pass on a conversion URL (e.g. using X2V, or prefixing the URL to the current page (or to the specific event within using a fragment identifier) with webcal://feeds.technorati.com/events/ ) and pass it onto the OS to get the OS to pass the URL onto the user's preferred local calendaring application for that app to subscribe to. | |||
| === Screen Shots === | === Screen Shots === | ||
Revision as of 20:35, 3 October 2007
User Interface
Recently there have been many really good user interface ideas and suggestions for working with microformats. This page serves to collect and document them so that we may be inspired by and iterate on each others' works.
Implementations
See implementations, and document examples of good UI from there, here.
- Miffy inserts a green square into the document to represent the presence of microformat
- Some Greasemonkey scripts use a separate iFrame for microformat content
- Other Greasemonkey scripts insert an icon inline into the page
- Tails Export (Firefox extension) can display and export some microformats.
Design Guidelines
These are some suggested design guidelines for Web designers and developers by Alex Faaborg, a user experience designer at Mozilla:
- Design based on actions, not data. A button that says "Send to Calendar" is considerably more useable than a green button that simply says "hCalendar"
- Use iconic images instead of acronyms. In addition to being more descriptive, they localize better. Here are some I've been showing in various talks: microformat icons. These are still very preliminary. Mozilla will likely release all of the source artwork for our microformat icons under a creative commons license around the launch of Firefox 3. This will enable Web designers to integrate the icons into their sites, and other Web browsers can consider using a similar set of icons.
Challenges
- Chris Messina: "What kind of solutions can we come up with that are single click only?"
- Andy Mabbett - How can we make them accessible to people with (for instance) visual disabilities?
- Alex Faaborg: Mozilla has had inquiries from reporters in the mainstream media (Wired and Business Week) who wanted to cover microformats in stories about the future of the Web browser, but they then later backed out because they felt the term "microformats" would only appeal to developers, and not the average reader.  These types of mainstream stories need to focus on the user experience, and not the underlying technology, but what term should reporters use to describe the overall feature?
- I think we should stick with the term "microformats" until someone comes up with a better term that doens't "only appeal to developers". Note that we should avoid terms which are either overloaded, or dilute the concepts, or are just another form of made-up jargon. Tantek
 
Social Network Portability
See the separate social-network-portability page.
Browser Integration
From screenshot brainstorms to working plugins, there is a lot going on with browser integration of microformats support.
In General
Browser support for microformats consists of three things in general:
- Automatically detect the presence of microformats on a page
- Parse them into a set of microformats for that page (preferably maintaining their relative relationships perhaps within a tree structure).
- Do something useful with them
Do something useful
Do something useful could be any or all of:
- User interface: Provide the user with an additional user interface for common actions to take with those microformats
- API: Provide an API (DOM extensions on "document" object?) to access those microformats for browser extension developers.
- Cache: cache that set/tree of parsed microformats along with the URL/Title/date-accessed of the page in the browser navigation "History" or even page cache, and then use that set of objects for various auto-complete/auto-fill uses and other enhancements to existing browser features.
Additional user interface
Some examples of additional user interface for common actions to take with microformats found in pages, grouped by specific microformat:
- hCard - for all at once, or for one at a time:
- "Add to Address Book" (convert the hCard to a vCard (.vcf) and pass it onto the OS to automatically open/incorporate into the user's preferred local address book application)
- add to Gmail, Yahoo Mail, Hotmail address book (etc.)
 
- hCalendar - for all at once, or for one at a time:
- "Add to Calendar" (convert the hCalendar events to iCalendar vevents (.ics) and pass them onto the OS to automatically open/incorporate into the user's preferred local calendaring application).
- "Subscribe to Calendar" - construct and pass on a conversion URL (e.g. using X2V, or prefixing the URL to the current page (or to the specific event within using a fragment identifier) with webcal://feeds.technorati.com/events/ ) and pass it onto the OS to get the OS to pass the URL onto the user's preferred local calendaring application for that app to subscribe to.
 
Screen Shots
- Conceptual Mockups of Microformat Detection in Firefox 3
- Jon Hicks: Proposal for a Safari Microformats plugin 
  
- Ben Ward: Microformats in Web Browsers 
  
- Microformats in Flock 
  
- Margin Marks UI Concept, Margin Marks Comps on Flickr
Plugins
- The microformat implementations page has some Greasemonkey scripts.
- http://greasemonkey.makedatamakesense.com/callto_tel/ by Scott Reynen
- Tails Export (Firefox extension) by Robert de Bruin.
- Jon Hicks has written a user stylesheet for Mac browsers that highlights hCard and hCalendar data.
Planning and Discussion
- Discussion of microformat detection in Firefox 3
- UI brainstorming on the Mozilla Wiki
- The Camino Wiki has a page where future microformats support is being discussed and organized
Simpler Markup Languages
There are plenty of wiki-formats that attempt to make it easier for more people author semantic markup, often with textually decorative punctuation.
As these simpler markup languages are something that *users* are expected to type, they are user interface.
Markdown extension for hCalendar
See Markdown and the hCal microformat which proposes an extension to the Markdown text markup language to capture and represent hCalendar event semantics in a human editable form.