Jerod, Kball, Divya, and Nick share their initial impressions of GitHub’s recently announced package registry, what JS skills are trending in job listings, and shout outs!
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
changelog2019. Start your server - head to linode.com/changelog
Gauge – Low maintenance test automation! Gauge is free and open source test automation framework that takes the pain out of acceptance testing.Less code, less maintenance, more acceptance testing. Gauge is a free and open source test automation framework that takes the pain out of acceptance testing. Gauge tests are in Markdown which makes writing and maintaining tests easier.
GitHub’s package registry
- Our “coverage” of GitHub’s Friday afternoon announcement
- GitHub’s official package registry feature page
- Remember when we had Jeff Lembeck on JS Party?
- Something strange is going on at npm
- Nobody Predicted Microsoft 😬
JS job trends
- Engineering & design progression maps: progression.fyi
- KBall’s megatrends post
Click here to listen along while you enjoy the transcript. 🎧
Hello, party people, and welcome back! It’s JS Party time. Once again, we have an awesome panel, as we like to do every single week. I’m Jerod, I’m here, I’m joined by three amazing people. Let’s start with Divya. Welcome back to JS Party.
Hello! Happy to be here.
And that’s not all… We’ve got Kball! That rhymed. Nice.
Kball rhymes with all sorts of stuff. Hey! Happy to be here.
And last but certainly not least is Nick Nisi. What’s up Nick?
Hoy, hoy. Is that gonna be your call signal from now on?
I think so. That’s how Mr. Burns answers the phone. “Uhm, hoy-hoy!” [laughter]
I like it. I actually like it a lot better when you do it with that affectation, so… I’d suggest keeping it, but doing it just like that next time.
We should do a JS Party where everyone adopts an accent. The whole thing.
Oh, my goodness.
That’d be terrible!
That’s be hard just to maintain that for 45 minutes.
That’d be so hard!
Let’s start off with GitHub, the source of all code, the host of most code, and trying to be the host of many packages. This was a big announcement that happened last week, and it happened kind of in a weird way, if you ask me. Friday afternoon…?
Yeah, exactly. I only heard about it because I was at a conference, and then a fellow speaker was like “Hey, did you hear about the announcement?” And he only knew about it because he worked at Microsoft. [laughs]
Yeah… I mean, I’m not a PR person, but I know that a common tactic of PR people is when they wanna bury a story - it has to come out, but they don’t wanna make it a big deal -they will announce it or put out a press release on a Friday afternoon. Famously, back in Antennagate, with Apple, when Steve Jobs held that event on the campus, and really wanted Antennagate just to end, back with the iPhone 4 (maybe it was), they had this event on Friday afternoon, and it was effective.
So it’s just a strange thing… Maybe they’re trying to fly under the radar. It’s hard for GitHub to fly under our radar, because we are so integrated. I mean, “we” not Changelog, but “we” the developer community… So maybe they just thought “Hey, let’s just do it now, and people will find out.” What do you guys think about the Friday afternoon live stream?
[04:11] I saw a tweet about it 2-3 days before, and I thought it was very strange, because usually I find out about new GitHub features on the homepage. There will just be like a little box that says “Hey…!”, and that links to their blog, and has whatever the new feature is. Draft PRs, or whatever. But I saw a tweet, and I’m like “Man, they never pre-announce an announcement like this”, so… I was pretty excited to tune in, and I watched the live stream and was excited about it.
I was there long enough to get the gist of the announcement, and then – it was Friday afternoon, I had other more relaxing things to be doing… So tell us about the stream itself, Nick. I know that Nat Friedman was up there, they brought up some demos… What was the overall feeling of that presentation?
It looks pretty cool. They did the typical thing with announcing new things, where they’re like – I can’t remember the presenter’s name, but he kept saying “Nothing up my sleeve” or “No tricks here.” They’re trying to tell you that it’s not magic, this is actually working, and it’s doing what we’re saying…
This isn’t vaporware?
Yeah… Which I thought was kind of funny. That was the big takeaway I got from it, other than the actual announcement.
Were they over-emphasizing that, to the extent where you’re like “Hm… Maybe this is vaporware…” [laughter]
Maybe I caught on to that, but no, I don’t think so.
So the details of this you can find in the show notes. Of course, you can just go to github.com/features/package-registry if you wanna read it for yourself. It says “Your packages, at home with their code.” And it says “With GitHub Package Registry you can safely publish and consume packages within your organization or with the entire world.” They have – I guess you could call it a limited set, or a starter set of supported ecosystems and language; npm, RubyGems, Docker, NuGet, Maven, and I think that’s it… There might be a couple more, but that’s at least what they’re launching with.
Yeah. I was really surprised Python wasn’t on there.
Like, pip is in there, and Python is a huge community, and I was like “Where’s Python?”
Yeah. Is that a diss, or is that just the MVP, trying to get something out there…
It makes a lot of sense, right? I guess first impressions, maybe… Kball, you’ve been quiet so far - first impressions just of the concept; okay, now GitHub is going to be a package registry… Whether it becomes THE package registry for some of these ecosystems or not, I think that’s still left to be found out, but… Just that they’re moving into this space, what is your initial impressions?
Yeah, so there’s two areas of this that I think are super-interesting, where GitHub can really make a difference relative to the status quo. One is I think this makes it far easier to set up internal package registries, to share code inside of an organization… Because you don’t have to figure out anything new, you don’t have to set up your own server to manage it, you don’t have to do any of that. You just use the tools you’re already using, and you can make internal packages and set up an internal registry. So I think the organizational case for that is really interesting.
But what this enables is at least the potential to do end-to-end validation of “Is the code I’m looking at as an open source developer reviewing this actually what’s getting installed in my system?”
That’s really interesting, and I think that that’s the one main place where they could shine with this. I was trying to think of how they might do that, and this does work with GitHub Actions right out of the box. You can have an action that once you push to master, then take that and package it up, or something, and maybe they could have some kind of badge system where if this package was deployed via this specific action, it gets this badge, and that’s like your certified pipeline badge. So it’s still up to the packages maybe at that point to set up that verification system, because I’m not sure they could do it in a global way… But at least then you know that it went through this automated system and not just somebody publishing straight from their desktop.
Chris in the chat is asking me a question, “Is this GitHub or is this Microsoft?” and what he means by that, I think… And we can’t know, but product roadmaps take a long time, and huge new – I mean, this is a whole other area of their business at this point; these things don’t spike out in three weeks and then get released. And we know Microsoft has purchased GitHub - gosh, probably coming up on a year, or 18 months; I can’t remember the exact timeframe. But the question is, was this a thing that was already up and moving with the previous GitHub management, with different leadership? Or is this a thing that Microsoft came and said “This is a next step.” Because this is a huge next step for them branching out.
Yup. It’s also really exciting, because with this it means that – because a lot of the times with package registries, like if you think of npm and RubyGems and so on, it’s really hard to find, like… Because there’s the package registry, and then there’s where the code is hosted, and a lot of the community is in GitHub; people submit issues, pull requests… They see the code, and you kind of gather in one place, and not in the actual package management place.
So with this it’s really nice, because it seems like a centralized location where people could be like “Oh, okay. I can easily discover packages in GitHub, and I can also see what are the open issues and things like that”, without having to toggle between like “Oh, I’m on npm, and now I have to go back to GitHub”, or do the weird click-through, which is like “Where is the GitHub link?”
The weird click-through, yeah…
I always find myself – I’ve done it so many times, but I’m always “The git… where is the GitHub link?”
That’s all I do on npm, is just find the GitHub link and then go there.
Exactly, and it’s really frustrating… But yeah, so hopefully this will be much nicer, a better workflow. And like you’re saying, Nick, with the GitHub Actions - I think that’ll be really neat as well, because I find in general whenever I publish a package, I would have to use the npm CLI, and then… It’s basically like two different things I’m doing. I’d be like “Push to GitHub”, and then from GitHub I have to version it, and then I have to be like “Okay, let me go publish it on npm”, and then figure out what’s happening. I’ve messed it up a couple of times. I’m like “Wait, let me roll back! Roll back!” [laughter]
And then the second one, which is almost the inverse problem, is –
I know, I was torn as well.
I kind of like that npm is a different company than GitHub, and a different company than whatever else. There’s GitLab, and GitHub, and whatever. If everything is going through GitHub, which is Microsoft, are we continuing to consolidate power in our industry in those top four companies?
And this is definitely the “embrace and extend” part of Microsoft’s past history.
The three-part strategy, yeah. It’s such a weird dichotomy, because you do have both concerns. You have a fragmentation concern, and then you have a centralization concern, and I think they’re both legitimate, you know? I could see both of them happening in certain ways, and both of them affecting negatively both the already diverse ecosystems, and then the convergent one ecosystem of GitHub.
Just to confirm, do we think that this is directly competing with npm’s enterprise solutions?
I assumed it wasn’t. I just assumed this was just a way for making the workflow easier, but it wasn’t necessarily a competition. I don’t know…
I would think it’s direct competition myself. I mean, it’s public or private, so I think there’s definitely – maybe not the on-premise stuff… Maybe. I don’t know. But definitely in terms of where enterprises do their packages; I think it’s a direct competition.
I do, too.
I mean there is also a sort of de-risking component here… Because I don’t know if I’m – I’m probably not the only one who’s watched all the npm-related drama on Twitter going down over the last few months…
But yeah, with that in the background there, there’s like a “Hm… I depend on this for an awful lot of stuff. Is this company gonna be around in another three years?”
Can you summarize that without slamming anybody? The drama.
Yes. So I’m not on the inside of this, I have no context over what is right or wrong… I know that there was once some buzz around a set of people being laid off from npm, that the assertion made (as I understand it) was that this was done very inelegantly, and by a third-party coming in, rather than direct conversations with the executives, and that perhaps this was done to people who had just recently been hired. So it was done in a way that left a lot of people with a bad taste in their mouth.
Following that, I have seen a number of high-profile members of npm saying that they are leaving npm, often without saying too much more than that… So not weighing in on the drama, or the this and the that. We did a – I don’t remember if it was JS party of Changelog, but there was an interview we did with Jeff Lembeck and his people… Well, I saw on Twitter that Jeff is leaving npm. And a number of other folks who have been at least very visible in the community representing npm have announced publicly that they are leaving npm. So it makes me wonder what’s going on behind the scenes there.
Running a company is bloody hard, and without knowing the background, I don’t wanna place judgment on one person on another, but it definitely seems like there is a lot of struggle happening there right now.
Well, if they are in distress, this will crank up the stress for sure, as they have now a heavyweight competitor. I guess we’ll talk about the state of the package registry right now… Sign up for the Beta; I guess similar to GitHub Actions, which is I think still “Sign up for the beta”, which has been a long time, by the way. Maybe showing some signs of big ships move slowly.
Google syndrome. How long was Gmail in beta?
12 years, wasn’t it something like that?
A couple of other interesting bits on this is that it does work within the APIs of the existing CLI apps that you would use. So you would still use npm or Yarn or this, and I assume the same thing for Docker and Maven and all of those; I was more just interested in the npm side of it, obviously… But then it also allows you to have public and private repos. And I think private is only for GitHub Pro, if I remember correctly…
I think it’s free for all now. They’ve changed that recently.
For repos. I was wondering about private packages.
Oh, for packages…. Um, actually it might be Pro, yeah. That would make sense why people go Pro.
Yeah, it was giving incentive to go Pro. [laughs] But yeah, that will be interesting. I think that that coupled with the things that you can potentially do with Actions, or with some kind of certified pipeline, are the things that will make this stand out over just npm, or RubyGems, or whatever the other package managers are.
Also, totally separately, but I’ve found it really interesting, because when GitHub announced their new registry, GitLab released an article saying “Hey, we did this before everyone else…” [laughter] It was an article saying they did this back in 2016, or something… It was like, “Okay, cool… Nice flex, GitLab.” [laughs]
That is funny.
[20:24] I really want to like GitLab, and every time that I’ve tried their UI, I’m like “This is so much worse than GitHub.”
The focus on design, interaction and UI isn’t there. And I think they’re doing some really innovative things, and I think they’ve done some great stuff for supporting the open source community and supporting the Vue community, which I love, but their product to me as a developer is pretty inferior relative to GitHub.
GitLab might become the new Dojo. Wasn’t Dojo the “Dojo already did that?” [laughter]
I was gonna make that joke…
I beat you to it. Okay, final thoughts on GitHub… A lot of this I think is kind of wait and see, our prognostication of what might happen, our fears, our desires. It’s compelling; integrated products are compelling. I think there’s an ideological tug of war here, because Git is distributed version control, and we’ve moved a lot of our stuff to one centralized for-profit company, and now here’s a whole other area which was on a different for-profit company, and now it’s like “Well, maybe GitHub will be a decentralized platform”, and that usually ends up bad.
I think over time Microsoft will start owning everything. We use VS Code, we use GitHub, and now we’ll use their registry… They’ll just own every step of the process.
And what’s interesting… There’s like four(ish) companies that are dominating the industry right now. You have Microsoft, you have Google, you have Facebook, you have Apple… Did I miss any? I think that’s pretty much it…
Did you say Amazon?
Oh, Amazon, right. 100%. Amazon. Of those, only one seems to have a bad reputation among developers. Facebook. Folks are kind of jumping on the bandwagon. “Oh, AWS is so awesome! Microsoft is so awesome, all these things they’re doing…!” and they are awesome. They’re doing a great job, building great things, and we’re letting them continue to consolidate power, and consolidate – as you say, Divya, eventually all of our stuff on this end will be using Microsoft products, and we’ll be hosting everything on AWS, and blah-blah-blah… And if you’re not hosting on AWS, you’re hosting on Azure, or you’re hosting on Google Cloud. That’s a very fragile world to live in, and it’s one where individuals have given up a whole lot of power.
Two last points that that makes me think of. The first one is that Microsoft – you just named Microsoft and said that only one has a bad reputation with developers, and that it wasn’t Microsoft, it was Facebook. And it’s true. Microsoft has been on a very intentional (I don’t know) five or six-year process of mending their relationship with the software developers that weren’t always inside of the Microsoft Windows camp. And they’ve done a heck of a job at it. It’s evidenced by everybody using VS Code, like Divya is saying; everybody is using GitHub and loving GitHub, and Microsoft owns that, and it hasn’t been bad for us yet… So it’s just interesting how successful they’ve been at changing their reputation, because public opinions are a very hard thing to sway.
[23:56] The second thought I had is there’s an adage, mostly about robotics and automation, and AI and whatnot, about Amazon - in the next ten years you will be either working for Amazon, or they will put you completely out of business. That’s the path that Amazon is on, just in the more mainstream space. So in a lot of ways maybe in the software space, set aside AWS, Microsoft might be on that path where they might be the player when it comes to developer tools over the next 5-10 years.
Yeah. I think it’s only in the recent few years where I’ve heard people say they would want to work for Microsoft… [laughs] I have not heard that in a really long time. And now there are lots of developers, very talented developers who are like “If Microsoft gave me a job, I would take it.”
That’s a huge shift. And that probably moves us to the next segment, on job skills stuff. We can talk about that later, but… It’s just an interesting way of how they’ve positioned themselves. In the developer community they’re seen quite well now. And they’ve obviously done a good job, so… Yeah.
Just to close it, there’s a Twitter account, @npm_parody that speculates on what npm might actually stand for, and I saw a tweet from them, “Nobody Protected Microsoft.” [laughter]
I believe that npm account was created specifically when the package manager was announced.
All of their tweets are May 10th.
Could this be…
…the new Horse JS?
Horse JS has longevity. They first tweeted May 10th, they last tweeted May 10th.
Oh, it’s a one-and-one kind of thing.
This is a one-hit-wonder Twitter account.
I’ll tell you right now that React is numero uno, so it wins the Game of Frameworks, I guess, even though – is it a framework? I don’t think it’s a framework. That being said, how do we define these things? Node.js is one there, so… Is it a framework? Git is on there. Is Git a framework? [laughs]
Yeah, I think they call this skills…
I know, but it was called “Game of Frameworks.” I know it’s a Game of Thrones reference, but it’s like, where are the frameworks? Anyways. I’m nit-picking at this point.
Not a good reference.
Yeah. Trying too hard.
That might be a legit situation, if they’re just going out and regexing a bunch of job postings, and somebody put a space between… We have to follow up and ask them on that.
Luckily, Script is not number eight. [laughter]
“We need scripting skills, nunchaku skills…”
jQuery in the top ten there. Still legitimate.
I’m a little sad that Vue is so low on that list… [laughs] Why is it so low?! It’s below Python… [laughter]
At least your framework is on there.
Yeah, that’s cool.
[laughs] And not featured things, like Dojo, Ember…
I think it is interesting to think about this… It’s hard to know without trend lines how much we should be considering this, but this is an interesting snapshot of what are people looking for. I do wonder – it says 300 job listings, and then it has numbers next to them, so I’m wondering, is this 267 job listings out of 300 featured React? And if so, why does Angular have 195? Are these saying “React or Angular”? That seems a little off…
Oh, I bet they probably are. There’s some job listings out there where they’ll just list off a laundry list of skills that you should have in there, and it’ll be a comma-separated list.
You should know React, Angular, Vue.js…
Right. 14 years of experience with GraphQL, stuff like that.
And there’s also general ones, which is like not really tech-specific… There’s like OOP, and then I think those design patterns as well, which I was like “That’s interesting…” Because that’s very general, and subjective.
Maybe it’s pre-supposed. [laughs]
What about in your listings? Is that how it is as well?
Yeah, I think so. I will have to double-check that though…
Uuh, now we’ve got – quick look…
And shout-out, by the way, to Natalie Marleny, who I’ve met at React Amsterdam, who pointed me at progression.fyi. It’s super-cool stuff. But this guy Johnny Burch has put this together, and one of the things that I’ve found pouring through these is different companies call these different levels, different things. At one company they might call it Engineering 1 vs. Junior Developer vs. this, that and the other, but there are a lot of commonalities across them… And this isn’t gonna tell you which skills in terms of “Should I be learning React versus whatever?” But if you’re entry-level and you’re a junior, typically what you’re gonna be doing is you’re gonna be working on pretty well-defined tasks, doing bug fixes, and really learning how to learn.
So your focus should be figuring out how to go deep. Pick one specialty, go deep. If you’re in the front-end, maybe pick React, or something. Pick one framework, go really deep on that, and don’t worry about all the other stuff, because junior developers are not being asked to integrate across five different things. They’re focused within one area. And then as you go up the hierarchy a little bit, you get into mid-level, 2-3 years in; now you should be able to do something on your own within your area of expertise, and start to get touching other things. That’s when you’re gonna start to branch out into other skill areas. But yeah, if you’re just coming out of a bootcamp, don’t try to do all the things. Pick one, go deep on it.
That’s a really interesting take. So would you say in 2019, if you’re gonna pick one to go deep, it seems like you can’t miss with React right now.
If you are in the front-end and you’re looking for something that’s going to get you a job, React is probably your best choice.
Sorry, Vue.js. Sorry, Divya.
Vue is still cool.
[35:59] It’s still cool. [laughs] So Rich Howell in the chat is also a Vue developer, and is currently applying for work, and can confirm that it’s pretty low on people’s list. He says thankfully, his Vue experience transfers over to React pretty well. So that’s one thing that you’ll find over time, is a lot of the skills from all these things transfer over. There are some – if you’re deep into Angular and you know the bugs, the workarounds for the bugs, that skill will not translate. Maybe your process of finding those workarounds absolutely will, but you know how exactly to interact with this API because you’ve gotten that deep into it - that itself probably won’t transfer over to another one, because they’re not gonna have that bug. They’re not gonna have that specific API. That being said, the general themes and architectural things in a lot of these frameworks will transfer over.
I think a lot of what happens with people is they just get analysis paralysis, and they’re just like “What do I pick? What do I do? I’ve spent most of my time reading articles like this, of which one, because it’s such a huge decision.” And I guess my point here is just realize it’s not that huge of a decision, and maybe just optimize for something like this - “Most jobs here… I’m just gonna learn that one and go from there.”
It does seem like today – although maybe tomorrow Vue will be higher up… But if you’re gonna just pick one and dive deep, it seems like React is in 2019 your best bet.
Yeah, there are some mega-trends that are showing up across the board, that to your point – like, if you learn in one example, it will then be easy to branch out. Staying in the front-end world - I think there are also some mega-trends in the back-end - component-oriented development. Thinking about things as a set of components that can be interact, and plug-and-play. React is doing that, Angular is doing that, Vue is doing that, Ember is doing that, Dojo is doing that, Mithril is doing that, Svelte is doing that… That is the approach that we’re going.
Start in React, because it’s easy to get a job there. Dive deep, but have in mind, “Okay, how am I thinking about components? What are the boundaries? How are we doing that?” That understanding, that knowledge, that experience is gonna translate no matter what framework you end up moving to in the next job, or whatever.
Similarly, things like declarative coding… We are increasingly moving to a declarative paradigm for our components, we’re not imperatively doing things we’re thinking about. “Here’s what this thing should be”, and letting the frameworks handle how and when. And that’s another place where so long as what you’re working in is doing that, which means maybe not focusing on jQuery… But if you’re doing React, those skills are once again gonna translate.
There’s a lot of these mega-trends… I identified five in a blog post earlier this year. But if you look for the bigger-picture questions, and start learning those within the context of one thing you’re going deep on, you’re not gonna end up in trouble when suddenly the flavor of the month changes.
I’m gonna assume that’s what that list meant by design patterns… To be like, generally, declarative vs. imperative. And how you do something in React, which is overall very specific to the framework, but the pattern of doing it can be used in Angular, and can be used in Vue if you just change some syntax and the structure; essentially, they all call it different things, but they might mean the same. So if you master one framework and just know it really well, translating can be frustrating, but at the same time you have the tools and you have those patterns that you already are familiar with, and they will probably translate quite easily once you get used to a different syntax, and everything.
Also, I think I posted in the chat, but have you seen that tweet that Emma tweeted a couple of days ago, about React being the kid who cuts school, and then Vue being the nice kid in school? [laughs]
[40:06] She was trying to immortalize the different technologies, and I thought it was really funny… And CSS is like flaky, unpredictable one. [laughs] It’s so funny…
What about the back-end, guys?
Just learn Express
I’m currently using a project called NestJS, which is like a TypeScript wrapper around Express, but it makes it more Angular (that’s the way I describe it), in a good way.
Give the elevator pitch on Express. Explain what that is.
It’s a way to handle routes for back-ends. You can define and say - when your server gets a call to this request (this URL, effectively), run this function and deliver something back. Then it gives you the ability to add in middleware and other things, so you can plug in and say “This route is only available to administrators, so before you actually serve it, double-check this route specifically, and make sure that the user is authenticated, to be able to see it. If not, throw them back in there; otherwise run the function.” And kind of abstracting that away, so that you don’t have to think about it on every single request.
Anybody have anything to add on the back-end space trends? What to learn, what to avoid maybe?
I think one thing that is tricky both on the front-end and on the back-end, and I think judging from what I’ve seen is something that you start to really wrap your head around a little later in the game - certainly a year or two at least into your career, if you’re coming from bootcamp, and we have focused very much on early-career folks for this conversation… This is data manipulation and data management. How do I think about taking data, transforming it, using it in different ways, whether that’s on the back-end, saying “What are the data stores that I’m working with and how do I normalize my data?”, or on the front-end, saying “Okay, I’m loading this data from APIs, but it may not be exactly what I need for my UI, unless I’m using GraphQL, or if I am using GraphQL, thinking about how do I generate those queries?”
[44:01] That way that data flows through systems, and you can manipulate it, and thinking about things like transformations, and mapping, and all that stuff - that seems to be something that is a little harder for folks to pick than the kind of first UI logic, or in the back-end, sort of first logic around “Okay, I’m setting up these routes, and this type of thing”, but really starts to be important as you go forward. That seems like you’re just thinking about data and how data flows through an application is something that – it’s not really well-captured in one particular tool here, but definitely is something that I’ve seen folks struggle with, and that is really important as you start to move from entry-level to a little bit more senior.
I think especially since it moves past just working on small features, and you have to think about the overall architecture, and whether it’s scalable and maintainable; those are the things that you have to think about - how does the data flow, what is the architecture of the back-end and how does it provide data to the front-end, and how does the front-end liaise with the back-end, and so on? And just understanding that requires a bit of experience, and having worked on different applications, having played around with things… Yeah, generally the more senior you get, the expectation is that you know how to do that, and how to work those problems.
Would you classify tooling as a back-end or a front-end thing? Like webpack, and other tooling like that.
Yeah, it depends on what kind of tooling you’re talking about, I guess. Are you talking about back-end tooling, or front-end tooling?
I would say version control, communication and things like this cross all those chasms, but toolings very specific to – I mean, Docker, I guess, would be another one that is general. Containers, that kind of stuff.
I feel like containers moves into dev-opsy space…
Well, at least to be able to use them, if not to create them, right?
Yeah, just like create a Docker file, and then like “Okay…”
That’s very much where I’m still at; it’s like “I can create a little Docker file, and I can do a thing, but…”
That’s usually where I’m at, yeah. And half the time when Docker doesn’t – sometimes it has trouble with hot reloading, and then people will be like “Oh, just restart your whatever”, and I’m like “Cool…” Just turn it off and on again; that’s pretty much mine as well, if it doesn’t work…
A lot of tools are like that. Git - you can get by on about eight Git commands for years. You’re just like “Do the magic incantation…”
Oh, 100% yeah.
Just write them down, and use them, and eventually you might figure out… I still don’t know exactly how Git works. I know there’s a lot of pointers to SHAs and stuff, but I don’t know; I just have all the commands memorized, and…
Yeah, and you don’t need to use all of them. I think I’ve only used the Git bisect twice ever, and that was a mistake… [laughs]
Yeah, I used it once, and I’m like “Oh, I’m never doing this again…”
Exactly, because it’s just like “I don’t know what’s happening.”
I just decided to write less bugs.
I’ve done an advanced Git workshop once, and I spent the first hour-and-a-half going through the anatomy of a single commit.
Wow… You should do that on the show sometime.
It’s very in-depth.
Yeah… There’s a lot of interesting things in there.
If you choose to climb that ladder, it does open up a lot of really interesting things. I definitely have been called in more than once to recover, like “Oh my god, I feel like I lost my code”, or “Oh, what happened here?” Just understanding how Git works, even if you don’t necessarily know all of the different commands, but if you’re willing to put in the work to build that mental model of like “What actually is happening, and where are these things, and what are the many ways that I can find and get to them?”, it does have benefits that flow out.
[48:03] I think also when you’re starting to have arguments around whether you should squash your commits or do a merge is when you’re like “Okay, I think I’ve leveled up my Git skills…”, to a point where you can have an opinion on one versus the other.
Even if you’re Nick and you have the wrong opinion… [laughter[
Hey, what does Nick think?
Squash all the way.
Oh, yes! I’m team squash, too. [laughs]
Nick is a pronounced forced pusher, so… You know who you’re talking to.
You know who you’re alliancing with right here.
I think I’ve had that opinion on teams before, because I’m like “I like clean history”, and they’re like “Well, clean history is everything”, and I’m like “That’s not clean. You’re sorting through the garbage.”
Exactly. The people who think that haven’t used git bisect.
Often clean history is incorrect history.
Do you wanna lie to your friends and family? Is that what you wanna do?
Yeah, but most of world history is not raw; it’s been cleaned up…
It’s written by the winners.
Which is why it can’t be believed. It’s untrustworthy.
I wanna show things the way that they should have gone.
Right. Which could make it very hard to track down what went wrong. Anyway… We’re way off the rails here, but it sounds like Jerod and I are on one side of a holy debate/war, and Divya and Nick are on another.
We’ve just found our next segment idea. [laughter]
Okay, folks, one of our favorite segments is shout-outs. This is a great opportunity for us to shout-out and thank or give props to a person, people, a project - anything really, that we think deserves some shout-outs and maybe hasn’t got them, maybe has, but we all like to take a turn. Let’s start off with Kball… Give us your shout-outs.
Alright, so I wanna shout-out a category, and then I’m gonna shout-out three particular examples. The category that I wanna shout-out is people who are doing work to bridge between design and development, and sort of emphasize UI-centric and design-centric front-end development. This is a place where stuff often goes wrong, and we’ve had whole conversations about challenges, even within the front-end development space, the divide and various other things… But there’s a lot of people doing yeomen’s work here.
Three particular people and instances I’m gonna shout out. First, there was a recent article on Smashing Magazine by Stefan Kaltenegger; I probably butchered his name… But he did this article on essentially how you can work to bridge the gap between designers and developers, and it’s just kind of a nice walkthrough of things that you can do as a developer and as a designer - I think more focused on the developer - to help bridge that gap. It also referenced out to a cool resource that I hadn’t seen before called “Can’t unsee”, which gives you practice developing your design eye. So that’s one of the three people I’m gonna shout-out on this subject.
[52:09] The next one is Ryan Singer, who wrote an article on the Signal vs. Noise blog recently about the place of UX, and looking at alternative ways of thinking about user experience as essentially being the boundary between any two things that are supply and demand. One, he was talking about - okay, between the user and the product, that’s where we usually think about it, but actually this concept of design is really important at every place where you have interactions between different groups. I think that was really cool.
And then the final shout-out I’m gonna do is for a conference that my friend Dylan Schiemann is involved with organizing. Conference organizers in general deserve shout-outs, but this one in particular is a conference called Halfstack, which is focused on UI-centric front-end development. They are expanding from being only in London, to having events in Vienna, New York, and Phoenix, and various other things.
It’s super-cool to see this UI-focused development stuff growing and being more present around the world, so props to those three people - to Stefan Kaltenegger, Ryan Singer and Dylan Schiemann, all of whose names I probably butchered.
Kball the Butcher. Alright, Divya, your turn.
Awesome. I’m gonna shout out to a conference, and someone on this panel is organizing it… NEJS. It is really cool, and I’ve spoken at NEJS two years ago; it was actually my first conference talk, and I feel like the organizers were so cool, and awesome, and the conference itself was wonderful. It wasn’t at the zoo, which it is gonna be this year, which is super-exciting. Also, I’m so excited about the theme! [laughs] It’s Life Aquatic, and it’s so cool! I heard someone’s gonna dress up as Steve Zissou…
Who is this someone you keep referring to?
I don’t know…
Could it be Nick Nisi?
[laughs] Could it be…?! I’m more interested in who’s gonna be the jaguar shark more than anything. [laughter]
I feel like we have to get that done now…
Yeah. I feel like Nick will just come out with this kid dressed as the jaguar shark.
That’d be so cute…!
“Baby shark doot doot”
Oh no, please don’t sing it!
Yeah, please don’t. Please don’t. Nooo, it’s too late…! It’s in there.
Yeah, I know. Once it’s in your head, you can’t get it out. And then this is another shout-out to a tool that Rouzbeh mentioned on the chat, which is Quokka.js. It’s interesting, because this is a tool that I recently heard about, and it’s funny that he posted it as well… So I was at NationJS, which is a small conference, also really great, in DC, and Nir Kaufman was one of the speakers; he’s big in the React community in New York. He spoke about Quokka, and it was so – I had never heard of it, and I think it’s really cool, because it allows you to prototype… It’s like a scratchpad for when you’re working on stuff, so you’re like “Oh wait, I’m working with this library, and I don’t know how it work”, and you can kind of just use it as a scratchpad, and be like “Let me try different things”, and then erase it when you’re done, without having to mess up your files… Which I think is so cool and interesting. Even the way that it was presented to me…
Most of the time you look at a framework, and you look at the documentation, and then that’s how you learn how it works; a library like Lodash, for example. But with this, you can actually work on the thing… Which I’ve done before. I’ve used RunKit, and various things on npm, where you’re like “Okay, I wanna play around with this tool, and see what things are doing”, but I think Quokka allows you to dig really deep into a specific library or tool, which is so interesting, just from a learning perspective… Going back to the conversation of scaling up - to be like “I’m a junior developer”, to be like “I wanna progress”, I think that’s such a great tool for you to just learn about how tools are created, how libraries are architectured, and so on.
And then the last thing - I really like shaders, just for fun. They don’t really do anything for me in terms of getting me money, or a job…
I worked on WebGL and shaders, which is something I don’t normally do… And you’re surrounded by super-smart people, and you learn about different things. Yeah, definitely Recurse is a huge shout-out, and the community is awesome as well. If you wanna just plug into a community of developers who are really excited about what they do… That’s not Twitter. Twitter has that, but you also have to sort of sort through the garbage, because you can’t squash [unintelligible 00:58:30.04], or whatever… So yeah, those are my shout-outs.
Very good. Well, we appreciate the NEJS shout-out. Nick, give the pitch here. Do we have tickets for sale? Or what’s the situation on NEJS?
Tickets for sale. It’s August 9th. Our early bird tickets are going right now, and you can pick them up at NEJS.com. I would say that our CFP is still open, but by the time this goes out, it will not be. But that’s okay, because we’ve got a lot of awesome proposals that have been submitted, and really looking forward to the painstaking task of having to say no to so many of them… Because that’s always the toughest part of being a conference organizer.
Otherwise, it’s August 9th at the Henry Doorly Zoo, the number one zoo in the world, according to many places…
Is it really?
I think so. At least it was at one point…
In the ’80s. No, just kidding.
[laughs] Yeah, it’s really cool.
At least in America, for sure, and maybe in the world, I believe. But it’s a spectacular zoo. While we’re talking conferences, real quick - and I’ll get over to you here, Nick - I wanted to mention All Things Open. This fall in October there will be a large portion of Changelog folks at that conference… So if you’re going to be there, give us a shout-out, let us know. We might organize something like a meetup, or a live show, or something; there’ll be a lot of JS Party people there as well… So I just wanted to give everybody a heads up that All Things Open, in October - it’s in North Carolina - is a thing that we’ll have representation, and we’d love to come out and see everybody, and come say hi. That’s just a quick one there… Back to you, Nick, on your shout-outs.
Wait, I wanna chime in on the zoo, really quick, as a former San Diego resident…
My gosh, San Diego Zoo is the best! Sorry, sorry… [laughs]
[01:00:19.08] I don’t know how to judge it, because I have not actually been to the Omaha Zoo, however I did look up a little bit of the statistics on them, and it looks like by – when was this… At least a number of years back, by a number of five million a year to one million a year, there are a lot more people who think the San Diego Zoo is a place worth going.
Hm… Now we’ve got a new ground war here.
We’ve got Git styles and zoos we can go back and forth on.
That might just be a statement about San Diego versus Omaha, I don’t know.
Yeah, I think it probably is. There’s a lot more people. San Diego has a pretty nice weather. I haven’t been to that zoo, but I’ve also heard that it’s a great zoo, so… There’s room in the world for more than one awesome zoo, but ours is the best. Alright, Nick. Your turn. [laughter]
Yeah… [laughs] My shout-outs - I’m gonna shout out to Rene Rubalcava; I might be mispronouncing his name. He’s a really cool guy who works at Esri. He runs a website called learn-dojo.com, and he’s just putting out these really cool tutorials on different parts of using the New Dojo. It’s just really great to see that, and the community, and they’re really great tutorials as well… So shout-out to Rene for doing that.
Then I just have to shout-out to Tim Pope, and specifically for his Vim Fugitive plugin. I just recently learned about the g command. I don’t know when that got added, but I’ve been using g status, and g read, and all of these commands to work for the most part with Git, but then I just go back to the command line for things… And with g, you can look at diffs of your commands and then stage those individual hunks right from there, right from within Vim, and you never have to leave, and it’s just so nice to be able to curate your Git commits and commit messages, all without ever having to leave them, so thank you Tim Pope for that.
Alright. Last but not least - my shout-outs. I wanna talk about something that maybe you know about, maybe you don’t… It is Go Time. You may know that we have another show that’s very similar to this one, called Go Time. And a lot like JS Party, where we had it going for a while, and we put JS Party on hiatus, and we tried to change some things to make things better, and we relaunched with an expanded panel - we had a very similar situation with Go Time.
[01:04:12.07] I just wanted to thank the new panelists, and say if you haven’t heard of Go Time, or you gave it a listen a while ago, it’s now a good time to check it back out, because it’s filled with very awesome people. I wanna thank them, and… Yeah, excited to have Go Time back.
The logo is so cool. I’m just looking at the mesh thing…
Thank you. Yeah, a little gopher head in there. Alright, any final words before we call it a day?
There’s nothing wrong with force push. [laughter] In certain circumstances. [laughter]
Why did I have to ask…?
You should have said everyone but Nick. [laughter]
I’m gonna end the show now, before Kball starts talking about the San Diego Zoo again… Okay, thank you everybody for sticking with us. This has been lots of fun. As always, more shows like this at Changelog.com/jsparty. Hey, do us a favor, if you liked this show - especially for people who are getting into this space, learning - give us a recommendation. We would really appreciate it. We love word of mouth; that means we’re doing a good job, putting out good content for you… And that is actually, still, even with all the technology that we have and all the social networks - word of mouth referrals is still the best way that people find and listen to new podcasts, so we’d appreciate you doing that.
That’s our show this week. We will see you next time.
Our transcripts are open source on GitHub. Improvements are welcome. 💚