Knowledge Hub

Resources &
Knowledge
Centre

Guides, case studies, whitepapers, and insights from Robin Automation's industrial engineering team.

Featured Resources

Technical Guides &
Case Studies

📋
Whitepaper

ISO 50001 Implementation Guide

Step-by-step guide to achieving ISO 50001 certification — from gap analysis to certification audit.

Download Free →
🤖
Case Study

Predictive Maintenance ROI — Steel Mill

How a hot rolling mill reduced unplanned downtime by 64% with Robin Industrial AI in Year 1.

Download Free →
🖥️
Whitepaper

DCIM Buyer's Guide 2025

What to look for in a DCIM platform — evaluation criteria, total cost of ownership, and vendor comparison.

Download Free →
Guide

MES Selection Guide for Manufacturers

How to evaluate and select the right MES for your manufacturing environment — requirements, RFP, and vendor scoring.

Download Free →
🎯
Case Study

SIRI Assessment — 3-Plant Steel Group

How SIRI digital maturity assessment identified SAR 45M in operational improvement opportunity across 3 plants.

Download Free →
💧
Technical Brief

Water Utility SCADA Modernization

Technical brief on SCADA architecture for distributed water utility networks — connectivity, redundancy, and cybersecurity.

Download Free →
Gated Downloads

Access Premium
Technical Content

Create a free account to access our full library of whitepapers, case studies, ROI calculators, and technical guides.

📚 Access Full Library 💬 Request a Specific Resource
🤖

Robin AI Assistant

Online — replies instantly

Powered by Robin Automation · Privacy
`; document.body.insertAdjacentHTML('beforeend', html); } // ─── Core chat engine ─── let chatOpen = false; let inputCallback = null; let currentInputConfig = null; function rcToggle() { chatOpen = !chatOpen; const box = document.getElementById('rc-box'); box.classList.toggle('open', chatOpen); // Remove notification dot on first open const notif = document.querySelector('#rc-fab .rc-notif'); if (notif) notif.remove(); // Start conversation on first open if (chatOpen && document.getElementById('rc-msgs').children.length === 0) { setTimeout(() => rcStep('start'), 300); } } function rcAddMsg(text, type='bot') { const msgs = document.getElementById('rc-msgs'); const el = document.createElement('div'); el.className = 'rc-msg ' + type; el.textContent = text.replace(/{name}/g, LEAD.name || 'there'); msgs.appendChild(el); msgs.scrollTop = msgs.scrollHeight; return el; } function rcAddTyping() { const msgs = document.getElementById('rc-msgs'); const el = document.createElement('div'); el.className = 'rc-typing'; el.id = 'rc-typing'; el.innerHTML = ''; msgs.appendChild(el); msgs.scrollTop = msgs.scrollHeight; } function rcRemoveTyping() { const t = document.getElementById('rc-typing'); if (t) t.remove(); } function rcAddOptions(options) { const msgs = document.getElementById('rc-msgs'); const wrap = document.createElement('div'); wrap.className = 'rc-opts'; options.forEach(opt => { const btn = document.createElement('button'); btn.className = 'rc-opt'; btn.textContent = opt.label; btn.onclick = () => { // Remove options wrap.remove(); // Show user selection rcAddMsg(opt.label, 'user'); // Store value if present if (opt.value) { // Detect which field we're filling based on current step const step = FLOWS[currentStep]; if (currentStep === 'demo_industry') LEAD.industry = opt.value; if (currentStep === 'demo_solution') LEAD.solution = opt.value; } // Navigate if (opt.url) { window.open(opt.url, '_blank'); } if (opt.next) setTimeout(() => rcStep(opt.next), 400); }; wrap.appendChild(btn); }); msgs.appendChild(wrap); msgs.scrollTop = msgs.scrollHeight; } function rcShowInput(config) { currentInputConfig = config; const area = document.getElementById('rc-input-area'); const input = document.getElementById('rc-input'); area.style.display = 'flex'; input.value = ''; input.placeholder = config.optional ? "Type or press Enter to skip..." : "Type your answer..."; setTimeout(() => input.focus(), 100); } function rcHideInput() { document.getElementById('rc-input-area').style.display = 'none'; currentInputConfig = null; } function rcSubmitInput() { if (!currentInputConfig) return; const input = document.getElementById('rc-input'); const val = input.value.trim(); if (!val && !currentInputConfig.optional) { input.style.borderColor = '#ff4757'; setTimeout(() => input.style.borderColor = '', 1000); return; } // Email validation if (currentInputConfig.validate === 'email' && val && !/\S+@\S+\.\S+/.test(val)) { input.style.borderColor = '#ff4757'; input.placeholder = "Please enter a valid email..."; setTimeout(() => { input.style.borderColor = ''; input.placeholder = "Type your answer..."; }, 2000); return; } rcHideInput(); rcAddMsg(val || "(skipped)", 'user'); LEAD[currentInputConfig.field] = val; const next = currentInputConfig.next; currentInputConfig = null; setTimeout(() => rcStep(next), 400); } function rcStep(stepKey) { currentStep = stepKey; const step = FLOWS[stepKey]; if (!step) return; // Handle close action if (step.action === 'close') { rcToggle(); return; } rcAddTyping(); const delay = step.msg ? Math.min(600 + step.msg.length * 8, 1400) : 400; setTimeout(() => { rcRemoveTyping(); // Process action first if (step.action === 'send_lead') sendLeadEmail("Specialist request from chatbot."); if (step.action === 'send_lead_and_calendly') { sendLeadEmail("Demo booking from chatbot."); // Show Calendly button if (step.msg) rcAddMsg(step.msg.replace(/{name}/g, LEAD.name || 'there'), 'bot'); const msgs = document.getElementById('rc-msgs'); const btn = document.createElement('button'); btn.className = 'rc-cal-btn'; btn.innerHTML = '📅 Open Booking Calendar'; btn.onclick = openCalendly; msgs.appendChild(btn); msgs.scrollTop = msgs.scrollHeight; if (step.next) setTimeout(() => rcStep(step.next), 1200); return; } if (step.msg) rcAddMsg(step.msg, 'bot'); if (step.input) { setTimeout(() => rcShowInput(step.input), 300); } else if (step.options) { setTimeout(() => rcAddOptions(step.options), 300); } }, delay); } // ─── Init on DOM ready ─── document.addEventListener('DOMContentLoaded', function() { buildChatbot(); // Show greeting bubble after 4 seconds setTimeout(function() { const fab = document.getElementById('rc-fab'); if (fab && !chatOpen) { const bubble = document.createElement('div'); bubble.style.cssText = 'position:fixed;bottom:100px;right:28px;z-index:9997;background:#0e1e38;border:1px solid rgba(0,132,255,.25);border-radius:12px;padding:12px 16px;font-size:.82rem;color:#e8f0fb;font-family:Inter,sans-serif;max-width:220px;box-shadow:0 8px 32px rgba(0,10,40,.5);animation:fadeInUp .3s ease;pointer-events:none'; bubble.innerHTML = '👋 Hi! Need help finding the right solution? I can help! 💡'; bubble.id = 'rc-bubble'; document.body.appendChild(bubble); setTimeout(() => { const b = document.getElementById('rc-bubble'); if(b) b.remove(); }, 5000); } }, 4000); });