Suz Hinton, Alex Sexton, and Nick Nisi talk with Dylan Schiemann about Dojo 2.0, managing an open source project, web standards, and more.
Rollbar – Our error monitoring partner. Rollbar provides real-time error monitoring, alerting, and analytics to help us resolve production errors in minutes. To start resolving errors in minutes, and deploying with confidence - head to rollbar.com/changelog
JSPARTY to save 20% on most passes. Location and dates: San Jose, California, June 11-14. Learn more - oreil.ly/2J4z8da
Fastly – Our bandwidth partner. Fastly powers fast, secure, and scalable digital experiences. Move beyond your content delivery network to their powerful edge cloud platform. Learn more at fastly.com.
Linode – Our cloud server of choice. Deploy a fast, efficient, native SSD cloud server for only $5/month. Get 4 months free using the code
changelog2018. Start your server - head to linode.com/changelog
Click here to listen along while you enjoy the transcript. 🎧
Hey! How’s it going?
Good! And second, we have Alex on the panel also, who from his latest tweet I see was having fun with teaching parrot noises this week. Alex, what’s up with that?
Yeah, my son was in a Mexican restaurant on Cinco de Mayo, doing parrot noises, which are “Kha-Kha, kha-kha!”, which also means poop in Spanish… [laughter] It was an interesting experience.
It’s really great to have you on the show, Dylan, to talk about Dojo. Welcome!
Thanks, I’m happy to be here.
Dojo was started by people such as yourself, Alex Russell, David Schontzler and others. Can you give us a brief history of how that came about? I think it was released in 2004, is that right?
Yeah, we started the project in 2004. Prior to that, we had another open source project called netWindows, and Alex famously sent out an email I think around April 2004 saying “What would you want from a next-generation DHTML toolkit?” We had a mailing list, and a number of people started responding and talking, and then a couple months later Alex and myself and David started committing the first bits of code.
Was it a mailing list? Wasn’t there like an old forum that doesn’t exist anymore, something like that?
Well, prior to that there was the WDF DOM forum started by ppk (Peter-Paul Koch), where we would discuss all the flaws of the DOM. That started probably in maybe 2001, and a lot of the people there have led to people who started working on Dojo. So yeah, it even goes back further than that.
[00:03:56.00] The name Dojo itself was suggested by Leonard Lin, who had a startup at the time. We just had terrible luck with naming; we got a cease and desist back in 2004 from Microsoft, which is kind of funny, because we’re such TypeScript fans now, but at the time because we had the word “windows” in the name netWindows, so… We had to change the name on that. It’s just a lot of good old history back then, when things were quite different.
In many ways, it was like writing software in the dark ages. Your goal was to make something work in both browsers, because there was no mobile web at the time. And the idea that you were going to take this platform that most people kind of laughed and shrugged off as something you sort of treated as a DOM view layer, and that you were gonna turn this into a real area where you would write applications was pretty crazy.
Alex and I and David were working at this company called Informatica - they’re still around - and they had some pretty exceptional needs at the time; a lot of it would be vector graphics based stuff, large datasets, grids, charts, and all sorts of other advanced features that not only could you not do them with a dated platform, but no one else even really tried at that time.
So what kind of features in Dojo when it came out became immediately popular?
Dojo 1 had something like 1,400 modules, so it was not a small framework at all. We had a build system, we had an early implementation of promises, we had various async patterns that are now taken for granted, but were not even conceived back then… Just lots of things that made the development of things better, and you can see lots of these things have influenced the standards that we have today.
For example, promises come from deferreds, which were an early concept contributed by Alex and another person named Mark Anderson in the Dojo project… As well as another person who worked on a library called mocheek at the time.
What else…? You could say WebComponents are heavily inspired by Dijit. The web has tried to get web components in place forever, but that’s obviously been a big change.
A lot of the ES5 and ES6 features around just array operators, bind and just other features like that didn’t exist, so libraries like Dojo popularized them.
Even real-time stuff too, right? Socket.d was Dojo…
[00:07:59.02] Yeah, Dojo had an early WebSocket implementation, and it had fallbacks to things like Forever Frame techniques, or long polling… Just because we needed real-time no matter what, so we started a project through the Dojo Foundation called CometD, that was basically one of the first open source real-time client server communication protocols as well.
I think that’s why I initially got into Dojo a long time ago. Not that I was ever super involved with it, but I think that was the only way you could get any of that done, and the documentation was good, and I had the fallbacks… It was really cool to see real-time.
Yeah, a lot of these things we just take for granted now, but they were really difficult to do. I remember sitting at OSCON in Portland I think in a coffee shop with another engineer, and we were trying to figure out how to trick Safari into doing real-time communications through an iFrame, and it turned out what you had to do was write to the DOM one kilobyte of white space intermittently, or else Safari would drop the frame connection after 30 seconds. So you would just randomly write white space junk.
Then IE - I think you had to write just any random characters, or maybe it was like 4 bytes of characters had to be written in. Just these really strange hacks you had to get working until WebSockets came to be.
It’s like a weird front-end no-op, I guess, for keeping something alive. That’s funny.
Jerod in the Slack chat says “I’m curious why Dojo has remained so niche all these years, yet is always highly regarded by anyone who has experience with it.”
My goal has never really been to say “Hey, we wanna own the web.” Instead, it’s “We wanna make a good influence on it and make it better”, whether that’s through using what we create, or what others create that might be inspired by it.
Niche is maybe a bit harsh as far as Dojo’s usage goes. It was pretty extensive for a long time… I think before Dojo 2, in the last few years, certainly just like jQuery and other frameworks falling off but IBM and a few huge enterprise-level people who needed that large set of documentation support and widgets were using it… So I don’t know; it certainly wasn’t jQuery-level, but it was pretty popular.
At one point we were used in over 80% of the Fortune 500. It doesn’t mean exclusively, just that it was very widespread in its usage.
I got involved with Dojo probably around 2011 when I started working with it at a startup I was at. That was right around the time of the big synchronous modules to AMD modules change that was happening; it was just a point release in the Dojo world… Can you talk about that a little bit? That seemed to be a really big turning point for the language, and of course, AMD got a lot of adoption in other frameworks as well.
Yeah… So James Burke was an early Dojo contributor when he was working at AOL, and then when he left to go to Mozilla, he found himself in a jQuery world and he wanted to bring the bits and pieces of Dojo that he liked to the broader ecosystem. So between him and a few other people, the AMD specification kind of came to light. John Hann and Rawld Gill are probably the two others known at that time.
Oh, you do? Nice.
One or two words are mine.
Very important contributions.
Absolutely. [laughs] And you know, the goal was to come up with a module format that worked asynchronously in browsers without needing a new language syntax, without needing a pre-processor to modify the code before it could run.
What happened is essentially around 2010-2011 that was kind of standardized or finalized. Dojo 1.7 was the first version of Dojo that switched from a more synchronous dojo.define, dojo.require style syntax to an AMD structure… And it pretty much revolutionized the way Dojo worked. It improved performance significantly, especially in IE, where it mattered most at the time. In hindsight, we probably should have called that Dojo 2, because so much changed at the time, and pretty much it was a major refactor of the framework, without really changing its capabilities at all.
If I recall correctly, Dojo didn’t actually use RequireJS though. Didn’t you all implement your own loader?
Yeah… You could use RequireJS with Dojo 1, but the idea was we wanted multiple implementations. RequireJS was pretty much intended for the jQuery community. The Dojo loader was also AMD-compliant. John Hann and Brian Cavalier had another one (I’m forgetting the name), but they’ve done a few as well.
Cujo, I think.
Yes, Cujo, there you go. And the idea was we wanted multiple implementations because otherwise we wouldn’t know if we actually had a good standard to solve different use cases.
Dojo has been around for a while now… I’m actually interested in the authorship side of things, and what has it been like maintaining something that is so popular for so long?
The joke among the people I know is that I’m incredibly stubborn. Dojo has lasted as long as it has because I won’t let it die, which is perhaps true, but perhaps kind of funny, as well… I’m not really one who’s willing to give up on something or let it go. I’m gonna keep it going. I have this real strong sense of duty to our users. If someone has taken the time to learn and adopt Dojo, I don’t wanna just say “Oh, I’m bored of that. We’re gonna shut it off and you can go figure something else out.” So just kind of that sense of “You’ve made the investment in us, we wanna make that to you” is what has really kept me going.
That said, the base of committers and contributors has changed drastically over the years. Almost no one who worked on the original Dojo (0.1) still works on Dojo today… But I think that’s okay. I think people’s lives and perspectives change, and their focus grows. Alex now is best known pretty much for trying to bring a lot of the goodness from Dojo 1 into the standards bodies through his work at Google.
[00:16:10.24] I think it’s not so much about “Hey, we need to all work on Dojo forever”, but how can we make the biggest mark or positive influence on the web?
That’s really insightful. Nick, when did you come to start contributing to Dojo?
So in 2011 I was working on an app – my first big challenge with Dojo was converting a 1.4 app to a 1.7 app, which meant completely changing over to AMD and learning that. I did that for a while at this startup; the CTO at that startup, John Christopher, he really was a big fan of Dojo, and dGrid was this other project that’s kind of a grid implementation that’s used in the Dojo ecosystem, and that was a really powerful tool for us in the app that we were building at the time.
Then it was from that dGrid project that I actually became familiar with SitePen and started looking to them as my next adventure in my career. I’ve been there pretty much ever since, so for about five years now, contributing to Dojo 1 and Dojo 2, and teaching workshops, and things like that. So I’ve been really happy to be a part of this community, and I think that there’s a lot fo really cool ideas that have been improved upon from Dojo 1.
One thing in particular is the Dijit system, with its declarative syntax for creating widgets that you can use, and having a whole lifecycle around that. That seems like it’s an earlier implementation of what Dylan was saying, like web components, or maybe even like React components. I think that it could maybe be seen as like a building block to get to where we are today, which is really cool.
Yeah, it’s really interesting… So the early data grid we had worked with real-time stuff, but it also was one of the first implementations of a virtualized DOM; it supported virtual scrolling, and virtualized rendering of nodes… And if you sort of look at Dojo’s grid plus Bespin, which later became the editor that’s now part of Amazon, the Cloud 9 editor - these were sort of the two early virtual DOM implementations that React was later crazy enough to say “We should do this for the whole page of your application.” So there was a lot of cool inspiration there, but if you think about it, data grids were kind of probably THE reason people chose Dojo 1 - we had a really nice, robust data grid, and we’ve had one for many years… And in the enterprise, every application kind of starts with the data grid.
Alright, Dylan, I think we’re gonna talk a little bit about Dojo 2, but it actually kind of reminds me of a slogan that isn’t anywhere near official, but… Wouldn’t you say that Dojo 2 is kind of a rehash of something that Dojo 1 already did? [laughter] And to that end, explain the misnomer with the “Don’t Ask, Don’t Tell”, and “Dojo Already Did That”, DADT.
[laughs] That’s funny. So I think it was the first ever JSConf, and Peter Higgins was there, and Pete’s quite humorous, and pretty much anytime anyone would talk about something, he would quickly remind that Dojo already did that… And it kind of became the official meme of the first couple of JSConfs, that no matter what anyone presented on anything, you could say that Dojo had already done that.
Mostly, I think we had a little bit of a chip on our shoulder and that we did do a lot of great things before others, and the ecosystem is not necessarily great at giving credit for where something comes from… But honestly, that doesn’t really matter, but it’s just kind of one of those things…
It was funny, just a couple years ago I finally met Addy Osmani in person after I think 10 years of talking online… This was before he had moved to San Francisco, so we’re in the Google London office and he pulls out his printouts with the “Dojo Already Did That” signs, and we took photos with it, which was really humorous… So every once in a while, someone just kind of brings that up and gives me a good laugh.
Alex, you mentioned Dojo 2, and I’m really looking forward to talking about that on this show. So Dojo 2 was just released super-recently, at the beginning of this month, is that right?
That is correct.
Tell us about this approach that you’ve had as a result of sort of bumping to a major new version.
Yeah… Really, the thrust of working on Dojo 2 has been over the past year and a half or two years, but I think I first started talking about the idea of Dojo 2 at a conference in 2010; so it’s been many years in the planning, and in many ways it’s kind of like when you’re a musician and you’ve had your first successful album and it’s really awesome, and then you don’t know what you should do next.
What we realized were a few things. One, whatever we create, we have to support for a long time. Two, we want something to be appreciably better than what we’ve created before, as well as something that is strong on its own, so not just a rehash of what other people are doing… And something that is very modern and forward-thinking.
Around 2014 we thought we were on a good path, and then we saw that ES6 was finally going to land, and we had also started to take a strong interest in TypeScript, so we pretty much scrapped everything we were doing, took a step back and said “Okay, if we were to start a new framework today, what would we build and how would we build it?” Then we took a few years to iterate on that, and we ended up with something that is sort of core to our beliefs with Dojo, which is that we want to provide a very solid foundation for the enterprise, we want something that’s going to scale up or scale down… But we’re really aligned with the ecosystem… Whereas Dojo 1 kind of had to build everything in a silo, Dojo 2 can say “You know what, everyone uses Webpack; let’s make this work nicely with Webpack”, instead of creating our own build system.
We did make a huge bet on TypeScript. While frameworks like Angular use TypeScript, Dojo 2 is pretty much designed assuming that you are a TypeScript engineer, which is a pretty radical departure from what we had done before.
As far as the ergonomics of using Dojo 2 versus Dojo 1, is it still a similar – like, there are Dijits and there are these things…? I assume it’s become more declarative, in like a more virtually DOM-y kind of way, all these types of things have been adopted… What are the main impacts of like day-to-day application development in Dojo 2 versus Dojo 1?
[00:24:07.16] Dojo 1 was really its own thing. We had our own module system, our own class-like system, our own widget system and so on… And part of that was because back in the day the standards process was not great; it was more black box, things would get thrown over the wall to you, as opposed to today, where it’s very much aligned with the ecosystem and there’s a lot of open participation.
So Dojo 2 is much different in that it’s very focused with standards and common patterns. Yes, we have a widget system, but it’s also built on a virtual DOM engine… One that we had originally started with using based on MECAT but that we forked, so we could get a bit more control over how we render widgets. It uses ES modules, we use Typescript, we have a number of core features…
In many ways, what we’ve tried to do is give you the flexibility of something like React, where you kind of have all of these nice, smaller pieces, but take advantage of the fact that we want a set of things that work together, in not quite as much as, say, Ember takes, where you’ve got everything designed only to work together, but… The idea is that you’ve got all these small pieces, like a good routing implementation and a good widget library and a good system for reactive components and so on, but we want them to be able to take advantage of actually being built together consistently and coherently.
I hear that. I think at any given time at work we’re upgrading 10 dependencies in order to be able to upgrade 2 dependencies, in order to be able to upgrade one dependency.
Yeah… SitePen, the commercial side of what I do - we do a lot of consulting work, whether it’s with Dojo or React or Angular or whatever, and we kind of know the pain points of working with various frameworks and solutions, so it kind of frames our reference on “Okay, what would I do if it was just up to me? I’d create something where these pieces work together and it’s not quite as painful to get started or to upgrade.”
We’ve also done a lot of fairly forward-thinking stuff. For example, one area where the virtual DOM paradigm kind of breaks down at times is when you’re working with something, and in general, you just need to know something about that particular DOM node… So the typical way is to say “Alright, I’m gonna punt on the virtual DOM here, just give me access to the node.” That might be for animating an object, changing its dimensions, setting a focus event on it… Or some of the newer API’s, like intersection observers and resize observers.
So what we’ve done is we’ve provided this pattern called a Meta. What it does is instead of you having to get the DOM node, we provide the properties for those common scenarios, so that you can still work with those behaviors in a reactive manner.
So what makes Dojo 2 pretty interesting to me is we’ve looked at like hundreds or thousands of little tiny, minor pain points or inconsistencies like that, and really tried to refine them and clean them up and make them feel more consistent.
Yeah, I think that that’s one of the biggest focus points for Dojo 2 - really a focus on making things easier for the developer that’s using it; so a big focus on developer ergonomics, with things like that in the Meta project, and other things. You mentioned that we write in TypeScript, where we assume that the users are TypeScript users, as well.
We also write all of our modules with TypeScript’s strict type-checking turned all the way on, so that it’s keeping us honest and it’s making for the best possible experience for the users of the framework.
Yeah, the TypeScript team jokes that we’re stricter than they are, because they’re not fully strict in their authoring of TypeScript itself. [laughter]
Doesn’t that then leak down into your strictness, though?
[00:28:13.22] No, no… I’m mostly just kidding. I mean, they’re very good engineers, but there’s just a few places where they can’t be fully strict, but we are. And it is a little more painful, but the goal is to make it so our end users don’t have to suffer for us not getting things just right.
When you talk about them not being strict - it’s in their own parser…? I guess I’m confused how – if you’re checking with their parser and they’re not strict, it seems like it would follow that you have the same… I guess I’m confused.
It’s a very meta problem, but… So TypeScript itself is - you know, like, most languages are authored in their own language, so it’s one of those interesting meta problems. I just mean that parts of the TypeScript compiler itself are not completely strict, and that’s okay… But for us, it’s a badge of honor to say “We’re fully strict, in that we’re going to catch every possible mistake that you might make, that the compiler could enforce.”
So I was taking a look at the Dojo 2 website, and just having a look at the first impression of what is important to you as an author of Dojo, and the Dojo community in general… And one thing that popped out to me that I found unique compared to other modern frameworks is the word “inclusiveness.” One of my personal passions is accessibility, so I was really excited to see that that had been brought to the top right on the front page. It talked about how internationalization and accessibility is built into Dojo, and the support of that. In my experience working with other framework, I’ve seen accessibility teams spin up from the community in order to sort of address some shortcomings for accessibility in other frameworks. That is clearly not a thing for Dojo 2, so can you just tell me a little bit about how internationalization and accessibility became a priority when you were authoring and releasing it?
Sure. So for Dojo 1, we were the first – okay, so back in like 2005-2006 we were at the first Ajax Experience conference. And we were on a panel, and the question that people kept asking about all this new Ajax stuff was “But is it accessible?” and everyone just kind of hung their heads in shame and said “No. That’s an area that’s ripe for innovation.”
IBM got involved at a very early stage shortly thereafter, and Becky Gibson and her team were part of the ARIA effort and part of making Dojo the first library that supported that standard. So for us it’s just been something we’ve done forever, and in parallel we also supported internationalization back then, too.
Stepping forward, that’s something we’re known for - we want what you create to work for all of your users. That might mean ranging from blindness, to foreign languages, to just having better keyboard shortcuts… You know, the full range of “How do you provide a better experience for all of your users?” So fundamentally for this, internationalization was a fairly different beast than accessibility. Internationalization - we leveraged a JS Foundation project called Globalize, and then provided that in a modern reactive manner. Basically, all of your out of the box components that you might author, you can easily hook them into an internationalization system and get all the nice things that Messageformat.js and Globalize give you.
Accessibility is about a few things… First of all, the components or widgets that we create are accessible out of the box. They comply and conform to the best standards that are out there, and that we’ve gone through and done that. Sarah Higley leads our efforts on Dojo 2 around accessibility.
[00:32:11.23] Then it’s about providing good guidance, good documentation information about how we do that, so that engineers don’t just turn around and break accessibility in their own efforts. Then we do also provide some automated testing for the things you can automate. Obviously, you cannot automate everything around accessibility, but there’s a few good tools - there’s aXe, and there’s Tenon, and a few others, and our Intern testing tool hooks into those to basically say “Hey, these are mistakes that you might make that could break accessibility.” You can automatically test for them in your code base, and at least be notified “Hey, this first passive stuff that you could do to break accessibility, you shouldn’t ever do, because the tests will tell you otherwise.”
I think - to be nice, but maybe not nice… I mean, a lot of people are impatient, and they just wanna get things out the door. Obviously, that’s not us, given how many years it really took us to feel like we got Dojo 2 right… And we still don’t feel like it’s perfect, but we feel like it’s solid enough that we can stand behind it. But I think in general people just aren’t patient enough to say “Hey, I’m going to solve all of these problems as perfectly as I can before I’m going to thrust them on people.”
I’ve been around the ecosystem long enough that I know that I don’t have to push something out first, I don’t have to race to get it done and sacrifice the things that matter.
I think it partially comes from the philosophy of the Dojo team of making a bunch of tools that work together. I do agree with the idea that the virtual DOM implementation, or a component implementation can be separated out and tested separately from a message format implementation or an internationalized component implementation… So splitting those out all seems good as far as code goes. The fact that Dojo already ships everything, all that works together, it kind of makes sense that they might have all these tools that work together, versus someone who’s like “Alright…” Like, when React came out, I remember being very underwhelmed; like, this looks cool, it looks fast for the view layer, or the render function of the view layer that I already have in my massive application, right? It just did this one very small thing, and everyone just kind of piecemeal put their own – you know, for the first six months of React, everyone was just adding it to their backbone applications as the view layer… So I think it is a different approach, for sure.
Yeah, it’s definitely a bit more holistic. I think in general accessibility is still challenging, even for HTML-type work, which makes it a bit more abstract for virtual DOM systems… I mean, I think there’s a lot of promise and potential with the accessibility object model (AOM) stuff that’s being done; it could potentially make this work a lot more smoothly, so that’s pretty promising as well.
But yeah, I think if you’re designing systems that work well together, you’re less likely to introduce things that break your approach. There’s the classic example of “Hey, I’ve pulled 20 widgets from 20 different places, and I don’t know if all of them are going to be accessible”, whereas if you release a set of widgets together and you’ve tested them all for accessibility, you could make the promise that “Hey, we may not be perfect, but we’ve put serious effort into thinking through these problems and done our best to do that, and then accepting fixes and releasing them quickly where we failed.”
[00:36:01.14] What kind of things do you think would help with that fragmentation issue that you just mentioned about “Well, Dojo is a collection of things that were worked on and that were made to be consistent”? When you have a whole community making lots of different types of components, such as when you can just npm install a React component, for example, or a Vue component, or an Ember component, how do you think that we could convince the community be more mindful of these things? How do we sort of stop that fragmentation of the different gaps that we see as far as accessibility goes?
One of the challenges we’ve had as an ecosystem is what I described as the GitHub effect, and GitHub obviously is one of the most amazing things to happen ever to software engineering… But it’s also a bit of a curse, in that before GitHub it was actually a challenge to start an open source project; it required effort in actually setting up a project and setting up source control… And today it’s so easy - you just create a URL and go to it and start a project… And what it’s done is it’s reduced the barrier to entry of creating your own framework, rather than the effort to contributing to someone else’s. So there’s a lot of value in getting people to actually work together and collaborate on things, that gets lost when everyone just kind of does their own thing, in their own way. And obviously, there’s a use for both, because you need innovation and creativity, and that only happens when people try and experiment and fail, and eventually find a nice path forward…
But you really do need people to decide “Hey, it’s worth the effort to get together and collaborate and come up with something that works together, and is consistent, and has some common standards and guidelines.” It’s both end user accessibility, but it’s also developer accessibility. If I have to learn slightly different APIs for each component I’m using, that’s tedious and that’s reducing my own experience from getting my work done.
So there’s just a lot of need to get people to collaborate and communicate and decide; it’s a challenge, and it’s one of the things I feel like Dojo was quite good at early on, but I think every project struggles with this. I don’t know if I have a good answer for it, so much as if you’re aware that the problem is probably human communication, you can maybe look at yourself and say “How can I make this better?”
It also seems like the projects – React doesn’t need to be building necessarily the internationalization layers or the accessibility rules, since they’re not releasing their own widgets… But it seems like they could release a set of standards of like “Here’s how we would expect this to be, and here’s this certification process” - not a real one, but just like “Here’s a thing you can run your thing through; if you run it through this, we’ll check for the following things, and then you can add this badge to your GitHub page… Just generally implying via docs and words what would be expected seems like it would go a really long way for at least the most popular widgets to just– people would PR that.
I think there’s a lot we could do, even in the current fragmented system, to standardize more on what’s expected for internationalization and accessibility.
Speaking of components, let’s talk about Dojo 2’s widgets. I saw in my research that they’re designed to be adaptable as like new open web standards are introduced, and they’re supposed to be just more forward-thinking than components of the past.
How do you ensure that going forward and how do you design these different widgets to be adaptable?
So we’ve taken a few interesting approaches. The first is everything in Dojo 2 is easily imported or exported as a web component, and that’s just how it works out of the box. So it’s not that Dojo 2 widgets have to be used as web components, but that they easily can be… As well as being able to pull in web components from elsewhere.
[00:40:16.04] Obviously, this is just the custom elements portion of the web components spec, but we think that’s really important because if you can reduce the barrier of entry between frameworks with regards to how components are authored and used, that’s really useful. It also is a standard way to say “I’m registering a custom tag that has these properties and these attributes and this behavior.”
Now, web components aren’t perfect. There’s a challenge in sort of cross-component communication, cross-component data sharing… They’re really designed to kind of be standalone. But you take advantage of the standard that’s there, and then you figure out how to augment it where you can. That’s kind of the foundational piece.
We also look for things we can do that make the authoring experience better. For example, we have this system that uses CSS modules and TypeScript together, so that when you’re applying a class name to a component, you can only as an author create valid TypeScript if you include a CSS class name that was part of that component’s CSS file. And we do that by just importing a TypeScript definition file that is automatically created from each CSS file that’s related to each component.
So for our last segment today Alex was gonna start chatting with Dylan about web standards and foundations, and you just had a few questions for Dylan around that.
Yeah. So Dylan, you have been involved in much more than Dojo in the past, specifically around standards stuff… One such interaction that I had with you is detailed in a talk that I gave around CSS colors.
I was excited to find out while I was researching the history of CSS color names that Dylan had many of the same questions that I had doing that research, and unfortunately he had asked them 11 years prior, and never got an answer. So I eventually found that information and replied to www style mailing list… But that was in 2001, when CSS 3 was being kind of ratified. I hadn’t realized that you had also been that deep into standards that long ago. 2001 is pre-Dojo… Yes?
Oh yeah, definitely a few years before.
So you were involved in that mailing list for years prior to that, I guess… You had even compiled all the different places that other people were confused about CSS color names, and linked them in your very informative post… So tell me a little bit about your standards history as well.
Today, standards are amazing compared to back then. I mean, they’re not perfect, but the open process, the way we handle things on GitHub, and talk through them publicly, and the growth of TC39 and WHATWG… I mean, Ian Hickson probably deserves the biggest amount of credit for sort of changing the way we think about the standardization process as a whole.
In the early Dojo 1 days I kind of had the feeling of “Standards are broken. We’ll just do whatever we want.” But today’s standards feel pretty good, so we try to align to them much more closely.
[00:48:03.27] Around the same time Dojo was released - I guess a little while after, but… I know I’ve talked to Alex Russell a little bit about this in the past, but you guys felt pretty strongly about code rights and licenses and licenses and things like that, to the extent where you created a very hands-off, but protective entity, which was I think one of the first foundations that I had known of. Obviously, there was Apache, but it was like pretty early on. So tell me about the history of the Dojo Foundation.
We said “We’re not creating fake, free open source software…” This was a pretty big deal at the time. And also, one company doesn’t really control the destiny of a project. The idea was to reduce the barrier to entry for other organizations to contribute and get involved, and I think the foundation is what led early on to companies like AOL and IBM and Esri and Sun and others at the time, to say “We can contribute to this, because you’ve gone through the effort to make sure that we’re not basically contributing to some other company’s IP, but instead we’re contributing to this shared ecosystem.”
I think that still ends up being an issue today. A lot of the fear and uncertainty and doubt around React has to do with clauses in Facebook’s ownership of that code. There were also a few other foundations that emerged… Give me that history, as well.
Yeah, so over the years Dojo had taken on a number of other projects, including one of yours, and then the jQuery Foundation was founded, and it had jQuery and some other projects… And then I think about three years ago Colin Snover introduced Kris and me. Kris Borchers was being the president or the director of the jQuery Foundation. He said, “You know, it’d probably be simpler if we just had one foundation that we could manage and take care of, instead of two…”, especially since a lot of the projects had strong overlap. So we had RequireJS and Lodash, which were quite popular in the jQuery community, and vice versa. So we merged, and then sort of rebranded and relaunched just the JS Foundation about two years ago.
Basically, the idea is it’s a home that provides support and protection for projects. The idea is not to fund development of projects. That kind of gets into some legal grey area around “Is this an open source foundation or is this a contractor in the middle?” But instead, it’s really just focused on providing the support for open source projects around community and legal rights, and support that frankly most open source committers are not really good at or don’t wanna think about, so it just kind of gives them the support they need around those areas.
You know, my hope has always been that the foundation would encourage projects to collaborate more, instead of reinventing the wheel. For example, with Dojo 2 we leverage the PointerEvents Polyfill, which is a JS Foundation project. We leverage Globalize, which is another project, we leverage Intern, which is the testing framework that’s part of the foundation, and we also use parts of Grunt for our development tooling…
[00:52:09.02] So the idea is really not to say “Hey, all these projects should become the same”, but if they have clear boundaries and API approaches, can they be used together in a nice way?
As far as like if I’m a person who maintains an open source library that’s not huge, but a lot of people use my calendar implementation, or my something implementation… What do you suggest they do as far as licensing? Obviously, there are very specific licenses they could choose, but suppose like foundations how they manage the same minefield?
It’s a challenge, because one of the goals of the foundation is not to become the graveyard for abandoned or ugly toys anymore, right? So it wants to have projects that are thriving and well-supported. So if you’re a really small project, it’s hard to say “Hey, I wanna join the foundation”, but it might make sense to join a project that’s part of the foundation, sort of thing.
The goal is you choose a license based on the behavior you want. The license that Dojo chooses is the BSD or the Apache 2, and we choose that to encourage adoption; we’re not trying to control people and force them to contribute back. Obviously, if you have a bug fix, we’d prefer it become part of the framework, rather than you having to maintain a forked version of Dojo forever.
When you choose a license for your project, you very much need to decide what you want your project to be, and try to find a license that’s gonna lead you in that path.
One thing that was pretty different when I started working on or committing to Foundation projects was the Committers’ Agreement, which is separate from the usage license… And I found that I think that’s where a lot of open source projects don’t have any corollary to the Foundation projects. So I doubt it’s even legal, but a lot of times in my small open source projects I’d say “You can use this under the MIT license, but you can commit to it under the Dojo Committers’ Agreement”, or whatever. Can you explain more about that?
A contributor license agreement is basically you’ve contributed some code and you’re saying “I authored this, or whoever paid for this to be authored approves of me contributing this code.” The idea is to make sure that we only accept code that we should accept. Now, it’s not a legal guarantee that there’ll never be a problem, but it’s the closest we can get to saying “Hey, we’ve vetted the source of this code and it’s been contributed as it should be.”
For years actually the Dojo Foundation said “Anyone could just follow the rules of the Dojo Foundation and contribute for code, even for their own project, in that way.” The JS Foundation works a little differently in that it has basically a CLA bot that when you open a PR, if you haven’t committed a PR to that project before, it makes you sign a form real quick in the browser that says “Hey, I know what I’m doing. I can contribute this code and I have the rights to” to streamline the process, but that also means it’s kind of limited to the projects that are part of the foundation, because it needs to hook into that system. But again, it’s just having a CLA process that says “I agree that the code I can contribute is mine to contribute” is really important.
[00:56:12.20] Yeah, I’ve definitely found that almost tends to be the place where I worry the most about getting code that looks good to me, but actually someone didn’t have the rights to actually give it to me. That can be scary.
Absolutely. Just doing everything you can to make sure your users aren’t gonna be sued for using your project is a good thing, and CLA is one part of that process, where the code you’re accepting, the person who has submitted it has at least declared they have the rights to do that, is really powerful.
Before I forget, I obviously forgot one Foundation project, which is a big one for data too, which is Webpack (which I mentioned earlier). Obviously, Sean Larkin and their team are doing really great work on Webpack, and we’ve had a lot of success with that as well.
I think Webpack certainly was not the frontrunner; when it came out there was a lot of competition at the time, and then suddenly it just took off, which is cool. When we’re talking about standards, we’re talking about what standards are you excited about either making it to browsers, or becoming standardized…? What’s the cool new stuff?
We’re pretty cautious in that we won’t really embrace something until it’s pretty far along. For example, we got burned a little bit on object.observe a few years ago, which reached level one, and we had kind of shimmed it and fixed everything we thought was broken with it to make it usable, to then have it discontinued as a standard… So in many ways we look at things, but we don’t really probably pay too much attention to them until they’re the equivalent of stage three.
Obviously, we’re pretty heavily aligned with TypeScript’s feature set as well. TypeScript is interesting, because a lot of people will say “We’ll just wait for that to become part of the TC39 process, and what a lot of people don’t realize is TypeScript can kind of get away with adding features that are around code integrity and authoring because they’re all gonna be removed at runtime anyway. It’s kind of liberating for them to not necessarily have to worry about the features that are going to go into the language, but that are more like developer time tool, language augmentation features.
So I don’t know that we’re clamoring or waiting for any specific features at the moment, so much as everytime we see something cool – we added Resize Observers just a few weeks before the final release, because there was finally a good shim for it, and native support had finally landed in Chrome, and we were like “Well, we can take advantage of this now.”
So it’s kind of the “Can you be nimble?” … but you don’t want to be so nimble that you adopt things before they’re ready, because then you’re gonna increase the risk of them being divergent from the standard itself.
That makes sense. I guess I was trying to get a little bit of your personal excitement, but…
I mean, I have some, but it’s like I’ve had my heart broken so many times, I’m very cautious… [laughs] We have a shim for Observables; the equivalent of RxJS Observables, but there’s like one small tweak… About two or three years ago it was proposed as a TC39 standard, and as far as we can tell it stalled, because it computes with streams, even though it’s fundamentally a lot simpler than to work within streams.
So we have this sitting in Dojo Shim; it’s there, you could use it… But we’ve ended up not really using it ourselves. Instead, what we’ve done is the things that should be observable in Dojo 2 are just observable by default, so we haven’t actually ended up using the API much at all. But when we first thought it was gonna be standardized, we had switched to having everything use it, and then it just kind of took its toll.
So it’s kind of like we’re very excited about a lot of the TC39 proposals around additional async behaviors, and around adding features to the class system, or trying to streamline the way classes work so they don’t get abused, and so forth… But until it’s like right there, we’re just very cautious because we don’t wanna get burned again.
[01:00:16.26] Dylan, can you enlighten us a little bit about what you see as the future of Dojo 2? Now that we’ve got the second version release out the door, can you talk a little bit about where we go from here?
Sure. In many ways, getting the .0 release done is kind of the point where you’re like “Okay, I think what I’ve got is good enough and substantial enough that people should start using it”, but it doesn’t mean it’s complete. I would say Dojo 1 was probably four or five years from 1.0 until maybe 1.7 or 1.8 where it felt really complete, from my perspective.
We have a lot we wanna do around widgets, we have features we wanna add around – things to add feature parity with Dojo 1 even. I mean, Dojo 1 was so big that there are many things we just haven’t tackled yet. We haven’t really started down the data grid path for Dojo 2 yet. There’s a lot of nice things we wanna do around PWAs, we’ve done a lot of proof of concepts for that, but we don’t yet have our PWA tooling in place that kind of makes your application automatically be a PWA.
There’s a lot of patterns around data… We have an implementation called Dojo Stores that is your sort of state management store, and it’s a little bit (in my opinion) easier to work with than something like Redux… But what we don’t yet have are the sort of patterns of “Hey, just hook this up to a RESTful endpoint” or “Hook this up to a WebSocket and get data into my application”, some of those ease of use things…
There’s a lot to do and we’d love contributions, but at the same time if you wait until you have everything perfect, then you’ll never ship, so you’ll have to kind of say “Okay, we’ve got enough that’s substantial here. Now this opens the door for a whole bunch of other things.”
We wanna get a nice design system done. Design systems are kind of a way to say “Hey, here’s a set of consistent UI patterns and widgets, and how they work together and how you use them…” So just a lot of things like that, really.
Can I poke more around the PWA topic? What are a couple of quick high-level things that you’re thinking about when it comes to PWAs?
One of the goals of Dojo 2 in general is that we wanna do things right out of the box. For example, a couple of features I haven’t mentioned - I’ll get to your question in a second, but let me set the preface for it - is things that are the right way should happen as automatically as possible.
[01:02:42.24] For example, we have this build time rendering system that does code splitting and rendering optimization, so what it does is it essentially delivers your initial view optimized as much as possible. Your HTML and CSS for your first view are rendered in line, and the code splitting happens automatically based on what features of your application you need at what point, without you have to write different code to do that… So instead of saying “Hey, how do we enable code splitting?”, we just do it for you. Or instead of saying “How do we make that first paint as fast as possible?”, we just do that automatically, out of the box.
So the same thing is true with a PWA - instead of saying “Hey, how do I make everything into a PWA?”, we say “Okay, how do we set up your manifest file? How do we set up all the different features you might need to have an impressive PWA out of the box?” and provide that as part of the build process, so that every app you create with Dojo 2 would automatically be a PWA, would be the goal.
Now obviously, there’s more you can do than that, but at least removing that sort of scaffolding, boilerplate effort up-front is a big win; it’s something we’ve done proof of concepts around, it’s something wanna land fairly soon, once we kind of sort out exactly how we wanna do that.
And the way we actually do that is kind of – I don’t think we really mentioned it, but we have a robust set of CLI tools that help you get up and running with the Dojo project and sets up the build for you and does everything for you, so you don’t have to mess around with a really complex Webpack config or anything like that. You don’t even have to realize that it’s using Webpack, and then you can build and serve your application in development, and then it’ll automatically rebuild on every change, and then also build for production from there.
So the PWA story kind of goes along with that, with “What can we provide from the CLI tooling to make it as simple as possible to take your app and convert it into a PWA, or to deliver it as a PWA.
That is very cool. I’m very excited to see the future of that as well. So I wanna take this moment to thank Dylan so much for coming on JS Party and sharing past, present and futures of Dojo, too.
Thanks for having me, it was a lot of fun.
Jerod dropped a rap into the JS Party Slack chat, and I see that there’s been some encouragement for me to do that rap… So Jerod, this one is for you:
“D to the Ylan, Schie to the Mann,
Here comes that Dojo that’s gonna make you a fan!
Big version 2, who saw it coming?
Two years later gonna get you up and running…!”
Thanks for tuning in, everyone. See you next week!
Our transcripts are open source on GitHub. Improvements are welcome. 💚