{"id":304613,"date":"2026-05-11T14:10:31","date_gmt":"2026-05-11T14:10:31","guid":{"rendered":"https:\/\/en-ca.wordpress.org\/plugins\/shift8-scrollshot\/"},"modified":"2026-05-11T14:10:20","modified_gmt":"2026-05-11T14:10:20","slug":"shift8-scrollshot","status":"publish","type":"plugin","link":"https:\/\/wordpress.org\/plugins\/shift8-scrollshot\/","author":15006456,"comment_status":"closed","ping_status":"closed","template":"","meta":{"version":"1.0.0","stable_tag":"trunk","tested":"6.9.4","requires":"5.8","requires_php":"7.4","requires_plugins":null,"header_name":"Shift8 ScrollShot","header_author":"Shift8 Web","header_description":"Scrolling tall-screenshot viewport effect. Add the class s8-scrollshot to a container and s8-scrollshot__image to an image inside it.","assets_banners_color":"","last_updated":"2026-05-11 14:10:20","external_support_url":"","external_repository_url":"","donate_link":"https:\/\/shift8web.ca","header_plugin_uri":"","header_author_uri":"https:\/\/shift8web.ca","rating":0,"author_block_rating":0,"active_installs":0,"downloads":16,"num_ratings":0,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":[],"upgrade_notice":{"1.0.0":"<p>Initial release.<\/p>"},"ratings":[],"assets_icons":[],"assets_banners":[],"assets_blueprints":{},"all_blocks":[],"tagged_versions":[],"block_files":[],"assets_screenshots":[],"screenshots":[],"jetpack_post_was_ever_published":false},"plugin_section":[],"plugin_tags":[785,4038,790,262577,23139],"plugin_category":[50],"plugin_contributors":[93487],"plugin_business_model":[],"class_list":["post-304613","plugin","type-plugin","status-publish","hentry","plugin_tags-animation","plugin_tags-screenshot","plugin_tags-scroll","plugin_tags-scrollshot","plugin_tags-viewport","plugin_category-media","plugin_contributors-shift8","plugin_committers-shift8"],"banners":[],"icons":{"svg":false,"icon":"https:\/\/s.w.org\/plugins\/geopattern-icon\/shift8-scrollshot.svg","icon_2x":false,"generated":true},"screenshots":[],"raw_content":"<!--section=description-->\n<p>Shift8 ScrollShot creates a scrolling screenshot viewport effect. Drop a tall image inside a container, add two CSS classes, and the plugin handles the rest. Works with any theme, page builder, or hand-coded HTML.<\/p>\n\n<p><strong>Features:<\/strong><\/p>\n\n<ul>\n<li>Auto-scroll mode: the image scrolls up and down automatically on a loop<\/li>\n<li>Scroll-linked mode: image position follows the page scroll<\/li>\n<li>Configurable pause at top and bottom of the scroll cycle<\/li>\n<li>Optional browser-style frame with traffic-light dots<\/li>\n<li>Per-instance configuration via data attributes<\/li>\n<li>Multiple independent instances on one page<\/li>\n<li>Respects <code>prefers-reduced-motion<\/code><\/li>\n<li>Vanilla JS with no jQuery or external libraries<\/li>\n<li>Lightweight assets (under 5 KB combined)<\/li>\n<\/ul>\n\n<h3>Usage<\/h3>\n\n<ol>\n<li>Add a container element (a div, section, or page builder container). Give it the CSS class <code>s8-scrollshot<\/code>.<\/li>\n<li>Inside that container, add an image element. Give it the CSS class <code>s8-scrollshot__image<\/code>.<\/li>\n<li>(Optional) Add data attributes to the container or image to configure the behavior.<\/li>\n<\/ol>\n\n<p>Data attributes can be placed on either the wrapper or the image. If the same attribute appears on both, the wrapper value takes priority.<\/p>\n\n<h4>Page Builder Setup<\/h4>\n\n<p>In Bricks Builder, Elementor, or other visual builders:<\/p>\n\n<ol>\n<li>Add a container or section element and apply the CSS class <code>s8-scrollshot<\/code>.<\/li>\n<li>Add an image element inside it and apply the CSS class <code>s8-scrollshot__image<\/code>.<\/li>\n<li>Use the builder's custom attributes panel to add any <code>data-*<\/code> attributes.<\/li>\n<\/ol>\n\n<h4>Plain HTML Example<\/h4>\n\n<pre><code>&lt;div class=\"s8-scrollshot\" data-mode=\"auto\" data-duration=\"15000\"&gt;\n  &lt;img class=\"s8-scrollshot__image\" src=\"screenshot.png\" alt=\"Screenshot\"&gt;\n&lt;\/div&gt;&lt;h3&gt;Data Attributes&lt;\/h3&gt;\n<\/code><\/pre>\n\n<p>All configuration is done through HTML data attributes on the <code>.s8-scrollshot<\/code> container or the <code>.s8-scrollshot__image<\/code> element. Wrapper values take priority over image values.<\/p>\n\n<ul>\n<li><code>data-mode<\/code> - <code>auto<\/code> or <code>scroll<\/code> (default: <code>auto<\/code>)<\/li>\n<li><code>data-duration<\/code> - Total cycle time in milliseconds (default: <code>12000<\/code>)<\/li>\n<li><code>data-end-pause<\/code> - Hold time at top and bottom in milliseconds (default: <code>1500<\/code>)<\/li>\n<li><code>data-pause-on-hover<\/code> - <code>true<\/code> or <code>false<\/code> (default: <code>true<\/code>)<\/li>\n<li><code>data-reverse<\/code> - <code>true<\/code> or <code>false<\/code>, controls bounce direction (default: <code>true<\/code>)<\/li>\n<li><code>data-frame<\/code> - <code>none<\/code> or <code>browser<\/code> (default: <code>none<\/code>)<\/li>\n<li><code>data-viewport-height<\/code> - Visible area height in pixels (default: <code>700<\/code>)<\/li>\n<li><code>data-viewport-width<\/code> - Viewport width in pixels, <code>0<\/code> for auto (default: <code>0<\/code>)<\/li>\n<li><code>data-easing<\/code> - Any CSS easing string (default: <code>ease-in-out<\/code>)<\/li>\n<\/ul>\n\n<!--section=installation-->\n<ol>\n<li>Upload the <code>shift8-scrollshot<\/code> folder to <code>\/wp-content\/plugins\/<\/code>.<\/li>\n<li>Activate the plugin through the Plugins screen in WordPress.<\/li>\n<\/ol>\n\n<!--section=faq-->\n<dl>\n<dt id=\"does%20it%20require%20a%20specific%20page%20builder%3F\"><h3>Does it require a specific page builder?<\/h3><\/dt>\n<dd><p>No. The plugin scans the DOM for <code>.s8-scrollshot<\/code> and <code>.s8-scrollshot__image<\/code> classes regardless of which theme or page builder rendered them. It works with Bricks, Elementor, Gutenberg blocks, hand-coded HTML, or any other setup.<\/p><\/dd>\n<dt id=\"can%20i%20have%20multiple%20instances%20on%20one%20page%3F\"><h3>Can I have multiple instances on one page?<\/h3><\/dt>\n<dd><p>Yes. Each <code>.s8-scrollshot<\/code> instance is independent.<\/p><\/dd>\n<dt id=\"what%20happens%20if%20my%20image%20is%20shorter%20than%20the%20viewport%3F\"><h3>What happens if my image is shorter than the viewport?<\/h3><\/dt>\n<dd><p>The plugin detects this and does nothing. No errors are thrown.<\/p><\/dd>\n<dt id=\"how%20do%20i%20control%20the%20width%3F\"><h3>How do I control the width?<\/h3><\/dt>\n<dd><p>Set a width on the container element, or use the <code>data-viewport-width<\/code> attribute with a pixel value. The image fills the viewport width automatically.<\/p><\/dd>\n<dt id=\"how%20do%20i%20make%20the%20scroll%20slower%3F\"><h3>How do I make the scroll slower?<\/h3><\/dt>\n<dd><p>Increase <code>data-duration<\/code>. For a slow scroll, try <code>15000<\/code> or <code>20000<\/code> (15-20 seconds per cycle). Also increase <code>data-end-pause<\/code> for longer holds at each end.<\/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":"Scrolling tall-screenshot viewport effect. Makes a tall image appear to scroll inside a fixed-height container.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/304613","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=304613"}],"author":[{"embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/shift8"}],"wp:attachment":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=304613"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=304613"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=304613"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=304613"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=304613"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=304613"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}