Open Source Friday with Alex Lichter and Nuxt.js
09 Mar 2024 (6 months ago)
Duolingo
- Duolingo uses GitHub Copilot to improve engineering efficiency, increasing productivity by 25% and enabling more thoughtful conversations and big ideas.
- Copilot is used daily by Duolingo employees and simplifies their day-to-day work.
KNX JS
- KNX JS is a meta framework for building any kind of application based on Vue.js.
- It provides superpowers to Vue applications, including easy deployment on various platforms and rendering modes.
- KNX JS values freedom of choice and ensures that deploys will work even if users switch platforms.
- Alexander Lehr, a contributor since 2017, joined the core team in 2018.
- Lehr's open-source journey began with PHP, where he contributed to documentation and packages before discovering front-end development.
Open-Source Contributions
- The speaker's open-source journey started with solving a personal problem, leading to the creation of a module for Kendo UI.
- They were later approached by the core team and invited to a conference in London, marking a significant moment in their open-source journey.
- Contributing to open-source doesn't have to start with big popular projects; beginners should start with smaller modules or good first issues.
- The Kendo UI and Vue communities are welcoming and supportive of beginner contributors.
Kendo UI and Next.js
- A live coding session showcased setting up a Next.js application with Kendo UI and demonstrated the hot module replacement feature.
- The speaker emphasized the importance of documentation and provided tips for finding modules and examples within the Kendo UI ecosystem.
- The KN Death Tools are a set of developer tools that run within a Next.js application.
- They provide an overview of the application's performance, modules, plugins, and components.
- The Death Tools are extensible, allowing developers to add their own custom windows and functionality.
- They include a VS Code tab for making changes to the Next.js application from within the tools.
Next.js
- The speaker demonstrated how to use the Death Tools to enable routing and create new views.
- Next.js supports file system-based routing, making it easy to add new pages and components.
- Route parameters and query parameters can be used to dynamically render content.
- Next.js supports both server-side rendering and static site generation, and JavaScript can be disabled for specific pages or routes.
- Route rules define granular control over which pages have JavaScript enabled, and caching and pre-rendering can be applied on a page or route basis.
- Next.js uses route rules to define dynamic data modes for different pages without using JavaScript.
- The default title for all pages can be defined in the configuration and overwritten for development or production builds.
- Debugging in Next.js can be challenging due to multiple packages and abstraction layers.
- The Discord server and the H3 relations website are helpful resources for debugging and understanding relationships between Next.js packages.
- The visualization tool used in the presentation is built using Vis data and is open-source.
Vue.js
- Next.js offers different strategies for fetching data, including async data fetch and plugins.
- Composable functions in Vue.js should only be called in a view or component context.
useRoute
should not be called inside a function that is not in a view context, such as a button event handler.
useFetch
can fetch data from an API and be used for server-side rendering.
useFetch
has a refresh
function for refetching data on the client side.
$fetch
is a wrapper around the fetch API that can submit forms.
useFetch
is recommended for data fetching in Vue.js, providing built-in features like automatic re-fetching when reactive properties change.
useAsyncData
is an alternative to useFetch
that allows choosing a custom fetching library.
- Vue.js provides end-to-end type safety for data fetching when using the Nitro server engine and API endpoints.
- Various methods can connect to databases in Vue.js, including KV stores, ORMs like Prisma or Drizzle, and lightweight SQL connectors like db0.
- Astro and Vue.js are both great frameworks, with Astro focusing on hydrating only active parts and Vue.js using server components to render static content on the server.
- Alex's podcast, Deja View, is coming out this month with Michael Ton, discussing the Vue ecosystem.
GitHub Copilot for Enterprise
- GitHub Copilot for Enterprise is now generally available, offering fine-tuned models based on an organization's code, integration with GitHub.com, and analysis of pull request diffs for more efficient code reviews.
Stability AI
- Stability AI announced the upcoming release of Stable Diffusion 3