diff --git a/mockup.html b/mockup.html index dcd8a27..704fcc4 100644 --- a/mockup.html +++ b/mockup.html @@ -118,6 +118,58 @@ body{font-family:var(--font-ui);background:var(--surf);color:var(--ink);line-hei .sub-feat span{background:#f3f4f6;padding:2px 7px;border-radius:6px} .pay-refund-note{font-size:11px;color:var(--mut);text-align:center;margin-bottom:12px} .pay-refund-note a{color:var(--bg);text-decoration:none} + +/* ── ВЫБОР ТИПА КЛИЕНТА ── */ +.client-type-block{margin:20px 0;background:var(--card);border:1.5px solid var(--line);border-radius:14px;overflow:hidden} +.client-type-hdr{padding:14px 16px 10px;font-size:13px;font-weight:700;color:var(--dark)} +.client-type-tabs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;border-top:1px solid var(--line)} +.ct-tab{padding:12px 8px;text-align:center;font-size:13px;font-weight:600;cursor:pointer;color:var(--mut);border-right:1px solid var(--line);transition:all .15s;user-select:none} +.ct-tab:last-child{border-right:none} +.ct-tab.act{background:var(--bg);color:#fff} +.ct-tab .ct-tab-ico{font-size:18px;display:block;margin-bottom:3px} + +/* B2B форма */ +.b2b-form{display:none;padding:16px;border-top:1px solid var(--line)} +.b2b-form.on{display:block} +.b2b-row{display:grid;gap:10px;margin-bottom:0} +.b2b-row.two{grid-template-columns:1fr 1fr} +.b2b-field{display:flex;flex-direction:column;gap:5px} +.b2b-field label{font-size:12px;font-weight:600;color:var(--mut);text-transform:uppercase;letter-spacing:.5px} +.b2b-field input{border:1.5px solid var(--line);border-radius:9px;padding:10px 12px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s} +.b2b-field input:focus{border-color:var(--bg)} +.b2b-field input.err{border-color:#9f1239} +.b2b-hint{font-size:11px;color:var(--mut);margin-top:2px} +.b2b-divider{margin:14px 0;border:none;border-top:1px solid var(--line)} + +/* Загрузка документов B2B */ +.b2b-docs-label{font-size:12px;font-weight:700;color:var(--dark);margin:14px 0 8px;text-transform:uppercase;letter-spacing:.5px} +.b2b-docs-note{font-size:12px;color:var(--mut);margin-bottom:10px} +.b2b-upload-area{display:grid;grid-template-columns:1fr 1fr;gap:8px} +.b2b-upload-btn{border:1.5px dashed var(--line);border-radius:12px;padding:14px 10px;text-align:center;cursor:pointer;background:#fafafa;transition:all .15s;position:relative;overflow:hidden} +.b2b-upload-btn:hover{border-color:var(--bg);background:var(--tint)} +.b2b-upload-btn input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%} +.b2b-upload-btn .ubtn-ico{font-size:22px;display:block;margin-bottom:5px} +.b2b-upload-btn .ubtn-lbl{font-size:12px;font-weight:600;color:var(--dark)} +.b2b-upload-btn .ubtn-sub{font-size:11px;color:var(--mut);margin-top:2px} +.b2b-upload-btn.has-file{border-color:var(--ok);border-style:solid;background:#f0fdf4} +.b2b-upload-btn.has-file .ubtn-lbl{color:var(--ok)} +.b2b-files-list{margin-top:8px} +.b2b-file-chip{display:inline-flex;align-items:center;gap:6px;background:#f3f4f6;border-radius:8px;padding:4px 8px;font-size:12px;margin:3px 3px 0 0} +.b2b-file-chip .rm{cursor:pointer;color:var(--mut);font-size:11px;margin-left:2px} +.b2b-file-chip .rm:hover{color:#9f1239} + +/* Camera preview */ +.b2b-camera-wrap{display:none;margin-top:10px} +.b2b-camera-wrap.on{display:block} +.b2b-video{width:100%;border-radius:10px;background:#000;max-height:240px;object-fit:cover} +.b2b-camera-controls{display:flex;gap:8px;margin-top:8px} +.b2b-snap-btn{flex:1;background:var(--bg);color:#fff;border:none;border-radius:9px;padding:10px;font-size:13px;font-weight:700;cursor:pointer} +.b2b-cancel-btn{background:#f3f4f6;color:var(--dark);border:none;border-radius:9px;padding:10px 14px;font-size:13px;cursor:pointer} +.b2b-canvas{display:none} +.b2b-photo-preview{display:none;margin-top:8px;position:relative} +.b2b-photo-preview img{width:100%;border-radius:10px;border:1.5px solid var(--ok)} +.b2b-photo-preview .rm-photo{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:50%;width:24px;height:24px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center} + /* ЮKassa modal */ .yk-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;align-items:flex-end;justify-content:center} .yk-overlay.on{display:flex} @@ -1461,7 +1513,102 @@ body{font-family:var(--font-ui);background:var(--surf);color:var(--ink);line-hei -
+ +
+
Кто оплачивает?
+
+
+ 🙋Физлицо +
+
+ 💼ИП +
+
+ 🏢ООО / АО +
+
+ + +
+ + +
+
+ + +
+
+
+
+ + + ИП — 12 цифр, ООО — 10 цифр +
+
+ + + Только для ООО / АО +
+
+
+
+ + +
+
+
+
+ + +
+
+ +
+ + +
Подтверждающие документы (необязательно)
+
Свидетельство ИП, выписка ЕГРЮЛ или приказ о назначении руководителя — ускорит оформление закрывающих документов.
+ +
+ +
+ + 📎 +
Загрузить файл
+
PDF, JPG, PNG, DOCX
+
+ +
+ 📷 +
Сфотографировать
+
Камера устройства
+
+
+ + +
+ + +
+ + +
+ + +
+
+ + +
+ Фото документа + +
+ +
+
+ +
Нажимая «Оплатить», вы соглашаетесь с офертой и обработкой ПДн. Данные договора остаются на вашем устройстве.
@@ -2882,7 +3029,35 @@ function toast(msg){ } function go(id){document.querySelectorAll('.screen').forEach(s=>s.classList.toggle('on',s.id===id)); if(id==='admin' && typeof _initAdmin==='function') setTimeout(_initAdmin,50); - if(id==='start') { _hchatDone=false; var m=document.getElementById('hchat-msgs'); if(m){m.innerHTML='';} var r=document.getElementById('hchat-replies'); if(r)r.style.display='none'; var ir=document.getElementById('hchat-input-row'); if(ir)ir.style.display='none'; setTimeout(initHeroChat,300); var rm=document.getElementById('rchat-msgs'); if(rm)rm.innerHTML=''; var s1=document.getElementById('el-step1'); if(s1)s1.style.display=''; var ic=document.getElementById('intake-custom'); if(ic)ic.value=''; };window.scrollTo(0,0);} + if(id==='start') { _hchatDone=false; var m=document.getElementById('hchat-msgs'); if(m){m.innerHTML='';} var r=document.getElementById('hchat-replies'); if(r)r.style.display='none'; var ir=document.getElementById('hchat-input-row'); if(ir)ir.style.display='none'; setTimeout(initHeroChat,300); var rm=document.getElementById('rchat-msgs'); if(rm)rm.innerHTML=''; var s1=document.getElementById('el-step1'); if(s1)s1.style.display=''; var ic=document.getElementById('intake-custom'); if(ic)ic.value=''; }; + if(id==='pay') { setTimeout(_initPayScreen, 80); } + window.scrollTo(0,0);} + +function _initPayScreen() { + // Восстановить сохранённые реквизиты B2B + try { + var saved = JSON.parse(localStorage.getItem('zashita_b2b') || 'null'); + if (saved && saved.type) { + setClientType(saved.type); + var set = function(elId, val){ var el=document.getElementById(elId); if(el&&val) el.value=val; }; + set('b2b-name', saved.name); + set('b2b-inn', saved.inn); + set('b2b-kpp', saved.kpp); + set('b2b-addr', saved.addr); + set('b2b-email', saved.email); + } + } catch(e){} + // Баланс + var credits = parseInt(localStorage.getItem('zashita_credits') || '0'); + var balEl = document.getElementById('pay-bal-credits'); + if (balEl) balEl.textContent = credits; + var useBtn = document.getElementById('pay-bal-use-btn'); + if (useBtn) useBtn.style.display = credits > 0 ? '' : 'none'; + var subEl = document.getElementById('pay-bal-sub'); + if (subEl) subEl.textContent = credits > 0 + ? 'Можно списать кредит вместо оплаты' + : 'Пополните баланс или оплатите разово'; +} /* ── СВОЙ ЗАПРОС ── */ let _customOpen = false; let _voiceRec = null; @@ -3047,6 +3222,156 @@ function selectPlan(n) { } +/* ── ВЫБОР ТИПА КЛИЕНТА + B2B ФОРМА ── */ + +var _clientType = 'fl'; // fl | ip | ooo +var _b2bFiles = []; // {name, size, dataUrl} +var _b2bPhoto = null; // dataUrl +var _cameraStream = null; + +function setClientType(type) { + _clientType = type; + ['fl','ip','ooo'].forEach(function(t){ + var el = document.getElementById('ctt-' + t); + if (el) el.classList.toggle('act', t === type); + }); + var form = document.getElementById('b2b-form'); + if (form) form.classList.toggle('on', type !== 'fl'); + // КПП — только для ООО/АО + var kppWrap = document.getElementById('b2b-kpp-wrap'); + if (kppWrap) kppWrap.style.display = (type === 'ooo') ? '' : 'none'; + // placeholder ИНН + var inn = document.getElementById('b2b-inn'); + if (inn) inn.placeholder = (type === 'ooo') ? '10 цифр' : '12 цифр'; +} + +function _validateB2B() { + if (_clientType === 'fl') return true; + var name = (document.getElementById('b2b-name').value || '').trim(); + var inn = (document.getElementById('b2b-inn').value || '').trim(); + var ok = true; + if (!name) { document.getElementById('b2b-name').classList.add('err'); ok = false; } + else document.getElementById('b2b-name').classList.remove('err'); + var innLen = _clientType === 'ooo' ? 10 : 12; + if (!inn || inn.length !== innLen || !/^\d+$/.test(inn)) { + document.getElementById('b2b-inn').classList.add('err'); ok = false; + } else { + document.getElementById('b2b-inn').classList.remove('err'); + } + if (!ok) toast('⚠️ Заполните обязательные поля: Название и ИНН'); + return ok; +} + +function _getB2BData() { + if (_clientType === 'fl') return null; + return { + type: _clientType, + name: (document.getElementById('b2b-name').value || '').trim(), + inn: (document.getElementById('b2b-inn').value || '').trim(), + kpp: (document.getElementById('b2b-kpp').value || '').trim(), + addr: (document.getElementById('b2b-addr').value || '').trim(), + email: (document.getElementById('b2b-email').value || '').trim(), + files: _b2bFiles.map(function(f){ return {name: f.name, size: f.size}; }), + photo: !!_b2bPhoto, + }; +} + +/* Файлы */ +function b2bFileSelected(input) { + var files = Array.from(input.files || []); + files.forEach(function(file){ + if (file.size > 10 * 1024 * 1024) { toast('Файл ' + file.name + ' слишком большой (макс 10 МБ)'); return; } + var reader = new FileReader(); + reader.onload = function(e){ + _b2bFiles.push({ name: file.name, size: file.size, dataUrl: e.target.result }); + _renderB2BFiles(); + }; + reader.readAsDataURL(file); + }); + input.value = ''; + var btn = document.getElementById('b2b-file-btn'); + if (btn) btn.classList.toggle('has-file', _b2bFiles.length > 0); +} + +function _renderB2BFiles() { + var list = document.getElementById('b2b-files-list'); + if (!list) return; + list.innerHTML = _b2bFiles.map(function(f, i){ + var kb = Math.round(f.size / 1024); + return '
📎 ' + f.name + ' (' + kb + ' КБ)' + + '
'; + }).join(''); +} + +function b2bRemoveFile(idx) { + _b2bFiles.splice(idx, 1); + _renderB2BFiles(); + var btn = document.getElementById('b2b-file-btn'); + if (btn) btn.classList.toggle('has-file', _b2bFiles.length > 0); +} + +/* Камера */ +function b2bOpenCamera() { + var wrap = document.getElementById('b2b-camera-wrap'); + if (!wrap) return; + if (!navigator.mediaDevices || !navigator.mediaDevices.getUserMedia) { + // Fallback: file input с capture + var inp = document.createElement('input'); + inp.type = 'file'; inp.accept = 'image/*'; inp.capture = 'environment'; + inp.onchange = function(){ b2bFileSelected(inp); }; + inp.click(); + return; + } + navigator.mediaDevices.getUserMedia({ video: { facingMode: 'environment' } }) + .then(function(stream){ + _cameraStream = stream; + var video = document.getElementById('b2b-video'); + if (video) { video.srcObject = stream; } + wrap.classList.add('on'); + var btn = document.getElementById('b2b-camera-btn'); + if (btn) btn.style.display = 'none'; + }) + .catch(function(e){ + toast('Нет доступа к камере: ' + (e.message || e)); + }); +} + +function b2bSnap() { + var video = document.getElementById('b2b-video'); + var canvas = document.getElementById('b2b-canvas'); + if (!video || !canvas) return; + canvas.width = video.videoWidth || 640; + canvas.height = video.videoHeight || 480; + canvas.getContext('2d').drawImage(video, 0, 0); + _b2bPhoto = canvas.toDataURL('image/jpeg', 0.85); + b2bCloseCamera(); + // Показываем превью + var prev = document.getElementById('b2b-photo-preview'); + var img = document.getElementById('b2b-photo-img'); + if (prev && img) { img.src = _b2bPhoto; prev.style.display = 'block'; } + var btn = document.getElementById('b2b-camera-btn'); + if (btn) btn.classList.add('has-file'); +} + +function b2bCloseCamera() { + if (_cameraStream) { + _cameraStream.getTracks().forEach(function(t){ t.stop(); }); + _cameraStream = null; + } + var wrap = document.getElementById('b2b-camera-wrap'); + if (wrap) wrap.classList.remove('on'); + var btn = document.getElementById('b2b-camera-btn'); + if (btn) btn.style.display = ''; +} + +function b2bRemovePhoto() { + _b2bPhoto = null; + var prev = document.getElementById('b2b-photo-preview'); + if (prev) prev.style.display = 'none'; + var btn = document.getElementById('b2b-camera-btn'); + if (btn) btn.classList.remove('has-file'); +} + /* ── ЮKASSA ВИДЖЕТ ── */ function ykOpen() { const priceEl = document.getElementById('pay-price-btn'); @@ -3775,6 +4100,11 @@ function useBalance() { // ЮKassa modal function ykOpen() { + // Валидация B2B перед открытием + if (!_validateB2B()) return; + // Сохраняем реквизиты в localStorage для будущих заказов + var b2b = _getB2BData(); + if (b2b) localStorage.setItem('zashita_b2b', JSON.stringify(b2b)); _updatePayBtn(); document.getElementById('yk-overlay').classList.add('on'); }