- 
force_balance_tags function breaks nested G in SVG ↗SVG icons with nested <g>may be corrupted when displayed in WordPress. This is a 4+ year old bug. The simple workaround is to uncheck “WordPress should correct invalidly nested XHTML automatically” in Settings > Writing.
- 
Yarn 4.10.0 ↗In addition to pnpm supporting minimumReleaseAgein pnpm 10.16, Yarn has introduced a similar feature withnpmMinimalAgeGate. There are some minor differences which mostly effectnpmMinimumReleaseAgeExclude. This option is similar to pnpm’sminimumReleaseAgeExcludebut also supports an exact match on package locators like@react-router/[email protected]or semver and micromatch globs like@react-router/node@^7.9.1,@react-router/node@npm:^7.9.1,@react-router/node@*, or@react-router/*.
- 
pnpm 10.16 ↗Zoltan Kochan, following a wave of incidents where common npm packages including debugwere compromised with a phishing attack last week andnxwas compromised with a credential catcher a few weeks ago:There have been several incidents recently where popular packages were successfully attacked. To reduce the risk of installing a compromised version, we are introducing a new setting that delays the installation of newly released dependencies. In most cases, such attacks are discovered quickly and the malicious versions are removed from the registry within an hour. The new setting is called minimumReleaseAge. It specifies the number of minutes that must pass after a version is published before pnpm will install it. For example, settingminimumReleaseAge: 1440ensures that only packages released at least one day ago can be installed.
- 
Middleware in React Router ↗We landed our initial unstable implementation of middleware behind a future flag in 7.3.0. Since then, we’ve been iterating on the API/implementation and working closely with community members who adopted the unstable flag for alpha testing. We received a ton of valuable feedback from those folks that helped us move the API to an even better spot in the end. We’re excited to finally stabilize these APIs in 7.9.0 behind the future.v8_middlewareflag and can’t wait to see the interesting patterns folks come up with when using them. There are already a handful of useful middlewares available in remix-utils that are worth checking out!Providing data from a parent to a child: // app/root.tsx const context = createContext<User>(); const userMiddleware: Route.MiddlewareFunction = ({ context }) => { let user = await getUser(request); context.set(userContext, user); // 👈 Provide data here }; export const middleware = [userMiddleware]; export async function loader({ context }) { return { user: context.get(userContext) }; // 👈 Access data here } // app/routes/_index.tsx export async function loader({ request }) { let user = context.get(userContext); // 👈 Access data here // ... }Short-circuiting child loaders with a redirect: // app/routes/_auth.tsx const requireUserMiddleware: Route.MiddlewareFunction = ({ context }) => { let user = await getUser(request); if (!user) { throw redirect("/login"); } // ... }; export const middleware = [requireUserMiddleware]; // app/routes/_auth.profile.tsx export async function loader({ request }) { // ✅ This code will never run if there's no logged-in user let data = await getUserData(request); return data; }Via X
- 
Secretive 3.0.0 ↗Secretive is an app by Max Goedjen for protecting and managing SSH keys with the Secure Enclave. I’ve been using it for years. Major release a couple days ago: A huge update! UI Refresh for macOS 26 Tahoe and Liquid Glass, Post-Quantum Key Support, Enhanced Security, and lots more! 
Follow
Featured Blog Post
- 
Starting at AppleI will help small businesses succeed by building Apple Business Essentials — a product which brings together device management, 24/7 Apple support, and iCloud storage into flexible subscription plans. More → 
