![Malicious npm Package Typosquats react-login-page to Deploy Keylogger](https://cdn.sanity.io/images/cgdhsj6q/production/007b21d9cf9e03ae0bb3f577d1bd59b9d715645a-1024x1024.webp?w=400&fit=max&auto=format)
Research
Security News
Malicious npm Package Typosquats react-login-page to Deploy Keylogger
Socket researchers unpack a typosquatting package with malicious code that logs keystrokes and exfiltrates sensitive data to a remote server.
@next/font
Advanced tools
Package description
@next/font is a package designed to optimize and manage fonts in Next.js applications. It provides a streamlined way to include and configure custom fonts, Google Fonts, and local fonts, ensuring better performance and easier font management.
Custom Fonts
This feature allows you to include custom fonts in your Next.js application by specifying the font source, weight, and style.
import { createFont } from '@next/font';
const myFont = createFont({
src: '/path/to/font.woff2',
weight: '400',
style: 'normal'
});
export default function MyApp() {
return (
<div style={{ fontFamily: myFont }}>Hello, world!</div>
);
}
Google Fonts
This feature allows you to easily include Google Fonts in your Next.js application by specifying the font family, weights, and styles.
import { createGoogleFont } from '@next/font';
const roboto = createGoogleFont({
family: 'Roboto',
weights: ['400', '700'],
styles: ['normal', 'italic']
});
export default function MyApp() {
return (
<div style={{ fontFamily: roboto }}>Hello, world!</div>
);
}
Local Fonts
This feature allows you to include local fonts in your Next.js application by specifying the local path to the font file, weight, and style.
import { createLocalFont } from '@next/font';
const localFont = createLocalFont({
src: '/local/path/to/font.woff2',
weight: '400',
style: 'normal'
});
export default function MyApp() {
return (
<div style={{ fontFamily: localFont }}>Hello, world!</div>
);
}
The 'typeface' package allows you to self-host fonts by providing a collection of pre-packaged fonts. It simplifies the process of including fonts in your project but does not offer the same level of integration with Next.js as @next/font.
The 'webfontloader' package is a JavaScript library for loading web fonts. It supports Google Fonts, Typekit, and custom fonts. While it is versatile, it requires more manual setup compared to the streamlined approach of @next/font.
The 'fontsource' package provides self-hosted open-source fonts bundled as npm packages. It offers a wide range of fonts and easy integration, but it does not have the specific optimizations for Next.js that @next/font provides.
Readme
@next/font
@next/font
includes built-in automatic self-hosting for any font file. This means you can optimally load web fonts with zero layout shift, thanks to the underlying CSS size-adjust property used.
This new font system also allows you to conveniently use all Google Fonts with performance and privacy in mind. CSS and font files are downloaded at build time and self-hosted with the rest of your static assets. No requests are sent to Google by the browser.
FAQs
Unknown package
We found that @next/font demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers unpack a typosquatting package with malicious code that logs keystrokes and exfiltrates sensitive data to a remote server.
Security News
The JavaScript community has launched the e18e initiative to improve ecosystem performance by cleaning up dependency trees, speeding up critical parts of the ecosystem, and documenting lighter alternatives to established tools.
Product
Socket now supports four distinct alert actions instead of the previous two, and alert triaging allows users to override the actions taken for all individual alerts.