TextWrap adalah implementasi JavaScript dari modul textwrap
yang tersedia di Python, yang menyediakan beberapa fungsi untuk membungkus dan memformat paragraf teks dengan panjang baris yang dibatasi. Modul ini berguna untuk memformat teks agar lebih mudah dibaca atau untuk kebutuhan tampilan.
TextWrap menawarkan fitur-fitur berikut:
- Teks Wrap: Membungkus teks menjadi beberapa baris (dengan tipe array) sesuai dengan lebar yang diberikan.
- Teks Fill: Membungkus teks seperti
wrap
, tetapi mengembalikan teks yang sudah dibungkus sebagai satu string, dengan baris-baris dipisahkan oleh karakter newline (\n
). - Teks Shorten: Membungkus teks menjadi satu baris dengan lebar maksimum yang diberikan, menggantikan bagian akhir teks dengan placeholder jika teks terlalu panjang.
- Teks Dedent: Menghapus indentasi umum dari setiap baris dalam teks yang diberikan.
- Teks Indent: Menambahkan string prefix (indentasi) di awal setiap baris dari teks yang diberikan. Opsi
predicate
dapat digunakan untuk mengontrol baris mana yang akan diberi prefix.
Untuk menginstal TextWrap secara lokal, ikuti langkah instalasi ini:
npm install @barudakrosul/textwrap
Untuk memulai menggunakan TextWrap, import modulnya terlebuh dahulu:
1. CommonJS
const textwrap = require("@barudakrosul/textwrap");
2. ESM (ECMAScript Modules)
import textwrap from "@barudakrosul/textwrap";
Contoh penggunaan:
console.log(textwrap.wrap("Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.", 11))
// Result:
// [
// 'Lorem ipsum', 'dolor sit',
// 'amet,', 'consectetur',
// 'adipisicing', 'elit, sed',
// 'do eiusmod', 'tempor',
// 'incididunt', 'ut labore',
// 'et dolore', 'magna',
// 'aliqua.'
// ]
console.log(textwrap.fill("Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.", 11))
// Result:
// Lorem ipsum
// dolor sit
// amet,
// consectetur
// adipisicing
// elit, sed
// do eiusmod
// tempor
// incididunt
// ut labore
// et dolore
// magna
// aliqua.
console.log(textwrap.shorten("Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.", 59))
// Result:
// Lorem ipsum dolor sit amet, consectetur adipisicing [...]
console.log(textwrap.dedent("Lorem ipsum dolor sit amet,\nconsectetur adipisicing elit,\nsed do eiusmod tempor incididunt ut labore et dolore magna aliqua."))
// Result:
// Lorem ipsum dolor sit amet,
// consectetur adipisicing elit,
// sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
console.log(textwrap.indent("Lorem ipsum dolor sit amet,\nconsectetur adipisicing elit,\nsed do eiusmod tempor incididunt ut labore et dolore magna aliqua.", "> "))
// Result:
// > Lorem ipsum dolor sit amet,
// > consectetur adipisicing elit,
// > sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Contoh menambahkan prefix untuk setiap newline, termasuk yang kosong:
console.log(textwrap.indent("Lorem ipsum dolor sit amet,\n\n\nconsectetur adipisicing elit,\nsed do eiusmod tempor incididunt ut labore et dolore magna aliqua.", "> ", lines => true))
// Result:
// > Lorem ipsum dolor sit amet,
// >
// >
// > consectetur adipisicing elit,
// > sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Contoh menambahkan prefix untuk setiap baris yang dimulai dengan string tertentu secara spesifik:
console.log(textwrap.indent("Lorem ipsum dolor sit amet,\nconsectetur adipisicing elit,\nsed do eiusmod tempor incididunt ut labore et dolore magna aliqua.", "> ", lines => lines.startsWith("Lorem")))
// Result:
// > Lorem ipsum dolor sit amet,
// consectetur adipisicing elit,
// sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Contoh menambahkan prefix untuk setiap baris yang terdapat string tertentu secara spesifik:
console.log(textwrap.indent("Lorem ipsum dolor sit amet,\nconsectetur adipisicing elit,\nsed do eiusmod tempor incididunt ut labore et dolore magna aliqua.", "> ", lines => lines.includes(",")))
// Result:
// > Lorem ipsum dolor sit amet,
// consectetur adipisicing elit,
// sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Contoh menambahkan prefix untuk setiap baris yang yang memiliki batas panjang tertentu:
console.log(textwrap.indent("Lorem ipsum dolor sit amet,\nconsectetur adipisicing elit,\nsed do eiusmod tempor incididunt ut labore et dolore magna aliqua.", "> ", lines => lines.length > 28))
// Result:
// Lorem ipsum dolor sit amet,
// > consectetur adipisicing elit,
// > sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Untuk fungsi wrap()
, fill()
, dan shorten()
mempunyai opsi tambahan. Adapun, opsi yang didukung di antaranya:
Nama |
Keterangan |
Tipe |
Nilai default |
|
Lebar maksimum baris yang dibungkus (kecuali |
|
70 |
|
String indentasi untuk baris pertama. |
|
"" |
|
String indentasi untuk baris-baris berikutnya. |
|
"" |
|
Jika |
|
|
|
Jika |
|
|
|
Jika |
|
|
|
Jika |
|
|
|
Jika |
|
|
|
Jika |
|
|
|
Ukuran tab dalam karakter. |
|
8 |
|
Jumlah maksimum baris. |
|
|
|
String yang digunakan untuk menggantikan bagian akhir teks jika terlalu panjang. |
|
|
Contoh dasar penggunaan opsi tersebut:
const text = "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.";
const width = 20;
const options = {
fix_sentence_endings: true,
break_long_words: false
};
console.log(textwrap.wrap(text, width, options));
Kontribusi pada TextWrap sangat dihargai! Baik melaporkan bug, menyarankan fitur baru, atau berkontribusi pada perbaikan kode.
TextWrap dilisensikan di bawah Lisensi MIT - lihat berkas LICENSE untuk detailnya.
TextWrap menghargai dukungan dan kontribusi dari individu dan proyek sumber terbuka berikut:
- @FajarKim - Pengembang utama dan pencipta aplikasi.
- Modul TextWrap Python - Sumber asli dalam pengembangan TextWrap JavaScript.
- Komunitas sumber terbuka - Untuk kontribusi berharga pada alat dan perpustakaan yang digunakan dalam proyek ini.
Kami sangat menghargai dukungan Anda untuk terus mengembangkan proyek ini. Jika Anda merasa proyek ini bermanfaat, Anda dapat mendukung kami dengan donasi:
Setiap donasi, berapapun jumlahnya, sangat berarti bagi kami. Terima kasih atas dukungan Anda! ❤️
Terus ikuti perubahan dan pembaruan terbaru TextWrap dengan mengacu ke Catatan Perubahan.
Terima kasih telah memilih TextWrap! Kami bertujuan untuk memberikan solusi yang mudah untuk memformat teks atau paragraf di beberapa lingkungan.