Header Image

Posted by Andy graham on Jan 16, 2026Read more >>
Genesis Equilibrium — Lightweight All-Rounder

Read more >>
Posted by Andy graham on Aug 17, 2022
Custom Build - Surly Straggler Bike

Posted by Andy graham on Jan 16, 2026Read more >>
Genesis Equilibrium Disc — Balanced Performance for Gravel & Road

Read more >>
Posted by Andy graham on Aug 17, 2022
Edinburgh Student Bike Bundle offer

Posted by Andy graham on Jan 16, 2026
Read more >>Genesis Vagabond Frameset — Custom Adventure Build

Read more >>
Posted by Andy graham on Aug 17, 2022
Custom Build Enigma Escape Titanium Gravel Bike

Posted by Andy graham on Jan 16, 2026
Genesis Vagabond Full Bike — Ultimate Adventure Ready Read more >>

Read more >>
Posted by Andy graham on Aug 17, 2022
Custom Build - Surly Steamroller Single Speed Bike

Posted by Andy graham on Jan 16, 2026
Genesis Vagabond 20 — Enhanced Adventure Performance Read more >>

Read more >>
Posted by Andy graham on Jun 18, 2022
Sell My Bike - ProjektRide's Process of Selling your old bike.

Posted by Andy graham on Jan 16, 2026
Genesis Vagabond 10 — Adventure Touring Made SimpleSell your bicycle with ProjektRide.

Read more >>

Read more >> <
< 1 2 263 427
<
hopify.shop, 'ngrok-skip-browser-warning': 'skip' }; if (window.Shopify?.theme?.role === 'main') { headers['X-Shopify-Theme-Schema-Name'] = window.Shopify.theme.schema_name; headers['X-Shopify-Theme-Schema-Version'] = window.Shopify.theme.schema_version; headers['X-Shopify-Theme-Store-Id'] = window.Shopify.theme.theme_store_id; } fetch( `${window._RestockRocketConfig.host}/api/v1/setting.json?translation_locale=${window._RestockRocketConfig.normalizedLocale}`, { headers } ) .then(function(response) { if (!response.ok) { throw new Error('Network response was not ok'); } return response.json(); }) .then(function(settings) { initializeScripts(settings); }) .catch(function(error) { // If request failed and we have cached settings (even if expired), use them as fallback if (cachedSettings) { console.debug('STOQ - using expired cached settings as fallback'); initializeScripts(cac hedSettings); } else { console.error('STOQ - failed to load settings:', error); } }) .catch(function(e) { console.error(e) }) } function initializeScripts(settings) { settings = applyTranslations(settings); window._RestockRocketConfig.settings = settings; console.debug(`STOQ - settings configured for ${window._RestockRocketConfig.pageType}`); // Setup cart selling plan updater BEFORE loading any scripts to avoid race conditions setupCartSellingPlanUpdater(settings); if(settings.enable_app) { const hijackIntegration = window._RestockRocketConfig.integrations.find(function(integration) { return integration.type === 'hijack' && integration.enabled && integration.page_types.includes(window._RestockRocketConfig.pageType); }) if(window._RestockRocketConfig.pageType === 'collection' && (settings.show_button_on_collection || settings.preorder_collection_enabled)) { createRestockRocketScript(window._RestockRocketCon
fig.scriptUrlCollection); } else if(window._RestockRocketConfig.pageType === 'index' && (settings.show_button_on_index || settings.preorder_index_enabled)) { createRestockRocketScript(window._RestockRocketConfig.scriptUrlCollection); } else if(window._RestockRocketConfig.pageType === 'search' && (settings.show_button_on_search || settings.preorder_search_enabled)) { createRestockRocketScript(window._RestockRocketConfig.scriptUrlCollection); } else if(window._RestockRocketConfig.pageType === 'page' && (settings.show_button_on_page || settings.preorder_page_enabled)) { createRestockRocketScript(window._RestockRocketConfig.scriptUrlCollection); } else if(window._RestockRocketConfig.pageType === 'product') { createRestockRocketScript(window._RestockRocketConfig.scriptUrlProduct); } else if(hijackIntegration) { createRestockRocketScript(window._RestockRocketConfig.scriptUrlCollection); } else { console.debug(`STOQ - no scripts enab led for ${window._RestockRocketConfig.pageType}`); } // Dispatch custom event when app is loaded // Cart selling plan updates will be triggered by stoq:inventory-data-loaded event const appLoadedEvent = new CustomEvent('stoq:loaded', { detail: { pageType: window._RestockRocketConfig.pageType, enabled: settings.enable_app, settings: settings, preorderEnabled: settings.preorder_enabled } }); console.debug('STOQ - dispatching app loaded event'); window.dispatchEvent(appLoadedEvent); } }