DX Hackfest: Developer Documentation

The GNOME Developer Experience hackfest wrapped up a couple of days ago. It was definitely one of the best GNOME hackfests that I have attended. There were lots of people there with diverse affiliations (Canonical, Suse, Lanedo, Collabora, Red Hat, the Linux Foundation…), who were all extremely focused and keen to work together.

The high attendance at the event meant that we were able to break into four groups, each of which focused on a different area of the developer experience: application definition, toolkit, documentation, and tools. A discussion at the beginning of the event and regular catch-up sessions ensured that we were all on the same page and working towards a common vision.

I spent most of my time as a part of the documentation group. Together we worked on a number of aspects of developer documentation.

Fred Peters, Aleksander Morgado and Thomas Bechtold hacked on DevHelp and made good progress modernising its user interface. The new version should be easier to use and should look much nicer.

Jasper St Pierre worked hard updating our automated documentation generation tools, and seemed to make some excellent progress towards extending their coverage for introspectable languages, especially JavaScript.

Me, Meg Ford, Federico Mena Quintero and Jakub Steiner looked at the GNOME developer website. We created an updated design and identified documentation that was missing or needed updating. Our decision to focus on JavaScript really helped with this and enabled us to effectively update the website design, as well as write new tutorials for first time GNOME application developers.

The new website design that we developed had a few goals:

  • Provide an effective interface for browsing and searching API documentation.
  • Include introductory guides that lay out the basic process involved in creating a GNOME application.
  • Include a space for the new version of the HIG (this is currently under development).
  • Be responsive, so that it can be viewed on tablets and phones.

Me and Meg created a couple of new tutorials that will go on the site, and Meg updated some of the tutorials for JavaScript. Federico started updating the existing platform overview. Jakub gave the site a new responsive layout and created some artwork for the homepage. Together, we started rearranging the content and the pages. There’s a couple of development branches on git.gnome.org where this work will continue and we hope to relaunch in the not too distant future.

I will also be reaching out to existing documentation contributors to get their advice and to figure out what additional documentation we will need. It would be great if they want to help with this work too, of course.

In general, the hackfest felt like a significant event. If we can push forward with the agenda that we have set, then the future looks extremely bright. If anybody who wasn’t at the hackfest wants to get involved, there is no shortage of things to do, and I would encourage you to get in touch.

Big thanks to the GNOME Foundation for supporting the event and to BetaGroup Coworking for being such generous hosts.

Settings!

Those of us who work on GNOME design have been busy with all kinds of things recently. One major area of activity has been settings (aka System Settings, aka GNOME Control Center). In total, we have produced designs for four new panels (search, notifications, privacy, and sharing) and we have redesigned four of the existing panels (power, network, display, and date & time). Some of these have already been implemented, some are being developed on, and a few more are waiting for coders to get involved.

The new panels are things we’ve wanted to do for a while. They represent an effort to allow applications to integrate better with GNOME 3: hence panels for configuring search and notifications. The new panels also reflect a long held goal to give users control over privacy, whether that is through controls over how much personal information is displayed on screen, how your identity is exposed over the network, or what content you are sharing.

We’ve also been working to improve the overall experience provided by GNOME Settings. Some of our existing settings panels weren’t (and still aren’t) as good as they could be, and we want them all to be easy to use and to look great.

Since so much work has been done for these settings panels, I thought it would be useful to show some mockups and give bit of background on the design for each panel. One thing you might notice here is a new set of design patterns around settings in GNOME, which has been made possible by the new list widget developed by Alex Larsson.
Continue reading Settings!

Give a detail this Christmas

When I last posted about Every Detail Matters, 27 detail bugs had been fixed by 9 contributors. About two and a half months later, 43 bugs have been fixed by a total of 12 contributors. We’ve made impressive progress, and the results are already making themselves felt. Testing the latest and greatest GNOME Shell, things definitely feel more polished and better executed.

This Christmas, Every Detail Matters brings you…

Crisp menu separators. The old ones were fuzzy; now you have a clear line.

menu-separators

Corner synergy. The rounded corners of popup bubbles and scrollbars have been aligned.

