Recommend this page to a friend! |
Download .zip |
Info | Documentation | View files (6) | Download .zip | Reputation | Support forum (1) | Blog (1) | Links |
Last Updated | Ratings | Unique User Downloads | Download Rankings | |||||
2021-08-06 (1 month ago) | Not yet rated by the users | Total: 81 This week: 1 | All time: 9,723 This week: 174 |
Version | License | PHP version | Categories | |||
read-time 1.0.1 | GNU General Publi... | 7 | PHP 5, Statistics, Text processing, B... |
Description | Author | ||||||||||||||
This class can estimate the time for a person to read an article. Innovation Award |
|
Calculates the read time of an article.
e.g: x min read
or 5 minutes read
.
Installation using composer
composer require waqarahmed/read-time
There are two static methods minRead(string $text)
andtime(sting $text)
.
Use this method for a simple x min read
message. It returns a rounded minutes number with a min read
message.
$text = str_repeat('ad bc ', 251); //502 words in $text
echo ReadTime::minRead($text);
The output:
2 min read
time()
method returns an array of the number of minutes
and seconds
required to read the given $text.
$text = str_repeat('ad bc ', 251); //502 words in $text
ReadTime::time($text);
The output:
['minutes' => 2, 'seconds' => 12]
Create an instance of the class to use - translation - right-to-left language support - JSON output - array output
The Constructor takes and sets these parameters:
public function __construct(
string $text,
array $translation = null,
bool $abbreviate = true,
bool $rtl = false,
string $language = null,
int $wordsPerMinute = 228
)
#### Class defaults
- $wordsPerMinute
default value is 200
- $rtl
language direction right-to-left is false
by default
- $translation
default is null
class outputs the English language by default
- $abbreviate
Abbreviate the word 'minute/minutes' to 'min' is true
by default
After initiating a new class object, call the getTime()
method to get the result.
Example:
4 minutes read
or 1 minute read
or abbreviated 4 min read
.
Reading time of different languages vary significantly (S. Klosinski, K. Dietz). Class method setTextLanguage() has estimated reading times of 17 languages taken from this study.
Reference: "Standardized Assessment of Reading Performance: The New International Reading Speed Texts IReST"
Arabic (ar) 138, Chinese (zh) 158, Dutch (nl) 202, English (en) 228, Finnish (fi) 161, French (fr) 195, German (el) 179, Hebrew (he) 187, Italian (it) 188, Japanese (jp) 193, Polish (pl) 166, Portoguese (pt) 181, Russian (ru) 184, Slovenian (sl) 180, Spanish (es) 218, Swedish (sv) 199, Turkish (tr) 166.
English is the default language. Set different languages by passing two letters (ISO 639-1) language codes to the setTextLanguag() method.
An example: Setting Turkish as the input language.
$text = str_repeat('ad bc ', 251); //502 words in $text
$result = new ReadTime($this->generateText(), ['minute' => 'dakika', 'minutes' => 'dakika', 'read' => 'okuman'], false, false, 'tr');
echo $result->getTime();
Pass translation array to the class to set the translations of the words: minute
, minutes
, min
and read
.
A passed array must be an associative array with any number of translation strings.
$translation = [
'min' => 'min',
'minute' => 'minute',
'minutes' => 'minutes',
'read' => 'read',
];
$text = str_repeat('ad bc ', 251); //502 words in $text
$result = new ReadTime($this->generateText(), ['minute' => 'minuto', 'minutes' => 'minutos', 'read' => 'leer'], false);
echo $result->getTime();
The Spanish translated output: 2 minutos leer
.
Set $rtl
property to true
and pass $translation
of languages written right-to-left.
$text = str_repeat('ad bc ', 251);
$result = new ReadTime($this->generateText(), ['minute' => '?????', 'minutes' => '?????', 'read' => '??????'], false, true);
echo $result->getTime();
Persian translated output: '?????? ????? 2'
Method to get JSON output of claculated read time and class properties.
A class instance with default properties outputs:
$text = str_repeat('hello world ', 251);
$result = new ReadTime($text);
echo $result->getJSON();
outputs:
{
"minutes": 2,
"time": {
"minutes": 2,
"seconds": 12
},
"wordCount": 502,
"translation": {
"min": "min",
"minute": "minute",
"minutes": "minutes",
"read": "read"
},
"abbreviate": true,
"wordsPerMinute": 228
}
Method to get array output of calculated read time and instance properties. A class instance with default properties:
$text = str_repeat('hello world ', 251);
$result = new ReadTime($text);
echo $result->getArray();
Outputs:
array(6) {
["minutes"]=>
int(2)
["time"]=>
array(2) {
["minutes"]=>
int(2)
["seconds"]=>
int(12)
}
["wordCount"]=>
int(502)
["translation"]=>
array(4) {
["min"]=>
string(3) "min"
["minute"]=>
string(6) "minute"
["minutes"]=>
string(7) "minutes"
["read"]=>
string(4) "read"
}
["abbreviate"]=>
bool(true)
["wordsPerMinute"]=>
int(228)
}
Files |
File | Role | Description | ||
---|---|---|---|---|
src (1 file) | ||||
tests (1 file) | ||||
composer.json | Data | Auxiliary data | ||
composer.lock | Data | Auxiliary data | ||
LICENSE | Lic. | License text | ||
README.md | Doc. | Documentation |
Version Control | Unique User Downloads | Download Rankings | |||||||||||||||
100% |
|
|
Applications that use this package |
If you know an application of this package, send a message to the author to add a link here.