Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
css-line-break
Advanced tools
The css-line-break npm package provides utilities for handling line breaking in text according to the CSS Text Module Level 3 specification. It is useful for developers who need to manage text rendering and line breaking in a way that is consistent with web standards.
Line Break Iterator
This feature allows you to create an iterator that breaks a string into segments according to CSS line breaking rules. The code sample demonstrates how to use the LineBreaker to iterate over the break points in a given text.
const { LineBreaker } = require('css-line-break');
const breaker = LineBreaker('This is a sample text.');
let bk;
while (!(bk = breaker.next()).done) {
console.log(bk.value);
}
Line Break Opportunities
This feature allows you to collect all possible line break opportunities in a string. The code sample shows how to gather all break points into an array.
const { LineBreaker } = require('css-line-break');
const breaker = LineBreaker('This is a sample text.');
const breakPoints = [];
let bk;
while (!(bk = breaker.next()).done) {
breakPoints.push(bk.value);
}
console.log(breakPoints);
Custom Line Break Rules
This feature allows you to apply custom line break rules, such as 'strict' or 'normal'. The code sample demonstrates how to use the 'strict' line break rule.
const { LineBreaker } = require('css-line-break');
const breaker = LineBreaker('This is a sample text.', { lineBreak: 'strict' });
let bk;
while (!(bk = breaker.next()).done) {
console.log(bk.value);
}
The linebreak package provides Unicode line breaking algorithms. It is similar to css-line-break but focuses more on Unicode standards rather than CSS-specific rules.
The wordwrapjs package offers text wrapping and line breaking functionalities. It is more general-purpose compared to css-line-break, which is specifically tailored to CSS Text Module Level 3 specifications.
A JavaScript library for Line Breaking and identifying Word Boundaries, implementing the Unicode Line Breaking Algorithm (UAX #14)
Line breaking, also known as word wrapping, is the process of breaking a section of text into lines such that it will fit in the available width of a page, window or other display area. The Unicode Line Breaking Algorithm performs part of this process. Given an input text, it produces a set of positions called "break opportunities" that are appropriate points to begin a new line. The selection of actual line break positions from the set of break opportunities is not covered by the Unicode Line Breaking Algorithm, but is in the domain of higher level software with knowledge of the available width and the display size of the text.
In addition, the module implements CSS specific tailoring options to line breaking as defined in CSS Text Module Level 3.
You can install the module via npm:
npm install css-line-break
The LineBreaker
creates an iterator that returns Break
s for a given text.
LineBreaker(text, [options]);
import {LineBreaker} from 'css-line-break';
const breaker = LineBreaker('Lorem ipsum lol.', {
lineBreak: 'strict',
wordBreak: 'normal'
});
const words = [];
let bk;
while (!(bk = breaker.next()).done) {
words.push(bk.value.slice());
}
assert.deepEqual(words, ['Lorem ', 'ipsum ', 'lol.']);
The following parameters are available for the options:
lineBreak
: normal
| strict
wordBreak
: normal
| break-all
| break-word
| keep-all
For more information how they affect the line breaking algorithms, check out CSS Text Module Level 3.
You can run the test suite with:
npm test
The library implements all the LineBreakTest.txt tests and a number of CSS web-platform-tests.
FAQs
css-line-break ==============
The npm package css-line-break receives a total of 1,442,755 weekly downloads. As such, css-line-break popularity was classified as popular.
We found that css-line-break demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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 uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.