bubble-corners-cropped

Login process indication. This has been the subject of a few different fixes. We now have proper insensitive states in the login screen, and a spinner is displayed if login is taking a while.

login-process

A “No messages” label when the tray is empty.

no-messages

A hover effect for window thumbnails. A border is displayed around window thumbnails when you hover over them; it’s a small thing, but it’s really satisfying.

thumbnail-highlight

A transparent top bar in the lock screen. I featured this in my last Every Detail Matters blog post; it has now properly landed, and has had some nice polish work done on it.

transparent-top-bar-scaled

An icon to remind you when you have headphones plugged in. This bug wasn’t actually part of Every Detail Matters, it goes to show that there is plenty more happening in GNOME to get the details right.

headphone-icon

We hope you like what we’ve been working on. If you’re looking for a hacking project for the holiday, check out the Every Detail Matters wiki page. GNOME Shell is a lot of fun to work on, and we’ve got some nice bugs just waiting for someone to fix them.

The Next Step

The GNOME Project has been working hard to evolve and improve GNOME 3 since it was initially released in April 2011. We’ve made substantial progress, introducing new features, like GNOME Online Accounts, the lock screen and integrated input sources. We’ve also adjusted and refined many parts of the core UX, including improvements to the Activities Overview, the new-look Message Tray and ongoing work on System Settings. This is important work, and there is more that still needs to be done.

However, the core UX isn’t just about the Activities Overview or System Settings. There is another, crucial aspect of the new experience that we are in the process of building: core applications. And there’s one type of application that is especially important for the GNOME 3 user experience: the content application.

Content is one of the most important parts of a user experience. People care about content. Software is often just a means to get at and do something with it, whether it is the means to share holiday photos with your family, create documents for work, or play that new album you just bought. If we are going to provide a competitive, first-class user experience, we have to do content well.
Continue reading The Next Step

Fantastic Progress in Every Detail Matters

Every Detail Matters is back for a second round, and let me tell you: it is bigger and better than ever. I have been totally blown away by the response we’ve received.

We managed to fix 20 Every Detail Matters bugs for GNOME 3.4. That target has already been blown out of the water for the 3.8 cycle. At the time of writing, I count 27 bugs fixed by 9 different contributors. We’ve got some really great fixes in there, like improving animations in the lock screen and making the login experience smoother. There’s also been some nice usability enhancements to the Message Tray and Activities Overview.

We’re not done yet though: there are 14 bugs that are currently being worked on, and many more that we want to tackle. I’m adding items to the list all the time, including new features as well as smaller tasks for newcomers. If you want to help make GNOME 3.8 awesome, check out the Every Detail Matters wiki page. If there isn’t something that appeals straight away, come back and check again: we’re updating the page all the time. There’s plenty of time to get involved.

Everyone who has contributed to Every Detail Matters has done a fantastic job so far. A special mention has to go out to Stéphane Démurget, who only recently started contributing, but who has been doing a brilliant job. Stéphane hasn’t just been fixing lots of bugs, but he has been fixing them with style, and has been a real pleasure to work with.

I’d also like to give big thanks to Giovanni Campanga, Florian Muellner and Jasper St. Pierre, who are regular contributors who have been busy fixing bugs and reviewing patches. And now for some screenshots of the work done so far. :)

Run Dialog

Yes, it’s a detail. But then, details matter: we have a nicer looking run dialog now. The most important feature of this is that it now has a close button, which means that people have an escape route if they accidentally open it. Another thing that this screenshot shows is our new background shade, which is used for modal dialogs and the overview. It used to be a flat transparency, but it has now been updated to use a radial gradient. This gives added depth and atmosphere.

Lock Screen

I’m cheating with this one, because it hasn’t actually landed yet. It is cool though: Florian has updated the lock screen to use a translucent top bar, which fits better with the overlaid screen shield metaphor that we’re using here. It also looks awesome. :)

Login Screen

Finally, another detail (which, like all details, matters): the login screen now has properly styled insensitive buttons, and we make sure that the Unlock button is insensitive until the password entry field contains some text.

Expect more updates in the future.