{"id":319908,"date":"2026-06-02T10:36:51","date_gmt":"2026-06-02T10:36:51","guid":{"rendered":"https:\/\/wordpress.org\/plugins\/idara-reading-time\/"},"modified":"2026-06-02T13:43:21","modified_gmt":"2026-06-02T13:43:21","slug":"idara-reading-time","status":"publish","type":"plugin","link":"https:\/\/wordpress.org\/plugins\/idara-reading-time\/","author":15500565,"comment_status":"closed","ping_status":"closed","template":"","meta":{"version":"1.0.0","stable_tag":"1.0.0","tested":"7.0","requires":"6.4","requires_php":"7.4","requires_plugins":null,"header_name":"Idara Reading Time","header_author":"Mohammad Sajid Ansari","header_description":"A lightweight Gutenberg block that shows estimated reading time with optional scroll progress bar. FSE-ready, no bloat, loads only where used.","assets_banners_color":"0e0b0e","last_updated":"2026-06-02 13:43:21","external_support_url":"","external_repository_url":"","donate_link":"","header_plugin_uri":"https:\/\/github.com\/sajid-ansari-65\/idara-reading-time","header_author_uri":"https:\/\/profiles.wordpress.org\/sajidansari65\/","rating":0,"author_block_rating":0,"active_installs":0,"downloads":39,"num_ratings":0,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":{"1.0.0":{"tag":"1.0.0","author":"sajidansari65","date":"2026-06-02 13:43:21"}},"upgrade_notice":[],"ratings":[],"assets_icons":{"icon-128x128.png":{"filename":"icon-128x128.png","revision":3557862,"resolution":"128x128","location":"assets","locale":"","width":128,"height":128},"icon-256x256.png":{"filename":"icon-256x256.png","revision":3557862,"resolution":"256x256","location":"assets","locale":"","width":256,"height":256},"icon.svg":{"filename":"icon.svg","revision":3557862,"resolution":false,"location":"assets","locale":false}},"assets_banners":{"banner-1544x500.png":{"filename":"banner-1544x500.png","revision":3557862,"resolution":"1544x500","location":"assets","locale":"","width":1544,"height":500},"banner-772x250.png":{"filename":"banner-772x250.png","revision":3557862,"resolution":"772x250","location":"assets","locale":"","width":772,"height":250}},"assets_blueprints":{},"all_blocks":{"idara\/reading-time":{"$schema":"https:\/\/schemas.wp.org\/trunk\/block.json","apiVersion":3,"name":"idara\/reading-time","version":"1.0.0","title":"Reading Time","category":"text","icon":"clock","description":"Smart reading time block with optional range display and scroll progress bar.","keywords":["reading time","read time","minutes","progress bar"],"textdomain":"idara-reading-time","editorScript":"file:.\/index.js","editorStyle":"file:.\/index.css","style":"file:.\/style-index.css","viewScript":"file:.\/view.js","render":"file:.\/render.php","attributes":{"wordsPerMinute":{"type":"number","default":200},"prefix":{"type":"string","default":""},"suffix":{"type":"string","default":"min read"},"rangeSuffix":{"type":"string","default":"min read"},"displayAsRange":{"type":"boolean","default":false},"rangeSpread":{"type":"number","default":1},"hideShortPosts":{"type":"boolean","default":false},"hideThreshold":{"type":"number","default":1},"iconStyle":{"type":"string","default":"clock"},"showProgressBar":{"type":"boolean","default":false},"progressBarColor":{"type":"string","default":"#4f46e5"},"progressBarHeight":{"type":"number","default":3},"progressBarPosition":{"type":"string","default":"top"}},"supports":{"html":false,"color":{"text":true,"background":false,"__experimentalDefaultControls":{"text":true}},"typography":{"fontSize":true,"fontWeight":true,"__experimentalDefaultControls":{"fontSize":true}},"spacing":{"margin":["top","bottom"],"padding":false},"align":["left","center","right"]},"example":{"attributes":{"prefix":"Reading time:","displayAsRange":true,"iconStyle":"clock"}}}},"tagged_versions":["1.0.0"],"block_files":[],"assets_screenshots":{"screenshot-1.png":{"filename":"screenshot-1.png","revision":3557825,"resolution":"1","location":"assets","locale":"","width":244,"height":254},"screenshot-2.png":{"filename":"screenshot-2.png","revision":3557825,"resolution":"2","location":"assets","locale":"","width":1524,"height":188},"screenshot-3.png":{"filename":"screenshot-3.png","revision":3557825,"resolution":"3","location":"assets","locale":"","width":570,"height":1020},"screenshot-4.png":{"filename":"screenshot-4.png","revision":3557825,"resolution":"4","location":"assets","locale":"","width":570,"height":898},"screenshot-5.png":{"filename":"screenshot-5.png","revision":3557825,"resolution":"5","location":"assets","locale":"","width":570,"height":898},"screenshot-6.png":{"filename":"screenshot-6.png","revision":3557825,"resolution":"6","location":"assets","locale":"","width":570,"height":1632},"screenshot-7.png":{"filename":"screenshot-7.png","revision":3557825,"resolution":"7","location":"assets","locale":"","width":3368,"height":1092},"screenshot-8.png":{"filename":"screenshot-8.png","revision":3557825,"resolution":"8","location":"assets","locale":"","width":862,"height":212}},"screenshots":{"1":"Block in the WordPress block inserter \u2014 find it by searching \"Reading Time\"","2":"Block selected in the editor with toolbar shortcuts for icon cycling and range toggle","3":"Block settings sidebar \u2014 Display, Calculation, Scroll progress bar, and Advanced panels","4":"Display panel \u2014 icon style picker (clock, timer, hourglass, or none), Single\/Range format toggle, and custom prefix\/suffix fields","5":"Calculation panel \u2014 adjustable words-per-minute (default 200 WPM) and hide-on-short-posts toggle","6":"Scroll progress bar panel \u2014 enable toggle, live mini-preview, position (top\/bottom), height, and color picker","7":"Frontend \u2014 reading time with clock icon displayed in a post, with scroll progress bar visible at the bottom of the page","8":"Frontend \u2014 reading time with hourglass icon displayed below the post title in a blog layout"}},"plugin_section":[],"plugin_tags":[323,204746,151844,9351,27629],"plugin_category":[],"plugin_contributors":[248558],"plugin_business_model":[],"class_list":["post-319908","plugin","type-plugin","status-publish","hentry","plugin_tags-blog","plugin_tags-fse","plugin_tags-gutenberg-block","plugin_tags-progress-bar","plugin_tags-reading-time","plugin_contributors-sajidansari65","plugin_committers-sajidansari65"],"banners":{"banner":"https:\/\/ps.w.org\/idara-reading-time\/assets\/banner-772x250.png?rev=3557862","banner_2x":"https:\/\/ps.w.org\/idara-reading-time\/assets\/banner-1544x500.png?rev=3557862","banner_rtl":false,"banner_2x_rtl":false},"icons":{"svg":"https:\/\/ps.w.org\/idara-reading-time\/assets\/icon.svg?rev=3557862","icon":"https:\/\/ps.w.org\/idara-reading-time\/assets\/icon.svg?rev=3557862","icon_2x":false,"generated":false},"screenshots":[{"src":"https:\/\/ps.w.org\/idara-reading-time\/assets\/screenshot-1.png?rev=3557825","caption":"Block in the WordPress block inserter \u2014 find it by searching \"Reading Time\""},{"src":"https:\/\/ps.w.org\/idara-reading-time\/assets\/screenshot-2.png?rev=3557825","caption":"Block selected in the editor with toolbar shortcuts for icon cycling and range toggle"},{"src":"https:\/\/ps.w.org\/idara-reading-time\/assets\/screenshot-3.png?rev=3557825","caption":"Block settings sidebar \u2014 Display, Calculation, Scroll progress bar, and Advanced panels"},{"src":"https:\/\/ps.w.org\/idara-reading-time\/assets\/screenshot-4.png?rev=3557825","caption":"Display panel \u2014 icon style picker (clock, timer, hourglass, or none), Single\/Range format toggle, and custom prefix\/suffix fields"},{"src":"https:\/\/ps.w.org\/idara-reading-time\/assets\/screenshot-5.png?rev=3557825","caption":"Calculation panel \u2014 adjustable words-per-minute (default 200 WPM) and hide-on-short-posts toggle"},{"src":"https:\/\/ps.w.org\/idara-reading-time\/assets\/screenshot-6.png?rev=3557825","caption":"Scroll progress bar panel \u2014 enable toggle, live mini-preview, position (top\/bottom), height, and color picker"},{"src":"https:\/\/ps.w.org\/idara-reading-time\/assets\/screenshot-7.png?rev=3557825","caption":"Frontend \u2014 reading time with clock icon displayed in a post, with scroll progress bar visible at the bottom of the page"},{"src":"https:\/\/ps.w.org\/idara-reading-time\/assets\/screenshot-8.png?rev=3557825","caption":"Frontend \u2014 reading time with hourglass icon displayed below the post title in a blog layout"}],"raw_content":"<!--section=description-->\n<p><strong>Idara Reading Time<\/strong> is a focused, single-purpose Gutenberg block that does one thing well: shows readers how long your post will take. It also offers an optional scroll progress bar \u2014 a thin bar pinned to the top or bottom of the page that fills as the visitor scrolls.<\/p>\n\n<p><em>Idara (\u0625\u062f\u0627\u0631\u0629) is an Arabic word meaning \"studio\" or \"administration\" \u2014 the brand behind a growing family of carefully crafted, single-purpose Gutenberg blocks.<\/em><\/p>\n\n<h4>Why this and not a full block suite?<\/h4>\n\n<p>Most block plugins ship 30+ blocks you'll never use, slowing your editor and your frontend. Idara plugins are deliberately small. This one is under 25 KB. CSS and JS load <strong>only on pages where the block is present<\/strong> \u2014 never globally.<\/p>\n\n<h4>Features<\/h4>\n\n<ul>\n<li>Estimated reading time, calculated server-side from your post content<\/li>\n<li>Display as a single value (\"3 min read\") or a friendly range (\"2\u20133 min read\")<\/li>\n<li>Adjustable words-per-minute (50\u2013600)<\/li>\n<li>4 icon styles: clock, timer, hourglass, or none<\/li>\n<li>Optional scroll progress bar with color, height, and position (top\/bottom)<\/li>\n<li>Hide on short posts (e.g. don't show on anything under 2 minutes)<\/li>\n<li>Custom prefix and suffix text<\/li>\n<li>Inherits theme typography and text color via block supports<\/li>\n<li>Full Site Editing (FSE) compatible \u2014 works inside block templates and template parts<\/li>\n<li>Block toolbar shortcuts for icon cycling and range toggle<\/li>\n<li>Semantic, accessible markup with ARIA labels<\/li>\n<li>No tracking, no external requests, no third-party services<\/li>\n<li>Translation-ready<\/li>\n<\/ul>\n\n<h4>Use cases<\/h4>\n\n<ul>\n<li>Blog posts where readers want to gauge time investment<\/li>\n<li>Long-form articles where the scroll progress bar improves engagement<\/li>\n<li>Documentation sites<\/li>\n<li>News and magazine layouts<\/li>\n<\/ul>\n\n<h3>Development<\/h3>\n\n<p>Source code and build tools are available on GitHub:\nhttps:\/\/github.com\/sajid-ansari-65\/idara-reading-time<\/p>\n\n<p>The <code>src\/<\/code> directory contains the unminified JavaScript (ES modules, JSX) and SCSS. Run <code>npm install &amp;&amp; npm run build<\/code> to compile.<\/p>\n\n<!--section=installation-->\n<ol>\n<li>Upload the plugin folder to <code>\/wp-content\/plugins\/<\/code>, or install via <strong>Plugins \u2192 Add New \u2192 Upload Plugin<\/strong><\/li>\n<li>Activate the plugin through the <strong>Plugins<\/strong> menu<\/li>\n<li>Open any post or page in the block editor<\/li>\n<li>Insert the <strong>Reading Time<\/strong> block where you want it displayed<\/li>\n<li>Configure icon, format, and progress bar from the block settings sidebar<\/li>\n<\/ol>\n\n<!--section=faq-->\n<dl>\n<dt id=\"how%20is%20reading%20time%20calculated%3F\"><h3>How is reading time calculated?<\/h3><\/dt>\n<dd><p>The plugin strips block markup, shortcodes, and HTML from the post content, counts the remaining words, and divides by your chosen words-per-minute setting (default 200). The minimum displayed value is 1 minute.<\/p><\/dd>\n<dt id=\"does%20it%20work%20with%20full%20site%20editing%20block%20themes%3F\"><h3>Does it work with Full Site Editing block themes?<\/h3><\/dt>\n<dd><p>Yes. You can place the block inside any block template or template part \u2014 for example, inside a \"Single Post\" template just below the Post Title block.<\/p><\/dd>\n<dt id=\"will%20this%20slow%20down%20my%20site%3F\"><h3>Will this slow down my site?<\/h3><\/dt>\n<dd><p>No. The entire plugin is under 25 KB, ships no jQuery, and makes zero external requests. Its CSS and JavaScript are enqueued <strong>only on pages that actually contain the block<\/strong> \u2014 never site-wide \u2014 so pages without it load exactly as before.<\/p><\/dd>\n<dt id=\"does%20the%20scroll%20progress%20bar%20affect%20performance%3F\"><h3>Does the scroll progress bar affect performance?<\/h3><\/dt>\n<dd><p>The frontend script is a tiny vanilla JavaScript file (under 1 KB) using a passive scroll listener and requestAnimationFrame. It is enqueued only on pages where the block is present.<\/p><\/dd>\n<dt id=\"can%20i%20style%20the%20block%3F\"><h3>Can I style the block?<\/h3><\/dt>\n<dd><p>Yes. The block fully supports WordPress block color and typography controls. The frontend uses simple class names: <code>.idara-rt<\/code>, <code>.idara-rt-icon<\/code>, <code>.idara-rt-text<\/code>, <code>.idara-rt-progress-wrap<\/code>, and <code>.idara-rt-progress-bar<\/code>.<\/p><\/dd>\n<dt id=\"does%20this%20plugin%20track%20users%20or%20send%20data%20anywhere%3F\"><h3>Does this plugin track users or send data anywhere?<\/h3><\/dt>\n<dd><p>No. Everything runs locally on your site. No external requests, no analytics, no tracking.<\/p><\/dd>\n<dt id=\"how%20do%20i%20display%20reading%20time%20as%20a%20range%3F\"><h3>How do I display reading time as a range?<\/h3><\/dt>\n<dd><p>In the block settings sidebar, click the \"Range\" button under Format. You can then choose how wide the range should be (1 to 5 minutes spread).<\/p><\/dd>\n\n<\/dl>\n\n<!--section=changelog-->\n<h4>1.0.0<\/h4>\n\n<ul>\n<li>Initial release<\/li>\n<\/ul>","raw_excerpt":"Show estimated reading time with an optional scroll progress bar. A lightweight, FSE-ready Gutenberg block that loads only where used.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/319908","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin"}],"about":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/types\/plugin"}],"replies":[{"embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/comments?post=319908"}],"author":[{"embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/sajidansari65"}],"wp:attachment":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=319908"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=319908"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=319908"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=319908"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=319908"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=319908"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}