[{"data":1,"prerenderedAt":15900},["ShallowReactive",2],{"navigation_docs":3,"-aws-bedrock":3338,"-aws-bedrock-surround":15895},[4,1707,1904,2358,2539,2608,2815,2937,2987,3044,3078,3204,3281,3334],{"title":5,"icon":6,"path":7,"stem":8,"children":9},"C#","i-devicon-csharp","\u002Fcsharp","01.csharp",[10,13,60,90,120,202,219,253,379,404,457,650,1364,1654,1703],{"title":11,"path":7,"stem":12},"C# та .NET","01.csharp\u002Findex",{"title":14,"icon":15,"path":16,"stem":17,"children":18,"page":59},"Fundamentals","i-lucide-book-open","\u002Fcsharp\u002Ffundamentals","01.csharp\u002F01.fundamentals",[19,23,27,31,35,39,43,47,51,55],{"title":20,"path":21,"stem":22},"Вступ до екосистеми .NET","\u002Fcsharp\u002Ffundamentals\u002Fintroduction-to-ecosystem","01.csharp\u002F01.fundamentals\u002F01.introduction-to-ecosystem",{"title":24,"path":25,"stem":26},"Структура програми на C#","\u002Fcsharp\u002Ffundamentals\u002Fprogram-structure","01.csharp\u002F01.fundamentals\u002F02.program-structure",{"title":28,"path":29,"stem":30},"Змінні та Типи Даних","\u002Fcsharp\u002Ffundamentals\u002Fvariables-data-types","01.csharp\u002F01.fundamentals\u002F03.variables-data-types",{"title":32,"path":33,"stem":34},"Масиви","\u002Fcsharp\u002Ffundamentals\u002Farrays","01.csharp\u002F01.fundamentals\u002F04.arrays",{"title":36,"path":37,"stem":38},"Strings & Text Handling","\u002Fcsharp\u002Ffundamentals\u002Fstrings-text-handling","01.csharp\u002F01.fundamentals\u002F05.strings-text-handling",{"title":40,"path":41,"stem":42},"Дати і Час","\u002Fcsharp\u002Ffundamentals\u002Fdates-time-handling","01.csharp\u002F01.fundamentals\u002F06.dates-time-handling",{"title":44,"path":45,"stem":46},"Потік Керування","\u002Fcsharp\u002Ffundamentals\u002Fcontrol-flow","01.csharp\u002F01.fundamentals\u002F07.control-flow",{"title":48,"path":49,"stem":50},"Методи","\u002Fcsharp\u002Ffundamentals\u002Fmethods","01.csharp\u002F01.fundamentals\u002F08.methods",{"title":52,"path":53,"stem":54},"Основи Відлагодження","\u002Fcsharp\u002Ffundamentals\u002Fdebugging-basics","01.csharp\u002F01.fundamentals\u002F09.debugging-basics",{"title":56,"path":57,"stem":58},"Інтерактивна Консоль (Classic)","\u002Fcsharp\u002Ffundamentals\u002Finteractive-console","01.csharp\u002F01.fundamentals\u002F10.interactive-console",false,{"title":61,"icon":62,"path":63,"stem":64,"children":65,"page":59},"OOP","i-lucide-box","\u002Fcsharp\u002Foop","01.csharp\u002F02.oop",[66,70,74,78,82,86],{"title":67,"path":68,"stem":69},"Package Management (Управління Пакетами)","\u002Fcsharp\u002Foop\u002Fpackage-management","01.csharp\u002F02.oop\u002F01.package-management",{"title":71,"path":72,"stem":73},"Класи та Об'єкти","\u002Fcsharp\u002Foop\u002Fclasses-objects","01.csharp\u002F02.oop\u002F02.classes-objects",{"title":75,"path":76,"stem":77},"Властивості та Поля","\u002Fcsharp\u002Foop\u002Fproperties-fields","01.csharp\u002F02.oop\u002F03.properties-fields",{"title":79,"path":80,"stem":81},"Стовпи ООП","\u002Fcsharp\u002Foop\u002Foop-pillars","01.csharp\u002F02.oop\u002F04.oop-pillars",{"title":83,"path":84,"stem":85},"Advanced Types","\u002Fcsharp\u002Foop\u002Fadvanced-types","01.csharp\u002F02.oop\u002F05.advanced-types",{"title":87,"path":88,"stem":89},"Namespaces (Простори Імен)","\u002Fcsharp\u002Foop\u002Fnamespaces","01.csharp\u002F02.oop\u002F06.namespaces",{"title":91,"icon":92,"path":93,"stem":94,"children":95,"page":59},"Advanced Core","i-lucide-zap","\u002Fcsharp\u002Fadvanced-core","01.csharp\u002F03.advanced-core",[96,100,104,108,112,116],{"title":97,"path":98,"stem":99},"Generics (Узагальнення)","\u002Fcsharp\u002Fadvanced-core\u002Fgenerics","01.csharp\u002F03.advanced-core\u002F01.generics",{"title":101,"path":102,"stem":103},"Делегати, Події та Лямбда-вирази","\u002Fcsharp\u002Fadvanced-core\u002Fdelegates-events-lambdas","01.csharp\u002F03.advanced-core\u002F02.delegates-events-lambdas",{"title":105,"path":106,"stem":107},"Interfaces Deep Dive (Інтерфейси: Поглиблений Розгляд)","\u002Fcsharp\u002Fadvanced-core\u002Finterfaces-deep-dive","01.csharp\u002F03.advanced-core\u002F03.interfaces-deep-dive",{"title":109,"path":110,"stem":111},"Обробка Винятків","\u002Fcsharp\u002Fadvanced-core\u002Fexception-handling","01.csharp\u002F03.advanced-core\u002F04.exception-handling",{"title":113,"path":114,"stem":115},"Pattern Matching","\u002Fcsharp\u002Fadvanced-core\u002Fpattern-matching","01.csharp\u002F03.advanced-core\u002F05.pattern-matching",{"title":117,"path":118,"stem":119},"Додаткові Можливості C#","\u002Fcsharp\u002Fadvanced-core\u002Fadditional-features","01.csharp\u002F03.advanced-core\u002F06.additional-features",{"title":121,"icon":122,"path":123,"stem":124,"children":125,"page":59},"Architecture Best Practices","i-lucide-building-2","\u002Fcsharp\u002Farchitecture-best-practices","01.csharp\u002F04.architecture-best-practices",[126,130,149,153,157,161,165,169],{"title":127,"path":128,"stem":129},"Software Design Principles (Частина 1)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fsoftware-design-principles","01.csharp\u002F04.architecture-best-practices\u002F01.software-design-principles",{"title":131,"icon":132,"path":133,"stem":134,"children":135,"page":59},"Design Patterns","i-lucide-folder","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns",[136],{"title":137,"icon":132,"path":138,"stem":139,"children":140,"page":59},"Creational","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational",[141,145],{"title":142,"path":143,"stem":144},"Singleton (Одинак)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational\u002Fsingleton","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational\u002F01.singleton",{"title":146,"path":147,"stem":148},"Builder (Будівельник)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdesign-patterns\u002Fcreational\u002Fbuilder","01.csharp\u002F04.architecture-best-practices\u002F02.design-patterns\u002Fcreational\u002F02.builder",{"title":150,"path":151,"stem":152},"Building Professional CLIs","\u002Fcsharp\u002Farchitecture-best-practices\u002Fbuilding-professional-clis","01.csharp\u002F04.architecture-best-practices\u002F03.building-professional-clis",{"title":154,"path":155,"stem":156},"Validation & Flow Control","\u002Fcsharp\u002Farchitecture-best-practices\u002Fvalidation-flow-control","01.csharp\u002F04.architecture-best-practices\u002F04.validation-flow-control",{"title":158,"path":159,"stem":160},"The Modern .NET Host (Microsoft.Extensions)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fmodern-dotnet-host","01.csharp\u002F04.architecture-best-practices\u002F05.modern-dotnet-host",{"title":162,"path":163,"stem":164},"Data Mapper: Repository та DAO патерни (Частина 1)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdata-mapper-part1","01.csharp\u002F04.architecture-best-practices\u002F06.data-mapper-part1",{"title":166,"path":167,"stem":168},"Data Mapper: Repository та DAO патерни (Частина 2)","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdata-mapper-part2","01.csharp\u002F04.architecture-best-practices\u002F07.data-mapper-part2",{"title":170,"icon":132,"path":171,"stem":172,"children":173,"page":59},"Di Ioc","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc",[174,178,182,186,190,194,198],{"title":175,"path":176,"stem":177},"Проблема залежностей та Інверсія Контролю","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fthe-dependency-problem","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F01.the-dependency-problem",{"title":179,"path":180,"stem":181},"Будуємо власний Service Container","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fbuild-your-own-container","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F02.build-your-own-container",{"title":183,"path":184,"stem":185},"Service Locator: Паттерн та Анти-паттерн","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fservice-locator-pattern","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F03.service-locator-pattern",{"title":187,"path":188,"stem":189},"Паттерни Dependency Injection","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fdependency-injection-patterns","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F04.dependency-injection-patterns",{"title":191,"path":192,"stem":193},"Microsoft DI: IServiceCollection та IServiceProvider","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fmicrosoft-di-deep-dive","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F05.microsoft-di-deep-dive",{"title":195,"path":196,"stem":197},"Service Lifetimes та Scopes","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fservice-lifetimes-and-scopes","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F06.service-lifetimes-and-scopes",{"title":199,"path":200,"stem":201},"DI Анти-паттерни та Найкращі Практики","\u002Fcsharp\u002Farchitecture-best-practices\u002Fdi-ioc\u002Fdi-anti-patterns-and-best-practices","01.csharp\u002F04.architecture-best-practices\u002F08.di-ioc\u002F07.di-anti-patterns-and-best-practices",{"title":203,"icon":132,"path":204,"stem":205,"children":206,"page":59},"Standard Library","\u002Fcsharp\u002Fstandard-library","01.csharp\u002F05.standard-library",[207,211,215],{"title":208,"path":209,"stem":210},"Collections (Колекції)","\u002Fcsharp\u002Fstandard-library\u002Fcollections","01.csharp\u002F05.standard-library\u002F01.collections",{"title":212,"path":213,"stem":214},"High Performance Types (Високопродуктивні Типи)","\u002Fcsharp\u002Fstandard-library\u002Fhigh-performance-types","01.csharp\u002F05.standard-library\u002F02.high-performance-types",{"title":216,"path":217,"stem":218},"LINQ (Language Integrated Query)","\u002Fcsharp\u002Fstandard-library\u002Flinq","01.csharp\u002F05.standard-library\u002F03.linq",{"title":220,"icon":221,"path":222,"stem":223,"children":224,"page":59},"System Internals Concurrency","i-lucide-server","\u002Fcsharp\u002Fsystem-internals-concurrency","01.csharp\u002F06.system-internals-concurrency",[225,229,233,237,241,245,249],{"title":226,"path":227,"stem":228},"Memory Management","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fmemory-management","01.csharp\u002F06.system-internals-concurrency\u002F01.memory-management",{"title":230,"path":231,"stem":232},"Reflection API: System.Type та Метадані","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Freflection-fundamentals","01.csharp\u002F06.system-internals-concurrency\u002F02.reflection-fundamentals",{"title":234,"path":235,"stem":236},"Attributes та Dynamic Language Runtime","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fattributes-dynamic","01.csharp\u002F06.system-internals-concurrency\u002F03.attributes-dynamic",{"title":238,"path":239,"stem":240},"Expression Trees: Швидка Альтернатива Рефлексії","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fexpression-trees-compiled","01.csharp\u002F06.system-internals-concurrency\u002F04.expression-trees-compiled",{"title":242,"path":243,"stem":244},"Source Generators: Compile-Time Code Generation","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fsource-generators","01.csharp\u002F06.system-internals-concurrency\u002F05.source-generators",{"title":246,"path":247,"stem":248},"Multithreading Fundamentals","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fmultithreading-fundamentals","01.csharp\u002F06.system-internals-concurrency\u002F06.multithreading-fundamentals",{"title":250,"path":251,"stem":252},"Synchronization Primitives","\u002Fcsharp\u002Fsystem-internals-concurrency\u002Fsynchronization-primitives","01.csharp\u002F06.system-internals-concurrency\u002F07.synchronization-primitives",{"title":254,"icon":255,"path":256,"stem":257,"children":258,"page":59},"System Programming Windows","i-lucide-cpu","\u002Fcsharp\u002Fsystem-programming-windows","01.csharp\u002F07.system-programming-windows",[259,263,267,271,275,279,283,287,291,295,299,303,307,311,315,319,323,327,331,335,339,343,347,351,355,359,363,367,371,375],{"title":260,"path":261,"stem":262},"Як Працює Операційна Система","\u002Fcsharp\u002Fsystem-programming-windows\u002Fhow-os-works","01.csharp\u002F07.system-programming-windows\u002F01.how-os-works",{"title":264,"path":265,"stem":266},"Процеси в .NET — API та Запуск","\u002Fcsharp\u002Fsystem-programming-windows\u002Fprocesses-in-dotnet","01.csharp\u002F07.system-programming-windows\u002F02.processes-in-dotnet",{"title":268,"path":269,"stem":270},"Процеси в .NET — IPC та Міжпроцесна Комунікація","\u002Fcsharp\u002Fsystem-programming-windows\u002F02a.processes-ipc","01.csharp\u002F07.system-programming-windows\u002F02a.processes-ipc",{"title":272,"path":273,"stem":274},"Application Domains та Збірки — AppDomain і AssemblyLoadContext","\u002Fcsharp\u002Fsystem-programming-windows\u002Fappdomains-assemblies","01.csharp\u002F07.system-programming-windows\u002F03.appdomains-assemblies",{"title":276,"path":277,"stem":278},"Application Domains та Збірки — Plug-in Система з Hot-Reload","\u002Fcsharp\u002Fsystem-programming-windows\u002F03a.appdomains-plugin-system","01.csharp\u002F07.system-programming-windows\u002F03a.appdomains-plugin-system",{"title":280,"path":281,"stem":282},"Потоки — Основи та API Thread","\u002Fcsharp\u002Fsystem-programming-windows\u002Fthread-fundamentals","01.csharp\u002F07.system-programming-windows\u002F04.thread-fundamentals",{"title":284,"path":285,"stem":286},"Потоки — Lifecycle, Пріоритети та Безпечне Завершення","\u002Fcsharp\u002Fsystem-programming-windows\u002F04a.thread-lifecycle-priorities","01.csharp\u002F07.system-programming-windows\u002F04a.thread-lifecycle-priorities",{"title":288,"path":289,"stem":290},"Проблеми Спільного Стану — Race Condition та Data Race","\u002Fcsharp\u002Fsystem-programming-windows\u002Fshared-state-problems","01.csharp\u002F07.system-programming-windows\u002F05.shared-state-problems",{"title":292,"path":293,"stem":294},"Проблеми Спільного Стану — Memory Model та volatile","\u002Fcsharp\u002Fsystem-programming-windows\u002F05a.shared-state-memory-model","01.csharp\u002F07.system-programming-windows\u002F05a.shared-state-memory-model",{"title":296,"path":297,"stem":298},"Синхронізація — Monitor, lock та еволюція примітивів","\u002Fcsharp\u002Fsystem-programming-windows\u002Fsynchronization-fundamentals","01.csharp\u002F07.system-programming-windows\u002F06.synchronization-fundamentals",{"title":300,"path":301,"stem":302},"Синхронізація — Наскрізний Приклад та Deadlock Detection","\u002Fcsharp\u002Fsystem-programming-windows\u002F06a.synchronization-walkthrough","01.csharp\u002F07.system-programming-windows\u002F06a.synchronization-walkthrough",{"title":304,"path":305,"stem":306},"Синхронізація — Mutex, Semaphore та Event-Based Primitives","\u002Fcsharp\u002Fsystem-programming-windows\u002Fsynchronization-advanced","01.csharp\u002F07.system-programming-windows\u002F07.synchronization-advanced",{"title":308,"path":309,"stem":310},"Синхронізація — Interlocked, Volatile та Lock-Free Структури","\u002Fcsharp\u002Fsystem-programming-windows\u002F07a.synchronization-advanced-walkthrough","01.csharp\u002F07.system-programming-windows\u002F07a.synchronization-advanced-walkthrough",{"title":312,"path":313,"stem":314},"Interlocked, CAS та Lock-Free Структури","\u002Fcsharp\u002Fsystem-programming-windows\u002Finterlocked-cas-lockfree","01.csharp\u002F07.system-programming-windows\u002F08.interlocked-cas-lockfree",{"title":316,"path":317,"stem":318},"Volatile, Memory Model та Spinning","\u002Fcsharp\u002Fsystem-programming-windows\u002F08a.volatile-memory-model","01.csharp\u002F07.system-programming-windows\u002F08a.volatile-memory-model",{"title":320,"path":321,"stem":322},"ThreadPool — Пул Потоків для Ефективного Виконання","\u002Fcsharp\u002Fsystem-programming-windows\u002Fthread-pool","01.csharp\u002F07.system-programming-windows\u002F09.thread-pool",{"title":324,"path":325,"stem":326},"ThreadPool — Просунуті Сценарії та Внутрішня Будова","\u002Fcsharp\u002Fsystem-programming-windows\u002F09a.thread-pool-advanced","01.csharp\u002F07.system-programming-windows\u002F09a.thread-pool-advanced",{"title":328,"path":329,"stem":330},"Concurrent та Immutable Collections","\u002Fcsharp\u002Fsystem-programming-windows\u002Fconcurrent-collections","01.csharp\u002F07.system-programming-windows\u002F10.concurrent-collections",{"title":332,"path":333,"stem":334},"TPL, Task та Композиція — Від Thread до Task","\u002Fcsharp\u002Fsystem-programming-windows\u002Ftpl-parallel-plinq","01.csharp\u002F07.system-programming-windows\u002F11.tpl-parallel-plinq",{"title":336,"path":337,"stem":338},"Parallel Class та PLINQ — Data Parallelism","\u002Fcsharp\u002Fsystem-programming-windows\u002F11a.tpl-parallel-plinq-advanced","01.csharp\u002F07.system-programming-windows\u002F11a.tpl-parallel-plinq-advanced",{"title":340,"path":341,"stem":342},"Async\u002FAwait — Фундамент Асинхронного Програмування","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-fundamentals","01.csharp\u002F07.system-programming-windows\u002F12.async-fundamentals",{"title":344,"path":345,"stem":346},"SynchronizationContext та ConfigureAwait — Контекст Виконання","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-context-configureawait","01.csharp\u002F07.system-programming-windows\u002F13.async-context-configureawait",{"title":348,"path":349,"stem":350},"Async — Просунуті Паттерни","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-advanced","01.csharp\u002F07.system-programming-windows\u002F14.async-advanced",{"title":352,"path":353,"stem":354},"System.Threading.Channels — Async Producer-Consumer","\u002Fcsharp\u002Fsystem-programming-windows\u002Fchannels","01.csharp\u002F07.system-programming-windows\u002F15.channels",{"title":356,"path":357,"stem":358},"Асинхронна Синхронізація","\u002Fcsharp\u002Fsystem-programming-windows\u002Fasync-synchronization","01.csharp\u002F07.system-programming-windows\u002F16.async-synchronization",{"title":360,"path":361,"stem":362},"Unsafe Code та Вказівники","\u002Fcsharp\u002Fsystem-programming-windows\u002Funsafe-code","01.csharp\u002F07.system-programming-windows\u002F17.unsafe-code",{"title":364,"path":365,"stem":366},"P\u002FInvoke та Windows API — Міст між .NET та Native Code","\u002Fcsharp\u002Fsystem-programming-windows\u002Fpinvoke-winapi","01.csharp\u002F07.system-programming-windows\u002F18.pinvoke-winapi",{"title":368,"path":369,"stem":370},"Реєстр Windows — Центральна База Конфігурації Системи","\u002Fcsharp\u002Fsystem-programming-windows\u002Fwindows-registry","01.csharp\u002F07.system-programming-windows\u002F19.windows-registry",{"title":372,"path":373,"stem":374},"Windows Hooks, Hotkeys та Services — Глибока Інтеграція з ОС","\u002Fcsharp\u002Fsystem-programming-windows\u002Fwindows-hooks-services","01.csharp\u002F07.system-programming-windows\u002F20.windows-hooks-services",{"title":376,"path":377,"stem":378},"Системне Програмування C# (Windows) — 07.system-programming-windows","\u002Fcsharp\u002Fsystem-programming-windows\u002Fimplementation_plan","01.csharp\u002F07.system-programming-windows\u002Fimplementation_plan",{"title":380,"icon":132,"path":381,"stem":382,"children":383,"page":59},"Io","\u002Fcsharp\u002Fio","01.csharp\u002F08.io",[384,388,392,396,400],{"title":385,"path":386,"stem":387},"8.1.1. Основи роботи з файловою системою","\u002Fcsharp\u002Fio\u002Ffile-system-basics","01.csharp\u002F08.io\u002F01.file-system-basics",{"title":389,"path":390,"stem":391},"8.1.2. Потоки (Streams) та Серіалізація Даних","\u002Fcsharp\u002Fio\u002Fstreams-serialization","01.csharp\u002F08.io\u002F02.streams-serialization",{"title":393,"path":394,"stem":395},"8.2.1. JSON Serialization з System.Text.Json","\u002Fcsharp\u002Fio\u002Fjson-serialization","01.csharp\u002F08.io\u002F03.json-serialization",{"title":397,"path":398,"stem":399},"8.2.2. XML Serialization та LINQ to XML","\u002Fcsharp\u002Fio\u002Fxml-serialization","01.csharp\u002F08.io\u002F04.xml-serialization",{"title":401,"path":402,"stem":403},"8.2.3. Binary Serialization: MessagePack та Protocol Buffers","\u002Fcsharp\u002Fio\u002Fbinary-serialization","01.csharp\u002F08.io\u002F05.binary-serialization",{"title":405,"icon":132,"path":406,"stem":407,"children":408,"page":59},"Ado Net","\u002Fcsharp\u002Fado-net","01.csharp\u002F09.ado-net",[409,413,417,421,425,429,433,437,441,445,449,453],{"title":410,"path":411,"stem":412},"9.1. Введення в ADO.NET","\u002Fcsharp\u002Fado-net\u002Fintroduction-to-adonet","01.csharp\u002F09.ado-net\u002F01.introduction-to-adonet",{"title":414,"path":415,"stem":416},"9.2. Клас DbConnection — з'єднання з базою даних","\u002Fcsharp\u002Fado-net\u002Fconnection","01.csharp\u002F09.ado-net\u002F02.connection",{"title":418,"path":419,"stem":420},"9.3. Клас DbCommand — виконання SQL-запитів","\u002Fcsharp\u002Fado-net\u002Fcommand-and-queries","01.csharp\u002F09.ado-net\u002F03.command-and-queries",{"title":422,"path":423,"stem":424},"9.4. Клас DbDataReader — ефективне читання даних","\u002Fcsharp\u002Fado-net\u002Fdatareader","01.csharp\u002F09.ado-net\u002F04.datareader",{"title":426,"path":427,"stem":428},"9.5. Параметризовані запити та захист від SQL Injection","\u002Fcsharp\u002Fado-net\u002Fparameters-and-sql-injection","01.csharp\u002F09.ado-net\u002F05.parameters-and-sql-injection",{"title":430,"path":431,"stem":432},"9.6. Транзакції в ADO.NET","\u002Fcsharp\u002Fado-net\u002Ftransactions","01.csharp\u002F09.ado-net\u002F06.transactions",{"title":434,"path":435,"stem":436},"9.7. DbProviderFactory — провайдер-незалежний код","\u002Fcsharp\u002Fado-net\u002Fprovider-factory","01.csharp\u002F09.ado-net\u002F07.provider-factory",{"title":438,"path":439,"stem":440},"9.8. Асинхронний доступ до даних","\u002Fcsharp\u002Fado-net\u002Fasync-data-access","01.csharp\u002F09.ado-net\u002F08.async-data-access",{"title":442,"path":443,"stem":444},"9.9. Від'єднаний режим: DataSet, DataTable, DataRow","\u002Fcsharp\u002Fado-net\u002Fdisconnected-mode-dataset","01.csharp\u002F09.ado-net\u002F09.disconnected-mode-dataset",{"title":446,"path":447,"stem":448},"9.10. DataAdapter — міст між DataSet та базою даних","\u002Fcsharp\u002Fado-net\u002Fdata-adapter","01.csharp\u002F09.ado-net\u002F10.data-adapter",{"title":450,"path":451,"stem":452},"9.11. Data Mapper та Repository: Архітектура доступу до даних","\u002Fcsharp\u002Fado-net\u002Fdata-mapper-repository","01.csharp\u002F09.ado-net\u002F11.data-mapper-repository",{"title":454,"path":455,"stem":456},"9.12. Identity Map, Unit of Work та Specification Pattern","\u002Fcsharp\u002Fado-net\u002Fadvanced-patterns","01.csharp\u002F09.ado-net\u002F12.advanced-patterns",{"title":458,"icon":255,"path":459,"stem":460,"children":461,"page":59},"Ef Core","\u002Fcsharp\u002Fef-core","01.csharp\u002F10.ef-core",[462,466,470,474,478,482,486,490,494,498,502,506,510,514,518,522,526,532,538,542,546,550,554,558,562,566,570,574,578,582,586,590,594,598,602,606,610,614,618,622,626,630,634,638,642,646],{"title":463,"path":464,"stem":465},"Що таке ORM? Від SQL до об'єктів","\u002Fcsharp\u002Fef-core\u002Fwhat-is-orm","01.csharp\u002F10.ef-core\u002F01.what-is-orm",{"title":467,"path":468,"stem":469},"Перший проєкт — від нуля до CRUD","\u002Fcsharp\u002Fef-core\u002Ffirst-project","01.csharp\u002F10.ef-core\u002F02.first-project",{"title":471,"path":472,"stem":473},"DbContext — Серце EF Core","\u002Fcsharp\u002Fef-core\u002Fdbcontext-deep-dive","01.csharp\u002F10.ef-core\u002F03.dbcontext-deep-dive",{"title":475,"path":476,"stem":477},"Провайдери баз даних — Архітектура та Вибір СУБД","\u002Fcsharp\u002Fef-core\u002Fdatabase-providers","01.csharp\u002F10.ef-core\u002F04.database-providers",{"title":479,"path":480,"stem":481},"Конвенції EF Core — Магія без конфігурації","\u002Fcsharp\u002Fef-core\u002Fconventions","01.csharp\u002F10.ef-core\u002F05.conventions",{"title":483,"path":484,"stem":485},"Fluent API та Data Annotations — Явна конфігурація моделі","\u002Fcsharp\u002Fef-core\u002Ffluent-api-vs-annotations","01.csharp\u002F10.ef-core\u002F06.fluent-api-vs-annotations",{"title":487,"path":488,"stem":489},"Зв'язки — One-to-One та One-to-Many","\u002Fcsharp\u002Fef-core\u002Frelationships-basics","01.csharp\u002F10.ef-core\u002F07.relationships-basics",{"title":491,"path":492,"stem":493},"Зв'язки Advanced — Many-to-Many та Складні Сценарії","\u002Fcsharp\u002Fef-core\u002Frelationships-advanced","01.csharp\u002F10.ef-core\u002F08.relationships-advanced",{"title":495,"path":496,"stem":497},"Властивості — Типи, Конвертери, Компаратори (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fproperty-configuration-part1","01.csharp\u002F10.ef-core\u002F09.property-configuration-part1",{"title":499,"path":500,"stem":501},"Властивості — Value Comparers, Generators, Shadow Properties (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fproperty-configuration-part2","01.csharp\u002F10.ef-core\u002F09.property-configuration-part2",{"title":503,"path":504,"stem":505},"Складні типи — Owned Types та Complex Types (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fcomplex-types-owned-part1","01.csharp\u002F10.ef-core\u002F10.complex-types-owned-part1",{"title":507,"path":508,"stem":509},"Складні типи — Complex Types, Keyless Entities, Порівняння (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fcomplex-types-owned-part2","01.csharp\u002F10.ef-core\u002F10.complex-types-owned-part2",{"title":511,"path":512,"stem":513},"JSON Columns — Складні дані у JSON (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fjson-columns-part1","01.csharp\u002F10.ef-core\u002F11.json-columns-part1",{"title":515,"path":516,"stem":517},"JSON Columns — Value Comparers, Індекси, Провайдери (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fjson-columns-part2","01.csharp\u002F10.ef-core\u002F11.json-columns-part2",{"title":519,"path":520,"stem":521},"Успадкування — Абстрактні класи та TPH (Частина 1)","\u002Fcsharp\u002Fef-core\u002Finheritance-part1","01.csharp\u002F10.ef-core\u002F12.inheritance-part1",{"title":523,"path":524,"stem":525},"Успадкування — TPT, TPC та Порівняння Стратегій (Частина 2)","\u002Fcsharp\u002Fef-core\u002Finheritance-part2","01.csharp\u002F10.ef-core\u002F12.inheritance-part2",{"title":527,"path":528,"stem":529,"children":530},"Індекси, Обмеження та Схема (Частина 1)","\u002Fcsharp\u002Fef-core\u002Findexes-constraints-part1","01.csharp\u002F10.ef-core\u002F13.indexes-constraints-part1",[531],{"title":527,"path":528,"stem":529},{"title":533,"path":534,"stem":535,"children":536},"Індекси, Обмеження та Схема (Частина 2)","\u002Fcsharp\u002Fef-core\u002Findexes-constraints-part2","01.csharp\u002F10.ef-core\u002F13.indexes-constraints-part2",[537],{"title":533,"path":534,"stem":535},{"title":539,"path":540,"stem":541},"Seed Data — Початкові Дані (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fseeding-part1","01.csharp\u002F10.ef-core\u002F14.seeding-part1",{"title":543,"path":544,"stem":545},"Seed Data — SQL-скрипти, Bogus та Стратегії (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fseeding-part2","01.csharp\u002F10.ef-core\u002F14.seeding-part2",{"title":547,"path":548,"stem":549},"Global Query Filters — Глобальні Фільтри (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fglobal-query-filters-part1","01.csharp\u002F10.ef-core\u002F15.global-query-filters-part1",{"title":551,"path":552,"stem":553},"Global Query Filters — Підводні камені та Інтеграція (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fglobal-query-filters-part2","01.csharp\u002F10.ef-core\u002F15.global-query-filters-part2",{"title":555,"path":556,"stem":557},"LINQ-запити в EF Core (Частина 1)","\u002Fcsharp\u002Fef-core\u002Flinq-queries-part1","01.csharp\u002F10.ef-core\u002F16.linq-queries-part1",{"title":559,"path":560,"stem":561},"LINQ-запити в EF Core (Частина 2)","\u002Fcsharp\u002Fef-core\u002Flinq-queries-part2","01.csharp\u002F10.ef-core\u002F16.linq-queries-part2",{"title":563,"path":564,"stem":565},"Завантаження Пов'язаних Даних (Частина 1)","\u002Fcsharp\u002Fef-core\u002Floading-related-data-part1","01.csharp\u002F10.ef-core\u002F17.loading-related-data-part1",{"title":567,"path":568,"stem":569},"Завантаження Пов'язаних Даних (Частина 2)","\u002Fcsharp\u002Fef-core\u002Floading-related-data-part2","01.csharp\u002F10.ef-core\u002F17.loading-related-data-part2",{"title":571,"path":572,"stem":573},"Raw SQL, Views та Stored Procedures (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fraw-sql-part1","01.csharp\u002F10.ef-core\u002F18.raw-sql-part1",{"title":575,"path":576,"stem":577},"Raw SQL — Stored Procedures, DbFunction та Bulk Operations (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fraw-sql-part2","01.csharp\u002F10.ef-core\u002F18.raw-sql-part2",{"title":579,"path":580,"stem":581},"Продвинуті Запити — Compiled Queries, Bulk та Оптимізація (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fadvanced-queries-part1","01.csharp\u002F10.ef-core\u002F19.advanced-queries-part1",{"title":583,"path":584,"stem":585},"Продвинуті Запити — Query Tags, Bulk та Interceptors (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fadvanced-queries-part2","01.csharp\u002F10.ef-core\u002F19.advanced-queries-part2",{"title":587,"path":588,"stem":589},"Change Tracker — Відстеження Змін (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fchange-tracking-part1","01.csharp\u002F10.ef-core\u002F20.change-tracking-part1",{"title":591,"path":592,"stem":593},"Change Tracker — Графи Об'єктів та Disconnected (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fchange-tracking-part2","01.csharp\u002F10.ef-core\u002F20.change-tracking-part2",{"title":595,"path":596,"stem":597},"Збереження Даних та Транзакції (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fsaving-data-part1","01.csharp\u002F10.ef-core\u002F21.saving-data-part1",{"title":599,"path":600,"stem":601},"Збереження Даних — Concurrency та Outbox (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fsaving-data-part2","01.csharp\u002F10.ef-core\u002F21.saving-data-part2",{"title":603,"path":604,"stem":605},"Конкурентність та Блокування (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fconcurrency-part1","01.csharp\u002F10.ef-core\u002F22.concurrency-part1",{"title":607,"path":608,"stem":609},"Конкурентність — Дедлоки та Queue Processing (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fconcurrency-part2","01.csharp\u002F10.ef-core\u002F22.concurrency-part2",{"title":611,"path":612,"stem":613},"Міграції в EF Core — Основи (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fmigrations-basics-part1","01.csharp\u002F10.ef-core\u002F23.migrations-basics-part1",{"title":615,"path":616,"stem":617},"Міграції в EF Core — Основи (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fmigrations-basics-part2","01.csharp\u002F10.ef-core\u002F23.migrations-basics-part2",{"title":619,"path":620,"stem":621},"Міграції — Просунуті Сценарії (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fmigrations-advanced-part1","01.csharp\u002F10.ef-core\u002F24.migrations-advanced-part1",{"title":623,"path":624,"stem":625},"Міграції — Просунуті Сценарії (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fmigrations-advanced-part2","01.csharp\u002F10.ef-core\u002F24.migrations-advanced-part2",{"title":627,"path":628,"stem":629},"Управління Схемою та Database-First (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fschema-management-part1","01.csharp\u002F10.ef-core\u002F25.schema-management-part1",{"title":631,"path":632,"stem":633},"Управління Схемою та Database-First (Частина 2)","\u002Fcsharp\u002Fef-core\u002Fschema-management-part2","01.csharp\u002F10.ef-core\u002F25.schema-management-part2",{"title":635,"path":636,"stem":637},"Продуктивність EF Core — Основи (Частина 1)","\u002Fcsharp\u002Fef-core\u002Fperformance-fundamentals-part1","01.csharp\u002F10.ef-core\u002F26.performance-fundamentals-part1",{"title":639,"path":640,"stem":641},"Interceptors в EF Core (Частина 1)","\u002Fcsharp\u002Fef-core\u002Finterceptors-part1","01.csharp\u002F10.ef-core\u002F29.interceptors-part1",{"title":643,"path":644,"stem":645},"Interceptors в EF Core — Connection, Transaction та Materialization (Частина 2)","\u002Fcsharp\u002Fef-core\u002Finterceptors-part2","01.csharp\u002F10.ef-core\u002F29.interceptors-part2",{"title":647,"path":648,"stem":649},"План вивчення Entity Framework Core — Повний курс","\u002Fcsharp\u002Fef-core\u002Fimplementation_plan","01.csharp\u002F10.ef-core\u002Fimplementation_plan",{"title":651,"icon":652,"path":653,"stem":654,"children":655,"page":59},"ASP.NET","i-devicon-dotnetcore","\u002Fcsharp\u002Faspnet","01.csharp\u002F11.aspnet",[656,730,791,869,927,941,967,1057,1111,1182,1212,1289,1346],{"title":657,"icon":658,"path":659,"stem":660,"children":661,"page":59},"Minimal API","i-lucide-network","\u002Fcsharp\u002Faspnet\u002Fminimal-api","01.csharp\u002F11.aspnet\u002F01.minimal-api",[662,666,670,674,678,682,686,690,694,698,702,706,710,714,718,722,726],{"title":663,"path":664,"stem":665},"Вступ до ASP.NET та еволюція фреймворку","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fintroduction","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F01.introduction",{"title":667,"path":668,"stem":669},"Перший додаток на ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Ffirst-application","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F02.first-application",{"title":671,"path":672,"stem":673},"WebApplication, Builder та Dependency Injection","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fwebapplication-builder","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F03.webapplication-builder",{"title":675,"path":676,"stem":677},"Конвеєр запитів та Middleware","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frequest-pipeline-middleware","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F04.request-pipeline-middleware",{"title":679,"path":680,"stem":681},"Маршрутизація в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frouting-basics","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F05.routing-basics",{"title":683,"path":684,"stem":685},"Маршрутизація в ASP.NET Core: Розширені можливості","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Frouting-advanced","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F06.routing-advanced",{"title":687,"path":688,"stem":689},"Статичні файли в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstatic-files","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F07.static-files",{"title":691,"path":692,"stem":693},"Статичні Активи: MapStaticAssets (ASP.NET Core 9.0)","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstatic-assets","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F08.static-assets",{"title":695,"path":696,"stem":697},"Конфігурація в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fconfiguration-fundamentals","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F09.configuration-fundamentals",{"title":699,"path":700,"stem":701},"Конфігурація: Паттерн Options","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fconfiguration-options","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F10.configuration-options",{"title":703,"path":704,"stem":705},"Логування в ASP.NET Core: Основи","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Flogging-basics","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F11.logging-basics",{"title":707,"path":708,"stem":709},"Логування: Serilog та Middleware","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Flogging-advanced","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F12.logging-advanced",{"title":711,"path":712,"stem":713},"Управління станом: HttpContext.Items та Cookies","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fstate-management","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F13.state-management",{"title":715,"path":716,"stem":717},"Стан сесії: Sessions","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fsession-state","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F14.session-state",{"title":719,"path":720,"stem":721},"Структура проєкту: від хаосу до архітектури","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fproject-structure","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F15.project-structure",{"title":723,"path":724,"stem":725},"Scalar у Minimal API: повний проєкт і Fluent OpenAPI","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fscalar-openapi-fluent","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F16.scalar-openapi-fluent",{"title":727,"path":728,"stem":729},"Swagger \u002F Swashbuckle у Minimal API: окремий класичний шлях","\u002Fcsharp\u002Faspnet\u002Fminimal-api\u002Fswagger-swashbuckle","01.csharp\u002F11.aspnet\u002F01.minimal-api\u002F17.swagger-swashbuckle",{"title":731,"icon":658,"path":732,"stem":733,"children":734,"page":59},"API","\u002Fcsharp\u002Faspnet\u002Fapi","01.csharp\u002F11.aspnet\u002F02.api",[735,739,743,747,751,755,759,763,767,771,775,779,783,787],{"title":736,"path":737,"stem":738},"Що таке API. Клієнт-серверна архітектура","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fwhat-is-api","01.csharp\u002F11.aspnet\u002F02.api\u002F01.what-is-api",{"title":740,"path":741,"stem":742},"Формати даних: JSON, XML, TOML та бінарні формати","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fdata-formats","01.csharp\u002F11.aspnet\u002F02.api\u002F02.data-formats",{"title":744,"path":745,"stem":746},"Парадигми API та концепція REST","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-paradigms-rest","01.csharp\u002F11.aspnet\u002F02.api\u002F03.api-paradigms-rest",{"title":748,"path":749,"stem":750},"HTTP-методи, статус-коди та заголовки","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fhttp-methods-status-codes","01.csharp\u002F11.aspnet\u002F02.api\u002F04.http-methods-status-codes",{"title":752,"path":753,"stem":754},"Організація HTTP API за принципами REST","\u002Fcsharp\u002Faspnet\u002Fapi\u002Frest-organizing","01.csharp\u002F11.aspnet\u002F02.api\u002F05.rest-organizing",{"title":756,"path":757,"stem":758},"Номенклатура URL та CRUD-операції","\u002Fcsharp\u002Faspnet\u002Fapi\u002Furl-nomenclature-crud","01.csharp\u002F11.aspnet\u002F02.api\u002F06.url-nomenclature-crud",{"title":760,"path":761,"stem":762},"Правила дизайну: іменування та стандарти","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-naming","01.csharp\u002F11.aspnet\u002F02.api\u002F07.api-design-naming",{"title":764,"path":765,"stem":766},"Валідація, ліміти та обробка помилок","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-validation","01.csharp\u002F11.aspnet\u002F02.api\u002F08.api-design-validation",{"title":768,"path":769,"stem":770},"Обробка помилок у Minimal API","\u002Fcsharp\u002Faspnet\u002Fapi\u002Ferror-handling-http","01.csharp\u002F11.aspnet\u002F02.api\u002F09.error-handling-http",{"title":772,"path":773,"stem":774},"Ідемпотентність та синхронізація стану","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fidempotency-sync","01.csharp\u002F11.aspnet\u002F02.api\u002F10.idempotency-sync",{"title":776,"path":777,"stem":778},"Пагінація та організація списків","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fpagination-lists","01.csharp\u002F11.aspnet\u002F02.api\u002F11.pagination-lists",{"title":780,"path":781,"stem":782},"Безпека API, кешування та інтернаціоналізація","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fsecurity-auth","01.csharp\u002F11.aspnet\u002F02.api\u002F12.security-auth",{"title":784,"path":785,"stem":786},"Процес проєктування API та документування","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fapi-design-process","01.csharp\u002F11.aspnet\u002F02.api\u002F13.api-design-process",{"title":788,"path":789,"stem":790},"OpenAPI: контракт, специфікація та документація API","\u002Fcsharp\u002Faspnet\u002Fapi\u002Fopenapi","01.csharp\u002F11.aspnet\u002F02.api\u002F14.openapi",{"title":792,"icon":793,"path":794,"stem":795,"children":796,"page":59},"Auth","i-lucide-shield-check","\u002Fcsharp\u002Faspnet\u002Fauth","01.csharp\u002F11.aspnet\u002F03.auth",[797,801,805,809,813,817,821,825,829,833,837,841,845,849,853,857,861,865],{"title":798,"path":799,"stem":800},"Основи аутентифікації та авторизації","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fauth-fundamentals","01.csharp\u002F11.aspnet\u002F03.auth\u002F01.auth-fundamentals",{"title":802,"path":803,"stem":804},"JWT-аутентифікація","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fjwt-authentication","01.csharp\u002F11.aspnet\u002F03.auth\u002F02.jwt-authentication",{"title":806,"path":807,"stem":808},"Авторизація: ролі, політики та resource-based доступ","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fauthorization-policies","01.csharp\u002F11.aspnet\u002F03.auth\u002F03.authorization-policies",{"title":810,"path":811,"stem":812},"Cookie-аутентифікація та ASP.NET Core Identity","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fcookie-auth-identity","01.csharp\u002F11.aspnet\u002F03.auth\u002F04.cookie-auth-identity",{"title":814,"path":815,"stem":816},"JWT + Refresh Tokens (HttpOnly Cookie)","\u002Fcsharp\u002Faspnet\u002Fauth\u002F04b.identity-auth-jwt","01.csharp\u002F11.aspnet\u002F03.auth\u002F04b.identity-auth-jwt",{"title":818,"path":819,"stem":820},"Identity: Підтвердження Email та Скидання Пароля","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-email-confirmation","01.csharp\u002F11.aspnet\u002F03.auth\u002F05.identity-email-confirmation",{"title":822,"path":823,"stem":824},"Identity: Двофакторна Аутентифікація (2FA)","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-two-factor","01.csharp\u002F11.aspnet\u002F03.auth\u002F06.identity-two-factor",{"title":826,"path":827,"stem":828},"Identity: Внутрішня Архітектура та Кастомізація","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fidentity-internals","01.csharp\u002F11.aspnet\u002F03.auth\u002F07.identity-internals",{"title":830,"path":831,"stem":832},"OAuth 2.0 та зовнішні провайдери","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foauth-external-providers","01.csharp\u002F11.aspnet\u002F03.auth\u002F08.oauth-external-providers",{"title":834,"path":835,"stem":836},"Безпека на практиці: CORS, HTTPS та захист від атак","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fsecurity-hardening","01.csharp\u002F11.aspnet\u002F03.auth\u002F09.security-hardening",{"title":838,"path":839,"stem":840},"Теорія OAuth 2.0: Поняття, Аналогії та Флоу","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foauth-theory","01.csharp\u002F11.aspnet\u002F03.auth\u002F10.oauth-theory",{"title":842,"path":843,"stem":844},"OIDC, OAuth 2.0 та Keycloak в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Foidc-keycloak","01.csharp\u002F11.aspnet\u002F03.auth\u002F10.oidc-keycloak",{"title":846,"path":847,"stem":848},"API Keys аутентифікація в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fapi-keys","01.csharp\u002F11.aspnet\u002F03.auth\u002F11.api-keys",{"title":850,"path":851,"stem":852},"Rate Limiting та Throttling в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frate-limiting","01.csharp\u002F11.aspnet\u002F03.auth\u002F12.rate-limiting",{"title":854,"path":855,"stem":856},"Refresh Token Rotation в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frefresh-token-rotation","01.csharp\u002F11.aspnet\u002F03.auth\u002F13.refresh-token-rotation",{"title":858,"path":859,"stem":860},"Certificate Authentication та mTLS в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fcertificate-auth","01.csharp\u002F11.aspnet\u002F03.auth\u002F14.certificate-auth",{"title":862,"path":863,"stem":864},"RBAC, ABAC та ReBAC в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Frbac-abac-rebac","01.csharp\u002F11.aspnet\u002F03.auth\u002F15.rbac-abac-rebac",{"title":866,"path":867,"stem":868},"Multi-tenancy та ізоляція даних в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fauth\u002Fmulti-tenancy","01.csharp\u002F11.aspnet\u002F03.auth\u002F16.multi-tenancy",{"title":870,"icon":871,"path":872,"stem":873,"children":874,"page":59},"Нотифікації","i-lucide-bell","\u002Fcsharp\u002Faspnet\u002Fnotifications","01.csharp\u002F11.aspnet\u002F04.notifications",[875,879,883,887,891,895,899,903,907,911,915,919,923],{"title":876,"path":877,"stem":878},"In-App нотифікації через базу даних","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fin-app-database-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F01.in-app-database-notifications",{"title":880,"path":881,"stem":882},"Polling: Регулярний запит оновлень","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fpolling","01.csharp\u002F11.aspnet\u002F04.notifications\u002F02.polling",{"title":884,"path":885,"stem":886},"Server-Sent Events: Однострімовий push від сервера","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fserver-sent-events","01.csharp\u002F11.aspnet\u002F04.notifications\u002F03.server-sent-events",{"title":888,"path":889,"stem":890},"WebSockets: Двостороннє з'єднання в реальному часі","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fwebsockets","01.csharp\u002F11.aspnet\u002F04.notifications\u002F04.websockets",{"title":892,"path":893,"stem":894},"SignalR: Абстракція над транспортами реального часу","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fsignalr","01.csharp\u002F11.aspnet\u002F04.notifications\u002F05.signalr",{"title":896,"path":897,"stem":898},"Background Services: Фонові задачі в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fbackground-services","01.csharp\u002F11.aspnet\u002F04.notifications\u002F06.background-services",{"title":900,"path":901,"stem":902},"Web Push нотифікації","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fweb-push","01.csharp\u002F11.aspnet\u002F04.notifications\u002F07.web-push",{"title":904,"path":905,"stem":906},"Email нотифікації","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Femail-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F08.email-notifications",{"title":908,"path":909,"stem":910},"Порівняння підходів: Як вибрати правильну технологію нотифікацій","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fchoosing-the-right-approach","01.csharp\u002F11.aspnet\u002F04.notifications\u002F09.choosing-the-right-approach",{"title":912,"path":913,"stem":914},"Hangfire: Надійне планування фонових задач","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire","01.csharp\u002F11.aspnet\u002F04.notifications\u002F10.hangfire",{"title":916,"path":917,"stem":918},"Практика: Конвертація зображень у WebP через Hangfire","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire-image-webp","01.csharp\u002F11.aspnet\u002F04.notifications\u002F11.hangfire-image-webp",{"title":920,"path":921,"stem":922},"Практика: Підготовка відео до HLS-стрімінгу через Hangfire","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Fhangfire-video-hls","01.csharp\u002F11.aspnet\u002F04.notifications\u002F12.hangfire-video-hls",{"title":924,"path":925,"stem":926},"Telegram-нотифікації: від одного повідомлення до масових розсилок і мульти-канального підходу","\u002Fcsharp\u002Faspnet\u002Fnotifications\u002Ftelegram-notifications","01.csharp\u002F11.aspnet\u002F04.notifications\u002F13.telegram-notifications",{"title":928,"icon":929,"path":930,"stem":931,"children":932,"page":59},"Інтернаціоналізація","i-lucide-languages","\u002Fcsharp\u002Faspnet\u002Fi18n","01.csharp\u002F11.aspnet\u002F05.i18n",[933,937],{"title":934,"path":935,"stem":936},"Інтернаціоналізація (i18n) у Minimal API: від A до Я","\u002Fcsharp\u002Faspnet\u002Fi18n\u002Finternationalization","01.csharp\u002F11.aspnet\u002F05.i18n\u002F01.internationalization",{"title":938,"path":939,"stem":940},"Humanizer: людиномовні рядки у .NET","\u002Fcsharp\u002Faspnet\u002Fi18n\u002Fhumanizer","01.csharp\u002F11.aspnet\u002F05.i18n\u002F02.humanizer",{"title":942,"icon":943,"path":944,"stem":945,"children":946,"page":59},"Кешування","i-lucide-layers","\u002Fcsharp\u002Faspnet\u002Fcaching","01.csharp\u002F11.aspnet\u002F06.caching",[947,951,955,959,963],{"title":948,"path":949,"stem":950},"Огляд кешування: чотири рівні і коли що обирати","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fcaching","01.csharp\u002F11.aspnet\u002F06.caching\u002F01.caching",{"title":952,"path":953,"stem":954},"IMemoryCache: кеш в оперативній пам'яті","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fmemory-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F02.memory-cache",{"title":956,"path":957,"stem":958},"IDistributedCache і Redis: розподілений кеш","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fdistributed-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F03.distributed-cache",{"title":960,"path":961,"stem":962},"Response Cache: HTTP-кешування через Cache-Control","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Fresponse-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F04.response-cache",{"title":964,"path":965,"stem":966},"Output Cache: серверний кеш HTTP-відповідей (.NET 7+)","\u002Fcsharp\u002Faspnet\u002Fcaching\u002Foutput-cache","01.csharp\u002F11.aspnet\u002F06.caching\u002F05.output-cache",{"title":968,"icon":969,"path":970,"stem":971,"children":972,"page":59},"Тестування","i-lucide-test-tube","\u002Fcsharp\u002Faspnet\u002Ftesting","01.csharp\u002F11.aspnet\u002F07.testing",[973,977,981,985,989,993,997,1001,1005,1009,1013,1017,1021,1025,1029,1033,1037,1041,1045,1049,1053],{"title":974,"path":975,"stem":976},"Що таке тестування? Від інтуїції до науки","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwhat-is-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F01.what-is-testing",{"title":978,"path":979,"stem":980},"Піраміда тестування — Стратегія, а не Догма","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-pyramid","01.csharp\u002F11.aspnet\u002F07.testing\u002F02.testing-pyramid",{"title":982,"path":983,"stem":984},"Дві Школи Тестування — Лондон проти Детройту","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-schools","01.csharp\u002F11.aspnet\u002F07.testing\u002F03.testing-schools",{"title":986,"path":987,"stem":988},"TDD та BDD — Тести як Дизайн-інструмент","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftdd-and-bdd","01.csharp\u002F11.aspnet\u002F07.testing\u002F04.tdd-and-bdd",{"title":990,"path":991,"stem":992},"Що саме тестувати — Техніки аналізу та Циклomatична складність","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwhat-to-test","01.csharp\u002F11.aspnet\u002F07.testing\u002F05.what-to-test",{"title":994,"path":995,"stem":996},"Тестові Фреймворки — Навіщо вони і що всередині","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftest-frameworks","01.csharp\u002F11.aspnet\u002F07.testing\u002F06.test-frameworks",{"title":998,"path":999,"stem":1000},"xUnit — Факти, Теорії та Lifecycle тестів","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fxunit-basics","01.csharp\u002F11.aspnet\u002F07.testing\u002F07.xunit-basics",{"title":1002,"path":1003,"stem":1004},"xUnit Advanced — Fixtures, Кастомізація та Розширення","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fxunit-advanced","01.csharp\u002F11.aspnet\u002F07.testing\u002F08.xunit-advanced",{"title":1006,"path":1007,"stem":1008},"Moq — Глибоке занурення в мокування","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fmocking-with-moq","01.csharp\u002F11.aspnet\u002F07.testing\u002F09.mocking-with-moq",{"title":1010,"path":1011,"stem":1012},"Тестування Баз Даних — EF Core, SQLite та Testcontainers","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fdatabase-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F10.database-testing",{"title":1014,"path":1015,"stem":1016},"Integration Testing — Частина 1 [Теорія та WebApplicationFactory]","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fintegration-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F11.integration-testing",{"title":1018,"path":1019,"stem":1020},"Інтеграційне тестування — Практика","\u002Fcsharp\u002Faspnet\u002Ftesting\u002F11a.integration-testing-practice","01.csharp\u002F11.aspnet\u002F07.testing\u002F11a.integration-testing-practice",{"title":1022,"path":1023,"stem":1024},"Integration Testing — Частина 2 [Просунуті Сценарії та Testcontainers]","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fintegration-testing-advanced","01.csharp\u002F11.aspnet\u002F07.testing\u002F12.integration-testing-advanced",{"title":1026,"path":1027,"stem":1028},"Професійний Postman: Колекції, Змінні та GitHub Інтеграція","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fpostman-professional","01.csharp\u002F11.aspnet\u002F07.testing\u002F13.postman-professional",{"title":1030,"path":1031,"stem":1032},"HttpClient у Тестах Частина 1: Архітектура та MockHttpMessageHandler","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fhttpclient-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F14.httpclient-testing",{"title":1034,"path":1035,"stem":1036},"HttpClient у Тестах Частина 2: WireMock.Net та Resilience","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fwiremock-net","01.csharp\u002F11.aspnet\u002F07.testing\u002F15.wiremock-net",{"title":1038,"path":1039,"stem":1040},"Патерни та Анти-патерни Тестування: Test Smells","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Ftesting-patterns","01.csharp\u002F11.aspnet\u002F07.testing\u002F16.testing-patterns",{"title":1042,"path":1043,"stem":1044},"Просунуті інструменти: Time, Snapshots та Властивості","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fadvanced-testing-tools","01.csharp\u002F11.aspnet\u002F07.testing\u002F17.advanced-testing-tools",{"title":1046,"path":1047,"stem":1048},"Тестування Архітектури з NetArchTest","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Farchitecture-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F18.architecture-testing",{"title":1050,"path":1051,"stem":1052},"Тестування Продуктивності: BenchmarkDotNet, NBomber та k6","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fperformance-testing","01.csharp\u002F11.aspnet\u002F07.testing\u002F19.performance-testing",{"title":1054,"path":1055,"stem":1056},"Залишок плану для курсу \"Тестування ASP.NET Minimal API\"","\u002Fcsharp\u002Faspnet\u002Ftesting\u002Fremaining_plan","01.csharp\u002F11.aspnet\u002F07.testing\u002Fremaining_plan",{"title":1058,"icon":1059,"path":1060,"stem":1061,"children":1062,"page":59},"Платежі","i-lucide-credit-card","\u002Fcsharp\u002Faspnet\u002Fpayments","01.csharp\u002F11.aspnet\u002F08.payments",[1063,1067,1071,1075,1079,1083,1087,1091,1095,1099,1103,1107],{"title":1064,"path":1065,"stem":1066},"Основи платіжної інфраструктури","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-fundamentals","01.csharp\u002F11.aspnet\u002F08.payments\u002F01.payment-fundamentals",{"title":1068,"path":1069,"stem":1070},"Методи оплати в Україні","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-methods-ukraine","01.csharp\u002F11.aspnet\u002F08.payments\u002F02.payment-methods-ukraine",{"title":1072,"path":1073,"stem":1074},"PCI DSS та безпека платежів","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpci-dss-security","01.csharp\u002F11.aspnet\u002F08.payments\u002F03.pci-dss-security",{"title":1076,"path":1077,"stem":1078},"Архітектура платіжної підсистеми","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fpayment-architecture","01.csharp\u002F11.aspnet\u002F08.payments\u002F04.payment-architecture",{"title":1080,"path":1081,"stem":1082},"Інтеграція LiqPay (ПриватБанк)","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fliqpay-integration","01.csharp\u002F11.aspnet\u002F08.payments\u002F05.liqpay-integration",{"title":1084,"path":1085,"stem":1086},"Інтеграція Monobank Acquiring API","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fmonobank-acquiring","01.csharp\u002F11.aspnet\u002F08.payments\u002F06.monobank-acquiring",{"title":1088,"path":1089,"stem":1090},"Інтеграція Stripe","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fstripe-integration","01.csharp\u002F11.aspnet\u002F08.payments\u002F07.stripe-integration",{"title":1092,"path":1093,"stem":1094},"Webhooks — глибоке занурення","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fwebhooks-deep-dive","01.csharp\u002F11.aspnet\u002F08.payments\u002F08.webhooks-deep-dive",{"title":1096,"path":1097,"stem":1098},"Підписки та рекурентні платежі","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fsubscriptions-recurring","01.csharp\u002F11.aspnet\u002F08.payments\u002F09.subscriptions-recurring",{"title":1100,"path":1101,"stem":1102},"Повернення коштів та диспути","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Frefunds-disputes","01.csharp\u002F11.aspnet\u002F08.payments\u002F10.refunds-disputes",{"title":1104,"path":1105,"stem":1106},"Тестування платіжних інтеграцій","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Ftesting-payments","01.csharp\u002F11.aspnet\u002F08.payments\u002F11.testing-payments",{"title":1108,"path":1109,"stem":1110},"Чекліст виходу в Production","\u002Fcsharp\u002Faspnet\u002Fpayments\u002Fproduction-checklist","01.csharp\u002F11.aspnet\u002F08.payments\u002F12.production-checklist",{"title":1112,"icon":1113,"items":1114,"path":1127,"stem":1128,"children":1129,"page":59},"Популярні бібліотеки","lucide:box",[1115,1116,1117,1118,1119,1120,1121,1122,1123,1124,1125,1126],"01.fluent-validation","02.mapster","03.erroror-result-pattern","04.serilog","05.mediatr","06.polly","07.health-checks","08.feature-management","09.fluent-email","10.quest-pdf","11.bogus","12.humanizer-guard","\u002Fcsharp\u002Faspnet\u002Flibraries","01.csharp\u002F11.aspnet\u002F09.libraries",[1130,1134,1138,1142,1146,1150,1154,1158,1162,1166,1170,1174,1178],{"title":1131,"path":1132,"stem":1133},"Валідація з FluentValidation в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffluent-validation","01.csharp\u002F11.aspnet\u002F09.libraries\u002F01.fluent-validation",{"title":1135,"path":1136,"stem":1137},"Маппінг об","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fmapster","01.csharp\u002F11.aspnet\u002F09.libraries\u002F02.mapster",{"title":1139,"path":1140,"stem":1141},"Обробка помилок з ErrorOr та Result Pattern в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ferroror-result-pattern","01.csharp\u002F11.aspnet\u002F09.libraries\u002F03.erroror-result-pattern",{"title":1143,"path":1144,"stem":1145},"Структуроване логування з Serilog в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fserilog","01.csharp\u002F11.aspnet\u002F09.libraries\u002F04.serilog",{"title":1147,"path":1148,"stem":1149},"CQRS та Mediator з MediatR в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fmediatr","01.csharp\u002F11.aspnet\u002F09.libraries\u002F05.mediatr",{"title":1151,"path":1152,"stem":1153},"Відмовостійкість з Polly в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fpolly","01.csharp\u002F11.aspnet\u002F09.libraries\u002F06.polly",{"title":1155,"path":1156,"stem":1157},"Health Checks в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fhealth-checks","01.csharp\u002F11.aspnet\u002F09.libraries\u002F07.health-checks",{"title":1159,"path":1160,"stem":1161},"Feature Management та Feature Flags в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffeature-management","01.csharp\u002F11.aspnet\u002F09.libraries\u002F08.feature-management",{"title":1163,"path":1164,"stem":1165},"Відправка Email з FluentEmail в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Ffluent-email","01.csharp\u002F11.aspnet\u002F09.libraries\u002F09.fluent-email",{"title":1167,"path":1168,"stem":1169},"Генерація PDF з QuestPDF в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fquest-pdf","01.csharp\u002F11.aspnet\u002F09.libraries\u002F10.quest-pdf",{"title":1171,"path":1172,"stem":1173},"Генерація тестових даних з Bogus в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fbogus","01.csharp\u002F11.aspnet\u002F09.libraries\u002F11.bogus",{"title":1175,"path":1176,"stem":1177},"Humanizer та Guard Clauses в ASP.NET Core","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fhumanizer-guard","01.csharp\u002F11.aspnet\u002F09.libraries\u002F12.humanizer-guard",{"title":1179,"path":1180,"stem":1181},"План модуля 10.libraries — Популярні бібліотеки ASP.NET","\u002Fcsharp\u002Faspnet\u002Flibraries\u002Fplan","01.csharp\u002F11.aspnet\u002F09.libraries\u002Fplan",{"title":1183,"icon":1184,"path":1185,"stem":1186,"children":1187,"page":59},"Razor Pages","i-lucide-layout-template","\u002Fcsharp\u002Faspnet\u002Frazor-pages","01.csharp\u002F11.aspnet\u002F10.razor-pages",[1188,1192,1196,1200,1204,1208],{"title":1189,"path":1190,"stem":1191},"Від Minimal API до Razor Pages: концептуальний перехід","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Ffrom-minimal-api","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F01.from-minimal-api",{"title":1193,"path":1194,"stem":1195},"PageModel: логіка сторінки Razor Pages","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fpage-model","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F02.page-model",{"title":1197,"path":1198,"stem":1199},"Razor синтаксис: шаблонізатор у .cshtml","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Frazor-syntax","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F03.razor-syntax",{"title":1201,"path":1202,"stem":1203},"Tag Helpers: типізований HTML","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Ftag-helpers","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F04.tag-helpers",{"title":1205,"path":1206,"stem":1207},"Форми і валідація: повний цикл обробки даних","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fforms-validation","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F05.forms-validation",{"title":1209,"path":1210,"stem":1211},"Практичний проєкт: TaskManager на Razor Pages","\u002Fcsharp\u002Faspnet\u002Frazor-pages\u002Fproject-task-manager","01.csharp\u002F11.aspnet\u002F10.razor-pages\u002F06.project-task-manager",{"title":1213,"path":1214,"stem":1215,"children":1216,"page":59},"ASP.NET Core MVC","\u002Fcsharp\u002Faspnet\u002Fmvc","01.csharp\u002F11.aspnet\u002F11.mvc",[1217,1221,1225,1229,1233,1237,1241,1245,1249,1253,1257,1261,1265,1269,1273,1277,1281,1285],{"title":1218,"path":1219,"stem":1220},"Патерн MVC: архітектура, що змінила веб","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmvc-pattern","01.csharp\u002F11.aspnet\u002F11.mvc\u002F01.mvc-pattern",{"title":1222,"path":1223,"stem":1224},"Від Razor Pages до MVC: концептуальний перехід","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffrom-razor-pages","01.csharp\u002F11.aspnet\u002F11.mvc\u002F02.from-razor-pages",{"title":1226,"path":1227,"stem":1228},"Controllers та Actions: серце MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fcontrollers-actions","01.csharp\u002F11.aspnet\u002F11.mvc\u002F03.controllers-actions",{"title":1230,"path":1231,"stem":1232},"Маршрутизація в MVC: Convention vs Attribute Routing","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Frouting-mvc","01.csharp\u002F11.aspnet\u002F11.mvc\u002F04.routing-mvc",{"title":1234,"path":1235,"stem":1236},"Model Binding: від HTTP до C#","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmodel-binding","01.csharp\u002F11.aspnet\u002F11.mvc\u002F05.model-binding",{"title":1238,"path":1239,"stem":1240},"Views, ViewData, ViewBag, TempData і ViewModel","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fviews-viewdata-tempdata","01.csharp\u002F11.aspnet\u002F11.mvc\u002F06.views-viewdata-tempdata",{"title":1242,"path":1243,"stem":1244},"Filters: аспектно-орієнтоване програмування в MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffilters","01.csharp\u002F11.aspnet\u002F11.mvc\u002F07.filters",{"title":1246,"path":1247,"stem":1248},"Areas: структурування великих застосунків","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fareas","01.csharp\u002F11.aspnet\u002F11.mvc\u002F08.areas",{"title":1250,"path":1251,"stem":1252},"View Components: повторювані незалежні блоки UI","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fview-components","01.csharp\u002F11.aspnet\u002F11.mvc\u002F09.view-components",{"title":1254,"path":1255,"stem":1256},"Display та Editor Templates","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fdisplay-editor-templates","01.csharp\u002F11.aspnet\u002F11.mvc\u002F10.display-editor-templates",{"title":1258,"path":1259,"stem":1260},"Валідація: IValidatableObject та FluentValidation","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fvalidation-advanced","01.csharp\u002F11.aspnet\u002F11.mvc\u002F11.validation-advanced",{"title":1262,"path":1263,"stem":1264},"HTMX: інтерактивність через HTML-атрибути","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fhtmx","01.csharp\u002F11.aspnet\u002F11.mvc\u002F12.htmx",{"title":1266,"path":1267,"stem":1268},"HTMX у ASP.NET Core MVC: серверна інтеграція","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fajax-htmx-mvc","01.csharp\u002F11.aspnet\u002F11.mvc\u002F13.ajax-htmx-mvc",{"title":1270,"path":1271,"stem":1272},"Практичний проєкт: Каталог товарів з HTMX","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fhtmx-project","01.csharp\u002F11.aspnet\u002F11.mvc\u002F14.htmx-project",{"title":1274,"path":1275,"stem":1276},"Завантаження та обробка файлів","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Ffile-upload","01.csharp\u002F11.aspnet\u002F11.mvc\u002F15.file-upload",{"title":1278,"path":1279,"stem":1280},"Глобалізація та Локалізація MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fglobalization-localization","01.csharp\u002F11.aspnet\u002F11.mvc\u002F16.globalization-localization",{"title":1282,"path":1283,"stem":1284},"Підсумковий проєкт: Блог-платформа","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fmvc-project","01.csharp\u002F11.aspnet\u002F11.mvc\u002F17.mvc-project",{"title":1286,"path":1287,"stem":1288},"План курсу: ASP.NET Core MVC","\u002Fcsharp\u002Faspnet\u002Fmvc\u002Fplan","01.csharp\u002F11.aspnet\u002F11.mvc\u002Fplan",{"title":1290,"path":1291,"stem":1292,"children":1293,"page":59},"Web Api","\u002Fcsharp\u002Faspnet\u002Fweb-api","01.csharp\u002F11.aspnet\u002F12.web-api",[1294,1298,1302,1306,1310,1314,1318,1322,1326,1330,1334,1338,1342],{"title":1295,"path":1296,"stem":1297},"Від Minimal API до Controller-based API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Ffrom-minimal-api-to-controllers","01.csharp\u002F11.aspnet\u002F12.web-api\u002F01.from-minimal-api-to-controllers",{"title":1299,"path":1300,"stem":1301},"ControllerBase, ActionResult\u003CT> та Response Types","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fcontroller-base-actionresult","01.csharp\u002F11.aspnet\u002F12.web-api\u002F02.controller-base-actionresult",{"title":1303,"path":1304,"stem":1305},"Content Negotiation - JSON, XML та власні форматери","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fcontent-negotiation","01.csharp\u002F11.aspnet\u002F12.web-api\u002F03.content-negotiation",{"title":1307,"path":1308,"stem":1309},"Версіонування API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fapi-versioning","01.csharp\u002F11.aspnet\u002F12.web-api\u002F04.api-versioning",{"title":1311,"path":1312,"stem":1313},"ProblemDetails та структурована обробка помилок","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fproblemdetails-error-handling","01.csharp\u002F11.aspnet\u002F12.web-api\u002F05.problemdetails-error-handling",{"title":1315,"path":1316,"stem":1317},"Фільтри у Web API контексті","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Ffilters-for-api","01.csharp\u002F11.aspnet\u002F12.web-api\u002F06.filters-for-api",{"title":1319,"path":1320,"stem":1321},"Пагінація, фільтрація та сортування","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fpagination-filtering-sorting","01.csharp\u002F11.aspnet\u002F12.web-api\u002F07.pagination-filtering-sorting",{"title":1323,"path":1324,"stem":1325},"HATEOAS та Resource Expansion","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fhateoas-resource-expansion","01.csharp\u002F11.aspnet\u002F12.web-api\u002F08.hateoas-resource-expansion",{"title":1327,"path":1328,"stem":1329},"Гібридна архітектура - Minimal API + Controllers","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fminimal-api-vs-controllers-hybrid","01.csharp\u002F11.aspnet\u002F12.web-api\u002F09.minimal-api-vs-controllers-hybrid",{"title":1331,"path":1332,"stem":1333},"Документація API - Swashbuckle, NSwag та генерація клієнтів","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fapi-documentation-generation","01.csharp\u002F11.aspnet\u002F12.web-api\u002F10.api-documentation-generation",{"title":1335,"path":1336,"stem":1337},"Health Checks та моніторинг API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fhealth-checks-monitoring","01.csharp\u002F11.aspnet\u002F12.web-api\u002F11.health-checks-monitoring",{"title":1339,"path":1340,"stem":1341},"Підсумковий проєкт - Production-Ready REST API","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fweb-api-project","01.csharp\u002F11.aspnet\u002F12.web-api\u002F12.web-api-project",{"title":1343,"path":1344,"stem":1345},"План курсу: ASP.NET Core Web API (Controllers)","\u002Fcsharp\u002Faspnet\u002Fweb-api\u002Fplan","01.csharp\u002F11.aspnet\u002F12.web-api\u002Fplan",{"title":1347,"icon":1348,"path":1349,"stem":1350,"children":1351,"page":59},"Моніторинг","i-lucide-activity","\u002Fcsharp\u002Faspnet\u002Fmonitoring","01.csharp\u002F11.aspnet\u002F13.monitoring",[1352,1356,1360],{"title":1353,"path":1354,"stem":1355},"Спостережуваність: від console.log до production-систем","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fobservability-intro","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F01.observability-intro",{"title":1357,"path":1358,"stem":1359},"Health Checks: перший рівень observability","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fhealth-checks","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F02.health-checks",{"title":1361,"path":1362,"stem":1363},"Вбудовані метрики .NET 10 та System.Diagnostics.Metrics","\u002Fcsharp\u002Faspnet\u002Fmonitoring\u002Fdotnet-metrics","01.csharp\u002F11.aspnet\u002F13.monitoring\u002F03.dotnet-metrics",{"title":1365,"icon":1366,"path":1367,"stem":1368,"children":1369,"page":59},"Desktop UI","i-lucide-app-window","\u002Fcsharp\u002Fdesktop-ui","01.csharp\u002F12.desktop-ui",[1370,1374,1378,1382,1386,1390,1394,1398,1402,1406,1410,1414,1418,1422,1426,1430,1434,1438,1442,1446,1450,1454,1458,1462,1466,1470,1474,1478,1482,1486,1490,1494,1498,1502,1506,1510,1514,1518,1522,1526,1530,1534,1538,1542,1546,1550,1554,1558,1562,1566,1570,1574,1578,1582,1586,1590,1594,1598,1602,1606,1610,1614,1618,1622,1626,1630,1634,1638,1642,1646,1650],{"title":1371,"path":1372,"stem":1373},"Що таке десктопна розробка?","\u002Fcsharp\u002Fdesktop-ui\u002Fwhat-is-desktop-dev","01.csharp\u002F12.desktop-ui\u002F01.what-is-desktop-dev",{"title":1375,"path":1376,"stem":1377},"Архітектура WPF — як влаштований графічний інтерфейс","\u002Fcsharp\u002Fdesktop-ui\u002Fwpf-architecture","01.csharp\u002F12.desktop-ui\u002F02.wpf-architecture",{"title":1379,"path":1380,"stem":1381},"Перший WPF-проєкт — від нуля до вікна","\u002Fcsharp\u002Fdesktop-ui\u002Ffirst-wpf-app","01.csharp\u002F12.desktop-ui\u002F03.first-wpf-app",{"title":1383,"path":1384,"stem":1385},"Перший Avalonia-проєкт: WPF для всіх платформ","\u002Fcsharp\u002Fdesktop-ui\u002F03a.first-avalonia-app","01.csharp\u002F12.desktop-ui\u002F03a.first-avalonia-app",{"title":1387,"path":1388,"stem":1389},"XAML: декларативний інтерфейс","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-basics","01.csharp\u002F12.desktop-ui\u002F04.xaml-basics",{"title":1391,"path":1392,"stem":1393},"Fluent UI у WPF — сучасний дизайн Windows 11","\u002Fcsharp\u002Fdesktop-ui\u002F04a.wpf-fluent-ui","01.csharp\u002F12.desktop-ui\u002F04a.wpf-fluent-ui",{"title":1395,"path":1396,"stem":1397},"WPF UI — сучасна бібліотека Fluent контролів","\u002Fcsharp\u002Fdesktop-ui\u002F04b.wpf-ui-library","01.csharp\u002F12.desktop-ui\u002F04b.wpf-ui-library",{"title":1399,"path":1400,"stem":1401},"HandyControl — велика бібліотека UI контролів для WPF","\u002Fcsharp\u002Fdesktop-ui\u002F04c.handycontrol-library","01.csharp\u002F12.desktop-ui\u002F04c.handycontrol-library",{"title":1403,"path":1404,"stem":1405},"Простори імен та ресурси XAML","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-namespaces-resources","01.csharp\u002F12.desktop-ui\u002F05.xaml-namespaces-resources",{"title":1407,"path":1408,"stem":1409},"XAML в Avalonia: ключові відмінності від WPF","\u002Fcsharp\u002Fdesktop-ui\u002F05a.avalonia-xaml-differences","01.csharp\u002F12.desktop-ui\u002F05a.avalonia-xaml-differences",{"title":1411,"path":1412,"stem":1413},"Розширення розмітки XAML (Markup Extensions)","\u002Fcsharp\u002Fdesktop-ui\u002Fxaml-markup-extensions","01.csharp\u002F12.desktop-ui\u002F06.xaml-markup-extensions",{"title":1415,"path":1416,"stem":1417},"Панелі Layout: StackPanel, WrapPanel, DockPanel","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-panels-part1","01.csharp\u002F12.desktop-ui\u002F07.layout-panels-part1",{"title":1419,"path":1420,"stem":1421},"Grid, Canvas, UniformGrid","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-panels-part2","01.csharp\u002F12.desktop-ui\u002F07.layout-panels-part2",{"title":1423,"path":1424,"stem":1425},"Просунуті техніки Layout","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-advanced","01.csharp\u002F12.desktop-ui\u002F08.layout-advanced",{"title":1427,"path":1428,"stem":1429},"Адаптивний Layout та найкращі практики","\u002Fcsharp\u002Fdesktop-ui\u002Flayout-responsive","01.csharp\u002F12.desktop-ui\u002F09.layout-responsive",{"title":1431,"path":1432,"stem":1433},"Layout в Avalonia: відмінності та нові можливості","\u002Fcsharp\u002Fdesktop-ui\u002F09a.layout-avalonia","01.csharp\u002F12.desktop-ui\u002F09a.layout-avalonia",{"title":1435,"path":1436,"stem":1437},"Button, Image, ProgressBar та інші базові контроли","\u002Fcsharp\u002Fdesktop-ui\u002Fbasic-controls","01.csharp\u002F12.desktop-ui\u002F10.basic-controls",{"title":1439,"path":1440,"stem":1441},"Контроли в Avalonia: відмінності від WPF","\u002Fcsharp\u002Fdesktop-ui\u002F10a.controls-avalonia","01.csharp\u002F12.desktop-ui\u002F10a.controls-avalonia",{"title":1443,"path":1444,"stem":1445},"Текстові контроли — TextBlock, TextBox, RichTextBox","\u002Fcsharp\u002Fdesktop-ui\u002Ftext-controls","01.csharp\u002F12.desktop-ui\u002F11.text-controls",{"title":1447,"path":1448,"stem":1449},"Контроли вибору — CheckBox, RadioButton, ComboBox, ListBox, DatePicker","\u002Fcsharp\u002Fdesktop-ui\u002Fselection-controls","01.csharp\u002F12.desktop-ui\u002F12.selection-controls",{"title":1451,"path":1452,"stem":1453},"Content Model — GroupBox, Expander, TabControl, StatusBar","\u002Fcsharp\u002Fdesktop-ui\u002Fcontent-controls","01.csharp\u002F12.desktop-ui\u002F13.content-controls",{"title":1455,"path":1456,"stem":1457},"UI\u002FUX принципи десктопних застосунків","\u002Fcsharp\u002Fdesktop-ui\u002F13a.ui-ux-principles","01.csharp\u002F12.desktop-ui\u002F13a.ui-ux-principles",{"title":1459,"path":1460,"stem":1461},"Dependency Properties — Концепція та Value Resolution","\u002Fcsharp\u002Fdesktop-ui\u002Fdependency-properties-part1","01.csharp\u002F12.desktop-ui\u002F14.dependency-properties-part1",{"title":1463,"path":1464,"stem":1465},"Avalonia Property System — StyledProperty та DirectProperty","\u002Fcsharp\u002Fdesktop-ui\u002F14a.avalonia-property-system","01.csharp\u002F12.desktop-ui\u002F14a.avalonia-property-system",{"title":1467,"path":1468,"stem":1469},"Attached Properties — Властивості без меж","\u002Fcsharp\u002Fdesktop-ui\u002Fattached-properties","01.csharp\u002F12.desktop-ui\u002F15.attached-properties",{"title":1471,"path":1472,"stem":1473},"Routed Events — Маршрутизація подій у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Frouted-events","01.csharp\u002F12.desktop-ui\u002F16.routed-events",{"title":1475,"path":1476,"stem":1477},"Data Binding — Від Code-Behind до Декларативності","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-basics-part1","01.csharp\u002F12.desktop-ui\u002F17.data-binding-basics-part1",{"title":1479,"path":1480,"stem":1481},"INotifyPropertyChanged — Живе оновлення UI","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-basics-part2","01.csharp\u002F12.desktop-ui\u002F17.data-binding-basics-part2",{"title":1483,"path":1484,"stem":1485},"Compiled Bindings в Avalonia — Безпека на етапі компіляції","\u002Fcsharp\u002Fdesktop-ui\u002F17a.avalonia-compiled-bindings","01.csharp\u002F12.desktop-ui\u002F17a.avalonia-compiled-bindings",{"title":1487,"path":1488,"stem":1489},"Просунутий Data Binding — ElementName, RelativeSource, MultiBinding","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-binding-advanced","01.csharp\u002F12.desktop-ui\u002F18.data-binding-advanced",{"title":1491,"path":1492,"stem":1493},"Value Converters — Перетворення типів даних у Data Binding","\u002Fcsharp\u002Fdesktop-ui\u002Fvalue-converters","01.csharp\u002F12.desktop-ui\u002F19.value-converters",{"title":1495,"path":1496,"stem":1497},"Data Templates — Візуалізація об'єктів у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-templates","01.csharp\u002F12.desktop-ui\u002F20.data-templates",{"title":1499,"path":1500,"stem":1501},"Collections Binding Part 1 — ObservableCollection та ItemsControl","\u002Fcsharp\u002Fdesktop-ui\u002Fcollections-binding-part1","01.csharp\u002F12.desktop-ui\u002F21.collections-binding-part1",{"title":1503,"path":1504,"stem":1505},"Collections Binding Part 2 — ICollectionView, Filtering, Sorting та Virtualization","\u002Fcsharp\u002Fdesktop-ui\u002Fcollections-binding-part2","01.csharp\u002F12.desktop-ui\u002F21.collections-binding-part2",{"title":1507,"path":1508,"stem":1509},"MVVM Pattern — Від Spaghetti Code до архітектури","\u002Fcsharp\u002Fdesktop-ui\u002Fmvvm-pattern","01.csharp\u002F12.desktop-ui\u002F22.mvvm-pattern",{"title":1511,"path":1512,"stem":1513},"ViewModel Implementation — Від BaseViewModel до валідації","\u002Fcsharp\u002Fdesktop-ui\u002Fviewmodel-implementation","01.csharp\u002F12.desktop-ui\u002F23.viewmodel-implementation",{"title":1515,"path":1516,"stem":1517},"Commands — Від event handlers до декларативних команд","\u002Fcsharp\u002Fdesktop-ui\u002Fcommands","01.csharp\u002F12.desktop-ui\u002F24.commands",{"title":1519,"path":1520,"stem":1521},"MVVM Toolkit — MVVM без boilerplate через Source Generators","\u002Fcsharp\u002Fdesktop-ui\u002Fmvvm-toolkit","01.csharp\u002F12.desktop-ui\u002F25.mvvm-toolkit",{"title":1523,"path":1524,"stem":1525},"Messenger Pattern — Комунікація між ViewModel без прямих посилань","\u002Fcsharp\u002Fdesktop-ui\u002Fmessenger-pattern","01.csharp\u002F12.desktop-ui\u002F26.messenger-pattern",{"title":1527,"path":1528,"stem":1529},"Стилі WPF — CSS для десктопу","\u002Fcsharp\u002Fdesktop-ui\u002Fstyles-basics","01.csharp\u002F12.desktop-ui\u002F27.styles-basics",{"title":1531,"path":1532,"stem":1533},"CSS-like стилі Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002F27a.avalonia-css-styling","01.csharp\u002F12.desktop-ui\u002F27a.avalonia-css-styling",{"title":1535,"path":1536,"stem":1537},"Control Templates — Частина 1. Концепція та TemplateBinding","\u002Fcsharp\u002Fdesktop-ui\u002Fcontrol-templates-part1","01.csharp\u002F12.desktop-ui\u002F28.control-templates-part1",{"title":1539,"path":1540,"stem":1541},"Control Templates — Частина 2. Named Parts та ContentPresenter","\u002Fcsharp\u002Fdesktop-ui\u002Fcontrol-templates-part2","01.csharp\u002F12.desktop-ui\u002F28.control-templates-part2",{"title":1543,"path":1544,"stem":1545},"Control Themes в Avalonia — нова ера стилізації","\u002Fcsharp\u002Fdesktop-ui\u002F28a.avalonia-control-themes","01.csharp\u002F12.desktop-ui\u002F28a.avalonia-control-themes",{"title":1547,"path":1548,"stem":1549},"Triggers та Visual State Manager у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Ftriggers-visual-states","01.csharp\u002F12.desktop-ui\u002F29.triggers-visual-states",{"title":1551,"path":1552,"stem":1553},"Pseudo-classes в Avalonia — замість WPF Triggers","\u002Fcsharp\u002Fdesktop-ui\u002F29a.avalonia-pseudo-classes","01.csharp\u002F12.desktop-ui\u002F29a.avalonia-pseudo-classes",{"title":1555,"path":1556,"stem":1557},"Теми та ресурсні словники у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fresources-themes","01.csharp\u002F12.desktop-ui\u002F30.resources-themes",{"title":1559,"path":1560,"stem":1561},"Avalonia Themes — Fluent Design та система тематизації","\u002Fcsharp\u002Fdesktop-ui\u002F30a.avalonia-themes-fluent","01.csharp\u002F12.desktop-ui\u002F30a.avalonia-themes-fluent",{"title":1563,"path":1564,"stem":1565},"Контроли колекцій — глибоке занурення","\u002Fcsharp\u002Fdesktop-ui\u002Fcollection-controls","01.csharp\u002F12.desktop-ui\u002F31.collection-controls",{"title":1567,"path":1568,"stem":1569},"DataGrid — колонки та базове відображення","\u002Fcsharp\u002Fdesktop-ui\u002Fdatagrid-part1","01.csharp\u002F12.desktop-ui\u002F32.datagrid-part1",{"title":1571,"path":1572,"stem":1573},"DataGrid — сортування, фільтрація, редагування","\u002Fcsharp\u002Fdesktop-ui\u002Fdatagrid-part2","01.csharp\u002F12.desktop-ui\u002F32.datagrid-part2",{"title":1575,"path":1576,"stem":1577},"TreeView та GridView","\u002Fcsharp\u002Fdesktop-ui\u002Ftreeview-listview","01.csharp\u002F12.desktop-ui\u002F33.treeview-listview",{"title":1579,"path":1580,"stem":1581},"Меню, Toolbar, ContextMenu, StatusBar","\u002Fcsharp\u002Fdesktop-ui\u002Fmenus-toolbars","01.csharp\u002F12.desktop-ui\u002F34.menus-toolbars",{"title":1583,"path":1584,"stem":1585},"Навігація та керування вікнами. Частина 1: вікна та сторінки","\u002Fcsharp\u002Fdesktop-ui\u002Fnavigation-windows-part1","01.csharp\u002F12.desktop-ui\u002F35.navigation-windows-part1",{"title":1587,"path":1588,"stem":1589},"Навігація та керування вікнами. Частина 2: MVVM-навігація","\u002Fcsharp\u002Fdesktop-ui\u002Fnavigation-windows-part2","01.csharp\u002F12.desktop-ui\u002F35.navigation-windows-part2",{"title":1591,"path":1592,"stem":1593},"Avalonia — Навігація та діалоги","\u002Fcsharp\u002Fdesktop-ui\u002F35a.avalonia-navigation-dialogs","01.csharp\u002F12.desktop-ui\u002F35a.avalonia-navigation-dialogs",{"title":1595,"path":1596,"stem":1597},"Діалоги та File Pickers у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fdialogs-file-pickers","01.csharp\u002F12.desktop-ui\u002F36.dialogs-file-pickers",{"title":1599,"path":1600,"stem":1601},"UserControl: компонентний підхід у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fuser-controls","01.csharp\u002F12.desktop-ui\u002F37.user-controls",{"title":1603,"path":1604,"stem":1605},"Custom Controls: Lookless Controls у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fcustom-controls","01.csharp\u002F12.desktop-ui\u002F38.custom-controls",{"title":1607,"path":1608,"stem":1609},"Avalonia TemplatedControl — Lookless Controls","\u002Fcsharp\u002Fdesktop-ui\u002F38a.avalonia-templated-controls","01.csharp\u002F12.desktop-ui\u002F38a.avalonia-templated-controls",{"title":1611,"path":1612,"stem":1613},"Анімації у WPF: Storyboard та Easing Functions","\u002Fcsharp\u002Fdesktop-ui\u002Fanimations-transitions","01.csharp\u002F12.desktop-ui\u002F39.animations-transitions",{"title":1615,"path":1616,"stem":1617},"Анімації в Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002F39a.avalonia-animations","01.csharp\u002F12.desktop-ui\u002F39a.avalonia-animations",{"title":1619,"path":1620,"stem":1621},"2D Графіка та Мультимедіа у WPF","\u002Fcsharp\u002Fdesktop-ui\u002Fmedia-graphics","01.csharp\u002F12.desktop-ui\u002F40.media-graphics",{"title":1623,"path":1624,"stem":1625},"Dependency Injection у WPF та Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002Fdi-integration","01.csharp\u002F12.desktop-ui\u002F41.di-integration",{"title":1627,"path":1628,"stem":1629},"SQLite та EF Core у десктопних додатках","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-persistence-part1","01.csharp\u002F12.desktop-ui\u002F42.data-persistence-part1",{"title":1631,"path":1632,"stem":1633},"Repository Pattern та Unit of Work","\u002Fcsharp\u002Fdesktop-ui\u002Fdata-persistence-part2","01.csharp\u002F12.desktop-ui\u002F43.data-persistence-part2",{"title":1635,"path":1636,"stem":1637},"Тестування ViewModels","\u002Fcsharp\u002Fdesktop-ui\u002Fviewmodel-testing","01.csharp\u002F12.desktop-ui\u002F44.viewmodel-testing",{"title":1639,"path":1640,"stem":1641},"Avalonia Headless Testing — тестування UI без вікон","\u002Fcsharp\u002Fdesktop-ui\u002F44a.avalonia-headless-testing","01.csharp\u002F12.desktop-ui\u002F44a.avalonia-headless-testing",{"title":1643,"path":1644,"stem":1645},"Кросплатформна розробка з Avalonia","\u002Fcsharp\u002Fdesktop-ui\u002Favalonia-cross-platform","01.csharp\u002F12.desktop-ui\u002F45.avalonia-cross-platform",{"title":1647,"path":1648,"stem":1649},"Пакування та розгортання Avalonia додатків","\u002Fcsharp\u002Fdesktop-ui\u002Favalonia-packaging-deployment","01.csharp\u002F12.desktop-ui\u002F46.avalonia-packaging-deployment",{"title":1651,"path":1652,"stem":1653},"Розгортання WPF застосунків","\u002Fcsharp\u002Fdesktop-ui\u002Fwpf-packaging-deployment","01.csharp\u002F12.desktop-ui\u002F47.wpf-packaging-deployment",{"title":1655,"icon":658,"path":1656,"stem":1657,"children":1658,"page":59},"Network Programming","\u002Fcsharp\u002Fnetwork-programming","01.csharp\u002F13.network-programming",[1659,1663,1667,1671,1675,1679,1683,1687,1691,1695,1699],{"title":1660,"path":1661,"stem":1662},"Основи комп'ютерних мереж","\u002Fcsharp\u002Fnetwork-programming\u002Ffoundations","01.csharp\u002F13.network-programming\u002F01.foundations",{"title":1664,"path":1665,"stem":1666},"Модель OSI та стек TCP\u002FIP","\u002Fcsharp\u002Fnetwork-programming\u002Fosi-model","01.csharp\u002F13.network-programming\u002F02.osi-model",{"title":1668,"path":1669,"stem":1670},"IP-протокол та адресація","\u002Fcsharp\u002Fnetwork-programming\u002Fip-addressing","01.csharp\u002F13.network-programming\u002F03.ip-addressing",{"title":1672,"path":1673,"stem":1674},"UDP — протокол без з'єднання","\u002Fcsharp\u002Fnetwork-programming\u002Fudp","01.csharp\u002F13.network-programming\u002F05.udp",{"title":1676,"path":1677,"stem":1678},"UDP Broadcast та Multicast","\u002Fcsharp\u002Fnetwork-programming\u002Fudp-broadcast-multicast","01.csharp\u002F13.network-programming\u002F06.udp-broadcast-multicast",{"title":1680,"path":1681,"stem":1682},"HTTP — протокол вебу","\u002Fcsharp\u002Fnetwork-programming\u002Fhttp-fundamentals","01.csharp\u002F13.network-programming\u002F07.http-fundamentals",{"title":1684,"path":1685,"stem":1686},"HttpListener — вбудований HTTP-сервер .NET","\u002Fcsharp\u002Fnetwork-programming\u002F07a.http-listener","01.csharp\u002F13.network-programming\u002F07a.http-listener",{"title":1688,"path":1689,"stem":1690},"HTTP Advanced — cookies, аутентифікація та HTTPS","\u002Fcsharp\u002Fnetwork-programming\u002Fhttp-advanced","01.csharp\u002F13.network-programming\u002F08.http-advanced",{"title":1692,"path":1693,"stem":1694},"SMTP та протоколи електронної пошти","\u002Fcsharp\u002Fnetwork-programming\u002Fsmtp","01.csharp\u002F13.network-programming\u002F09.smtp",{"title":1696,"path":1697,"stem":1698},"WebSocket — повнодуплексний протокол реального часу","\u002Fcsharp\u002Fnetwork-programming\u002Fwebsockets","01.csharp\u002F13.network-programming\u002F10.websockets",{"title":1700,"path":1701,"stem":1702},"TLS\u002FSSL — криптографічний захист мережевих з'єднань","\u002Fcsharp\u002Fnetwork-programming\u002Ftls-ssl","01.csharp\u002F13.network-programming\u002F11.tls-ssl",{"title":1704,"path":1705,"stem":1706},"C# & .NET: The Ultimate Roadmap","\u002Fcsharp\u002Froadmap","01.csharp\u002Froadmap",{"title":1708,"icon":1709,"path":1710,"stem":1711,"children":1712,"page":59},"C++","i-devicon-cplusplus","\u002Fcpp","02.cpp",[1713,1717,1721,1725,1729,1733,1737,1741,1745,1748,1752,1756,1760,1764,1768,1772,1776,1780,1784,1788,1792,1796,1800,1804,1808,1812,1816,1820,1824,1828,1832,1836,1840,1844,1848,1852,1856,1860,1864,1868,1872,1876,1880,1884,1888,1892,1896,1900],{"title":1714,"path":1715,"stem":1716},"Вступ у програмування та алгоритми","\u002Fcpp\u002Fintro-algorithms","02.cpp\u002F01.intro-algorithms",{"title":1718,"path":1719,"stem":1720},"Code Style: угоди про оформлення коду","\u002Fcpp\u002Fcode-style","02.cpp\u002F02.code-style",{"title":1722,"path":1723,"stem":1724},"Середовище розробки та перший проєкт","\u002Fcpp\u002Fide-setup","02.cpp\u002F03.ide-setup",{"title":1726,"path":1727,"stem":1728},"Вивід даних на екран","\u002Fcpp\u002Fdata-output","02.cpp\u002F04.data-output",{"title":1730,"path":1731,"stem":1732},"Типи даних, змінні та константи","\u002Fcpp\u002Fdata-types-variables","02.cpp\u002F05.data-types-variables",{"title":1734,"path":1735,"stem":1736},"Ввід даних з клавіатури","\u002Fcpp\u002Fdata-input","02.cpp\u002F06.data-input",{"title":1738,"path":1739,"stem":1740},"Оператори, перетворення типів та логічні операції","\u002Fcpp\u002Foperators-type-conversion","02.cpp\u002F07.operators-type-conversion",{"title":1742,"path":1743,"stem":1744},"Цикли","\u002Fcpp\u002Floops","02.cpp\u002F08.loops",{"title":32,"path":1746,"stem":1747},"\u002Fcpp\u002Farrays","02.cpp\u002F09.arrays",{"title":1749,"path":1750,"stem":1751},"Алгоритми сортування та аналіз складності","\u002Fcpp\u002Fsorting","02.cpp\u002F10.sorting",{"title":1753,"path":1754,"stem":1755},"Алгоритми пошуку","\u002Fcpp\u002Fsearching","02.cpp\u002F11.searching",{"title":1757,"path":1758,"stem":1759},"Функції: основи","\u002Fcpp\u002Ffunctions-basics","02.cpp\u002F12.functions-basics",{"title":1761,"path":1762,"stem":1763},"Функції: прототипи, область видимості та додаткові можливості","\u002Fcpp\u002Ffunctions-scope","02.cpp\u002F13.functions-scope",{"title":1765,"path":1766,"stem":1767},"Функції: перевантаження та шаблони","\u002Fcpp\u002Ffunctions-overloading-templates","02.cpp\u002F14.functions-overloading-templates",{"title":1769,"path":1770,"stem":1771},"Вказівники: основи","\u002Fcpp\u002Fpointers-basics","02.cpp\u002F15.pointers-basics",{"title":1773,"path":1774,"stem":1775},"Посилання (References)","\u002Fcpp\u002Freferences","02.cpp\u002F16.references",{"title":1777,"path":1778,"stem":1779},"Вказівники, const і масиви","\u002Fcpp\u002Fpointers-const-arrays","02.cpp\u002F17.pointers-const-arrays",{"title":1781,"path":1782,"stem":1783},"Адресна арифметика","\u002Fcpp\u002Fpointer-arithmetic","02.cpp\u002F18.pointer-arithmetic",{"title":1785,"path":1786,"stem":1787},"Динамічна пам'ять","\u002Fcpp\u002Fdynamic-memory","02.cpp\u002F19.dynamic-memory",{"title":1789,"path":1790,"stem":1791},"Вказівники типу void","\u002Fcpp\u002Fvoid-pointers","02.cpp\u002F20.void-pointers",{"title":1793,"path":1794,"stem":1795},"Вказівники на вказівники","\u002Fcpp\u002Fpointers-to-pointers","02.cpp\u002F21.pointers-to-pointers",{"title":1797,"path":1798,"stem":1799},"Оператор доступу до членів через вказівник (->)","\u002Fcpp\u002Fmember-access-operator","02.cpp\u002F22.member-access-operator",{"title":1801,"path":1802,"stem":1803},"Цикл for-each (Range-based for)","\u002Fcpp\u002Fforeach-loop","02.cpp\u002F23.foreach-loop",{"title":1805,"path":1806,"stem":1807},"Вказівники на функції","\u002Fcpp\u002Ffunction-pointers","02.cpp\u002F24.function-pointers",{"title":1809,"path":1810,"stem":1811},"Лямбда-вирази","\u002Fcpp\u002Flambdas","02.cpp\u002F25.lambdas",{"title":1813,"path":1814,"stem":1815},"Лямбда-захоплення","\u002Fcpp\u002Flambda-captures","02.cpp\u002F26.lambda-captures",{"title":1817,"path":1818,"stem":1819},"Еліпсис","\u002Fcpp\u002Fellipsis","02.cpp\u002F27.ellipsis",{"title":1821,"path":1822,"stem":1823},"Безпечні альтернативи еліпсису","\u002Fcpp\u002F27a.ellipsis","02.cpp\u002F27a.ellipsis",{"title":1825,"path":1826,"stem":1827},"Аргументи командного рядка","\u002Fcpp\u002Fcommand-line-arguments","02.cpp\u002F28.command-line-arguments",{"title":1829,"path":1830,"stem":1831},"Перерахування (enum)","\u002Fcpp\u002Fenum","02.cpp\u002F29.enum",{"title":1833,"path":1834,"stem":1835},"Класи-перерахування (enum class)","\u002Fcpp\u002Fenum-class","02.cpp\u002F30.enum-class",{"title":1837,"path":1838,"stem":1839},"Псевдоніми типів (typedef і using)","\u002Fcpp\u002Ftype-aliases","02.cpp\u002F31.type-aliases",{"title":1841,"path":1842,"stem":1843},"Системи числення та двійкова арифметика","\u002Fcpp\u002Fnumber-systems","02.cpp\u002F32.number-systems",{"title":1845,"path":1846,"stem":1847},"Структури (struct): агрегування даних","\u002Fcpp\u002Fstruct","02.cpp\u002F33.struct",{"title":1849,"path":1850,"stem":1851},"Структури у функціях","\u002Fcpp\u002Fstruct-functions","02.cpp\u002F34.struct-functions",{"title":1853,"path":1854,"stem":1855},"Масиви структур і вкладені структури","\u002Fcpp\u002Fstruct-arrays","02.cpp\u002F35.struct-arrays",{"title":1857,"path":1858,"stem":1859},"Патерни struct та межі застосування","\u002Fcpp\u002Fstruct-patterns","02.cpp\u002F36.struct-patterns",{"title":1861,"path":1862,"stem":1863},"Символи та таблиця ASCII","\u002Fcpp\u002Fascii-characters","02.cpp\u002F37.ascii-characters",{"title":1865,"path":1866,"stem":1867},"Unicode та кодування UTF","\u002Fcpp\u002Funicode-utf","02.cpp\u002F38.unicode-utf",{"title":1869,"path":1870,"stem":1871},"C-style рядки","\u002Fcpp\u002Fc-strings","02.cpp\u002F39.c-strings",{"title":1873,"path":1874,"stem":1875},"Вступ до std::string","\u002Fcpp\u002Fstd-string-intro","02.cpp\u002F40.std-string-intro",{"title":1877,"path":1878,"stem":1879},"Довжина, ємність та доступ до символів std::string","\u002Fcpp\u002Fstd-string-capacity-access","02.cpp\u002F41.std-string-capacity-access",{"title":1881,"path":1882,"stem":1883},"Модифікація std::string: присвоювання, додавання, вставка, видалення та заміна","\u002Fcpp\u002Fstd-string-modification","02.cpp\u002F42.std-string-modification",{"title":1885,"path":1886,"stem":1887},"Пошук у std::string: find, npos та практичні патерни","\u002Fcpp\u002Fstd-string-search","02.cpp\u002F43.std-string-search",{"title":1889,"path":1890,"stem":1891},"std::string_view: невласницький погляд на рядок без копіювання","\u002Fcpp\u002Fstd-string-view","02.cpp\u002F44.std-string-view",{"title":1893,"path":1894,"stem":1895},"Об'єднання (union): один блок пам'яті, кілька інтерпретацій","\u002Fcpp\u002Funion","02.cpp\u002F45.union",{"title":1897,"path":1898,"stem":1899},"Організація коду: файли, препроцесор, простори імен","\u002Fcpp\u002Fmultifile-programs","02.cpp\u002F46.multifile-programs",{"title":1901,"path":1902,"stem":1903},"План навчання: Курс C++ — Продовження (Статті 29–60+)","\u002Fcpp\u002Fcurriculum-plan","02.cpp\u002Fcurriculum-plan",{"title":1905,"icon":1906,"path":1907,"stem":1908,"children":1909,"page":59},"JavaScript","i-devicon-javascript","\u002Fjavascript","03.javascript",[1910,1936,1990,2012,2316,2354],{"title":1911,"icon":1912,"path":1913,"stem":1914,"children":1915,"page":59},"Events","i-lucide-mouse-pointer-click","\u002Fjavascript\u002Fevents","03.javascript\u002F01.events",[1916,1920,1924,1928,1932],{"title":1917,"path":1918,"stem":1919},"Вступ до подій браузера","\u002Fjavascript\u002Fevents\u002Fintro","03.javascript\u002F01.events\u002F01.intro",{"title":1921,"path":1922,"stem":1923},"Бульбашковий механізм (Bubbling) та занурення (Capturing)","\u002Fjavascript\u002Fevents\u002Fbubbling-capturing","03.javascript\u002F01.events\u002F02.bubbling-capturing",{"title":1925,"path":1926,"stem":1927},"Делегування подій (Event Delegation)","\u002Fjavascript\u002Fevents\u002Fdelegate-events","03.javascript\u002F01.events\u002F03.delegate-events",{"title":1929,"path":1930,"stem":1931},"Типові дії браузера та preventDefault()","\u002Fjavascript\u002Fevents\u002Fprevent-default","03.javascript\u002F01.events\u002F04.prevent-default",{"title":1933,"path":1934,"stem":1935},"Запуск користувацьких подій (Custom Events)","\u002Fjavascript\u002Fevents\u002Fcustom-events","03.javascript\u002F01.events\u002F05.custom-events",{"title":1937,"icon":1938,"path":1939,"stem":1940,"children":1941,"page":59},"Network","i-lucide-globe","\u002Fjavascript\u002Fnetwork","03.javascript\u002F02.network",[1942,1946,1950,1954,1958,1962,1966,1970,1974,1978,1982,1986],{"title":1943,"path":1944,"stem":1945},"Fetch API - Сучасний підхід до HTTP-запитів","\u002Fjavascript\u002Fnetwork\u002F01-fetch-api","03.javascript\u002F02.network\u002F01-fetch-api",{"title":1947,"path":1948,"stem":1949},"FormData - Робота з формами та файлами","\u002Fjavascript\u002Fnetwork\u002F02-formdata","03.javascript\u002F02.network\u002F02-formdata",{"title":1951,"path":1952,"stem":1953},"Відстеження прогресу завантаження","\u002Fjavascript\u002Fnetwork\u002F03-download-progress","03.javascript\u002F02.network\u002F03-download-progress",{"title":1955,"path":1956,"stem":1957},"Переривання fetch-запитів","\u002Fjavascript\u002Fnetwork\u002F04-abort-requests","03.javascript\u002F02.network\u002F04-abort-requests",{"title":1959,"path":1960,"stem":1961},"CORS - Запити між різними джерелами","\u002Fjavascript\u002Fnetwork\u002F05-cors","03.javascript\u002F02.network\u002F05-cors",{"title":1963,"path":1964,"stem":1965},"Fetch API - Повний довідник опцій","\u002Fjavascript\u002Fnetwork\u002F06-fetch-options","03.javascript\u002F02.network\u002F06-fetch-options",{"title":1967,"path":1968,"stem":1969},"URL Objects - Робота з посиланнями","\u002Fjavascript\u002Fnetwork\u002F07-url-objects","03.javascript\u002F02.network\u002F07-url-objects",{"title":1971,"path":1972,"stem":1973},"XMLHttpRequest - AJAX та низькорівневі запити","\u002Fjavascript\u002Fnetwork\u002F08-xmlhttprequest","03.javascript\u002F02.network\u002F08-xmlhttprequest",{"title":1975,"path":1976,"stem":1977},"Відновлюване завантаження файлів","\u002Fjavascript\u002Fnetwork\u002F09-resumable-upload","03.javascript\u002F02.network\u002F09-resumable-upload",{"title":1979,"path":1980,"stem":1981},"Cookies, document.cookie та світ після \"Cookiepocalypse\"","\u002Fjavascript\u002Fnetwork\u002F10-cookies","03.javascript\u002F02.network\u002F10-cookies",{"title":1983,"path":1984,"stem":1985},"js-cookie: Керування Cookies без Болю","\u002Fjavascript\u002Fnetwork\u002F11-js-cookie","03.javascript\u002F02.network\u002F11-js-cookie",{"title":1987,"path":1988,"stem":1989},"Axios: Потужний HTTP-клієнт для JavaScript","\u002Fjavascript\u002Fnetwork\u002F12-axios","03.javascript\u002F02.network\u002F12-axios",{"title":1991,"icon":1992,"path":1993,"stem":1994,"children":1995,"page":59},"Bom","i-lucide-monitor","\u002Fjavascript\u002Fbom","03.javascript\u002F03.bom",[1996,2000,2004,2008],{"title":1997,"path":1998,"stem":1999},"LocalStorage, SessionStorage та patterns збереження даних","\u002Fjavascript\u002Fbom\u002F01-localstorage","03.javascript\u002F03.bom\u002F01-localstorage",{"title":2001,"path":2002,"stem":2003},"Location Object - Керування адресою сторінки","\u002Fjavascript\u002Fbom\u002F02-location-object","03.javascript\u002F03.bom\u002F02-location-object",{"title":2005,"path":2006,"stem":2007},"History API - Керування історією браузера","\u002Fjavascript\u002Fbom\u002F03-history-api","03.javascript\u002F03.bom\u002F03-history-api",{"title":2009,"path":2010,"stem":2011},"Navigator Object - Ідентифікація та Можливості Пристрою","\u002Fjavascript\u002Fbom\u002F04-navigator-object","03.javascript\u002F03.bom\u002F04-navigator-object",{"title":2013,"icon":2014,"path":2015,"stem":2016,"children":2017},"React","i-devicon-react","\u002Fjavascript\u002Freact","03.javascript\u002F04.react\u002Findex",[2018,2019,2023,2027,2031,2035,2098,2133,2285],{"title":2013,"path":2015,"stem":2016},{"title":2020,"path":2021,"stem":2022},"Робота з Формами в React","\u002Fjavascript\u002Freact\u002Freact-forms","03.javascript\u002F04.react\u002F01.react-forms",{"title":2024,"path":2025,"stem":2026},"React Hook Form: Професійна Робота з Формами","\u002Fjavascript\u002Freact\u002Freact-hook-form","03.javascript\u002F04.react\u002F02.react-hook-form",{"title":2028,"path":2029,"stem":2030},"React Hook Form: Глибоке Розуміння Архітектури та Оптимізації","\u002Fjavascript\u002Freact\u002Freact-hook-form-new","03.javascript\u002F04.react\u002F02.react-hook-form-new",{"title":2032,"path":2033,"stem":2034},"Axios та React: Професійна Архітектура Запитів","\u002Fjavascript\u002Freact\u002Fdata-fetching-axios","03.javascript\u002F04.react\u002F03.data-fetching-axios",{"title":2036,"icon":132,"path":2037,"stem":2038,"children":2039},"Tanstack Query","\u002Fjavascript\u002Freact\u002Ftanstack-query","03.javascript\u002F04.react\u002F04.tanstack-query\u002Findex",[2040,2042,2046,2050,2054,2058,2062,2066,2070,2074,2078,2082,2086,2090,2094],{"title":2041,"path":2037,"stem":2038},"TanStack Query: Майстерність Керування Станом Сервера",{"title":2043,"path":2044,"stem":2045},"Парадигма Server State: Чому useEffect недостатньо","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-state-paradigm","03.javascript\u002F04.react\u002F04.tanstack-query\u002F01.server-state-paradigm",{"title":2047,"path":2048,"stem":2049},"Встановлення та Налаштування: Фундамент","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Finstallation-and-devtools","03.javascript\u002F04.react\u002F04.tanstack-query\u002F02.installation-and-devtools",{"title":2051,"path":2052,"stem":2053},"Основи Запитів та Магія Ключів","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fquery-basics-and-keys","03.javascript\u002F04.react\u002F04.tanstack-query\u002F03.query-basics-and-keys",{"title":2055,"path":2056,"stem":2057},"Синхронізація Даних: Життєвий Цикл Запиту","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fdata-synchronization","03.javascript\u002F04.react\u002F04.tanstack-query\u002F04.data-synchronization",{"title":2059,"path":2060,"stem":2061},"Мутації та Інвалідація: Зміна Даних","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fmutations-and-invalidation","03.javascript\u002F04.react\u002F04.tanstack-query\u002F05.mutations-and-invalidation",{"title":2063,"path":2064,"stem":2065},"Оптимістичні Оновлення: Швидше за Світло","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Foptimistic-updates","03.javascript\u002F04.react\u002F04.tanstack-query\u002F06.optimistic-updates",{"title":2067,"path":2068,"stem":2069},"Пагінація та Infinite Scroll","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fpagination-and-load-more","03.javascript\u002F04.react\u002F04.tanstack-query\u002F07.pagination-and-load-more",{"title":2071,"path":2072,"stem":2073},"Просунуті Патерни та Оптимізація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F04.tanstack-query\u002F08.advanced-patterns",{"title":2075,"path":2076,"stem":2077},"Архітектура та Best Practices","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Farchitecture-and-best-practices","03.javascript\u002F04.react\u002F04.tanstack-query\u002F09.architecture-and-best-practices",{"title":2079,"path":2080,"stem":2081},"Server-Side Rendering (SSR) та Гідратація","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fserver-side-rendering","03.javascript\u002F04.react\u002F04.tanstack-query\u002F10.server-side-rendering",{"title":2083,"path":2084,"stem":2085},"Стратегії Тестування","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Ftesting-strategies","03.javascript\u002F04.react\u002F04.tanstack-query\u002F11.testing-strategies",{"title":2087,"path":2088,"stem":2089},"Аутентифікація та Обробка Помилок","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fauthentication-and-errors","03.javascript\u002F04.react\u002F04.tanstack-query\u002F12.authentication-and-errors",{"title":2091,"path":2092,"stem":2093},"React Suspense та Майбутнє","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Freact-suspense","03.javascript\u002F04.react\u002F04.tanstack-query\u002F13.react-suspense",{"title":2095,"path":2096,"stem":2097},"Глибоке Занурення в Продуктивність","\u002Fjavascript\u002Freact\u002Ftanstack-query\u002Fperformance-deep-dive","03.javascript\u002F04.react\u002F04.tanstack-query\u002F14.performance-deep-dive",{"title":2099,"icon":2014,"path":2100,"stem":2101,"children":2102},"React Router","\u002Fjavascript\u002Freact\u002Freact-router","03.javascript\u002F04.react\u002F05.react-router\u002Findex",[2103,2105,2109,2113,2117,2121,2125,2129],{"title":2104,"path":2100,"stem":2101},"React Router: Навігаційна система сучасного вебу",{"title":2106,"path":2107,"stem":2108},"Налаштування та Базовий Роутинг","\u002Fjavascript\u002Freact\u002Freact-router\u002Fsetup-and-basic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F01.setup-and-basic-routing",{"title":2110,"path":2111,"stem":2112},"Динамічна Навігація","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnavigation-and-links","03.javascript\u002F04.react\u002F05.react-router\u002F02.navigation-and-links",{"title":2114,"path":2115,"stem":2116},"Вкладені Маршрути та Макети","\u002Fjavascript\u002Freact\u002Freact-router\u002Fnested-routes-and-layouts","03.javascript\u002F04.react\u002F05.react-router\u002F03.nested-routes-and-layouts",{"title":2118,"path":2119,"stem":2120},"Динамічні Маршрути та Параметри","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdynamic-routing","03.javascript\u002F04.react\u002F05.react-router\u002F04.dynamic-routing",{"title":2122,"path":2123,"stem":2124},"Data APIs: Loaders та Actions","\u002Fjavascript\u002Freact\u002Freact-router\u002Fdata-loading","03.javascript\u002F04.react\u002F05.react-router\u002F05.data-loading",{"title":2126,"path":2127,"stem":2128},"Просунуті Патерни","\u002Fjavascript\u002Freact\u002Freact-router\u002Fadvanced-patterns","03.javascript\u002F04.react\u002F05.react-router\u002F06.advanced-patterns",{"title":2130,"path":2131,"stem":2132},"Legacy Routing: Компонентний підхід","\u002Fjavascript\u002Freact\u002Freact-router\u002Flegacy-routing","03.javascript\u002F04.react\u002F05.react-router\u002F07.legacy-routing",{"title":2134,"icon":132,"path":2135,"stem":2136,"children":2137},"Redux","\u002Fjavascript\u002Freact\u002Fredux","03.javascript\u002F04.react\u002F06.redux\u002Findex",[2138,2140,2156,2185,2194,2215,2231,2260],{"title":2139,"path":2135,"stem":2136},"Redux: Еволюція управління станом",{"title":14,"icon":15,"path":2141,"stem":2142,"children":2143,"page":59},"\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals",[2144,2148,2152],{"title":2145,"path":2146,"stem":2147},"Вступ до State Management","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fintro-state-management","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F01.intro-state-management",{"title":2149,"path":2150,"stem":2151},"Філософія Redux та Три Принципи","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fredux-philosophy","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F02.redux-philosophy",{"title":2153,"path":2154,"stem":2155},"Чисті функції та Іммутабельність","\u002Fjavascript\u002Freact\u002Fredux\u002Ffundamentals\u002Fpure-functions-immutability","03.javascript\u002F04.react\u002F06.redux\u002F01.fundamentals\u002F03.pure-functions-immutability",{"title":2157,"icon":132,"path":2158,"stem":2159,"children":2160,"page":59},"Classic Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux",[2161,2165,2169,2173,2177,2181],{"title":2162,"path":2163,"stem":2164},"Створення Store (Classic Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fstore-setup","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F01.store-setup",{"title":2166,"path":2167,"stem":2168},"Actions, Constants та Action Creators","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Factions-constants","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F02.actions-constants",{"title":2170,"path":2171,"stem":2172},"Логіка Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freducers","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F03.reducers",{"title":2174,"path":2175,"stem":2176},"Комбінування Reducers (Root Reducer)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fdata-flow","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F04.data-flow",{"title":2178,"path":2179,"stem":2180},"Підключення до React (React-Redux)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Freact-redux-connection","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F05.react-redux-connection",{"title":2182,"path":2183,"stem":2184},"Middleware та Асинхронність (Redux Thunk)","\u002Fjavascript\u002Freact\u002Fredux\u002Fclassic-redux\u002Fmiddleware-thunk","03.javascript\u002F04.react\u002F06.redux\u002F02.classic-redux\u002F06.middleware-thunk",{"title":2186,"icon":132,"path":2187,"stem":2188,"children":2189,"page":59},"Transition To Rtk","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk",[2190],{"title":2191,"path":2192,"stem":2193},"Проблеми класичного Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftransition-to-rtk\u002Fproblems-with-classic","03.javascript\u002F04.react\u002F06.redux\u002F03.transition-to-rtk\u002F01.problems-with-classic",{"title":2195,"icon":132,"path":2196,"stem":2197,"children":2198,"page":59},"Redux Toolkit","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit",[2199,2203,2207,2211],{"title":2200,"path":2201,"stem":2202},"Налаштування Store з configureStore","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fconfigure-store","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F01.configure-store",{"title":2204,"path":2205,"stem":2206},"createSlice: Революція в Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fcreate-slice","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F02.create-slice",{"title":2208,"path":2209,"stem":2210},"Асинхронність з createAsyncThunk","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fasync-thunks","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F03.async-thunks",{"title":2212,"path":2213,"stem":2214},"04. Entity Adapter: Керування нормалізованим станом","\u002Fjavascript\u002Freact\u002Fredux\u002Fredux-toolkit\u002Fentity-adapter","03.javascript\u002F04.react\u002F06.redux\u002F04.redux-toolkit\u002F04.entity-adapter",{"title":2216,"icon":92,"path":2217,"stem":2218,"children":2219,"page":59},"Advanced","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced",[2220,2224,2228],{"title":2221,"path":2222,"stem":2223},"Мемоізація та Селектори: Повний Гайд по Reselect","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Fselectors-reselect","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F01.selectors-reselect",{"title":2225,"path":2226,"stem":2227},"RTK Query: Архітектура Серверного Кешу","\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Frtk-query-intro","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F02.rtk-query-intro",{"title":2075,"path":2229,"stem":2230},"\u002Fjavascript\u002Freact\u002Fredux\u002Fadvanced\u002Farchitecture-best-practices","03.javascript\u002F04.react\u002F06.redux\u002F05.advanced\u002F03.architecture-best-practices",{"title":2232,"icon":132,"path":2233,"stem":2234,"children":2235,"page":59},"Project Kanban","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban",[2236,2240,2244,2248,2252,2256],{"title":2237,"path":2238,"stem":2239},"Проєкт: Kanban Board (Trello Clone)","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fproject-overview","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F01.project-overview",{"title":2241,"path":2242,"stem":2243},"Налаштування та Типізація","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fsetup-and-types","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F02.setup-and-types",{"title":2245,"path":2246,"stem":2247},"Board Slice: Серце Дошки","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fboard-slice","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F03.board-slice",{"title":2249,"path":2250,"stem":2251},"Логіка Drag & Drop","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Fdrag-and-drop-logic","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F04.drag-and-drop-logic",{"title":2253,"path":2254,"stem":2255},"Інтеграція з RTK Query","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Frtk-query-integration","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F05.rtk-query-integration",{"title":2257,"path":2258,"stem":2259},"Optimistic Updates","\u002Fjavascript\u002Freact\u002Fredux\u002Fproject-kanban\u002Foptimistic-updates","03.javascript\u002F04.react\u002F06.redux\u002F06.project-kanban\u002F06.optimistic-updates",{"title":2261,"icon":132,"path":2262,"stem":2263,"children":2264,"page":59},"Testing","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting","03.javascript\u002F04.react\u002F06.redux\u002F07.testing",[2265,2269,2273,2277,2281],{"title":2266,"path":2267,"stem":2268},"Тестування Redux","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Fintro-testing","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F01.intro-testing",{"title":2270,"path":2271,"stem":2272},"Тестування Reducers","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-reducers","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F02.testing-reducers",{"title":2274,"path":2275,"stem":2276},"Тестування Селекторів","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-selectors","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F03.testing-selectors",{"title":2278,"path":2279,"stem":2280},"Тестування Компонентів (Integration)","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-components","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F04.testing-components",{"title":2282,"path":2283,"stem":2284},"Тестування Async Thunks","\u002Fjavascript\u002Freact\u002Fredux\u002Ftesting\u002Ftesting-thunks","03.javascript\u002F04.react\u002F06.redux\u002F07.testing\u002F05.testing-thunks",{"title":2286,"icon":132,"path":2287,"stem":2288,"children":2289},"Ui Libraries","\u002Fjavascript\u002Freact\u002Fui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002Findex",[2290,2292,2296,2300,2304,2308,2312],{"title":2291,"path":2287,"stem":2288},"UI Бібліотеки в React",{"title":2293,"path":2294,"stem":2295},"Вступ до UI Бібліотек: Навіщо Винаходити Велосипед Двічі?","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fintroduction-to-ui-libraries","03.javascript\u002F04.react\u002F07.ui-libraries\u002F01.introduction-to-ui-libraries",{"title":2297,"path":2298,"stem":2299},"Філософія shadcn\u002Fui: \"Not a Component Library\"","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-philosophy","03.javascript\u002F04.react\u002F07.ui-libraries\u002F02.shadcn-philosophy",{"title":2301,"path":2302,"stem":2303},"Установка та Налаштування shadcn\u002Fui","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-installation","03.javascript\u002F04.react\u002F07.ui-libraries\u002F03.shadcn-installation",{"title":2305,"path":2306,"stem":2307},"Базові Компоненти shadcn\u002Fui: Фундамент Інтерфейсу","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-basics","03.javascript\u002F04.react\u002F07.ui-libraries\u002F04.shadcn-components-basics",{"title":2309,"path":2310,"stem":2311},"Компоненти Форм: Побудова Інтерактивних Form","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-forms","03.javascript\u002F04.react\u002F07.ui-libraries\u002F05.shadcn-components-forms",{"title":2313,"path":2314,"stem":2315},"Складні Компоненти: Dialog, Dropdown, Table та Command","\u002Fjavascript\u002Freact\u002Fui-libraries\u002Fshadcn-components-advanced","03.javascript\u002F04.react\u002F07.ui-libraries\u002F06.shadcn-components-advanced",{"title":2317,"icon":2318,"path":2319,"stem":2320,"children":2321,"page":59},"TypeScript","i-devicon-typescript","\u002Fjavascript\u002Ftypescript","03.javascript\u002F05.typescript",[2322,2326,2330,2334,2338,2342,2346,2350],{"title":2323,"path":2324,"stem":2325},"TypeScript: Броня для вашого коду","\u002Fjavascript\u002Ftypescript\u002Fintro-and-basic-types","03.javascript\u002F05.typescript\u002F01.intro-and-basic-types",{"title":2327,"path":2328,"stem":2329},"Майстерність Моделювання Даних: Інтерфейси та Просунуті Типи","\u002Fjavascript\u002Ftypescript\u002Finterfaces-and-advanced-types","03.javascript\u002F05.typescript\u002F02.interfaces-and-advanced-types",{"title":2331,"path":2332,"stem":2333},"Алхімія Типів: Generics та Utility Types","\u002Fjavascript\u002Ftypescript\u002Fgenerics-and-utilities","03.javascript\u002F05.typescript\u002F03.generics-and-utilities",{"title":2335,"path":2336,"stem":2337},"Архітектура та Шаблони: Класи в TypeScript","\u002Fjavascript\u002Ftypescript\u002Fclasses-and-oop","03.javascript\u002F05.typescript\u002F04.classes-and-oop",{"title":2339,"path":2340,"stem":2341},"Продакшн та Екосистема: Advanced Config & Workflow","\u002Fjavascript\u002Ftypescript\u002Fadvanced-patterns-and-config","03.javascript\u002F05.typescript\u002F05.advanced-patterns-and-config",{"title":2343,"path":2344,"stem":2345},"TypeScript у світі React","\u002Fjavascript\u002Ftypescript\u002Freact-basics","03.javascript\u002F05.typescript\u002F06.react-basics",{"title":2347,"path":2348,"stem":2349},"React + TypeScript: Продвинуті патерни","\u002Fjavascript\u002Ftypescript\u002Freact-advanced","03.javascript\u002F05.typescript\u002F07.react-advanced",{"title":2351,"path":2352,"stem":2353},"React + TypeScript: Екосистема та бібліотеки","\u002Fjavascript\u002Ftypescript\u002Freact-ecosystem","03.javascript\u002F05.typescript\u002F08.react-ecosystem",{"title":2355,"path":2356,"stem":2357},"Atomic Design","\u002Fjavascript\u002Fatomic-design","03.javascript\u002F2.atomic-design",{"title":2359,"icon":2360,"path":2361,"stem":2362,"children":2363,"page":59},"Java","i-devicon-java","\u002Fjava","04.java",[2364,2367,2370,2374,2378,2382,2386],{"title":162,"path":2365,"stem":2366},"\u002Fjava\u002Fdata-mapper-part1","04.java\u002F01.data-mapper-part1",{"title":166,"path":2368,"stem":2369},"\u002Fjava\u002Fdata-mapper-part2","04.java\u002F02.data-mapper-part2",{"title":2371,"path":2372,"stem":2373},"Service Layer: Організація бізнес-логіки","\u002Fjava\u002Fservice-layer","04.java\u002F03.service-layer",{"title":2375,"path":2376,"stem":2377},"Rich Domain Model та State Pattern","\u002Fjava\u002Frich-domain-model","04.java\u002F04.rich-domain-model",{"title":2379,"path":2380,"stem":2381},"Патерни для складної бізнес-логіки","\u002Fjava\u002Fbusiness-logic-patterns","04.java\u002F05.business-logic-patterns",{"title":2383,"path":2384,"stem":2385},"Обробка помилок та валідація","\u002Fjava\u002Ferror-handling-validation","04.java\u002F06.error-handling-validation",{"title":2387,"path":2388,"stem":2389,"children":2390,"page":59},"Проектування баз даних","\u002Fjava\u002Fpr2","04.java\u002Fpr2",[2391,2395,2399,2403,2407,2411,2415,2419,2423,2427,2431,2435,2439,2443,2447,2451,2455,2459,2463,2467,2471,2475,2479,2483,2487,2491,2495,2499,2503,2507,2511,2515,2519,2523,2527,2531,2535],{"title":2392,"path":2393,"stem":2394},"Концептуальне моделювання: Мистецтво розуміння предметної області","\u002Fjava\u002Fpr2\u002Fconceptual-modeling","04.java\u002Fpr2\u002F01.conceptual-modeling",{"title":2396,"path":2397,"stem":2398},"Логічне моделювання: Від бізнес-ідей до структур даних","\u002Fjava\u002Fpr2\u002Flogical-modeling","04.java\u002Fpr2\u002F02.logical-modeling",{"title":2400,"path":2401,"stem":2402},"Нормалізація: Гігієна даних та боротьба з аномаліями","\u002Fjava\u002Fpr2\u002Fnormalization","04.java\u002Fpr2\u002F03.normalization",{"title":2404,"path":2405,"stem":2406},"Фізична схема: Від абстракції до DDL","\u002Fjava\u002Fpr2\u002Fphysical-schema","04.java\u002Fpr2\u002F04.physical-schema",{"title":2408,"path":2409,"stem":2410},"Архітектурна класифікація таблиць","\u002Fjava\u002Fpr2\u002Ftable-classification","04.java\u002Fpr2\u002F05.table-classification",{"title":2412,"path":2413,"stem":2414},"Database Migrations: Версіонування схеми з Flyway","\u002Fjava\u002Fpr2\u002Fdatabase-migrations","04.java\u002Fpr2\u002F06.database-migrations",{"title":2416,"path":2417,"stem":2418},"А що, якби це була не реляційна БД?","\u002Fjava\u002Fpr2\u002Fbeyond-relational","04.java\u002Fpr2\u002F07.beyond-relational",{"title":2420,"path":2421,"stem":2422},"Object-Relational Impedance Mismatch: Два світи, що не хочуть дружити","\u002Fjava\u002Fpr2\u002Fimpedance-mismatch","04.java\u002Fpr2\u002F09.impedance-mismatch",{"title":2424,"path":2425,"stem":2426},"JDBC: Перший контакт із базою даних","\u002Fjava\u002Fpr2\u002Fjdbc-fundamentals","04.java\u002Fpr2\u002F10.jdbc-fundamentals",{"title":2428,"path":2429,"stem":2430},"Якість коду: Spotless, SpotBugs та SonarQube","\u002Fjava\u002Fpr2\u002F10a.code-quality","04.java\u002Fpr2\u002F10a.code-quality",{"title":2432,"path":2433,"stem":2434},"Connection Pool: Патерн Object Pool для JDBC-з'єднань","\u002Fjava\u002Fpr2\u002Fconnection-pool","04.java\u002Fpr2\u002F11.connection-pool",{"title":2436,"path":2437,"stem":2438},"Row Data Gateway: Об'єкт як обгортка рядка таблиці","\u002Fjava\u002Fpr2\u002Frow-data-gateway","04.java\u002Fpr2\u002F12.row-data-gateway",{"title":2440,"path":2441,"stem":2442},"Table Data Gateway: Фасад таблиці як архітектурний відступ","\u002Fjava\u002Fpr2\u002Ftable-data-gateway","04.java\u002Fpr2\u002F13.table-data-gateway",{"title":2444,"path":2445,"stem":2446},"Repository + Data Mapper: Правильна шарова архітектура з JDBC","\u002Fjava\u002Fpr2\u002Frepository-data-mapper","04.java\u002Fpr2\u002F14.repository-data-mapper",{"title":2448,"path":2449,"stem":2450},"Identity Map: Кешування сутностей у рамках сесії","\u002Fjava\u002Fpr2\u002Fidentity-map","04.java\u002Fpr2\u002F15.identity-map",{"title":2452,"path":2453,"stem":2454},"Unit of Work: Відстеження змін і координація JDBC-транзакцій","\u002Fjava\u002Fpr2\u002Funit-of-work","04.java\u002Fpr2\u002F16.unit-of-work",{"title":2456,"path":2457,"stem":2458},"Strategy: Замінювані SQL-стратегії для підтримки різних СУБД","\u002Fjava\u002Fpr2\u002Fstrategy-sql","04.java\u002Fpr2\u002F17.strategy-sql",{"title":2460,"path":2461,"stem":2462},"Proxy: Lazy Loading для One-To-Many колекцій","\u002Fjava\u002Fpr2\u002Fproxy-lazy-loading","04.java\u002Fpr2\u002F18.proxy-lazy-loading",{"title":2464,"path":2465,"stem":2466},"Generic Repository через Java Reflection: анотації та динамічний SQL","\u002Fjava\u002Fpr2\u002Fgeneric-repository-reflection","04.java\u002Fpr2\u002F19.generic-repository-reflection",{"title":2468,"path":2469,"stem":2470},"Specification Pattern: Композиція бізнес-правил для складних запитів","\u002Fjava\u002Fpr2\u002Fspecification-pattern","04.java\u002Fpr2\u002F20.specification-pattern",{"title":2472,"path":2473,"stem":2474},"Розширені можливості Specification Pattern: підзапити, агрегації та гібридний підхід","\u002Fjava\u002Fpr2\u002F20a.advanced-specifications","04.java\u002Fpr2\u002F20a.advanced-specifications",{"title":2476,"path":2477,"stem":2478},"Асинхронність у JDBC: Від блокуючих викликів до CompletableFuture","\u002Fjava\u002Fpr2\u002Fasynchronous-jdbc","04.java\u002Fpr2\u002F21.asynchronous-jdbc",{"title":2480,"path":2481,"stem":2482},"Інтеграційне тестування JDBC-репозиторіїв: Embedded H2 та патерн AAA","\u002Fjava\u002Fpr2\u002Fintegration-testing-h2","04.java\u002Fpr2\u002F22.integration-testing-h2",{"title":2484,"path":2485,"stem":2486},"Testcontainers: Тестування з реальною PostgreSQL у Docker-контейнерах","\u002Fjava\u002Fpr2\u002Fintegration-testing-testcontainers","04.java\u002Fpr2\u002F23.integration-testing-testcontainers",{"title":2488,"path":2489,"stem":2490},"Google Guice: Впровадження залежностей у JavaFX-проєкті","\u002Fjava\u002Fpr2\u002Fdependency-injection-guice","04.java\u002Fpr2\u002F24.dependency-injection-guice",{"title":2492,"path":2493,"stem":2494},"JavaFX: Основи побудови графічних інтерфейсів","\u002Fjava\u002Fpr2\u002Fjavafx-fundamentals","04.java\u002Fpr2\u002F25.javafx-fundamentals",{"title":2496,"path":2497,"stem":2498},"Properties та Bindings: Реактивність у JavaFX","\u002Fjava\u002Fpr2\u002Fjavafx-properties-bindings","04.java\u002Fpr2\u002F26.javafx-properties-bindings",{"title":2500,"path":2501,"stem":2502},"MVC vs MVP vs MVVM: Еволюція архітектурних патернів UI","\u002Fjava\u002Fpr2\u002Fui-architecture-patterns","04.java\u002Fpr2\u002F27.ui-architecture-patterns",{"title":2504,"path":2505,"stem":2506},"MVVM на практиці: Побудова ViewModel","\u002Fjava\u002Fpr2\u002Fmvvm-viewmodel-implementation","04.java\u002Fpr2\u002F28.mvvm-viewmodel-implementation",{"title":2508,"path":2509,"stem":2510},"View та Controller: Зв'язування з ViewModel через FXML","\u002Fjava\u002Fpr2\u002Fmvvm-view-controller","04.java\u002Fpr2\u002F29.mvvm-view-controller",{"title":2512,"path":2513,"stem":2514},"Інтеграція MVVM з Guice: Автоматична ін'єкція залежностей","\u002Fjava\u002Fpr2\u002Fmvvm-guice-integration","04.java\u002Fpr2\u002F30.mvvm-guice-integration",{"title":2516,"path":2517,"stem":2518},"Валідація та обробка помилок у MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-validation-error-handling","04.java\u002Fpr2\u002F31.mvvm-validation-error-handling",{"title":2520,"path":2521,"stem":2522},"Навігація та управління екранами у JavaFX MVVM","\u002Fjava\u002Fpr2\u002Fmvvm-navigation-screen-management","04.java\u002Fpr2\u002F32.mvvm-navigation-screen-management",{"title":2524,"path":2525,"stem":2526},"Тестування JavaFX MVVM-додатків","\u002Fjava\u002Fpr2\u002Fmvvm-testing","04.java\u002Fpr2\u002F33.mvvm-testing",{"title":2528,"path":2529,"stem":2530},"Стилізація та теми у JavaFX: CSS та User Experience","\u002Fjava\u002Fpr2\u002Fjavafx-styling-themes","04.java\u002Fpr2\u002F34.javafx-styling-themes",{"title":2532,"path":2533,"stem":2534},"AtlantaFX: Сучасні теми для JavaFX додатків","\u002Fjava\u002Fpr2\u002Fatlantafx-modern-themes","04.java\u002Fpr2\u002F35.atlantafx-modern-themes",{"title":2536,"path":2537,"stem":2538},"Пакування та розповсюдження JavaFX-додатків","\u002Fjava\u002Fpr2\u002Fjar-packaging-distribution","04.java\u002Fpr2\u002F36.jar-packaging-distribution",{"title":2540,"icon":2541,"path":2542,"stem":2543,"children":2544,"page":59},"Python","i-devicon-python","\u002Fpython","05.python",[2545,2549,2552,2556,2560,2564,2568,2572,2576,2580,2584,2588,2592,2596,2600,2604],{"title":2546,"path":2547,"stem":2548},"Модулі, Пакети та Віртуальні Середовища","\u002Fpython\u002Fmodules-packages-venv","05.python\u002F00.modules-packages-venv",{"title":71,"path":2550,"stem":2551},"\u002Fpython\u002Fclasses-objects","05.python\u002F01.classes-objects",{"title":2553,"path":2554,"stem":2555},"Інкапсуляція, Керування Доступом та Властивості","\u002Fpython\u002Fencapsulation","05.python\u002F02.encapsulation",{"title":2557,"path":2558,"stem":2559},"Наслідування, MRO та суперсила super()","\u002Fpython\u002Finheritance-mro","05.python\u002F03.inheritance-mro",{"title":2561,"path":2562,"stem":2563},"Абстракція — ABC проти Статичних Протоколів (PEP 544)","\u002Fpython\u002Fabstraction-protocols","05.python\u002F04.abstraction-protocols",{"title":2565,"path":2566,"stem":2567},"Магічні методи (Dunder) та Емуляція протоколів","\u002Fpython\u002Fdunder-methods","05.python\u002F05.dunder-methods",{"title":2569,"path":2570,"stem":2571},"Декоратори та Керування життєвим циклом методів","\u002Fpython\u002Fdecorators-static-class","05.python\u002F06.decorators-static-class",{"title":2573,"path":2574,"stem":2575},"Дескриптори — Магія доступу до атрибутів","\u002Fpython\u002Fdescriptors","05.python\u002F07.descriptors",{"title":2577,"path":2578,"stem":2579},"Метакласи — Динамічне створення класів під капотом CPython","\u002Fpython\u002Fmetaclasses","05.python\u002F08.metaclasses",{"title":2581,"path":2582,"stem":2583},"Dataclasses, NamedTuple та сучасні контейнери Python","\u002Fpython\u002Fmodern-containers","05.python\u002F09.modern-containers",{"title":2585,"path":2586,"stem":2587},"GIL та модель конкурентності CPython — фундамент перед потоками і процесами","\u002Fpython\u002Fgil-concurrency-intro","05.python\u002F11.gil-concurrency-intro",{"title":2589,"path":2590,"stem":2591},"Threading — конкурентність для I\u002FO-bound задач","\u002Fpython\u002Fthreading","05.python\u002F12.threading",{"title":2593,"path":2594,"stem":2595},"Multiprocessing — справжній паралелізм для CPU-bound задач","\u002Fpython\u002Fmultiprocessing","05.python\u002F13.multiprocessing",{"title":2597,"path":2598,"stem":2599},"asyncio — кооперативна конкурентність та event loop","\u002Fpython\u002Fasyncio","05.python\u002F14.asyncio",{"title":2601,"path":2602,"stem":2603},"📦 Повний посібник з модулів, пакетів та віртуальних середовищ у Python","\u002Fpython\u002Flesson_9","05.python\u002Flesson_9",{"title":2605,"path":2606,"stem":2607},"[object Object]","\u002Fpython\u002Foop-plan","05.python\u002Foop-plan",{"title":2609,"icon":2610,"path":2611,"stem":2612,"children":2613,"page":59},"Бази даних","i-lucide-database","\u002Fdatabases","06.databases",[2614,2644,2667,2704,2733,2751,2785,2797,2806],{"title":2615,"icon":2616,"path":2617,"stem":2618,"children":2619,"page":59},"Intro","i-lucide-play","\u002Fdatabases\u002Fintro","06.databases\u002F01.intro",[2620,2624,2628,2632,2636,2640],{"title":2621,"path":2622,"stem":2623},"Введення в теорію баз даних","\u002Fdatabases\u002Fintro\u002Fintroduction-to-databases","06.databases\u002F01.intro\u002F01.introduction-to-databases",{"title":2625,"path":2626,"stem":2627},"Реляційна модель даних","\u002Fdatabases\u002Fintro\u002Frelational-model-theory","06.databases\u002F01.intro\u002F02.relational-model-theory",{"title":2629,"path":2630,"stem":2631},"ER-моделювання","\u002Fdatabases\u002Fintro\u002Fer-modeling","06.databases\u002F01.intro\u002F03.er-modeling",{"title":2633,"path":2634,"stem":2635},"Логічне проектування БД","\u002Fdatabases\u002Fintro\u002Flogical-schema","06.databases\u002F01.intro\u002F04.logical-schema",{"title":2637,"path":2638,"stem":2639},"Класифікація таблиць","\u002Fdatabases\u002Fintro\u002Ftable-classification","06.databases\u002F01.intro\u002F05.table-classification",{"title":2641,"path":2642,"stem":2643},"PlantUML для баз даних","\u002Fdatabases\u002Fintro\u002Fplantuml-diagrams","06.databases\u002F01.intro\u002F06.plantuml-diagrams",{"title":2645,"icon":2610,"path":2646,"stem":2647,"children":2648,"page":59},"MS SQL Server Start","\u002Fdatabases\u002Fms-sql-server-start","06.databases\u002F02.ms-sql-server-start",[2649,2653,2659,2663],{"title":2650,"path":2651,"stem":2652},"Типи даних у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fdata-types","06.databases\u002F02.ms-sql-server-start\u002F01.data-types",{"title":2654,"path":2655,"stem":2656,"children":2657},"Індекси у MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-indexes","06.databases\u002F02.ms-sql-server-start\u002F02.sql-indexes",[2658],{"title":2654,"path":2655,"stem":2656},{"title":2660,"path":2661,"stem":2662},"Системні бази даних MS SQL Server","\u002Fdatabases\u002Fms-sql-server-start\u002Fsystem-databases","06.databases\u002F02.ms-sql-server-start\u002F03.system-databases",{"title":2664,"path":2665,"stem":2666},"Огляд мови SQL та запитів","\u002Fdatabases\u002Fms-sql-server-start\u002Fsql-queries-overview","06.databases\u002F02.ms-sql-server-start\u002F04.sql-queries-overview",{"title":2668,"icon":2610,"path":2669,"stem":2670,"children":2671,"page":59},"SQL","\u002Fdatabases\u002Fsql","06.databases\u002F03.sql",[2672,2676,2680,2684,2688,2692,2696,2700],{"title":2673,"path":2674,"stem":2675},"Налаштування демонстраційної бази даних","\u002Fdatabases\u002Fsql\u002Fsample-database-setup","06.databases\u002F03.sql\u002F00.sample-database-setup",{"title":2677,"path":2678,"stem":2679},"DDL - Створення таблиць (CREATE TABLE)","\u002Fdatabases\u002Fsql\u002Fddl-create-table","06.databases\u002F03.sql\u002F01.ddl-create-table",{"title":2681,"path":2682,"stem":2683},"DDL - Зміна та видалення таблиць (ALTER, DROP)","\u002Fdatabases\u002Fsql\u002Fddl-alter-drop-table","06.databases\u002F03.sql\u002F02.ddl-alter-drop-table",{"title":2685,"path":2686,"stem":2687},"SELECT запити - Основи","\u002Fdatabases\u002Fsql\u002Fselect-queries-fundamentals","06.databases\u002F03.sql\u002F03.select-queries-fundamentals",{"title":2689,"path":2690,"stem":2691},"SELECT запити - Розширені можливості","\u002Fdatabases\u002Fsql\u002Fselect-queries-advanced","06.databases\u002F03.sql\u002F04.select-queries-advanced",{"title":2693,"path":2694,"stem":2695},"INSERT запити - Додавання даних","\u002Fdatabases\u002Fsql\u002Finsert-queries","06.databases\u002F03.sql\u002F05.insert-queries",{"title":2697,"path":2698,"stem":2699},"UPDATE та DELETE запити","\u002Fdatabases\u002Fsql\u002Fupdate-delete-queries","06.databases\u002F03.sql\u002F06.update-delete-queries",{"title":2701,"path":2702,"stem":2703},"Транзакції в SQL","\u002Fdatabases\u002Fsql\u002Ftransactions","06.databases\u002F03.sql\u002F07.transactions",{"title":2705,"icon":2610,"path":2706,"stem":2707,"children":2708,"page":59},"Multi Table Databases","\u002Fdatabases\u002Fmulti-table-databases","06.databases\u002F04.multi-table-databases",[2709,2713,2717,2721,2725,2729],{"title":2710,"path":2711,"stem":2712},"Зв'язки та нормалізація БД","\u002Fdatabases\u002Fmulti-table-databases\u002Frelationships-and-normalization","06.databases\u002F04.multi-table-databases\u002F00.relationships-and-normalization",{"title":2714,"path":2715,"stem":2716},"INNER JOIN - З'єднання таблиць","\u002Fdatabases\u002Fmulti-table-databases\u002Finner-join","06.databases\u002F04.multi-table-databases\u002F01.inner-join",{"title":2718,"path":2719,"stem":2720},"OUTER JOINs - LEFT, RIGHT, FULL","\u002Fdatabases\u002Fmulti-table-databases\u002Fouter-joins","06.databases\u002F04.multi-table-databases\u002F02.outer-joins",{"title":2722,"path":2723,"stem":2724},"CROSS та SELF JOINs","\u002Fdatabases\u002Fmulti-table-databases\u002Fcross-self-joins","06.databases\u002F04.multi-table-databases\u002F03.cross-self-joins",{"title":2726,"path":2727,"stem":2728},"Підзапити (Subqueries)","\u002Fdatabases\u002Fmulti-table-databases\u002Fsubqueries","06.databases\u002F04.multi-table-databases\u002F04.subqueries",{"title":2730,"path":2731,"stem":2732},"Агрегації з JOIN","\u002Fdatabases\u002Fmulti-table-databases\u002Faggregations-with-joins","06.databases\u002F04.multi-table-databases\u002F05.aggregations-with-joins",{"title":2734,"icon":2735,"path":2736,"stem":2737,"children":2738,"page":59},"Aggregate Functions","i-lucide-calculator","\u002Fdatabases\u002Faggregate-functions","06.databases\u002F05.aggregate-functions",[2739,2743,2747],{"title":2740,"path":2741,"stem":2742},"Функції агрегування в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fintroduction-aggregate-functions","06.databases\u002F05.aggregate-functions\u002F01.introduction-aggregate-functions",{"title":2744,"path":2745,"stem":2746},"Групування даних в MS SQL Server","\u002Fdatabases\u002Faggregate-functions\u002Fgrouping-data","06.databases\u002F05.aggregate-functions\u002F02.grouping-data",{"title":2748,"path":2749,"stem":2750},"Підзапити з агрегатними функціями","\u002Fdatabases\u002Faggregate-functions\u002Fsubqueries-aggregates","06.databases\u002F05.aggregate-functions\u002F03.subqueries-aggregates",{"title":2752,"icon":2753,"path":2754,"stem":2755,"children":2756,"page":59},"Тригери та зберігаємі процедури","i-lucide-database-zap","\u002Fdatabases\u002Ftriggers-stored-procedures","06.databases\u002F07.triggers-stored-procedures",[2757,2761,2765,2769,2773,2777,2781],{"title":2758,"path":2759,"stem":2760},"DML-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fdml-triggers","06.databases\u002F07.triggers-stored-procedures\u002F01.dml-triggers",{"title":2762,"path":2763,"stem":2764},"DDL-тригери","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fddl-triggers","06.databases\u002F07.triggers-stored-procedures\u002F02.ddl-triggers",{"title":2766,"path":2767,"stem":2768},"Transact-SQL розширення","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransact-sql-extensions","06.databases\u002F07.triggers-stored-procedures\u002F03.transact-sql-extensions",{"title":2770,"path":2771,"stem":2772},"Транзакції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Ftransactions","06.databases\u002F07.triggers-stored-procedures\u002F04.transactions",{"title":2774,"path":2775,"stem":2776},"Зберігаємі процедури","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fstored-procedures","06.databases\u002F07.triggers-stored-procedures\u002F05.stored-procedures",{"title":2778,"path":2779,"stem":2780},"Користувацькі функції","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fuser-defined-functions","06.databases\u002F07.triggers-stored-procedures\u002F06.user-defined-functions",{"title":2782,"path":2783,"stem":2784},"Безпека баз даних","\u002Fdatabases\u002Ftriggers-stored-procedures\u002Fsecurity","06.databases\u002F07.triggers-stored-procedures\u002F08.security",{"title":2782,"icon":793,"path":2786,"stem":2787,"children":2788,"page":59},"\u002Fdatabases\u002Fsecurity","06.databases\u002F08.security",[2789,2793],{"title":2790,"path":2791,"stem":2792},"Вступ до безпеки баз даних","\u002Fdatabases\u002Fsecurity\u002Fintroduction","06.databases\u002F08.security\u002F01.introduction",{"title":2794,"path":2795,"stem":2796},"Системні представлення та метадані","\u002Fdatabases\u002Fsecurity\u002Fsystem-views","06.databases\u002F08.security\u002F02.system-views",{"title":2798,"icon":2799,"path":2800,"stem":2801,"children":2802,"page":59},"Резервне копіювання та відновлення","i-lucide-database-backup","\u002Fdatabases\u002Fbackup-recovery","06.databases\u002F09.backup-recovery",[2803],{"title":2798,"path":2804,"stem":2805},"\u002Fdatabases\u002Fbackup-recovery\u002Fbackup-restore","06.databases\u002F09.backup-recovery\u002F01.backup-restore",{"title":2807,"icon":2808,"path":2809,"stem":2810,"children":2811,"page":59},"Повнотекстовий пошук","i-lucide-search","\u002Fdatabases\u002Ffull-text-search","06.databases\u002F10.full-text-search",[2812],{"title":2807,"path":2813,"stem":2814},"\u002Fdatabases\u002Ffull-text-search\u002Ffull-text-search","06.databases\u002F10.full-text-search\u002F01.full-text-search",{"title":2816,"icon":2817,"path":2818,"stem":2819,"children":2820,"page":59},"Tools","i-lucide-wrench","\u002Ftools","07.tools",[2821,2897],{"title":2822,"icon":2823,"path":2824,"stem":2825,"children":2826},"Docker","i-simple-icons-docker","\u002Ftools\u002Fdocker","07.tools\u002F01.docker\u002Findex",[2827,2829,2833,2837,2841,2845,2849,2853,2857,2861,2865,2869,2873,2877,2881,2885,2889,2893],{"title":2828,"path":2824,"stem":2825},"Docker: від нуля до production",{"title":2830,"path":2831,"stem":2832},"Контейнеризація — від проблеми до рішення","\u002Ftools\u002Fdocker\u002Fcontainerization-concept","07.tools\u002F01.docker\u002F01.containerization-concept",{"title":2834,"path":2835,"stem":2836},"Docker — що це і навіщо?","\u002Ftools\u002Fdocker\u002Fdocker-what-and-why","07.tools\u002F01.docker\u002F02.docker-what-and-why",{"title":2838,"path":2839,"stem":2840},"Архітектура Docker Engine","\u002Ftools\u002Fdocker\u002Fdocker-architecture","07.tools\u002F01.docker\u002F03.docker-architecture",{"title":2842,"path":2843,"stem":2844},"Встановлення Docker","\u002Ftools\u002Fdocker\u002Finstallation","07.tools\u002F01.docker\u002F04.installation",{"title":2846,"path":2847,"stem":2848},"Перший контейнер — docker run","\u002Ftools\u002Fdocker\u002Ffirst-container","07.tools\u002F01.docker\u002F05.first-container",{"title":2850,"path":2851,"stem":2852},"Життєвий цикл контейнера","\u002Ftools\u002Fdocker\u002Fcontainer-lifecycle","07.tools\u002F01.docker\u002F06.container-lifecycle",{"title":2854,"path":2855,"stem":2856},"Docker Images — фундаментальні концепції","\u002Ftools\u002Fdocker\u002Fdocker-images-fundamentals","07.tools\u002F01.docker\u002F07.docker-images-fundamentals",{"title":2858,"path":2859,"stem":2860},"Dockerfile — основи","\u002Ftools\u002Fdocker\u002Fdockerfile-basics","07.tools\u002F01.docker\u002F08.dockerfile-basics",{"title":2862,"path":2863,"stem":2864},"Dockerfile — просунуті техніки","\u002Ftools\u002Fdocker\u002Fdockerfile-advanced","07.tools\u002F01.docker\u002F09.dockerfile-advanced",{"title":2866,"path":2867,"stem":2868},"Build Context та кешування шарів","\u002Ftools\u002Fdocker\u002Fbuild-context-and-cache","07.tools\u002F01.docker\u002F10.build-context-and-cache",{"title":2870,"path":2871,"stem":2872},"Реєстри Docker-образів","\u002Ftools\u002Fdocker\u002Fimage-registries","07.tools\u002F01.docker\u002F11.image-registries",{"title":2874,"path":2875,"stem":2876},"Контейнеризація .NET додатків","\u002Ftools\u002Fdocker\u002Fdotnet-containerization","07.tools\u002F01.docker\u002F12.dotnet-containerization",{"title":2878,"path":2879,"stem":2880},"Томи та збереження даних","\u002Ftools\u002Fdocker\u002Fvolumes-and-data","07.tools\u002F01.docker\u002F13.volumes-and-data",{"title":2882,"path":2883,"stem":2884},"Основи мережі в Docker","\u002Ftools\u002Fdocker\u002Fnetworking-basics","07.tools\u002F01.docker\u002F14.networking-basics",{"title":2886,"path":2887,"stem":2888},"Змінні оточення та конфігурація","\u002Ftools\u002Fdocker\u002Fenvironment-and-configuration","07.tools\u002F01.docker\u002F15.environment-and-configuration",{"title":2890,"path":2891,"stem":2892},"Docker Compose — оркестрація контейнерів","\u002Ftools\u002Fdocker\u002Fdocker-compose-basics","07.tools\u002F01.docker\u002F16.docker-compose-basics",{"title":2894,"path":2895,"stem":2896},"Docker Compose — Multi-Service застосунки","\u002Ftools\u002Fdocker\u002Fcompose-multi-service","07.tools\u002F01.docker\u002F17.compose-multi-service",{"title":2898,"icon":2899,"path":2900,"stem":2901,"children":2902},"Kubernetes","simple-icons:kubernetes","\u002Ftools\u002Fkubernetes","07.tools\u002F02.kubernetes\u002Findex",[2903,2905,2909,2913,2917,2921,2925,2929,2933],{"title":2904,"path":2900,"stem":2901},"Kubernetes: від розробки до production",{"title":2906,"path":2907,"stem":2908},"Kubernetes — коли Docker Compose більше не вистачає","\u002Ftools\u002Fkubernetes\u002Fwhy-kubernetes","07.tools\u002F02.kubernetes\u002F01.why-kubernetes",{"title":2910,"path":2911,"stem":2912},"Архітектура Kubernetes — анатомія кластера","\u002Ftools\u002Fkubernetes\u002Fkubernetes-architecture","07.tools\u002F02.kubernetes\u002F02.kubernetes-architecture",{"title":2914,"path":2915,"stem":2916},"Локальне середовище — minikube, kind та k3s","\u002Ftools\u002Fkubernetes\u002Flocal-environment","07.tools\u002F02.kubernetes\u002F03.local-environment",{"title":2918,"path":2919,"stem":2920},"Pod — атомарна одиниця Kubernetes","\u002Ftools\u002Fkubernetes\u002Fpods-and-containers","07.tools\u002F02.kubernetes\u002F04.pods-and-containers",{"title":2922,"path":2923,"stem":2924},"Патерни використання Pod","\u002Ftools\u002Fkubernetes\u002Fpod-patterns","07.tools\u002F02.kubernetes\u002F05.pod-patterns",{"title":2926,"path":2927,"stem":2928},"Deployment — декларативне управління Pod","\u002Ftools\u002Fkubernetes\u002Fdeployment-basics","07.tools\u002F02.kubernetes\u002F06.deployment-basics",{"title":2930,"path":2931,"stem":2932},"Rolling Updates та управління життєвим циклом Deployment","\u002Ftools\u002Fkubernetes\u002Fdeployment-rolling-updates","07.tools\u002F02.kubernetes\u002F07.deployment-rolling-updates",{"title":2934,"path":2935,"stem":2936},"Service — мережева абстракція для Pod","\u002Ftools\u002Fkubernetes\u002Fservices-networking","07.tools\u002F02.kubernetes\u002F08.services-networking",{"title":2938,"icon":2939,"path":2940,"stem":2941,"children":2942,"page":59},"Software Engineering","i-lucide-code-2","\u002Fsoftware-engineering","09.software-engineering",[2943,2947,2951,2955,2959,2963,2967,2971,2975,2979,2983],{"title":2944,"path":2945,"stem":2946},"1. Аналіз предметної області. Експертні знання та складність","\u002Fsoftware-engineering\u002Fintro-subdomains","09.software-engineering\u002F01.intro-subdomains",{"title":2948,"path":2949,"stem":2950},"2. Обмежені контексти. Інтеграція обмежених контекстів","\u002Fsoftware-engineering\u002Fintegrating-limited-contexts","09.software-engineering\u002F02.integrating-limited-contexts",{"title":2952,"path":2953,"stem":2954},"3. Реалізація простої бізнес-логіки","\u002Fsoftware-engineering\u002Fsimple","09.software-engineering\u002F03.simple",{"title":2956,"path":2957,"stem":2958},"4. Опрацювання складної бізнес-логіки","\u002Fsoftware-engineering\u002Fcomplex-business-logic","09.software-engineering\u002F04.complex-business-logic",{"title":2960,"path":2961,"stem":2962},"5. Моделювання фактора часу. Подієво-орієнтована архітектура.","\u002Fsoftware-engineering\u002Fmodelling-the-time-factor","09.software-engineering\u002F05.modelling-the-time-factor",{"title":2964,"path":2965,"stem":2966},"6. Архітектурні патерни","\u002Fsoftware-engineering\u002Farchitectural-patterns","09.software-engineering\u002F06.architectural-patterns",{"title":2968,"path":2969,"stem":2970},"Паттерни взаємодії","\u002Fsoftware-engineering\u002Fpatterns-of-interaction","09.software-engineering\u002F07.patterns-of-interaction",{"title":2972,"path":2973,"stem":2974},"Евристика проєктування","\u002Fsoftware-engineering\u002Fdesign-heuristics","09.software-engineering\u002F08.design-heuristics",{"title":2976,"path":2977,"stem":2978},"Еволюція проєктних рішень","\u002Fsoftware-engineering\u002Fevolution-of-design-solutions","09.software-engineering\u002F09.evolution-of-design-solutions",{"title":2980,"path":2981,"stem":2982},"EventStorming","\u002Fsoftware-engineering\u002Feventstorming","09.software-engineering\u002F10.eventstorming",{"title":2984,"path":2985,"stem":2986},"DDD на практиці","\u002Fsoftware-engineering\u002Fddd-in-practice","09.software-engineering\u002F11.ddd-in-practice",{"title":2988,"icon":943,"path":2989,"stem":2990,"children":2991,"page":59},"DDD","\u002Fddd","10.ddd",[2992,2996,3000,3004,3008,3012,3016,3020,3024,3028,3032,3036,3040],{"title":2993,"path":2994,"stem":2995},"Аналіз предметної області","\u002Fddd\u002Fdomain-analysis","10.ddd\u002F01.domain-analysis",{"title":2997,"path":2998,"stem":2999},"Експертні знання про предметну область","\u002Fddd\u002Fdomain-expert-knowledge","10.ddd\u002F02.domain-expert-knowledge",{"title":3001,"path":3002,"stem":3003},"Як осмислити складність предметної області","\u002Fddd\u002Fmanaging-domain-complexity","10.ddd\u002F03.managing-domain-complexity",{"title":3005,"path":3006,"stem":3007},"Інтеграція обмежених контекстів","\u002Fddd\u002Fbounded-context-integration","10.ddd\u002F04.bounded-context-integration",{"title":3009,"path":3010,"stem":3011},"Реалізація простої бізнес-логіки","\u002Fddd\u002Fsimple-business-logic","10.ddd\u002F05.simple-business-logic",{"title":3013,"path":3014,"stem":3015},"Обробка складної бізнес-логіки","\u002Fddd\u002Fcomplex-business-logic","10.ddd\u002F06.complex-business-logic",{"title":3017,"path":3018,"stem":3019},"Моделювання фактора часу","\u002Fddd\u002Ftime-modeling","10.ddd\u002F07.time-modeling",{"title":3021,"path":3022,"stem":3023},"Глава 8. Архітектурні Патерни","\u002Fddd\u002Farchitectural-patterns","10.ddd\u002F08.architectural-patterns",{"title":3025,"path":3026,"stem":3027},"Глава 9. Патерни Взаємодії","\u002Fddd\u002Finteraction-patterns","10.ddd\u002F09.interaction-patterns",{"title":3029,"path":3030,"stem":3031},"Глава 10. Проектні Евристики","\u002Fddd\u002Fdesign-heuristics","10.ddd\u002F10.design-heuristics",{"title":3033,"path":3034,"stem":3035},"Глава 11. Еволюція Проектних Рішень","\u002Fddd\u002Fevolution-of-design-decisions","10.ddd\u002F11.evolution-of-design-decisions",{"title":3037,"path":3038,"stem":3039},"Глава 12. EventStorming","\u002Fddd\u002Fevent-storming","10.ddd\u002F12.event-storming",{"title":3041,"path":3042,"stem":3043},"Глава 13. DDD на Практиці","\u002Fddd\u002Fddd-in-practice","10.ddd\u002F13.ddd-in-practice",{"title":3045,"icon":3046,"path":3047,"stem":3048,"children":3049,"page":59},"Media Streaming","i-lucide-video","\u002Fmedia-streaming","11.media-streaming",[3050,3054,3058,3062,3066,3070,3074],{"title":3051,"path":3052,"stem":3053},"01. Магія Стрімінгу: Що відбувається, коли ви натискаєте \"Play\"","\u002Fmedia-streaming\u002Fintroduction","11.media-streaming\u002F01.introduction",{"title":3055,"path":3056,"stem":3057},"02. Анатомія Медіа: Кодеки, Контейнери та Стиснення","\u002Fmedia-streaming\u002Faudio-video-anatomy","11.media-streaming\u002F02.audio-video-anatomy",{"title":3059,"path":3060,"stem":3061},"03. The Gym: FFmpeg Deep Dive","\u002Fmedia-streaming\u002Fffmpeg-gym","11.media-streaming\u002F03.ffmpeg-gym",{"title":3063,"path":3064,"stem":3065},"04. HLS Protocol: HTTP Live Streaming у Деталях","\u002Fmedia-streaming\u002Fhls-protocol","11.media-streaming\u002F04.hls-protocol",{"title":3067,"path":3068,"stem":3069},"05. DASH Protocol: Відкритий Стандарт","\u002Fmedia-streaming\u002Fdash-protocol","11.media-streaming\u002F05.dash-protocol",{"title":3071,"path":3072,"stem":3073},"06. Масштабування: CDN та Adaptive Bitrate","\u002Fmedia-streaming\u002Fcdn-and-adaptive-bitrate","11.media-streaming\u002F06.cdn-and-adaptive-bitrate",{"title":3075,"path":3076,"stem":3077},"07. Війна із Затримкою (Latency)","\u002Fmedia-streaming\u002Frealtime-latency","11.media-streaming\u002F07.realtime-latency",{"title":3079,"icon":3080,"path":3081,"stem":3082,"children":3083,"page":59},"HTML & CSS","i-devicon-html5","\u002Fhtml-css","12.html-css",[3084,3088,3092,3096,3100,3104,3108,3112,3116,3120,3124,3128,3132,3136,3140,3144,3148,3152,3156,3160,3164,3168,3172,3176,3180,3184,3188,3192,3196,3200],{"title":3085,"path":3086,"stem":3087},"Вступ до HTML. Структура документа","\u002Fhtml-css\u002Fintro-html-structure","12.html-css\u002F01.intro-html-structure",{"title":3089,"path":3090,"stem":3091},"Форматування тексту в HTML","\u002Fhtml-css\u002Fhtml-text-formatting","12.html-css\u002F02.html-text-formatting",{"title":3093,"path":3094,"stem":3095},"Посилання та зображення в HTML","\u002Fhtml-css\u002Fhtml-links-images","12.html-css\u002F03.html-links-images",{"title":3097,"path":3098,"stem":3099},"Списки та таблиці в HTML","\u002Fhtml-css\u002Fhtml-lists-tables","12.html-css\u002F04.html-lists-tables",{"title":3101,"path":3102,"stem":3103},"Форми в HTML","\u002Fhtml-css\u002Fhtml-forms","12.html-css\u002F05.html-forms",{"title":3105,"path":3106,"stem":3107},"Семантичні елементи HTML5","\u002Fhtml-css\u002Fhtml-semantic-elements","12.html-css\u002F06.html-semantic-elements",{"title":3109,"path":3110,"stem":3111},"Мультимедіа та розширені елементи HTML","\u002Fhtml-css\u002Fhtml-multimedia-advanced","12.html-css\u002F07.html-multimedia-advanced",{"title":3113,"path":3114,"stem":3115},"Мікророзмітка та SEO в HTML","\u002Fhtml-css\u002Fhtml-microdata-seo","12.html-css\u002F08.html-microdata-seo",{"title":3117,"path":3118,"stem":3119},"Вступ до CSS. Селектори та специфічність","\u002Fhtml-css\u002Fcss-intro-selectors","12.html-css\u002F09.css-intro-selectors",{"title":3121,"path":3122,"stem":3123},"Блокова модель CSS. Відступи. Box Sizing","\u002Fhtml-css\u002Fcss-box-model","12.html-css\u002F10.css-box-model",{"title":3125,"path":3126,"stem":3127},"Розміри у CSS: повний довідник одиниць і ключових слів","\u002Fhtml-css\u002F10a.css-sizing","12.html-css\u002F10a.css-sizing",{"title":3129,"path":3130,"stem":3131},"Типографіка в CSS. Шрифти та текст","\u002Fhtml-css\u002Fcss-typography","12.html-css\u002F11.css-typography",{"title":3133,"path":3134,"stem":3135},"Кольори та фони в CSS","\u002Fhtml-css\u002Fcss-colors-backgrounds","12.html-css\u002F12.css-colors-backgrounds",{"title":3137,"path":3138,"stem":3139},"Тіні та фільтри в CSS","\u002Fhtml-css\u002F12b.css-shadows-filters","12.html-css\u002F12b.css-shadows-filters",{"title":3141,"path":3142,"stem":3143},"CSS Flexbox: Фундамент гнучких макетів","\u002Fhtml-css\u002Fcss-flexbox-fundamentals","12.html-css\u002F13.css-flexbox-fundamentals",{"title":3145,"path":3146,"stem":3147},"CSS Flexbox: Вирівнювання та Позиціонування","\u002Fhtml-css\u002Fcss-flexbox-alignment-sizing-and-patterns","12.html-css\u002F14.css-flexbox-alignment-sizing-and-patterns",{"title":3149,"path":3150,"stem":3151},"CSS Grid. Двовимірний макет. Частина 1","\u002Fhtml-css\u002Fcss-layout-grid","12.html-css\u002F15.css-layout-grid",{"title":3153,"path":3154,"stem":3155},"CSS Grid. Двовимірний макет. Частина 2","\u002Fhtml-css\u002Fcss-layout-grid-advanced","12.html-css\u002F16.css-layout-grid-advanced",{"title":3157,"path":3158,"stem":3159},"Позиціонування в CSS. Z-index. Stacking Context","\u002Fhtml-css\u002Fcss-positioning","12.html-css\u002F17.css-positioning",{"title":3161,"path":3162,"stem":3163},"CSS Анімації та Переходи","\u002Fhtml-css\u002Fcss-animations-transitions","12.html-css\u002F18.css-animations-transitions",{"title":3165,"path":3166,"stem":3167},"Адаптивний дизайн. Media Queries. Частина 1","\u002Fhtml-css\u002Fcss-responsive-media-queries","12.html-css\u002F19.css-responsive-media-queries",{"title":3169,"path":3170,"stem":3171},"Адаптивний дизайн. Частина 2: clamp(), Container Queries, @layer","\u002Fhtml-css\u002Fcss-responsive-advanced","12.html-css\u002F20.css-responsive-advanced",{"title":3173,"path":3174,"stem":3175},"CSS Custom Properties. Методології. Сучасний CSS","\u002Fhtml-css\u002Fcss-variables-methodologies","12.html-css\u002F21.css-variables-methodologies",{"title":3177,"path":3178,"stem":3179},"Сучасний CSS 2023–2025: Нові можливості","\u002Fhtml-css\u002Fcss-modern-features","12.html-css\u002F22.css-modern-features",{"title":3181,"path":3182,"stem":3183},"CSS Nesting, @layer, @scope та @property: нативний препроцесор","\u002Fhtml-css\u002F22a.css-nesting-modern-syntax","12.html-css\u002F22a.css-nesting-modern-syntax",{"title":3185,"path":3186,"stem":3187},"CSS для форм та інтерактивних станів","\u002Fhtml-css\u002Fcss-forms-interactive-states","12.html-css\u002F23.css-forms-interactive-states",{"title":3189,"path":3190,"stem":3191},"Доступність у CSS (CSS Accessibility)","\u002Fhtml-css\u002Fcss-accessibility","12.html-css\u002F24.css-accessibility",{"title":3193,"path":3194,"stem":3195},"CSS-функції та сучасні sizing primitives","\u002Fhtml-css\u002Fcss-functions-sizing","12.html-css\u002F25.css-functions-sizing",{"title":3197,"path":3198,"stem":3199},"Rendering Pipeline і CSS Performance","\u002Fhtml-css\u002Fcss-rendering-performance","12.html-css\u002F26.css-rendering-performance",{"title":3201,"path":3202,"stem":3203},"CSS Best Practices: типові ситуації та правильні рішення","\u002Fhtml-css\u002Fcss-best-practices","12.html-css\u002F27.css-best-practices",{"title":3205,"path":3206,"stem":3207,"children":3208,"page":59},"AWS","\u002Faws","13.aws",[3209,3213,3217,3221,3225,3229,3233,3237,3241,3245,3249,3253,3257,3261,3265,3269,3273,3277],{"title":3210,"path":3211,"stem":3212},"Реєстрація AWS акаунту та студентські програми","\u002Faws\u002Faccount-registration","13.aws\u002F00.account-registration",{"title":3214,"path":3215,"stem":3216},"Вступ до хмарних обчислень та AWS","\u002Faws\u002Fintroduction-to-cloud","13.aws\u002F01.introduction-to-cloud",{"title":3218,"path":3219,"stem":3220},"AWS IAM — Identity and Access Management","\u002Faws\u002Fiam","13.aws\u002F02.iam",{"title":3222,"path":3223,"stem":3224},"AWS IAM CLI — Довідник команд","\u002Faws\u002F02a.iam-doc","13.aws\u002F02a.iam-doc",{"title":3226,"path":3227,"stem":3228},"Docker та контейнеризація в AWS — ECR, ECS та Fargate","\u002Faws\u002Fdocker-ecs","13.aws\u002F03.docker-ecs",{"title":3230,"path":3231,"stem":3232},"AWS ECR \u002F ECS CLI — Довідник команд","\u002Faws\u002F03a.docker-ecs-doc","13.aws\u002F03a.docker-ecs-doc",{"title":3234,"path":3235,"stem":3236},"Amazon EC2 — Elastic Compute Cloud","\u002Faws\u002Fec2","13.aws\u002F04.ec2",{"title":3238,"path":3239,"stem":3240},"AWS EC2 CLI — Довідник команд","\u002Faws\u002F04a.ec2-doc","13.aws\u002F04a.ec2-doc",{"title":3242,"path":3243,"stem":3244},"Elastic Load Balancing та Auto Scaling","\u002Faws\u002Falb-asg","13.aws\u002F05.alb-asg",{"title":3246,"path":3247,"stem":3248},"Amazon S3 — Simple Storage Service","\u002Faws\u002Fs3","13.aws\u002F06.s3",{"title":3250,"path":3251,"stem":3252},"Amazon CloudFront — Content Delivery Network","\u002Faws\u002Fcloudfront","13.aws\u002F07.cloudfront",{"title":3254,"path":3255,"stem":3256},"Amazon RDS — Relational Database Service","\u002Faws\u002Frds","13.aws\u002F08.rds",{"title":3258,"path":3259,"stem":3260},"Amazon DynamoDB — NoSQL Database","\u002Faws\u002Fdynamodb","13.aws\u002F09.dynamodb",{"title":3262,"path":3263,"stem":3264},"AWS Lambda та Serverless Compute","\u002Faws\u002Flambda","13.aws\u002F10.lambda",{"title":3266,"path":3267,"stem":3268},"Amazon Bedrock - Foundation Models, RAG та Agents","\u002Faws\u002Fbedrock","13.aws\u002F22.bedrock",{"title":3270,"path":3271,"stem":3272},"Amazon Rekognition - Комп'ютерний зір","\u002Faws\u002Frekognition","13.aws\u002F23.rekognition",{"title":3274,"path":3275,"stem":3276},"Amazon Textract - Інтелектуальний аналіз документів","\u002Faws\u002Ftextract","13.aws\u002F24.textract",{"title":3278,"path":3279,"stem":3280},"Amazon Polly, Transcribe, Comprehend та Translate","\u002Faws\u002Faudio-nlp-services","13.aws\u002F25.audio-nlp-services",{"title":3282,"path":3283,"stem":3284,"children":3285,"page":59},"Tailwind","\u002Ftailwind","21.tailwind",[3286,3290,3294,3298,3302,3306,3310,3314,3318,3322,3326,3330],{"title":3287,"path":3288,"stem":3289},"Що таке Tailwind CSS і навіщо він потрібен","\u002Ftailwind\u002Ftailwind-intro-philosophy","21.tailwind\u002F01.tailwind-intro-philosophy",{"title":3291,"path":3292,"stem":3293},"Встановлення та налаштування Tailwind CSS v4","\u002Ftailwind\u002Ftailwind-installation-setup","21.tailwind\u002F02.tailwind-installation-setup",{"title":3295,"path":3296,"stem":3297},"Utility-класи: основи та система Tailwind","\u002Ftailwind\u002Ftailwind-utility-classes-core","21.tailwind\u002F03.tailwind-utility-classes-core",{"title":3299,"path":3300,"stem":3301},"Layout: Flexbox та Grid через Tailwind","\u002Ftailwind\u002Ftailwind-flexbox-grid","21.tailwind\u002F04.tailwind-flexbox-grid",{"title":3303,"path":3304,"stem":3305},"Кастомізація теми через @theme у Tailwind v4","\u002Ftailwind\u002Ftailwind-theme-customization","21.tailwind\u002F05.tailwind-theme-customization",{"title":3307,"path":3308,"stem":3309},"Варіанти: hover, focus, responsive, dark mode та нові v4","\u002Ftailwind\u002Ftailwind-variants-states","21.tailwind\u002F06.tailwind-variants-states",{"title":3311,"path":3312,"stem":3313},"Типографіка та система кольорів у Tailwind v4","\u002Ftailwind\u002Ftailwind-typography-colors","21.tailwind\u002F07.tailwind-typography-colors",{"title":3315,"path":3316,"stem":3317},"Компоненти та повторюваність: @apply, @utility та патерни","\u002Ftailwind\u002Ftailwind-components-patterns","21.tailwind\u002F08.tailwind-components-patterns",{"title":3319,"path":3320,"stem":3321},"Темна тема та система дизайн-токенів у Tailwind v4","\u002Ftailwind\u002Ftailwind-dark-mode-theming","21.tailwind\u002F09.tailwind-dark-mode-theming",{"title":3323,"path":3324,"stem":3325},"Довільні значення та контейнерні запити у Tailwind v4","\u002Ftailwind\u002Ftailwind-arbitrary-container-queries","21.tailwind\u002F10.tailwind-arbitrary-container-queries",{"title":3327,"path":3328,"stem":3329},"Анімації, трансформації та 3D у Tailwind v4","\u002Ftailwind\u002Ftailwind-animations-transforms","21.tailwind\u002F11.tailwind-animations-transforms",{"title":3331,"path":3332,"stem":3333},"Tailwind CLI, PostCSS та інтеграція з фреймворками","\u002Ftailwind\u002Ftailwind-cli-tooling","21.tailwind\u002F12.tailwind-cli-tooling",{"title":3335,"path":3336,"stem":3337},"Тестування компонентів діаграм","\u002Ftest-components","98.test-components",{"id":3339,"title":3266,"body":3340,"description":15889,"extension":15890,"links":15891,"meta":15892,"navigation":3426,"path":3267,"seo":15893,"stem":3268,"__hash__":15894},"docs\u002F13.aws\u002F22.bedrock.md",{"type":3341,"value":3342,"toc":15861},"minimark",[3343,3347,3352,3360,3388,3545,3548,3552,3555,3632,3634,3638,3655,3658,3832,3834,3838,3841,3863,3868,3875,3878,5344,5346,5350,5353,5357,6307,6311,6314,6866,6870,6873,7233,7235,7239,7242,7246,8893,8897,8900,8934,10312,10316,12261,12263,12267,12273,12279,12294,12298,12301,12317,13622,13624,13628,13634,13638,14610,14612,14616,14622,14625,14639,14643,14646,15707,15709,15713,15716,15857],[3344,3345,3266],"h1",{"id":3346},"amazon-bedrock-foundation-models-rag-та-agents",[3348,3349,3351],"h2",{"id":3350},"що-таке-amazon-bedrock","Що таке Amazon Bedrock?",[3353,3354,3355,3359],"p",{},[3356,3357,3358],"strong",{},"Amazon Bedrock"," — це повністю керований сервіс, що надає уніфікований API для роботи з провідними базовими моделями (Foundation Models) від Anthropic, Meta, Mistral AI, Stability AI та самої Amazon. На відміну від використання окремих API безпосередньо від розробників моделей, Bedrock розгортає ці моделі всередині безпечного периметру AWS, забезпечуючи:",[3361,3362,3363,3370,3376,3382],"ul",{},[3364,3365,3366,3369],"li",{},[3356,3367,3368],{},"Конфіденційність даних",": ваші промпти та корпоративні дані ніколи не залишають ваш AWS-акаунт, не використовуються для навчання публічних моделей і повністю захищені шифруванням.",[3364,3371,3372,3375],{},[3356,3373,3374],{},"Уніфікований інтерфейс",": один SDK та один клієнт для виклику різних моделей (наприклад, перемикання з Claude на Llama потребує лише зміни ID моделі).",[3364,3377,3378,3381],{},[3356,3379,3380],{},"Стійкість та масштабованість",": робота через хмарну інфраструктуру AWS із підтримкою Provisioned Throughput для гарантованої пропускної здатності.",[3364,3383,3384,3387],{},[3356,3385,3386],{},"Інтеграцію з іншими сервісами AWS",": нативне підключення до S3, OpenSearch, IAM, CloudWatch, Lambda та VPC.",[3389,3390,3391],"plant-uml",{},[3392,3393,3398],"pre",{"className":3394,"code":3395,"language":3396,"meta":3397,"style":3397},"language-plantuml shiki shiki-themes light-plus dark-plus dark-plus","@startuml\nskinparam style plain\nskinparam backgroundColor #ffffff\n\ntitle \"Архітектура взаємодії з Amazon Bedrock\"\n\nactor \"Клієнт (React \u002F .NET)\" as CLIENT\nrectangle \"AWSSDK.BedrockRuntime\\n(IAM Auth)\" as SDK #dbeafe\ndatabase \"S3 \u002F OpenSearch\\n(Knowledge Base)\" as KB #d1fae5\nrectangle \"Amazon Bedrock Service\" as BED #fef3c7\n\npackage \"Foundation Models (AWS Hosted)\" as FMS #fde68a {\n    rectangle \"Claude 3.5 Sonnet \u002F Haiku\\n(Anthropic)\" as CL\n    rectangle \"Llama 3.2 \u002F 3.1\\n(Meta)\" as LL\n    rectangle \"Titan Text \u002F Embeddings\\n(Amazon)\" as TIT\n}\n\nCLIENT -right-> SDK : HTTPS \u002F Signature V4\nSDK -right-> BED : InvokeModel \u002F Stream\nBED -down-> FMS : Маршрутизація запиту\nBED -left-> KB : Пошук контексту (RAG)\nFMS -up-> BED : Відповідь моделі\nBED -left-> CLIENT : Текст (токен за токеном або JSON)\n@enduml\n","plantuml","",[3399,3400,3401,3409,3415,3421,3428,3434,3439,3445,3451,3457,3463,3468,3474,3480,3486,3492,3498,3503,3509,3515,3521,3527,3533,3539],"code",{"__ignoreMap":3397},[3402,3403,3406],"span",{"class":3404,"line":3405},"line",1,[3402,3407,3408],{},"@startuml\n",[3402,3410,3412],{"class":3404,"line":3411},2,[3402,3413,3414],{},"skinparam style plain\n",[3402,3416,3418],{"class":3404,"line":3417},3,[3402,3419,3420],{},"skinparam backgroundColor #ffffff\n",[3402,3422,3424],{"class":3404,"line":3423},4,[3402,3425,3427],{"emptyLinePlaceholder":3426},true,"\n",[3402,3429,3431],{"class":3404,"line":3430},5,[3402,3432,3433],{},"title \"Архітектура взаємодії з Amazon Bedrock\"\n",[3402,3435,3437],{"class":3404,"line":3436},6,[3402,3438,3427],{"emptyLinePlaceholder":3426},[3402,3440,3442],{"class":3404,"line":3441},7,[3402,3443,3444],{},"actor \"Клієнт (React \u002F .NET)\" as CLIENT\n",[3402,3446,3448],{"class":3404,"line":3447},8,[3402,3449,3450],{},"rectangle \"AWSSDK.BedrockRuntime\\n(IAM Auth)\" as SDK #dbeafe\n",[3402,3452,3454],{"class":3404,"line":3453},9,[3402,3455,3456],{},"database \"S3 \u002F OpenSearch\\n(Knowledge Base)\" as KB #d1fae5\n",[3402,3458,3460],{"class":3404,"line":3459},10,[3402,3461,3462],{},"rectangle \"Amazon Bedrock Service\" as BED #fef3c7\n",[3402,3464,3466],{"class":3404,"line":3465},11,[3402,3467,3427],{"emptyLinePlaceholder":3426},[3402,3469,3471],{"class":3404,"line":3470},12,[3402,3472,3473],{},"package \"Foundation Models (AWS Hosted)\" as FMS #fde68a {\n",[3402,3475,3477],{"class":3404,"line":3476},13,[3402,3478,3479],{},"    rectangle \"Claude 3.5 Sonnet \u002F Haiku\\n(Anthropic)\" as CL\n",[3402,3481,3483],{"class":3404,"line":3482},14,[3402,3484,3485],{},"    rectangle \"Llama 3.2 \u002F 3.1\\n(Meta)\" as LL\n",[3402,3487,3489],{"class":3404,"line":3488},15,[3402,3490,3491],{},"    rectangle \"Titan Text \u002F Embeddings\\n(Amazon)\" as TIT\n",[3402,3493,3495],{"class":3404,"line":3494},16,[3402,3496,3497],{},"}\n",[3402,3499,3501],{"class":3404,"line":3500},17,[3402,3502,3427],{"emptyLinePlaceholder":3426},[3402,3504,3506],{"class":3404,"line":3505},18,[3402,3507,3508],{},"CLIENT -right-> SDK : HTTPS \u002F Signature V4\n",[3402,3510,3512],{"class":3404,"line":3511},19,[3402,3513,3514],{},"SDK -right-> BED : InvokeModel \u002F Stream\n",[3402,3516,3518],{"class":3404,"line":3517},20,[3402,3519,3520],{},"BED -down-> FMS : Маршрутизація запиту\n",[3402,3522,3524],{"class":3404,"line":3523},21,[3402,3525,3526],{},"BED -left-> KB : Пошук контексту (RAG)\n",[3402,3528,3530],{"class":3404,"line":3529},22,[3402,3531,3532],{},"FMS -up-> BED : Відповідь моделі\n",[3402,3534,3536],{"class":3404,"line":3535},23,[3402,3537,3538],{},"BED -left-> CLIENT : Текст (токен за токеном або JSON)\n",[3402,3540,3542],{"class":3404,"line":3541},24,[3402,3543,3544],{},"@enduml\n",[3546,3547],"hr",{},[3348,3549,3551],{"id":3550},"foundation-models-у-bedrock-огляд","Foundation Models у Bedrock: огляд",[3353,3553,3554],{},"Bedrock дозволяє вибирати моделі під конкретні бізнес-задачі та бюджет:",[3556,3557,3558,3581,3598,3615],"card-group",{},[3559,3560,3563,3566,3567,3570,3571,3573,3577,3578],"card",{"icon":3561,"title":3562},"i-heroicons-sparkles","Claude 3.5 Sonnet & Haiku",[3356,3564,3565],{},"Постачальник:"," Anthropic",[3568,3569],"br",{},"\nНайкращі моделі за якістю кодування, логічного мислення (reasoning) та обробки великих обсягів тексту. Claude 3.5 Sonnet є галузевим стандартом для складних аналітичних завдань. Haiku — надзвичайно швидка та дешева модель для простих операцій.",[3568,3572],{},[3574,3575,3576],"em",{},"ID:"," ",[3399,3579,3580],{},"anthropic.claude-3-5-sonnet-20241022-v2:0",[3559,3582,3585,3587,3588,3590,3591,3593,3577,3595],{"icon":3583,"title":3584},"i-heroicons-cpu-chip","Llama 3.2 & 3.1",[3356,3586,3565],{}," Meta",[3568,3589],{},"\nВідкриті моделі з відмінним співвідношенням швидкості та якості. Llama 3.2 підтримує візуальні дані (multimodal), а Llama 3.1 405B є однією з найпотужніших відкритих моделей у світі. Ідеальні для кастомізації.",[3568,3592],{},[3574,3594,3576],{},[3399,3596,3597],{},"meta.llama3-1-70b-instruct-v1:0",[3559,3599,3602,3604,3605,3607,3608,3610,3577,3612],{"icon":3600,"title":3601},"i-heroicons-bolt","Mistral Large",[3356,3603,3565],{}," Mistral AI",[3568,3606],{},"\nМоделі з високою продуктивністю, глибоким розумінням коду та чудовою підтримкою виклику зовнішніх функцій (Function Calling \u002F Tool Use).",[3568,3609],{},[3574,3611,3576],{},[3399,3613,3614],{},"mistral.mistral-large-2402-v1:0",[3559,3616,3619,3621,3622,3624,3625,3627,3577,3629],{"icon":3617,"title":3618},"i-simple-icons-amazonaws","Amazon Titan & Embeddings",[3356,3620,3565],{}," Amazon",[3568,3623],{},"\nTitan Text Premier підходить для базових текстових задач. Titan Embeddings V2 є оптимальним рішенням для перетворення тексту у вектори (1024 виміри) для пошуку у базах знань (RAG).",[3568,3626],{},[3574,3628,3576],{},[3399,3630,3631],{},"amazon.titan-embed-text-v2:0",[3546,3633],{},[3348,3635,3637],{"id":3636},"налаштування-доступу-та-iam-політики","Налаштування доступу та IAM політики",[3353,3639,3640,3641,3643,3644,3643,3647,3650,3651,3654],{},"Перш ніж викликати моделі з коду, необхідно увімкнути їх у консолі AWS: ",[3356,3642,3358],{}," -> ",[3356,3645,3646],{},"Model access",[3356,3648,3649],{},"Manage model access"," -> Позначити потрібні моделі та натиснути ",[3356,3652,3653],{},"Save changes",".",[3353,3656,3657],{},"Для роботи застосунку потрібні такі IAM дозволи:",[3392,3659,3663],{"className":3660,"code":3661,"language":3662,"meta":3397,"style":3397},"language-json shiki shiki-themes light-plus dark-plus dark-plus","{\n  \"Version\": \"2012-10-17\",\n  \"Statement\": [\n    {\n      \"Effect\": \"Allow\",\n      \"Action\": [\n        \"bedrock:InvokeModel\",\n        \"bedrock:InvokeModelWithResponseStream\"\n      ],\n      \"Resource\": [\n        \"arn:aws:bedrock:us-east-1::foundation-model\u002Fanthropic.claude-3-5-sonnet-20241022-v2:0\",\n        \"arn:aws:bedrock:us-east-1::foundation-model\u002Fanthropic.claude-3-haiku-20240307-v1:0\",\n        \"arn:aws:bedrock:us-east-1::foundation-model\u002Famazon.titan-embed-text-v2:0\"\n      ]\n    },\n    {\n      \"Effect\": \"Allow\",\n      \"Action\": [\n        \"bedrock-agent-runtime:RetrieveAndGenerate\",\n        \"bedrock-agent-runtime:Retrieve\"\n      ],\n      \"Resource\": \"*\"\n    }\n  ]\n}\n","json",[3399,3664,3665,3671,3687,3695,3700,3712,3719,3726,3731,3736,3743,3750,3757,3762,3767,3772,3776,3786,3792,3799,3804,3808,3817,3822,3827],{"__ignoreMap":3397},[3402,3666,3667],{"class":3404,"line":3405},[3402,3668,3670],{"class":3669},"sHH4Y","{\n",[3402,3672,3673,3677,3680,3684],{"class":3404,"line":3411},[3402,3674,3676],{"class":3675},"sLwNe","  \"Version\"",[3402,3678,3679],{"class":3669},": ",[3402,3681,3683],{"class":3682},"sbdoH","\"2012-10-17\"",[3402,3685,3686],{"class":3669},",\n",[3402,3688,3689,3692],{"class":3404,"line":3417},[3402,3690,3691],{"class":3675},"  \"Statement\"",[3402,3693,3694],{"class":3669},": [\n",[3402,3696,3697],{"class":3404,"line":3423},[3402,3698,3699],{"class":3669},"    {\n",[3402,3701,3702,3705,3707,3710],{"class":3404,"line":3430},[3402,3703,3704],{"class":3675},"      \"Effect\"",[3402,3706,3679],{"class":3669},[3402,3708,3709],{"class":3682},"\"Allow\"",[3402,3711,3686],{"class":3669},[3402,3713,3714,3717],{"class":3404,"line":3436},[3402,3715,3716],{"class":3675},"      \"Action\"",[3402,3718,3694],{"class":3669},[3402,3720,3721,3724],{"class":3404,"line":3441},[3402,3722,3723],{"class":3682},"        \"bedrock:InvokeModel\"",[3402,3725,3686],{"class":3669},[3402,3727,3728],{"class":3404,"line":3447},[3402,3729,3730],{"class":3682},"        \"bedrock:InvokeModelWithResponseStream\"\n",[3402,3732,3733],{"class":3404,"line":3453},[3402,3734,3735],{"class":3669},"      ],\n",[3402,3737,3738,3741],{"class":3404,"line":3459},[3402,3739,3740],{"class":3675},"      \"Resource\"",[3402,3742,3694],{"class":3669},[3402,3744,3745,3748],{"class":3404,"line":3465},[3402,3746,3747],{"class":3682},"        \"arn:aws:bedrock:us-east-1::foundation-model\u002Fanthropic.claude-3-5-sonnet-20241022-v2:0\"",[3402,3749,3686],{"class":3669},[3402,3751,3752,3755],{"class":3404,"line":3470},[3402,3753,3754],{"class":3682},"        \"arn:aws:bedrock:us-east-1::foundation-model\u002Fanthropic.claude-3-haiku-20240307-v1:0\"",[3402,3756,3686],{"class":3669},[3402,3758,3759],{"class":3404,"line":3476},[3402,3760,3761],{"class":3682},"        \"arn:aws:bedrock:us-east-1::foundation-model\u002Famazon.titan-embed-text-v2:0\"\n",[3402,3763,3764],{"class":3404,"line":3482},[3402,3765,3766],{"class":3669},"      ]\n",[3402,3768,3769],{"class":3404,"line":3488},[3402,3770,3771],{"class":3669},"    },\n",[3402,3773,3774],{"class":3404,"line":3494},[3402,3775,3699],{"class":3669},[3402,3777,3778,3780,3782,3784],{"class":3404,"line":3500},[3402,3779,3704],{"class":3675},[3402,3781,3679],{"class":3669},[3402,3783,3709],{"class":3682},[3402,3785,3686],{"class":3669},[3402,3787,3788,3790],{"class":3404,"line":3505},[3402,3789,3716],{"class":3675},[3402,3791,3694],{"class":3669},[3402,3793,3794,3797],{"class":3404,"line":3511},[3402,3795,3796],{"class":3682},"        \"bedrock-agent-runtime:RetrieveAndGenerate\"",[3402,3798,3686],{"class":3669},[3402,3800,3801],{"class":3404,"line":3517},[3402,3802,3803],{"class":3682},"        \"bedrock-agent-runtime:Retrieve\"\n",[3402,3805,3806],{"class":3404,"line":3523},[3402,3807,3735],{"class":3669},[3402,3809,3810,3812,3814],{"class":3404,"line":3529},[3402,3811,3740],{"class":3675},[3402,3813,3679],{"class":3669},[3402,3815,3816],{"class":3682},"\"*\"\n",[3402,3818,3819],{"class":3404,"line":3535},[3402,3820,3821],{"class":3669},"    }\n",[3402,3823,3824],{"class":3404,"line":3541},[3402,3825,3826],{"class":3669},"  ]\n",[3402,3828,3830],{"class":3404,"line":3829},25,[3402,3831,3497],{"class":3669},[3546,3833],{},[3348,3835,3837],{"id":3836},"виклик-bedrock-api-з-net-8","Виклик Bedrock API з .NET 8",[3353,3839,3840],{},"Для роботи з API Bedrock Runtime використовується офіційний NuGet-пакет:",[3392,3842,3846],{"className":3843,"code":3844,"language":3845,"meta":3397,"style":3397},"language-bash shiki shiki-themes light-plus dark-plus dark-plus","dotnet add package AWSSDK.BedrockRuntime\n","bash",[3399,3847,3848],{"__ignoreMap":3397},[3402,3849,3850,3854,3857,3860],{"class":3404,"line":3405},[3402,3851,3853],{"class":3852},"s8Opu","dotnet",[3402,3855,3856],{"class":3682}," add",[3402,3858,3859],{"class":3682}," package",[3402,3861,3862],{"class":3682}," AWSSDK.BedrockRuntime\n",[3864,3865,3867],"h3",{"id":3866},"реалізація-bedrockclaudeservice","Реалізація BedrockClaudeService",[3353,3869,3870,3871,3874],{},"Оскільки Bedrock використовує уніфікований API, запити надсилаються через метод ",[3399,3872,3873],{},"InvokeModelAsync",". Тіло запиту формується у форматі Messages API, який є специфічним для сімейства моделей Claude.",[3353,3876,3877],{},"Нижче наведено повноцінний та повністю працездатний сервіс для надсилання запитів та збереження контексту чату:",[3392,3879,3884],{"className":3880,"code":3881,"filename":3882,"language":3883,"meta":3397,"style":3397},"language-csharp shiki shiki-themes light-plus dark-plus dark-plus","using System.Text;\nusing System.Text.Json;\nusing System.Text.Json.Serialization;\nusing Amazon.BedrockRuntime;\nusing Amazon.BedrockRuntime.Model;\n\nnamespace AwsAiPlayground.Services;\n\npublic record ChatMessage(\n    [property: JsonPropertyName(\"role\")] string Role,\n    [property: JsonPropertyName(\"content\")] List\u003CClaudeContent> Content);\n\npublic record ClaudeContent(\n    [property: JsonPropertyName(\"type\")] string Type,\n    [property: JsonPropertyName(\"text\")] string Text);\n\npublic record ClaudeRequestBody(\n    [property: JsonPropertyName(\"anthropic_version\")] string AnthropicVersion,\n    [property: JsonPropertyName(\"max_tokens\")] int MaxTokens,\n    [property: JsonPropertyName(\"temperature\")] float Temperature,\n    [property: JsonPropertyName(\"system\")] string? System,\n    [property: JsonPropertyName(\"messages\")] List\u003CChatMessage> Messages);\n\npublic record ClaudeResponseBody(\n    [property: JsonPropertyName(\"id\")] string Id,\n    [property: JsonPropertyName(\"type\")] string Type,\n    [property: JsonPropertyName(\"role\")] string Role,\n    [property: JsonPropertyName(\"content\")] List\u003CClaudeContent> Content,\n    [property: JsonPropertyName(\"stop_reason\")] string StopReason,\n    [property: JsonPropertyName(\"usage\")] ClaudeUsage Usage);\n\npublic record ClaudeUsage(\n    [property: JsonPropertyName(\"input_tokens\")] int InputTokens,\n    [property: JsonPropertyName(\"output_tokens\")] int OutputTokens);\n\npublic sealed class BedrockClaudeService\n{\n    private readonly IAmazonBedrockRuntime _bedrockClient;\n    private const string ClaudeSonnetId = \"anthropic.claude-3-5-sonnet-20241022-v2:0\";\n\n    public BedrockClaudeService(IAmazonBedrockRuntime bedrockClient)\n    {\n        _bedrockClient = bedrockClient;\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F Надсилає поодинокий запит до Claude 3.5 Sonnet та повертає текстову відповідь.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async Task\u003Cstring> AskClaudeAsync(string prompt, string? systemInstruction = null)\n    {\n        var messages = new List\u003CChatMessage>\n        {\n            new(\"user\", [new(\"text\", prompt)])\n        };\n\n        var requestBody = new ClaudeRequestBody(\n            AnthropicVersion: \"bedrock-2023-05-31\",\n            MaxTokens: 2048,\n            Temperature: 0.7f,\n            System: systemInstruction,\n            Messages: messages\n        );\n\n        var jsonOptions = new JsonSerializerOptions\n        {\n            DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull\n        };\n        var serializedBody = JsonSerializer.Serialize(requestBody, jsonOptions);\n\n        var request = new InvokeModelRequest\n        {\n            ModelId = ClaudeSonnetId,\n            ContentType = \"application\u002Fjson\",\n            Accept = \"application\u002Fjson\",\n            Body = new MemoryStream(Encoding.UTF8.GetBytes(serializedBody))\n        };\n\n        try\n        {\n            var response = await _bedrockClient.InvokeModelAsync(request);\n\n            using var reader = new StreamReader(response.Body);\n            var responseBodyJson = await reader.ReadToEndAsync();\n\n            var result = JsonSerializer.Deserialize\u003CClaudeResponseBody>(responseBodyJson);\n            return result?.Content.FirstOrDefault(c => c.Type == \"text\")?.Text \n                   ?? throw new InvalidOperationException(\"Empty response from Bedrock model.\");\n        }\n        catch (AmazonBedrockRuntimeException ex)\n        {\n            \u002F\u002F Логування помилок AWS Bedrock (наприклад, перевищення ліміту запитів або відсутність доступу)\n            throw new Exception($\"AWS Bedrock Runtime Error: {ex.Message}\", ex);\n        }\n    }\n}\n","Services\u002FBedrockClaudeService.cs","csharp",[3399,3885,3886,3904,3921,3942,3955,3972,3976,3992,3996,4010,4041,4076,4080,4091,4115,4139,4143,4154,4178,4203,4228,4255,4286,4290,4301,4325,4348,4371,4400,4425,4451,4456,4468,4493,4518,4523,4537,4542,4559,4581,4586,4606,4611,4624,4629,4634,4651,4657,4669,4713,4718,4741,4747,4775,4781,4786,4802,4815,4829,4842,4854,4865,4871,4876,4891,4896,4912,4917,4947,4952,4967,4972,4985,4998,5010,5046,5051,5056,5062,5067,5094,5099,5130,5152,5157,5187,5233,5255,5261,5278,5283,5289,5329,5334,5339],{"__ignoreMap":3397},[3402,3887,3888,3892,3896,3898,3901],{"class":3404,"line":3405},[3402,3889,3891],{"class":3890},"s8xlr","using",[3402,3893,3895],{"class":3894},"sN1BT"," System",[3402,3897,3654],{"class":3669},[3402,3899,3900],{"class":3894},"Text",[3402,3902,3903],{"class":3669},";\n",[3402,3905,3906,3908,3910,3912,3914,3916,3919],{"class":3404,"line":3411},[3402,3907,3891],{"class":3890},[3402,3909,3895],{"class":3894},[3402,3911,3654],{"class":3669},[3402,3913,3900],{"class":3894},[3402,3915,3654],{"class":3669},[3402,3917,3918],{"class":3894},"Json",[3402,3920,3903],{"class":3669},[3402,3922,3923,3925,3927,3929,3931,3933,3935,3937,3940],{"class":3404,"line":3417},[3402,3924,3891],{"class":3890},[3402,3926,3895],{"class":3894},[3402,3928,3654],{"class":3669},[3402,3930,3900],{"class":3894},[3402,3932,3654],{"class":3669},[3402,3934,3918],{"class":3894},[3402,3936,3654],{"class":3669},[3402,3938,3939],{"class":3894},"Serialization",[3402,3941,3903],{"class":3669},[3402,3943,3944,3946,3948,3950,3953],{"class":3404,"line":3423},[3402,3945,3891],{"class":3890},[3402,3947,3621],{"class":3894},[3402,3949,3654],{"class":3669},[3402,3951,3952],{"class":3894},"BedrockRuntime",[3402,3954,3903],{"class":3669},[3402,3956,3957,3959,3961,3963,3965,3967,3970],{"class":3404,"line":3430},[3402,3958,3891],{"class":3890},[3402,3960,3621],{"class":3894},[3402,3962,3654],{"class":3669},[3402,3964,3952],{"class":3894},[3402,3966,3654],{"class":3669},[3402,3968,3969],{"class":3894},"Model",[3402,3971,3903],{"class":3669},[3402,3973,3974],{"class":3404,"line":3436},[3402,3975,3427],{"emptyLinePlaceholder":3426},[3402,3977,3978,3982,3985,3987,3990],{"class":3404,"line":3441},[3402,3979,3981],{"class":3980},"su1O8","namespace",[3402,3983,3984],{"class":3894}," AwsAiPlayground",[3402,3986,3654],{"class":3669},[3402,3988,3989],{"class":3894},"Services",[3402,3991,3903],{"class":3669},[3402,3993,3994],{"class":3404,"line":3447},[3402,3995,3427],{"emptyLinePlaceholder":3426},[3402,3997,3998,4001,4004,4007],{"class":3404,"line":3453},[3402,3999,4000],{"class":3980},"public",[3402,4002,4003],{"class":3980}," record",[3402,4005,4006],{"class":3894}," ChatMessage",[3402,4008,4009],{"class":3669},"(\n",[3402,4011,4012,4015,4018,4020,4023,4026,4029,4032,4035,4039],{"class":3404,"line":3459},[3402,4013,4014],{"class":3669},"    [",[3402,4016,4017],{"class":3980},"property",[3402,4019,3679],{"class":3669},[3402,4021,4022],{"class":3894},"JsonPropertyName",[3402,4024,4025],{"class":3669},"(",[3402,4027,4028],{"class":3682},"\"role\"",[3402,4030,4031],{"class":3669},")] ",[3402,4033,4034],{"class":3980},"string",[3402,4036,4038],{"class":4037},"siwwj"," Role",[3402,4040,3686],{"class":3669},[3402,4042,4043,4045,4047,4049,4051,4053,4056,4058,4061,4064,4067,4070,4073],{"class":3404,"line":3465},[3402,4044,4014],{"class":3669},[3402,4046,4017],{"class":3980},[3402,4048,3679],{"class":3669},[3402,4050,4022],{"class":3894},[3402,4052,4025],{"class":3669},[3402,4054,4055],{"class":3682},"\"content\"",[3402,4057,4031],{"class":3669},[3402,4059,4060],{"class":3894},"List",[3402,4062,4063],{"class":3669},"\u003C",[3402,4065,4066],{"class":3894},"ClaudeContent",[3402,4068,4069],{"class":3669},"> ",[3402,4071,4072],{"class":4037},"Content",[3402,4074,4075],{"class":3669},");\n",[3402,4077,4078],{"class":3404,"line":3470},[3402,4079,3427],{"emptyLinePlaceholder":3426},[3402,4081,4082,4084,4086,4089],{"class":3404,"line":3476},[3402,4083,4000],{"class":3980},[3402,4085,4003],{"class":3980},[3402,4087,4088],{"class":3894}," ClaudeContent",[3402,4090,4009],{"class":3669},[3402,4092,4093,4095,4097,4099,4101,4103,4106,4108,4110,4113],{"class":3404,"line":3482},[3402,4094,4014],{"class":3669},[3402,4096,4017],{"class":3980},[3402,4098,3679],{"class":3669},[3402,4100,4022],{"class":3894},[3402,4102,4025],{"class":3669},[3402,4104,4105],{"class":3682},"\"type\"",[3402,4107,4031],{"class":3669},[3402,4109,4034],{"class":3980},[3402,4111,4112],{"class":4037}," Type",[3402,4114,3686],{"class":3669},[3402,4116,4117,4119,4121,4123,4125,4127,4130,4132,4134,4137],{"class":3404,"line":3488},[3402,4118,4014],{"class":3669},[3402,4120,4017],{"class":3980},[3402,4122,3679],{"class":3669},[3402,4124,4022],{"class":3894},[3402,4126,4025],{"class":3669},[3402,4128,4129],{"class":3682},"\"text\"",[3402,4131,4031],{"class":3669},[3402,4133,4034],{"class":3980},[3402,4135,4136],{"class":4037}," Text",[3402,4138,4075],{"class":3669},[3402,4140,4141],{"class":3404,"line":3494},[3402,4142,3427],{"emptyLinePlaceholder":3426},[3402,4144,4145,4147,4149,4152],{"class":3404,"line":3500},[3402,4146,4000],{"class":3980},[3402,4148,4003],{"class":3980},[3402,4150,4151],{"class":3894}," ClaudeRequestBody",[3402,4153,4009],{"class":3669},[3402,4155,4156,4158,4160,4162,4164,4166,4169,4171,4173,4176],{"class":3404,"line":3505},[3402,4157,4014],{"class":3669},[3402,4159,4017],{"class":3980},[3402,4161,3679],{"class":3669},[3402,4163,4022],{"class":3894},[3402,4165,4025],{"class":3669},[3402,4167,4168],{"class":3682},"\"anthropic_version\"",[3402,4170,4031],{"class":3669},[3402,4172,4034],{"class":3980},[3402,4174,4175],{"class":4037}," AnthropicVersion",[3402,4177,3686],{"class":3669},[3402,4179,4180,4182,4184,4186,4188,4190,4193,4195,4198,4201],{"class":3404,"line":3511},[3402,4181,4014],{"class":3669},[3402,4183,4017],{"class":3980},[3402,4185,3679],{"class":3669},[3402,4187,4022],{"class":3894},[3402,4189,4025],{"class":3669},[3402,4191,4192],{"class":3682},"\"max_tokens\"",[3402,4194,4031],{"class":3669},[3402,4196,4197],{"class":3980},"int",[3402,4199,4200],{"class":4037}," MaxTokens",[3402,4202,3686],{"class":3669},[3402,4204,4205,4207,4209,4211,4213,4215,4218,4220,4223,4226],{"class":3404,"line":3517},[3402,4206,4014],{"class":3669},[3402,4208,4017],{"class":3980},[3402,4210,3679],{"class":3669},[3402,4212,4022],{"class":3894},[3402,4214,4025],{"class":3669},[3402,4216,4217],{"class":3682},"\"temperature\"",[3402,4219,4031],{"class":3669},[3402,4221,4222],{"class":3980},"float",[3402,4224,4225],{"class":4037}," Temperature",[3402,4227,3686],{"class":3669},[3402,4229,4230,4232,4234,4236,4238,4240,4243,4245,4247,4250,4253],{"class":3404,"line":3523},[3402,4231,4014],{"class":3669},[3402,4233,4017],{"class":3980},[3402,4235,3679],{"class":3669},[3402,4237,4022],{"class":3894},[3402,4239,4025],{"class":3669},[3402,4241,4242],{"class":3682},"\"system\"",[3402,4244,4031],{"class":3669},[3402,4246,4034],{"class":3980},[3402,4248,4249],{"class":3669},"? ",[3402,4251,4252],{"class":4037},"System",[3402,4254,3686],{"class":3669},[3402,4256,4257,4259,4261,4263,4265,4267,4270,4272,4274,4276,4279,4281,4284],{"class":3404,"line":3529},[3402,4258,4014],{"class":3669},[3402,4260,4017],{"class":3980},[3402,4262,3679],{"class":3669},[3402,4264,4022],{"class":3894},[3402,4266,4025],{"class":3669},[3402,4268,4269],{"class":3682},"\"messages\"",[3402,4271,4031],{"class":3669},[3402,4273,4060],{"class":3894},[3402,4275,4063],{"class":3669},[3402,4277,4278],{"class":3894},"ChatMessage",[3402,4280,4069],{"class":3669},[3402,4282,4283],{"class":4037},"Messages",[3402,4285,4075],{"class":3669},[3402,4287,4288],{"class":3404,"line":3535},[3402,4289,3427],{"emptyLinePlaceholder":3426},[3402,4291,4292,4294,4296,4299],{"class":3404,"line":3541},[3402,4293,4000],{"class":3980},[3402,4295,4003],{"class":3980},[3402,4297,4298],{"class":3894}," ClaudeResponseBody",[3402,4300,4009],{"class":3669},[3402,4302,4303,4305,4307,4309,4311,4313,4316,4318,4320,4323],{"class":3404,"line":3829},[3402,4304,4014],{"class":3669},[3402,4306,4017],{"class":3980},[3402,4308,3679],{"class":3669},[3402,4310,4022],{"class":3894},[3402,4312,4025],{"class":3669},[3402,4314,4315],{"class":3682},"\"id\"",[3402,4317,4031],{"class":3669},[3402,4319,4034],{"class":3980},[3402,4321,4322],{"class":4037}," Id",[3402,4324,3686],{"class":3669},[3402,4326,4328,4330,4332,4334,4336,4338,4340,4342,4344,4346],{"class":3404,"line":4327},26,[3402,4329,4014],{"class":3669},[3402,4331,4017],{"class":3980},[3402,4333,3679],{"class":3669},[3402,4335,4022],{"class":3894},[3402,4337,4025],{"class":3669},[3402,4339,4105],{"class":3682},[3402,4341,4031],{"class":3669},[3402,4343,4034],{"class":3980},[3402,4345,4112],{"class":4037},[3402,4347,3686],{"class":3669},[3402,4349,4351,4353,4355,4357,4359,4361,4363,4365,4367,4369],{"class":3404,"line":4350},27,[3402,4352,4014],{"class":3669},[3402,4354,4017],{"class":3980},[3402,4356,3679],{"class":3669},[3402,4358,4022],{"class":3894},[3402,4360,4025],{"class":3669},[3402,4362,4028],{"class":3682},[3402,4364,4031],{"class":3669},[3402,4366,4034],{"class":3980},[3402,4368,4038],{"class":4037},[3402,4370,3686],{"class":3669},[3402,4372,4374,4376,4378,4380,4382,4384,4386,4388,4390,4392,4394,4396,4398],{"class":3404,"line":4373},28,[3402,4375,4014],{"class":3669},[3402,4377,4017],{"class":3980},[3402,4379,3679],{"class":3669},[3402,4381,4022],{"class":3894},[3402,4383,4025],{"class":3669},[3402,4385,4055],{"class":3682},[3402,4387,4031],{"class":3669},[3402,4389,4060],{"class":3894},[3402,4391,4063],{"class":3669},[3402,4393,4066],{"class":3894},[3402,4395,4069],{"class":3669},[3402,4397,4072],{"class":4037},[3402,4399,3686],{"class":3669},[3402,4401,4403,4405,4407,4409,4411,4413,4416,4418,4420,4423],{"class":3404,"line":4402},29,[3402,4404,4014],{"class":3669},[3402,4406,4017],{"class":3980},[3402,4408,3679],{"class":3669},[3402,4410,4022],{"class":3894},[3402,4412,4025],{"class":3669},[3402,4414,4415],{"class":3682},"\"stop_reason\"",[3402,4417,4031],{"class":3669},[3402,4419,4034],{"class":3980},[3402,4421,4422],{"class":4037}," StopReason",[3402,4424,3686],{"class":3669},[3402,4426,4428,4430,4432,4434,4436,4438,4441,4443,4446,4449],{"class":3404,"line":4427},30,[3402,4429,4014],{"class":3669},[3402,4431,4017],{"class":3980},[3402,4433,3679],{"class":3669},[3402,4435,4022],{"class":3894},[3402,4437,4025],{"class":3669},[3402,4439,4440],{"class":3682},"\"usage\"",[3402,4442,4031],{"class":3669},[3402,4444,4445],{"class":3894},"ClaudeUsage",[3402,4447,4448],{"class":4037}," Usage",[3402,4450,4075],{"class":3669},[3402,4452,4454],{"class":3404,"line":4453},31,[3402,4455,3427],{"emptyLinePlaceholder":3426},[3402,4457,4459,4461,4463,4466],{"class":3404,"line":4458},32,[3402,4460,4000],{"class":3980},[3402,4462,4003],{"class":3980},[3402,4464,4465],{"class":3894}," ClaudeUsage",[3402,4467,4009],{"class":3669},[3402,4469,4471,4473,4475,4477,4479,4481,4484,4486,4488,4491],{"class":3404,"line":4470},33,[3402,4472,4014],{"class":3669},[3402,4474,4017],{"class":3980},[3402,4476,3679],{"class":3669},[3402,4478,4022],{"class":3894},[3402,4480,4025],{"class":3669},[3402,4482,4483],{"class":3682},"\"input_tokens\"",[3402,4485,4031],{"class":3669},[3402,4487,4197],{"class":3980},[3402,4489,4490],{"class":4037}," InputTokens",[3402,4492,3686],{"class":3669},[3402,4494,4496,4498,4500,4502,4504,4506,4509,4511,4513,4516],{"class":3404,"line":4495},34,[3402,4497,4014],{"class":3669},[3402,4499,4017],{"class":3980},[3402,4501,3679],{"class":3669},[3402,4503,4022],{"class":3894},[3402,4505,4025],{"class":3669},[3402,4507,4508],{"class":3682},"\"output_tokens\"",[3402,4510,4031],{"class":3669},[3402,4512,4197],{"class":3980},[3402,4514,4515],{"class":4037}," OutputTokens",[3402,4517,4075],{"class":3669},[3402,4519,4521],{"class":3404,"line":4520},35,[3402,4522,3427],{"emptyLinePlaceholder":3426},[3402,4524,4526,4528,4531,4534],{"class":3404,"line":4525},36,[3402,4527,4000],{"class":3980},[3402,4529,4530],{"class":3980}," sealed",[3402,4532,4533],{"class":3980}," class",[3402,4535,4536],{"class":3894}," BedrockClaudeService\n",[3402,4538,4540],{"class":3404,"line":4539},37,[3402,4541,3670],{"class":3669},[3402,4543,4545,4548,4551,4554,4557],{"class":3404,"line":4544},38,[3402,4546,4547],{"class":3980},"    private",[3402,4549,4550],{"class":3980}," readonly",[3402,4552,4553],{"class":3894}," IAmazonBedrockRuntime",[3402,4555,4556],{"class":4037}," _bedrockClient",[3402,4558,3903],{"class":3669},[3402,4560,4562,4564,4567,4570,4573,4576,4579],{"class":3404,"line":4561},39,[3402,4563,4547],{"class":3980},[3402,4565,4566],{"class":3980}," const",[3402,4568,4569],{"class":3980}," string",[3402,4571,4572],{"class":4037}," ClaudeSonnetId",[3402,4574,4575],{"class":3669}," = ",[3402,4577,4578],{"class":3682},"\"anthropic.claude-3-5-sonnet-20241022-v2:0\"",[3402,4580,3903],{"class":3669},[3402,4582,4584],{"class":3404,"line":4583},40,[3402,4585,3427],{"emptyLinePlaceholder":3426},[3402,4587,4589,4592,4595,4597,4600,4603],{"class":3404,"line":4588},41,[3402,4590,4591],{"class":3980},"    public",[3402,4593,4594],{"class":3852}," BedrockClaudeService",[3402,4596,4025],{"class":3669},[3402,4598,4599],{"class":3894},"IAmazonBedrockRuntime",[3402,4601,4602],{"class":4037}," bedrockClient",[3402,4604,4605],{"class":3669},")\n",[3402,4607,4609],{"class":3404,"line":4608},42,[3402,4610,3699],{"class":3669},[3402,4612,4614,4617,4619,4622],{"class":3404,"line":4613},43,[3402,4615,4616],{"class":4037},"        _bedrockClient",[3402,4618,4575],{"class":3669},[3402,4620,4621],{"class":4037},"bedrockClient",[3402,4623,3903],{"class":3669},[3402,4625,4627],{"class":3404,"line":4626},44,[3402,4628,3821],{"class":3669},[3402,4630,4632],{"class":3404,"line":4631},45,[3402,4633,3427],{"emptyLinePlaceholder":3426},[3402,4635,4637,4641,4644,4648],{"class":3404,"line":4636},46,[3402,4638,4640],{"class":4639},"spJ8K","    \u002F\u002F\u002F ",[3402,4642,4063],{"class":4643},"s0P7L",[3402,4645,4647],{"class":4646},"sKtos","summary",[3402,4649,4650],{"class":4643},">\n",[3402,4652,4654],{"class":3404,"line":4653},47,[3402,4655,4656],{"class":4639},"    \u002F\u002F\u002F Надсилає поодинокий запит до Claude 3.5 Sonnet та повертає текстову відповідь.\n",[3402,4658,4660,4662,4665,4667],{"class":3404,"line":4659},48,[3402,4661,4640],{"class":4639},[3402,4663,4664],{"class":4643},"\u003C\u002F",[3402,4666,4647],{"class":4646},[3402,4668,4650],{"class":4643},[3402,4670,4672,4674,4677,4680,4682,4684,4686,4689,4691,4693,4696,4699,4701,4703,4706,4708,4711],{"class":3404,"line":4671},49,[3402,4673,4591],{"class":3980},[3402,4675,4676],{"class":3980}," async",[3402,4678,4679],{"class":3894}," Task",[3402,4681,4063],{"class":3669},[3402,4683,4034],{"class":3980},[3402,4685,4069],{"class":3669},[3402,4687,4688],{"class":3852},"AskClaudeAsync",[3402,4690,4025],{"class":3669},[3402,4692,4034],{"class":3980},[3402,4694,4695],{"class":4037}," prompt",[3402,4697,4698],{"class":3669},", ",[3402,4700,4034],{"class":3980},[3402,4702,4249],{"class":3669},[3402,4704,4705],{"class":4037},"systemInstruction",[3402,4707,4575],{"class":3669},[3402,4709,4710],{"class":3980},"null",[3402,4712,4605],{"class":3669},[3402,4714,4716],{"class":3404,"line":4715},50,[3402,4717,3699],{"class":3669},[3402,4719,4721,4724,4727,4729,4732,4735,4737,4739],{"class":3404,"line":4720},51,[3402,4722,4723],{"class":3980},"        var",[3402,4725,4726],{"class":4037}," messages",[3402,4728,4575],{"class":3669},[3402,4730,4731],{"class":3980},"new",[3402,4733,4734],{"class":3894}," List",[3402,4736,4063],{"class":3669},[3402,4738,4278],{"class":3894},[3402,4740,4650],{"class":3669},[3402,4742,4744],{"class":3404,"line":4743},52,[3402,4745,4746],{"class":3669},"        {\n",[3402,4748,4750,4753,4755,4758,4761,4763,4765,4767,4769,4772],{"class":3404,"line":4749},53,[3402,4751,4752],{"class":3980},"            new",[3402,4754,4025],{"class":3669},[3402,4756,4757],{"class":3682},"\"user\"",[3402,4759,4760],{"class":3669},", [",[3402,4762,4731],{"class":3980},[3402,4764,4025],{"class":3669},[3402,4766,4129],{"class":3682},[3402,4768,4698],{"class":3669},[3402,4770,4771],{"class":4037},"prompt",[3402,4773,4774],{"class":3669},")])\n",[3402,4776,4778],{"class":3404,"line":4777},54,[3402,4779,4780],{"class":3669},"        };\n",[3402,4782,4784],{"class":3404,"line":4783},55,[3402,4785,3427],{"emptyLinePlaceholder":3426},[3402,4787,4789,4791,4794,4796,4798,4800],{"class":3404,"line":4788},56,[3402,4790,4723],{"class":3980},[3402,4792,4793],{"class":4037}," requestBody",[3402,4795,4575],{"class":3669},[3402,4797,4731],{"class":3980},[3402,4799,4151],{"class":3894},[3402,4801,4009],{"class":3669},[3402,4803,4805,4808,4810,4813],{"class":3404,"line":4804},57,[3402,4806,4807],{"class":4037},"            AnthropicVersion",[3402,4809,3679],{"class":3669},[3402,4811,4812],{"class":3682},"\"bedrock-2023-05-31\"",[3402,4814,3686],{"class":3669},[3402,4816,4818,4821,4823,4827],{"class":3404,"line":4817},58,[3402,4819,4820],{"class":4037},"            MaxTokens",[3402,4822,3679],{"class":3669},[3402,4824,4826],{"class":4825},"sJj4R","2048",[3402,4828,3686],{"class":3669},[3402,4830,4832,4835,4837,4840],{"class":3404,"line":4831},59,[3402,4833,4834],{"class":4037},"            Temperature",[3402,4836,3679],{"class":3669},[3402,4838,4839],{"class":4825},"0.7f",[3402,4841,3686],{"class":3669},[3402,4843,4845,4848,4850,4852],{"class":3404,"line":4844},60,[3402,4846,4847],{"class":4037},"            System",[3402,4849,3679],{"class":3669},[3402,4851,4705],{"class":4037},[3402,4853,3686],{"class":3669},[3402,4855,4857,4860,4862],{"class":3404,"line":4856},61,[3402,4858,4859],{"class":4037},"            Messages",[3402,4861,3679],{"class":3669},[3402,4863,4864],{"class":4037},"messages\n",[3402,4866,4868],{"class":3404,"line":4867},62,[3402,4869,4870],{"class":3669},"        );\n",[3402,4872,4874],{"class":3404,"line":4873},63,[3402,4875,3427],{"emptyLinePlaceholder":3426},[3402,4877,4879,4881,4884,4886,4888],{"class":3404,"line":4878},64,[3402,4880,4723],{"class":3980},[3402,4882,4883],{"class":4037}," jsonOptions",[3402,4885,4575],{"class":3669},[3402,4887,4731],{"class":3980},[3402,4889,4890],{"class":3894}," JsonSerializerOptions\n",[3402,4892,4894],{"class":3404,"line":4893},65,[3402,4895,4746],{"class":3669},[3402,4897,4899,4902,4904,4907,4909],{"class":3404,"line":4898},66,[3402,4900,4901],{"class":4037},"            DefaultIgnoreCondition",[3402,4903,4575],{"class":3669},[3402,4905,4906],{"class":4037},"JsonIgnoreCondition",[3402,4908,3654],{"class":3669},[3402,4910,4911],{"class":4037},"WhenWritingNull\n",[3402,4913,4915],{"class":3404,"line":4914},67,[3402,4916,4780],{"class":3669},[3402,4918,4920,4922,4925,4927,4930,4932,4935,4937,4940,4942,4945],{"class":3404,"line":4919},68,[3402,4921,4723],{"class":3980},[3402,4923,4924],{"class":4037}," serializedBody",[3402,4926,4575],{"class":3669},[3402,4928,4929],{"class":4037},"JsonSerializer",[3402,4931,3654],{"class":3669},[3402,4933,4934],{"class":3852},"Serialize",[3402,4936,4025],{"class":3669},[3402,4938,4939],{"class":4037},"requestBody",[3402,4941,4698],{"class":3669},[3402,4943,4944],{"class":4037},"jsonOptions",[3402,4946,4075],{"class":3669},[3402,4948,4950],{"class":3404,"line":4949},69,[3402,4951,3427],{"emptyLinePlaceholder":3426},[3402,4953,4955,4957,4960,4962,4964],{"class":3404,"line":4954},70,[3402,4956,4723],{"class":3980},[3402,4958,4959],{"class":4037}," request",[3402,4961,4575],{"class":3669},[3402,4963,4731],{"class":3980},[3402,4965,4966],{"class":3894}," InvokeModelRequest\n",[3402,4968,4970],{"class":3404,"line":4969},71,[3402,4971,4746],{"class":3669},[3402,4973,4975,4978,4980,4983],{"class":3404,"line":4974},72,[3402,4976,4977],{"class":4037},"            ModelId",[3402,4979,4575],{"class":3669},[3402,4981,4982],{"class":4037},"ClaudeSonnetId",[3402,4984,3686],{"class":3669},[3402,4986,4988,4991,4993,4996],{"class":3404,"line":4987},73,[3402,4989,4990],{"class":4037},"            ContentType",[3402,4992,4575],{"class":3669},[3402,4994,4995],{"class":3682},"\"application\u002Fjson\"",[3402,4997,3686],{"class":3669},[3402,4999,5001,5004,5006,5008],{"class":3404,"line":5000},74,[3402,5002,5003],{"class":4037},"            Accept",[3402,5005,4575],{"class":3669},[3402,5007,4995],{"class":3682},[3402,5009,3686],{"class":3669},[3402,5011,5013,5016,5018,5020,5023,5025,5028,5030,5033,5035,5038,5040,5043],{"class":3404,"line":5012},75,[3402,5014,5015],{"class":4037},"            Body",[3402,5017,4575],{"class":3669},[3402,5019,4731],{"class":3980},[3402,5021,5022],{"class":3894}," MemoryStream",[3402,5024,4025],{"class":3669},[3402,5026,5027],{"class":4037},"Encoding",[3402,5029,3654],{"class":3669},[3402,5031,5032],{"class":4037},"UTF8",[3402,5034,3654],{"class":3669},[3402,5036,5037],{"class":3852},"GetBytes",[3402,5039,4025],{"class":3669},[3402,5041,5042],{"class":4037},"serializedBody",[3402,5044,5045],{"class":3669},"))\n",[3402,5047,5049],{"class":3404,"line":5048},76,[3402,5050,4780],{"class":3669},[3402,5052,5054],{"class":3404,"line":5053},77,[3402,5055,3427],{"emptyLinePlaceholder":3426},[3402,5057,5059],{"class":3404,"line":5058},78,[3402,5060,5061],{"class":3890},"        try\n",[3402,5063,5065],{"class":3404,"line":5064},79,[3402,5066,4746],{"class":3669},[3402,5068,5070,5073,5076,5078,5081,5083,5085,5087,5089,5092],{"class":3404,"line":5069},80,[3402,5071,5072],{"class":3980},"            var",[3402,5074,5075],{"class":4037}," response",[3402,5077,4575],{"class":3669},[3402,5079,5080],{"class":3980},"await",[3402,5082,4556],{"class":4037},[3402,5084,3654],{"class":3669},[3402,5086,3873],{"class":3852},[3402,5088,4025],{"class":3669},[3402,5090,5091],{"class":4037},"request",[3402,5093,4075],{"class":3669},[3402,5095,5097],{"class":3404,"line":5096},81,[3402,5098,3427],{"emptyLinePlaceholder":3426},[3402,5100,5102,5105,5108,5111,5113,5115,5118,5120,5123,5125,5128],{"class":3404,"line":5101},82,[3402,5103,5104],{"class":3890},"            using",[3402,5106,5107],{"class":3980}," var",[3402,5109,5110],{"class":4037}," reader",[3402,5112,4575],{"class":3669},[3402,5114,4731],{"class":3980},[3402,5116,5117],{"class":3894}," StreamReader",[3402,5119,4025],{"class":3669},[3402,5121,5122],{"class":4037},"response",[3402,5124,3654],{"class":3669},[3402,5126,5127],{"class":4037},"Body",[3402,5129,4075],{"class":3669},[3402,5131,5133,5135,5138,5140,5142,5144,5146,5149],{"class":3404,"line":5132},83,[3402,5134,5072],{"class":3980},[3402,5136,5137],{"class":4037}," responseBodyJson",[3402,5139,4575],{"class":3669},[3402,5141,5080],{"class":3980},[3402,5143,5110],{"class":4037},[3402,5145,3654],{"class":3669},[3402,5147,5148],{"class":3852},"ReadToEndAsync",[3402,5150,5151],{"class":3669},"();\n",[3402,5153,5155],{"class":3404,"line":5154},84,[3402,5156,3427],{"emptyLinePlaceholder":3426},[3402,5158,5160,5162,5165,5167,5169,5171,5174,5176,5179,5182,5185],{"class":3404,"line":5159},85,[3402,5161,5072],{"class":3980},[3402,5163,5164],{"class":4037}," result",[3402,5166,4575],{"class":3669},[3402,5168,4929],{"class":4037},[3402,5170,3654],{"class":3669},[3402,5172,5173],{"class":3852},"Deserialize",[3402,5175,4063],{"class":3669},[3402,5177,5178],{"class":3894},"ClaudeResponseBody",[3402,5180,5181],{"class":3669},">(",[3402,5183,5184],{"class":4037},"responseBodyJson",[3402,5186,4075],{"class":3669},[3402,5188,5190,5193,5195,5198,5200,5202,5205,5207,5210,5213,5215,5217,5220,5223,5225,5228,5230],{"class":3404,"line":5189},86,[3402,5191,5192],{"class":3890},"            return",[3402,5194,5164],{"class":4037},[3402,5196,5197],{"class":3669},"?.",[3402,5199,4072],{"class":4037},[3402,5201,3654],{"class":3669},[3402,5203,5204],{"class":3852},"FirstOrDefault",[3402,5206,4025],{"class":3669},[3402,5208,5209],{"class":4037},"c",[3402,5211,5212],{"class":3669}," => ",[3402,5214,5209],{"class":4037},[3402,5216,3654],{"class":3669},[3402,5218,5219],{"class":4037},"Type",[3402,5221,5222],{"class":3669}," == ",[3402,5224,4129],{"class":3682},[3402,5226,5227],{"class":3669},")?.",[3402,5229,3900],{"class":4037},[3402,5231,5232],{"class":3669}," \n",[3402,5234,5236,5239,5242,5245,5248,5250,5253],{"class":3404,"line":5235},87,[3402,5237,5238],{"class":3669},"                   ?? ",[3402,5240,5241],{"class":3890},"throw",[3402,5243,5244],{"class":3980}," new",[3402,5246,5247],{"class":3894}," InvalidOperationException",[3402,5249,4025],{"class":3669},[3402,5251,5252],{"class":3682},"\"Empty response from Bedrock model.\"",[3402,5254,4075],{"class":3669},[3402,5256,5258],{"class":3404,"line":5257},88,[3402,5259,5260],{"class":3669},"        }\n",[3402,5262,5264,5267,5270,5273,5276],{"class":3404,"line":5263},89,[3402,5265,5266],{"class":3890},"        catch",[3402,5268,5269],{"class":3669}," (",[3402,5271,5272],{"class":3894},"AmazonBedrockRuntimeException",[3402,5274,5275],{"class":4037}," ex",[3402,5277,4605],{"class":3669},[3402,5279,5281],{"class":3404,"line":5280},90,[3402,5282,4746],{"class":3669},[3402,5284,5286],{"class":3404,"line":5285},91,[3402,5287,5288],{"class":4639},"            \u002F\u002F Логування помилок AWS Bedrock (наприклад, перевищення ліміту запитів або відсутність доступу)\n",[3402,5290,5292,5295,5297,5300,5302,5305,5309,5312,5314,5317,5320,5323,5325,5327],{"class":3404,"line":5291},92,[3402,5293,5294],{"class":3890},"            throw",[3402,5296,5244],{"class":3980},[3402,5298,5299],{"class":3894}," Exception",[3402,5301,4025],{"class":3669},[3402,5303,5304],{"class":3682},"$\"AWS Bedrock Runtime Error: ",[3402,5306,5308],{"class":5307},"sD7JJ","{",[3402,5310,5311],{"class":4037},"ex",[3402,5313,3654],{"class":5307},[3402,5315,5316],{"class":4037},"Message",[3402,5318,5319],{"class":5307},"}",[3402,5321,5322],{"class":3682},"\"",[3402,5324,4698],{"class":3669},[3402,5326,5311],{"class":4037},[3402,5328,4075],{"class":3669},[3402,5330,5332],{"class":3404,"line":5331},93,[3402,5333,5260],{"class":3669},[3402,5335,5337],{"class":3404,"line":5336},94,[3402,5338,3821],{"class":3669},[3402,5340,5342],{"class":3404,"line":5341},95,[3402,5343,3497],{"class":3669},[3546,5345],{},[3348,5347,5349],{"id":5348},"реалізація-streaming-responses-sse","Реалізація Streaming Responses (SSE)",[3353,5351,5352],{},"Стрімінг дозволяє отримувати токени відповіді по мірі їх генерації моделлю. Це критично для сучасних чат-інтерфейсів, оскільки користувач починає читати відповідь миттєво.",[3864,5354,5356],{"id":5355},"_1-сервіс-асинхронного-стрімінгу-у-net-8","1. Сервіс асинхронного стрімінгу у .NET 8",[3392,5358,5361],{"className":3880,"code":5359,"filename":5360,"language":3883,"meta":3397,"style":3397},"using System.Runtime.CompilerServices;\nusing System.Text;\nusing System.Text.Json;\nusing Amazon.BedrockRuntime;\nusing Amazon.BedrockRuntime.Model;\n\nnamespace AwsAiPlayground.Services;\n\npublic sealed class BedrockStreamingService\n{\n    private readonly IAmazonBedrockRuntime _bedrockClient;\n    private const string ClaudeSonnetId = \"anthropic.claude-3-5-sonnet-20241022-v2:0\";\n\n    public BedrockStreamingService(IAmazonBedrockRuntime bedrockClient)\n    {\n        _bedrockClient = bedrockClient;\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F Повертає асинхронний потік текстових чанків від Claude 3.5 Sonnet.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async IAsyncEnumerable\u003Cstring> StreamClaudeResponseAsync(\n        List\u003CChatMessage> chatHistory,\n        string? systemInstruction = null,\n        [EnumeratorCancellation] CancellationToken cancellationToken = default)\n    {\n        var requestBody = new ClaudeRequestBody(\n            AnthropicVersion: \"bedrock-2023-05-31\",\n            MaxTokens: 2048,\n            Temperature: 0.7f,\n            System: systemInstruction,\n            Messages: chatHistory\n        );\n\n        var serializedBody = JsonSerializer.Serialize(requestBody);\n\n        var request = new InvokeModelWithResponseStreamRequest\n        {\n            ModelId = ClaudeSonnetId,\n            ContentType = \"application\u002Fjson\",\n            Accept = \"application\u002Fjson\",\n            Body = new MemoryStream(Encoding.UTF8.GetBytes(serializedBody))\n        };\n\n        InvokeModelWithResponseStreamResponse response;\n        try\n        {\n            response = await _bedrockClient.InvokeModelWithResponseStreamAsync(request, cancellationToken);\n        }\n        catch (AmazonBedrockRuntimeException ex)\n        {\n            yield return $\"[ERROR: {ex.Message}]\";\n            yield break;\n        }\n\n        await foreach (var ev in response.Body.WithCancellation(cancellationToken))\n        {\n            if (ev is PayloadPart payloadPart)\n            {\n                using var reader = new StreamReader(payloadPart.Bytes);\n                var chunkJson = await reader.ReadToEndAsync(cancellationToken);\n\n                using var doc = JsonDocument.Parse(chunkJson);\n                var root = doc.RootElement;\n\n                \u002F\u002F Для Claude Messages API стрімінг надсилає об'єкти з типом \"content_block_delta\"\n                if (root.TryGetProperty(\"type\", out var typeProp) && \n                    typeProp.GetString() == \"content_block_delta\")\n                {\n                    if (root.TryGetProperty(\"delta\", out var deltaProp) && \n                        deltaProp.TryGetProperty(\"text\", out var textProp))\n                    {\n                        var text = textProp.GetString();\n                        if (!string.IsNullOrEmpty(text))\n                        {\n                            yield return text;\n                        }\n                    }\n                }\n            }\n        }\n    }\n}\n","Services\u002FBedrockStreamingService.cs",[3399,5362,5363,5381,5393,5409,5421,5437,5441,5453,5457,5468,5472,5484,5500,5504,5519,5523,5533,5537,5541,5551,5556,5566,5586,5602,5617,5641,5645,5659,5669,5679,5689,5699,5708,5712,5716,5736,5740,5753,5757,5767,5777,5787,5815,5819,5823,5832,5836,5840,5867,5871,5883,5887,5913,5922,5926,5930,5966,5970,5991,5996,6023,6047,6051,6077,6096,6100,6105,6137,6155,6160,6189,6213,6218,6237,6259,6264,6275,6280,6285,6290,6295,6299,6303],{"__ignoreMap":3397},[3402,5364,5365,5367,5369,5371,5374,5376,5379],{"class":3404,"line":3405},[3402,5366,3891],{"class":3890},[3402,5368,3895],{"class":3894},[3402,5370,3654],{"class":3669},[3402,5372,5373],{"class":3894},"Runtime",[3402,5375,3654],{"class":3669},[3402,5377,5378],{"class":3894},"CompilerServices",[3402,5380,3903],{"class":3669},[3402,5382,5383,5385,5387,5389,5391],{"class":3404,"line":3411},[3402,5384,3891],{"class":3890},[3402,5386,3895],{"class":3894},[3402,5388,3654],{"class":3669},[3402,5390,3900],{"class":3894},[3402,5392,3903],{"class":3669},[3402,5394,5395,5397,5399,5401,5403,5405,5407],{"class":3404,"line":3417},[3402,5396,3891],{"class":3890},[3402,5398,3895],{"class":3894},[3402,5400,3654],{"class":3669},[3402,5402,3900],{"class":3894},[3402,5404,3654],{"class":3669},[3402,5406,3918],{"class":3894},[3402,5408,3903],{"class":3669},[3402,5410,5411,5413,5415,5417,5419],{"class":3404,"line":3423},[3402,5412,3891],{"class":3890},[3402,5414,3621],{"class":3894},[3402,5416,3654],{"class":3669},[3402,5418,3952],{"class":3894},[3402,5420,3903],{"class":3669},[3402,5422,5423,5425,5427,5429,5431,5433,5435],{"class":3404,"line":3430},[3402,5424,3891],{"class":3890},[3402,5426,3621],{"class":3894},[3402,5428,3654],{"class":3669},[3402,5430,3952],{"class":3894},[3402,5432,3654],{"class":3669},[3402,5434,3969],{"class":3894},[3402,5436,3903],{"class":3669},[3402,5438,5439],{"class":3404,"line":3436},[3402,5440,3427],{"emptyLinePlaceholder":3426},[3402,5442,5443,5445,5447,5449,5451],{"class":3404,"line":3441},[3402,5444,3981],{"class":3980},[3402,5446,3984],{"class":3894},[3402,5448,3654],{"class":3669},[3402,5450,3989],{"class":3894},[3402,5452,3903],{"class":3669},[3402,5454,5455],{"class":3404,"line":3447},[3402,5456,3427],{"emptyLinePlaceholder":3426},[3402,5458,5459,5461,5463,5465],{"class":3404,"line":3453},[3402,5460,4000],{"class":3980},[3402,5462,4530],{"class":3980},[3402,5464,4533],{"class":3980},[3402,5466,5467],{"class":3894}," BedrockStreamingService\n",[3402,5469,5470],{"class":3404,"line":3459},[3402,5471,3670],{"class":3669},[3402,5473,5474,5476,5478,5480,5482],{"class":3404,"line":3465},[3402,5475,4547],{"class":3980},[3402,5477,4550],{"class":3980},[3402,5479,4553],{"class":3894},[3402,5481,4556],{"class":4037},[3402,5483,3903],{"class":3669},[3402,5485,5486,5488,5490,5492,5494,5496,5498],{"class":3404,"line":3470},[3402,5487,4547],{"class":3980},[3402,5489,4566],{"class":3980},[3402,5491,4569],{"class":3980},[3402,5493,4572],{"class":4037},[3402,5495,4575],{"class":3669},[3402,5497,4578],{"class":3682},[3402,5499,3903],{"class":3669},[3402,5501,5502],{"class":3404,"line":3476},[3402,5503,3427],{"emptyLinePlaceholder":3426},[3402,5505,5506,5508,5511,5513,5515,5517],{"class":3404,"line":3482},[3402,5507,4591],{"class":3980},[3402,5509,5510],{"class":3852}," BedrockStreamingService",[3402,5512,4025],{"class":3669},[3402,5514,4599],{"class":3894},[3402,5516,4602],{"class":4037},[3402,5518,4605],{"class":3669},[3402,5520,5521],{"class":3404,"line":3488},[3402,5522,3699],{"class":3669},[3402,5524,5525,5527,5529,5531],{"class":3404,"line":3494},[3402,5526,4616],{"class":4037},[3402,5528,4575],{"class":3669},[3402,5530,4621],{"class":4037},[3402,5532,3903],{"class":3669},[3402,5534,5535],{"class":3404,"line":3500},[3402,5536,3821],{"class":3669},[3402,5538,5539],{"class":3404,"line":3505},[3402,5540,3427],{"emptyLinePlaceholder":3426},[3402,5542,5543,5545,5547,5549],{"class":3404,"line":3511},[3402,5544,4640],{"class":4639},[3402,5546,4063],{"class":4643},[3402,5548,4647],{"class":4646},[3402,5550,4650],{"class":4643},[3402,5552,5553],{"class":3404,"line":3517},[3402,5554,5555],{"class":4639},"    \u002F\u002F\u002F Повертає асинхронний потік текстових чанків від Claude 3.5 Sonnet.\n",[3402,5557,5558,5560,5562,5564],{"class":3404,"line":3523},[3402,5559,4640],{"class":4639},[3402,5561,4664],{"class":4643},[3402,5563,4647],{"class":4646},[3402,5565,4650],{"class":4643},[3402,5567,5568,5570,5572,5575,5577,5579,5581,5584],{"class":3404,"line":3529},[3402,5569,4591],{"class":3980},[3402,5571,4676],{"class":3980},[3402,5573,5574],{"class":3894}," IAsyncEnumerable",[3402,5576,4063],{"class":3669},[3402,5578,4034],{"class":3980},[3402,5580,4069],{"class":3669},[3402,5582,5583],{"class":3852},"StreamClaudeResponseAsync",[3402,5585,4009],{"class":3669},[3402,5587,5588,5591,5593,5595,5597,5600],{"class":3404,"line":3535},[3402,5589,5590],{"class":3894},"        List",[3402,5592,4063],{"class":3669},[3402,5594,4278],{"class":3894},[3402,5596,4069],{"class":3669},[3402,5598,5599],{"class":4037},"chatHistory",[3402,5601,3686],{"class":3669},[3402,5603,5604,5607,5609,5611,5613,5615],{"class":3404,"line":3541},[3402,5605,5606],{"class":3980},"        string",[3402,5608,4249],{"class":3669},[3402,5610,4705],{"class":4037},[3402,5612,4575],{"class":3669},[3402,5614,4710],{"class":3980},[3402,5616,3686],{"class":3669},[3402,5618,5619,5622,5625,5628,5631,5634,5636,5639],{"class":3404,"line":3829},[3402,5620,5621],{"class":3669},"        [",[3402,5623,5624],{"class":3894},"EnumeratorCancellation",[3402,5626,5627],{"class":3669},"] ",[3402,5629,5630],{"class":3894},"CancellationToken",[3402,5632,5633],{"class":4037}," cancellationToken",[3402,5635,4575],{"class":3669},[3402,5637,5638],{"class":3980},"default",[3402,5640,4605],{"class":3669},[3402,5642,5643],{"class":3404,"line":4327},[3402,5644,3699],{"class":3669},[3402,5646,5647,5649,5651,5653,5655,5657],{"class":3404,"line":4350},[3402,5648,4723],{"class":3980},[3402,5650,4793],{"class":4037},[3402,5652,4575],{"class":3669},[3402,5654,4731],{"class":3980},[3402,5656,4151],{"class":3894},[3402,5658,4009],{"class":3669},[3402,5660,5661,5663,5665,5667],{"class":3404,"line":4373},[3402,5662,4807],{"class":4037},[3402,5664,3679],{"class":3669},[3402,5666,4812],{"class":3682},[3402,5668,3686],{"class":3669},[3402,5670,5671,5673,5675,5677],{"class":3404,"line":4402},[3402,5672,4820],{"class":4037},[3402,5674,3679],{"class":3669},[3402,5676,4826],{"class":4825},[3402,5678,3686],{"class":3669},[3402,5680,5681,5683,5685,5687],{"class":3404,"line":4427},[3402,5682,4834],{"class":4037},[3402,5684,3679],{"class":3669},[3402,5686,4839],{"class":4825},[3402,5688,3686],{"class":3669},[3402,5690,5691,5693,5695,5697],{"class":3404,"line":4453},[3402,5692,4847],{"class":4037},[3402,5694,3679],{"class":3669},[3402,5696,4705],{"class":4037},[3402,5698,3686],{"class":3669},[3402,5700,5701,5703,5705],{"class":3404,"line":4458},[3402,5702,4859],{"class":4037},[3402,5704,3679],{"class":3669},[3402,5706,5707],{"class":4037},"chatHistory\n",[3402,5709,5710],{"class":3404,"line":4470},[3402,5711,4870],{"class":3669},[3402,5713,5714],{"class":3404,"line":4495},[3402,5715,3427],{"emptyLinePlaceholder":3426},[3402,5717,5718,5720,5722,5724,5726,5728,5730,5732,5734],{"class":3404,"line":4520},[3402,5719,4723],{"class":3980},[3402,5721,4924],{"class":4037},[3402,5723,4575],{"class":3669},[3402,5725,4929],{"class":4037},[3402,5727,3654],{"class":3669},[3402,5729,4934],{"class":3852},[3402,5731,4025],{"class":3669},[3402,5733,4939],{"class":4037},[3402,5735,4075],{"class":3669},[3402,5737,5738],{"class":3404,"line":4525},[3402,5739,3427],{"emptyLinePlaceholder":3426},[3402,5741,5742,5744,5746,5748,5750],{"class":3404,"line":4539},[3402,5743,4723],{"class":3980},[3402,5745,4959],{"class":4037},[3402,5747,4575],{"class":3669},[3402,5749,4731],{"class":3980},[3402,5751,5752],{"class":3894}," InvokeModelWithResponseStreamRequest\n",[3402,5754,5755],{"class":3404,"line":4544},[3402,5756,4746],{"class":3669},[3402,5758,5759,5761,5763,5765],{"class":3404,"line":4561},[3402,5760,4977],{"class":4037},[3402,5762,4575],{"class":3669},[3402,5764,4982],{"class":4037},[3402,5766,3686],{"class":3669},[3402,5768,5769,5771,5773,5775],{"class":3404,"line":4583},[3402,5770,4990],{"class":4037},[3402,5772,4575],{"class":3669},[3402,5774,4995],{"class":3682},[3402,5776,3686],{"class":3669},[3402,5778,5779,5781,5783,5785],{"class":3404,"line":4588},[3402,5780,5003],{"class":4037},[3402,5782,4575],{"class":3669},[3402,5784,4995],{"class":3682},[3402,5786,3686],{"class":3669},[3402,5788,5789,5791,5793,5795,5797,5799,5801,5803,5805,5807,5809,5811,5813],{"class":3404,"line":4608},[3402,5790,5015],{"class":4037},[3402,5792,4575],{"class":3669},[3402,5794,4731],{"class":3980},[3402,5796,5022],{"class":3894},[3402,5798,4025],{"class":3669},[3402,5800,5027],{"class":4037},[3402,5802,3654],{"class":3669},[3402,5804,5032],{"class":4037},[3402,5806,3654],{"class":3669},[3402,5808,5037],{"class":3852},[3402,5810,4025],{"class":3669},[3402,5812,5042],{"class":4037},[3402,5814,5045],{"class":3669},[3402,5816,5817],{"class":3404,"line":4613},[3402,5818,4780],{"class":3669},[3402,5820,5821],{"class":3404,"line":4626},[3402,5822,3427],{"emptyLinePlaceholder":3426},[3402,5824,5825,5828,5830],{"class":3404,"line":4631},[3402,5826,5827],{"class":3894},"        InvokeModelWithResponseStreamResponse",[3402,5829,5075],{"class":4037},[3402,5831,3903],{"class":3669},[3402,5833,5834],{"class":3404,"line":4636},[3402,5835,5061],{"class":3890},[3402,5837,5838],{"class":3404,"line":4653},[3402,5839,4746],{"class":3669},[3402,5841,5842,5845,5847,5849,5851,5853,5856,5858,5860,5862,5865],{"class":3404,"line":4659},[3402,5843,5844],{"class":4037},"            response",[3402,5846,4575],{"class":3669},[3402,5848,5080],{"class":3980},[3402,5850,4556],{"class":4037},[3402,5852,3654],{"class":3669},[3402,5854,5855],{"class":3852},"InvokeModelWithResponseStreamAsync",[3402,5857,4025],{"class":3669},[3402,5859,5091],{"class":4037},[3402,5861,4698],{"class":3669},[3402,5863,5864],{"class":4037},"cancellationToken",[3402,5866,4075],{"class":3669},[3402,5868,5869],{"class":3404,"line":4671},[3402,5870,5260],{"class":3669},[3402,5872,5873,5875,5877,5879,5881],{"class":3404,"line":4715},[3402,5874,5266],{"class":3890},[3402,5876,5269],{"class":3669},[3402,5878,5272],{"class":3894},[3402,5880,5275],{"class":4037},[3402,5882,4605],{"class":3669},[3402,5884,5885],{"class":3404,"line":4720},[3402,5886,4746],{"class":3669},[3402,5888,5889,5892,5895,5898,5900,5902,5904,5906,5908,5911],{"class":3404,"line":4743},[3402,5890,5891],{"class":3890},"            yield",[3402,5893,5894],{"class":3890}," return",[3402,5896,5897],{"class":3682}," $\"[ERROR: ",[3402,5899,5308],{"class":5307},[3402,5901,5311],{"class":4037},[3402,5903,3654],{"class":5307},[3402,5905,5316],{"class":4037},[3402,5907,5319],{"class":5307},[3402,5909,5910],{"class":3682},"]\"",[3402,5912,3903],{"class":3669},[3402,5914,5915,5917,5920],{"class":3404,"line":4749},[3402,5916,5891],{"class":3890},[3402,5918,5919],{"class":3890}," break",[3402,5921,3903],{"class":3669},[3402,5923,5924],{"class":3404,"line":4777},[3402,5925,5260],{"class":3669},[3402,5927,5928],{"class":3404,"line":4783},[3402,5929,3427],{"emptyLinePlaceholder":3426},[3402,5931,5932,5935,5938,5940,5943,5946,5949,5951,5953,5955,5957,5960,5962,5964],{"class":3404,"line":4788},[3402,5933,5934],{"class":3980},"        await",[3402,5936,5937],{"class":3890}," foreach",[3402,5939,5269],{"class":3669},[3402,5941,5942],{"class":3980},"var",[3402,5944,5945],{"class":4037}," ev",[3402,5947,5948],{"class":3890}," in",[3402,5950,5075],{"class":4037},[3402,5952,3654],{"class":3669},[3402,5954,5127],{"class":4037},[3402,5956,3654],{"class":3669},[3402,5958,5959],{"class":3852},"WithCancellation",[3402,5961,4025],{"class":3669},[3402,5963,5864],{"class":4037},[3402,5965,5045],{"class":3669},[3402,5967,5968],{"class":3404,"line":4804},[3402,5969,4746],{"class":3669},[3402,5971,5972,5975,5977,5980,5983,5986,5989],{"class":3404,"line":4817},[3402,5973,5974],{"class":3852},"            if",[3402,5976,5269],{"class":3669},[3402,5978,5979],{"class":4037},"ev",[3402,5981,5982],{"class":3980}," is",[3402,5984,5985],{"class":3894}," PayloadPart",[3402,5987,5988],{"class":4037}," payloadPart",[3402,5990,4605],{"class":3669},[3402,5992,5993],{"class":3404,"line":4831},[3402,5994,5995],{"class":3669},"            {\n",[3402,5997,5998,6001,6003,6005,6007,6009,6011,6013,6016,6018,6021],{"class":3404,"line":4844},[3402,5999,6000],{"class":4037},"                using",[3402,6002,5107],{"class":4037},[3402,6004,5110],{"class":4037},[3402,6006,4575],{"class":3669},[3402,6008,4731],{"class":3980},[3402,6010,5117],{"class":3894},[3402,6012,4025],{"class":3669},[3402,6014,6015],{"class":4037},"payloadPart",[3402,6017,3654],{"class":3669},[3402,6019,6020],{"class":4037},"Bytes",[3402,6022,4075],{"class":3669},[3402,6024,6025,6028,6031,6033,6035,6037,6039,6041,6043,6045],{"class":3404,"line":4856},[3402,6026,6027],{"class":4037},"                var",[3402,6029,6030],{"class":4037}," chunkJson",[3402,6032,4575],{"class":3669},[3402,6034,5080],{"class":3980},[3402,6036,5110],{"class":4037},[3402,6038,3654],{"class":3669},[3402,6040,5148],{"class":3852},[3402,6042,4025],{"class":3669},[3402,6044,5864],{"class":4037},[3402,6046,4075],{"class":3669},[3402,6048,6049],{"class":3404,"line":4867},[3402,6050,3427],{"emptyLinePlaceholder":3426},[3402,6052,6053,6055,6057,6060,6062,6065,6067,6070,6072,6075],{"class":3404,"line":4873},[3402,6054,6000],{"class":4037},[3402,6056,5107],{"class":4037},[3402,6058,6059],{"class":4037}," doc",[3402,6061,4575],{"class":3669},[3402,6063,6064],{"class":4037},"JsonDocument",[3402,6066,3654],{"class":3669},[3402,6068,6069],{"class":3852},"Parse",[3402,6071,4025],{"class":3669},[3402,6073,6074],{"class":4037},"chunkJson",[3402,6076,4075],{"class":3669},[3402,6078,6079,6081,6084,6086,6089,6091,6094],{"class":3404,"line":4878},[3402,6080,6027],{"class":4037},[3402,6082,6083],{"class":4037}," root",[3402,6085,4575],{"class":3669},[3402,6087,6088],{"class":4037},"doc",[3402,6090,3654],{"class":3669},[3402,6092,6093],{"class":4037},"RootElement",[3402,6095,3903],{"class":3669},[3402,6097,6098],{"class":3404,"line":4893},[3402,6099,3427],{"emptyLinePlaceholder":3426},[3402,6101,6102],{"class":3404,"line":4898},[3402,6103,6104],{"class":4639},"                \u002F\u002F Для Claude Messages API стрімінг надсилає об'єкти з типом \"content_block_delta\"\n",[3402,6106,6107,6110,6112,6115,6117,6120,6122,6124,6126,6129,6131,6134],{"class":3404,"line":4914},[3402,6108,6109],{"class":3852},"                if",[3402,6111,5269],{"class":3669},[3402,6113,6114],{"class":4037},"root",[3402,6116,3654],{"class":3669},[3402,6118,6119],{"class":3852},"TryGetProperty",[3402,6121,4025],{"class":3669},[3402,6123,4105],{"class":3682},[3402,6125,4698],{"class":3669},[3402,6127,6128],{"class":3980},"out",[3402,6130,5107],{"class":3980},[3402,6132,6133],{"class":4037}," typeProp",[3402,6135,6136],{"class":3669},") && \n",[3402,6138,6139,6142,6144,6147,6150,6153],{"class":3404,"line":4919},[3402,6140,6141],{"class":4037},"                    typeProp",[3402,6143,3654],{"class":3669},[3402,6145,6146],{"class":3852},"GetString",[3402,6148,6149],{"class":3669},"() == ",[3402,6151,6152],{"class":3682},"\"content_block_delta\"",[3402,6154,4605],{"class":3669},[3402,6156,6157],{"class":3404,"line":4949},[3402,6158,6159],{"class":3669},"                {\n",[3402,6161,6162,6165,6167,6169,6171,6173,6175,6178,6180,6182,6184,6187],{"class":3404,"line":4954},[3402,6163,6164],{"class":3852},"                    if",[3402,6166,5269],{"class":3669},[3402,6168,6114],{"class":4037},[3402,6170,3654],{"class":3669},[3402,6172,6119],{"class":3852},[3402,6174,4025],{"class":3669},[3402,6176,6177],{"class":3682},"\"delta\"",[3402,6179,4698],{"class":3669},[3402,6181,6128],{"class":3980},[3402,6183,5107],{"class":3980},[3402,6185,6186],{"class":4037}," deltaProp",[3402,6188,6136],{"class":3669},[3402,6190,6191,6194,6196,6198,6200,6202,6204,6206,6208,6211],{"class":3404,"line":4969},[3402,6192,6193],{"class":4037},"                        deltaProp",[3402,6195,3654],{"class":3669},[3402,6197,6119],{"class":3852},[3402,6199,4025],{"class":3669},[3402,6201,4129],{"class":3682},[3402,6203,4698],{"class":3669},[3402,6205,6128],{"class":3980},[3402,6207,5107],{"class":3980},[3402,6209,6210],{"class":4037}," textProp",[3402,6212,5045],{"class":3669},[3402,6214,6215],{"class":3404,"line":4974},[3402,6216,6217],{"class":3669},"                    {\n",[3402,6219,6220,6223,6226,6228,6231,6233,6235],{"class":3404,"line":4987},[3402,6221,6222],{"class":4037},"                        var",[3402,6224,6225],{"class":4037}," text",[3402,6227,4575],{"class":3669},[3402,6229,6230],{"class":4037},"textProp",[3402,6232,3654],{"class":3669},[3402,6234,6146],{"class":3852},[3402,6236,5151],{"class":3669},[3402,6238,6239,6242,6245,6247,6249,6252,6254,6257],{"class":3404,"line":5000},[3402,6240,6241],{"class":3852},"                        if",[3402,6243,6244],{"class":3669}," (!",[3402,6246,4034],{"class":3980},[3402,6248,3654],{"class":3669},[3402,6250,6251],{"class":3852},"IsNullOrEmpty",[3402,6253,4025],{"class":3669},[3402,6255,6256],{"class":4037},"text",[3402,6258,5045],{"class":3669},[3402,6260,6261],{"class":3404,"line":5012},[3402,6262,6263],{"class":3669},"                        {\n",[3402,6265,6266,6269,6271,6273],{"class":3404,"line":5048},[3402,6267,6268],{"class":4037},"                            yield",[3402,6270,5894],{"class":4037},[3402,6272,6225],{"class":4037},[3402,6274,3903],{"class":3669},[3402,6276,6277],{"class":3404,"line":5053},[3402,6278,6279],{"class":3669},"                        }\n",[3402,6281,6282],{"class":3404,"line":5058},[3402,6283,6284],{"class":3669},"                    }\n",[3402,6286,6287],{"class":3404,"line":5064},[3402,6288,6289],{"class":3669},"                }\n",[3402,6291,6292],{"class":3404,"line":5069},[3402,6293,6294],{"class":3669},"            }\n",[3402,6296,6297],{"class":3404,"line":5096},[3402,6298,5260],{"class":3669},[3402,6300,6301],{"class":3404,"line":5101},[3402,6302,3821],{"class":3669},[3402,6304,6305],{"class":3404,"line":5132},[3402,6306,3497],{"class":3669},[3864,6308,6310],{"id":6309},"_2-контролер-aspnet-core-для-server-sent-events","2. Контролер ASP.NET Core для Server-Sent Events",[3353,6312,6313],{},"Створюємо API-ендпоінт, який ретранслює потік токенів клієнту через протокол Server-Sent Events (SSE).",[3392,6315,6318],{"className":3880,"code":6316,"filename":6317,"language":3883,"meta":3397,"style":3397},"using Microsoft.AspNetCore.Mvc;\nusing AwsAiPlayground.Services;\n\nnamespace AwsAiPlayground.Controllers;\n\n[ApiController]\n[Route(\"api\u002F[controller]\")]\npublic sealed class ChatController : ControllerBase\n{\n    private readonly BedrockStreamingService _streamingService;\n\n    public ChatController(BedrockStreamingService streamingService)\n    {\n        _streamingService = streamingService;\n    }\n\n    [HttpPost(\"stream\")]\n    public async Task StreamChat([FromBody] List\u003CChatMessage> history, CancellationToken cancellationToken)\n    {\n        Response.Headers.Append(\"Content-Type\", \"text\u002Fevent-stream\");\n        Response.Headers.Append(\"Cache-Control\", \"no-cache\");\n        Response.Headers.Append(\"Connection\", \"keep-alive\");\n\n        const string systemPrompt = \"Ти професійний розробник ПЗ. Відповідай українською мовою лаконічно.\";\n\n        try\n        {\n            await foreach (var chunk in _streamingService.StreamClaudeResponseAsync(history, systemPrompt, cancellationToken))\n            {\n                \u002F\u002F Записуємо чанк у форматі SSE: data: \u003Ccontent>\\n\\n\n                var data = JsonSerializer.Serialize(new { text = chunk });\n                await Response.WriteAsync($\"data: {data}\\n\\n\", cancellationToken);\n                await Response.Body.FlushAsync(cancellationToken);\n            }\n            \n            await Response.WriteAsync(\"data: [DONE]\\n\\n\", cancellationToken);\n            await Response.Body.FlushAsync(cancellationToken);\n        }\n        catch (OperationCanceledException)\n        {\n            \u002F\u002F Клієнт розірвав з'єднання, завершуємо роботу\n        }\n    }\n}\n","Controllers\u002FChatController.cs",[3399,6319,6320,6339,6351,6355,6368,6372,6383,6398,6415,6419,6432,6436,6452,6456,6468,6472,6476,6490,6528,6532,6559,6583,6607,6611,6628,6632,6636,6640,6677,6681,6686,6718,6755,6776,6780,6785,6810,6830,6834,6845,6849,6854,6858,6862],{"__ignoreMap":3397},[3402,6321,6322,6324,6327,6329,6332,6334,6337],{"class":3404,"line":3405},[3402,6323,3891],{"class":3890},[3402,6325,6326],{"class":3894}," Microsoft",[3402,6328,3654],{"class":3669},[3402,6330,6331],{"class":3894},"AspNetCore",[3402,6333,3654],{"class":3669},[3402,6335,6336],{"class":3894},"Mvc",[3402,6338,3903],{"class":3669},[3402,6340,6341,6343,6345,6347,6349],{"class":3404,"line":3411},[3402,6342,3891],{"class":3890},[3402,6344,3984],{"class":3894},[3402,6346,3654],{"class":3669},[3402,6348,3989],{"class":3894},[3402,6350,3903],{"class":3669},[3402,6352,6353],{"class":3404,"line":3417},[3402,6354,3427],{"emptyLinePlaceholder":3426},[3402,6356,6357,6359,6361,6363,6366],{"class":3404,"line":3423},[3402,6358,3981],{"class":3980},[3402,6360,3984],{"class":3894},[3402,6362,3654],{"class":3669},[3402,6364,6365],{"class":3894},"Controllers",[3402,6367,3903],{"class":3669},[3402,6369,6370],{"class":3404,"line":3430},[3402,6371,3427],{"emptyLinePlaceholder":3426},[3402,6373,6374,6377,6380],{"class":3404,"line":3436},[3402,6375,6376],{"class":3669},"[",[3402,6378,6379],{"class":3894},"ApiController",[3402,6381,6382],{"class":3669},"]\n",[3402,6384,6385,6387,6390,6392,6395],{"class":3404,"line":3441},[3402,6386,6376],{"class":3669},[3402,6388,6389],{"class":3894},"Route",[3402,6391,4025],{"class":3669},[3402,6393,6394],{"class":3682},"\"api\u002F[controller]\"",[3402,6396,6397],{"class":3669},")]\n",[3402,6399,6400,6402,6404,6406,6409,6412],{"class":3404,"line":3447},[3402,6401,4000],{"class":3980},[3402,6403,4530],{"class":3980},[3402,6405,4533],{"class":3980},[3402,6407,6408],{"class":3894}," ChatController",[3402,6410,6411],{"class":3669}," : ",[3402,6413,6414],{"class":3894},"ControllerBase\n",[3402,6416,6417],{"class":3404,"line":3453},[3402,6418,3670],{"class":3669},[3402,6420,6421,6423,6425,6427,6430],{"class":3404,"line":3459},[3402,6422,4547],{"class":3980},[3402,6424,4550],{"class":3980},[3402,6426,5510],{"class":3894},[3402,6428,6429],{"class":4037}," _streamingService",[3402,6431,3903],{"class":3669},[3402,6433,6434],{"class":3404,"line":3465},[3402,6435,3427],{"emptyLinePlaceholder":3426},[3402,6437,6438,6440,6442,6444,6447,6450],{"class":3404,"line":3470},[3402,6439,4591],{"class":3980},[3402,6441,6408],{"class":3852},[3402,6443,4025],{"class":3669},[3402,6445,6446],{"class":3894},"BedrockStreamingService",[3402,6448,6449],{"class":4037}," streamingService",[3402,6451,4605],{"class":3669},[3402,6453,6454],{"class":3404,"line":3476},[3402,6455,3699],{"class":3669},[3402,6457,6458,6461,6463,6466],{"class":3404,"line":3482},[3402,6459,6460],{"class":4037},"        _streamingService",[3402,6462,4575],{"class":3669},[3402,6464,6465],{"class":4037},"streamingService",[3402,6467,3903],{"class":3669},[3402,6469,6470],{"class":3404,"line":3488},[3402,6471,3821],{"class":3669},[3402,6473,6474],{"class":3404,"line":3494},[3402,6475,3427],{"emptyLinePlaceholder":3426},[3402,6477,6478,6480,6483,6485,6488],{"class":3404,"line":3500},[3402,6479,4014],{"class":3669},[3402,6481,6482],{"class":3894},"HttpPost",[3402,6484,4025],{"class":3669},[3402,6486,6487],{"class":3682},"\"stream\"",[3402,6489,6397],{"class":3669},[3402,6491,6492,6494,6496,6498,6501,6504,6507,6509,6511,6513,6515,6517,6520,6522,6524,6526],{"class":3404,"line":3505},[3402,6493,4591],{"class":3980},[3402,6495,4676],{"class":3980},[3402,6497,4679],{"class":3894},[3402,6499,6500],{"class":3852}," StreamChat",[3402,6502,6503],{"class":3669},"([",[3402,6505,6506],{"class":3894},"FromBody",[3402,6508,5627],{"class":3669},[3402,6510,4060],{"class":3894},[3402,6512,4063],{"class":3669},[3402,6514,4278],{"class":3894},[3402,6516,4069],{"class":3669},[3402,6518,6519],{"class":4037},"history",[3402,6521,4698],{"class":3669},[3402,6523,5630],{"class":3894},[3402,6525,5633],{"class":4037},[3402,6527,4605],{"class":3669},[3402,6529,6530],{"class":3404,"line":3511},[3402,6531,3699],{"class":3669},[3402,6533,6534,6537,6539,6542,6544,6547,6549,6552,6554,6557],{"class":3404,"line":3517},[3402,6535,6536],{"class":4037},"        Response",[3402,6538,3654],{"class":3669},[3402,6540,6541],{"class":4037},"Headers",[3402,6543,3654],{"class":3669},[3402,6545,6546],{"class":3852},"Append",[3402,6548,4025],{"class":3669},[3402,6550,6551],{"class":3682},"\"Content-Type\"",[3402,6553,4698],{"class":3669},[3402,6555,6556],{"class":3682},"\"text\u002Fevent-stream\"",[3402,6558,4075],{"class":3669},[3402,6560,6561,6563,6565,6567,6569,6571,6573,6576,6578,6581],{"class":3404,"line":3523},[3402,6562,6536],{"class":4037},[3402,6564,3654],{"class":3669},[3402,6566,6541],{"class":4037},[3402,6568,3654],{"class":3669},[3402,6570,6546],{"class":3852},[3402,6572,4025],{"class":3669},[3402,6574,6575],{"class":3682},"\"Cache-Control\"",[3402,6577,4698],{"class":3669},[3402,6579,6580],{"class":3682},"\"no-cache\"",[3402,6582,4075],{"class":3669},[3402,6584,6585,6587,6589,6591,6593,6595,6597,6600,6602,6605],{"class":3404,"line":3529},[3402,6586,6536],{"class":4037},[3402,6588,3654],{"class":3669},[3402,6590,6541],{"class":4037},[3402,6592,3654],{"class":3669},[3402,6594,6546],{"class":3852},[3402,6596,4025],{"class":3669},[3402,6598,6599],{"class":3682},"\"Connection\"",[3402,6601,4698],{"class":3669},[3402,6603,6604],{"class":3682},"\"keep-alive\"",[3402,6606,4075],{"class":3669},[3402,6608,6609],{"class":3404,"line":3535},[3402,6610,3427],{"emptyLinePlaceholder":3426},[3402,6612,6613,6616,6618,6621,6623,6626],{"class":3404,"line":3541},[3402,6614,6615],{"class":3980},"        const",[3402,6617,4569],{"class":3980},[3402,6619,6620],{"class":4037}," systemPrompt",[3402,6622,4575],{"class":3669},[3402,6624,6625],{"class":3682},"\"Ти професійний розробник ПЗ. Відповідай українською мовою лаконічно.\"",[3402,6627,3903],{"class":3669},[3402,6629,6630],{"class":3404,"line":3829},[3402,6631,3427],{"emptyLinePlaceholder":3426},[3402,6633,6634],{"class":3404,"line":4327},[3402,6635,5061],{"class":3890},[3402,6637,6638],{"class":3404,"line":4350},[3402,6639,4746],{"class":3669},[3402,6641,6642,6645,6647,6649,6651,6654,6656,6658,6660,6662,6664,6666,6668,6671,6673,6675],{"class":3404,"line":4373},[3402,6643,6644],{"class":3980},"            await",[3402,6646,5937],{"class":3890},[3402,6648,5269],{"class":3669},[3402,6650,5942],{"class":3980},[3402,6652,6653],{"class":4037}," chunk",[3402,6655,5948],{"class":3890},[3402,6657,6429],{"class":4037},[3402,6659,3654],{"class":3669},[3402,6661,5583],{"class":3852},[3402,6663,4025],{"class":3669},[3402,6665,6519],{"class":4037},[3402,6667,4698],{"class":3669},[3402,6669,6670],{"class":4037},"systemPrompt",[3402,6672,4698],{"class":3669},[3402,6674,5864],{"class":4037},[3402,6676,5045],{"class":3669},[3402,6678,6679],{"class":3404,"line":4402},[3402,6680,5995],{"class":3669},[3402,6682,6683],{"class":3404,"line":4427},[3402,6684,6685],{"class":4639},"                \u002F\u002F Записуємо чанк у форматі SSE: data: \u003Ccontent>\\n\\n\n",[3402,6687,6688,6690,6693,6695,6697,6699,6701,6703,6705,6708,6710,6712,6715],{"class":3404,"line":4453},[3402,6689,6027],{"class":4037},[3402,6691,6692],{"class":4037}," data",[3402,6694,4575],{"class":3669},[3402,6696,4929],{"class":4037},[3402,6698,3654],{"class":3669},[3402,6700,4934],{"class":3852},[3402,6702,4025],{"class":3669},[3402,6704,4731],{"class":3980},[3402,6706,6707],{"class":3669}," { ",[3402,6709,6256],{"class":4037},[3402,6711,4575],{"class":3669},[3402,6713,6714],{"class":4037},"chunk",[3402,6716,6717],{"class":3669}," });\n",[3402,6719,6720,6723,6726,6728,6731,6733,6736,6738,6741,6743,6747,6749,6751,6753],{"class":3404,"line":4458},[3402,6721,6722],{"class":3980},"                await",[3402,6724,6725],{"class":4037}," Response",[3402,6727,3654],{"class":3669},[3402,6729,6730],{"class":3852},"WriteAsync",[3402,6732,4025],{"class":3669},[3402,6734,6735],{"class":3682},"$\"data: ",[3402,6737,5308],{"class":5307},[3402,6739,6740],{"class":4037},"data",[3402,6742,5319],{"class":5307},[3402,6744,6746],{"class":6745},"sjcCO","\\n\\n",[3402,6748,5322],{"class":3682},[3402,6750,4698],{"class":3669},[3402,6752,5864],{"class":4037},[3402,6754,4075],{"class":3669},[3402,6756,6757,6759,6761,6763,6765,6767,6770,6772,6774],{"class":3404,"line":4470},[3402,6758,6722],{"class":3980},[3402,6760,6725],{"class":4037},[3402,6762,3654],{"class":3669},[3402,6764,5127],{"class":4037},[3402,6766,3654],{"class":3669},[3402,6768,6769],{"class":3852},"FlushAsync",[3402,6771,4025],{"class":3669},[3402,6773,5864],{"class":4037},[3402,6775,4075],{"class":3669},[3402,6777,6778],{"class":3404,"line":4495},[3402,6779,6294],{"class":3669},[3402,6781,6782],{"class":3404,"line":4520},[3402,6783,6784],{"class":3669},"            \n",[3402,6786,6787,6789,6791,6793,6795,6797,6800,6802,6804,6806,6808],{"class":3404,"line":4525},[3402,6788,6644],{"class":3980},[3402,6790,6725],{"class":4037},[3402,6792,3654],{"class":3669},[3402,6794,6730],{"class":3852},[3402,6796,4025],{"class":3669},[3402,6798,6799],{"class":3682},"\"data: [DONE]",[3402,6801,6746],{"class":6745},[3402,6803,5322],{"class":3682},[3402,6805,4698],{"class":3669},[3402,6807,5864],{"class":4037},[3402,6809,4075],{"class":3669},[3402,6811,6812,6814,6816,6818,6820,6822,6824,6826,6828],{"class":3404,"line":4539},[3402,6813,6644],{"class":3980},[3402,6815,6725],{"class":4037},[3402,6817,3654],{"class":3669},[3402,6819,5127],{"class":4037},[3402,6821,3654],{"class":3669},[3402,6823,6769],{"class":3852},[3402,6825,4025],{"class":3669},[3402,6827,5864],{"class":4037},[3402,6829,4075],{"class":3669},[3402,6831,6832],{"class":3404,"line":4544},[3402,6833,5260],{"class":3669},[3402,6835,6836,6838,6840,6843],{"class":3404,"line":4561},[3402,6837,5266],{"class":3890},[3402,6839,5269],{"class":3669},[3402,6841,6842],{"class":3894},"OperationCanceledException",[3402,6844,4605],{"class":3669},[3402,6846,6847],{"class":3404,"line":4583},[3402,6848,4746],{"class":3669},[3402,6850,6851],{"class":3404,"line":4588},[3402,6852,6853],{"class":4639},"            \u002F\u002F Клієнт розірвав з'єднання, завершуємо роботу\n",[3402,6855,6856],{"class":3404,"line":4608},[3402,6857,5260],{"class":3669},[3402,6859,6860],{"class":3404,"line":4613},[3402,6861,3821],{"class":3669},[3402,6863,6864],{"class":3404,"line":4626},[3402,6865,3497],{"class":3669},[3864,6867,6869],{"id":6868},"_3-реєстрація-залежностей-у-programcs","3. Реєстрація залежностей у Program.cs",[3353,6871,6872],{},"Переконайтеся, що сервіси та AWS клієнт правильно налаштовані в контейнері залежностей ASP.NET Core:",[3392,6874,6877],{"className":3880,"code":6875,"filename":6876,"language":3883,"meta":3397,"style":3397},"using Amazon.BedrockRuntime;\nusing AwsAiPlayground.Services;\n\nvar builder = WebApplication.CreateBuilder(args);\n\nbuilder.Services.AddControllers();\n\n\u002F\u002F Реєструємо клієнт Bedrock Runtime із регіоном us-east-1\nbuilder.Services.AddSingleton\u003CIAmazonBedrockRuntime>(sp => \n    new AmazonBedrockRuntimeClient(Amazon.RegionEndpoint.USEast1));\n\nbuilder.Services.AddSingleton\u003CBedrockClaudeService>();\nbuilder.Services.AddSingleton\u003CBedrockStreamingService>();\n\n\u002F\u002F Дозволяємо CORS для локального React розробницького серверу\nbuilder.Services.AddCors(options =>\n{\n    options.AddPolicy(\"CorsPolicy\", policy =>\n    {\n        policy.WithOrigins(\"http:\u002F\u002Flocalhost:5173\")\n              .AllowAnyHeader()\n              .AllowAnyMethod()\n              .AllowCredentials();\n    });\n});\n\nvar app = builder.Build();\n\napp.UseCors(\"CorsPolicy\");\napp.MapControllers();\napp.Run();\n","Program.cs",[3399,6878,6879,6891,6903,6907,6931,6935,6951,6955,6960,6985,7011,7015,7035,7053,7057,7062,7083,7087,7109,7113,7130,7141,7150,7159,7164,7169,7173,7191,7195,7211,7222],{"__ignoreMap":3397},[3402,6880,6881,6883,6885,6887,6889],{"class":3404,"line":3405},[3402,6882,3891],{"class":3890},[3402,6884,3621],{"class":3894},[3402,6886,3654],{"class":3669},[3402,6888,3952],{"class":3894},[3402,6890,3903],{"class":3669},[3402,6892,6893,6895,6897,6899,6901],{"class":3404,"line":3411},[3402,6894,3891],{"class":3890},[3402,6896,3984],{"class":3894},[3402,6898,3654],{"class":3669},[3402,6900,3989],{"class":3894},[3402,6902,3903],{"class":3669},[3402,6904,6905],{"class":3404,"line":3417},[3402,6906,3427],{"emptyLinePlaceholder":3426},[3402,6908,6909,6911,6914,6916,6919,6921,6924,6926,6929],{"class":3404,"line":3423},[3402,6910,5942],{"class":3980},[3402,6912,6913],{"class":4037}," builder",[3402,6915,4575],{"class":3669},[3402,6917,6918],{"class":4037},"WebApplication",[3402,6920,3654],{"class":3669},[3402,6922,6923],{"class":3852},"CreateBuilder",[3402,6925,4025],{"class":3669},[3402,6927,6928],{"class":4037},"args",[3402,6930,4075],{"class":3669},[3402,6932,6933],{"class":3404,"line":3430},[3402,6934,3427],{"emptyLinePlaceholder":3426},[3402,6936,6937,6940,6942,6944,6946,6949],{"class":3404,"line":3436},[3402,6938,6939],{"class":4037},"builder",[3402,6941,3654],{"class":3669},[3402,6943,3989],{"class":4037},[3402,6945,3654],{"class":3669},[3402,6947,6948],{"class":3852},"AddControllers",[3402,6950,5151],{"class":3669},[3402,6952,6953],{"class":3404,"line":3441},[3402,6954,3427],{"emptyLinePlaceholder":3426},[3402,6956,6957],{"class":3404,"line":3447},[3402,6958,6959],{"class":4639},"\u002F\u002F Реєструємо клієнт Bedrock Runtime із регіоном us-east-1\n",[3402,6961,6962,6964,6966,6968,6970,6973,6975,6977,6979,6982],{"class":3404,"line":3453},[3402,6963,6939],{"class":4037},[3402,6965,3654],{"class":3669},[3402,6967,3989],{"class":4037},[3402,6969,3654],{"class":3669},[3402,6971,6972],{"class":3852},"AddSingleton",[3402,6974,4063],{"class":3669},[3402,6976,4599],{"class":3894},[3402,6978,5181],{"class":3669},[3402,6980,6981],{"class":4037},"sp",[3402,6983,6984],{"class":3669}," => \n",[3402,6986,6987,6990,6993,6995,6998,7000,7003,7005,7008],{"class":3404,"line":3459},[3402,6988,6989],{"class":3980},"    new",[3402,6991,6992],{"class":3894}," AmazonBedrockRuntimeClient",[3402,6994,4025],{"class":3669},[3402,6996,6997],{"class":4037},"Amazon",[3402,6999,3654],{"class":3669},[3402,7001,7002],{"class":4037},"RegionEndpoint",[3402,7004,3654],{"class":3669},[3402,7006,7007],{"class":4037},"USEast1",[3402,7009,7010],{"class":3669},"));\n",[3402,7012,7013],{"class":3404,"line":3465},[3402,7014,3427],{"emptyLinePlaceholder":3426},[3402,7016,7017,7019,7021,7023,7025,7027,7029,7032],{"class":3404,"line":3470},[3402,7018,6939],{"class":4037},[3402,7020,3654],{"class":3669},[3402,7022,3989],{"class":4037},[3402,7024,3654],{"class":3669},[3402,7026,6972],{"class":3852},[3402,7028,4063],{"class":3669},[3402,7030,7031],{"class":3894},"BedrockClaudeService",[3402,7033,7034],{"class":3669},">();\n",[3402,7036,7037,7039,7041,7043,7045,7047,7049,7051],{"class":3404,"line":3476},[3402,7038,6939],{"class":4037},[3402,7040,3654],{"class":3669},[3402,7042,3989],{"class":4037},[3402,7044,3654],{"class":3669},[3402,7046,6972],{"class":3852},[3402,7048,4063],{"class":3669},[3402,7050,6446],{"class":3894},[3402,7052,7034],{"class":3669},[3402,7054,7055],{"class":3404,"line":3482},[3402,7056,3427],{"emptyLinePlaceholder":3426},[3402,7058,7059],{"class":3404,"line":3488},[3402,7060,7061],{"class":4639},"\u002F\u002F Дозволяємо CORS для локального React розробницького серверу\n",[3402,7063,7064,7066,7068,7070,7072,7075,7077,7080],{"class":3404,"line":3494},[3402,7065,6939],{"class":4037},[3402,7067,3654],{"class":3669},[3402,7069,3989],{"class":4037},[3402,7071,3654],{"class":3669},[3402,7073,7074],{"class":3852},"AddCors",[3402,7076,4025],{"class":3669},[3402,7078,7079],{"class":4037},"options",[3402,7081,7082],{"class":3669}," =>\n",[3402,7084,7085],{"class":3404,"line":3500},[3402,7086,3670],{"class":3669},[3402,7088,7089,7092,7094,7097,7099,7102,7104,7107],{"class":3404,"line":3505},[3402,7090,7091],{"class":4037},"    options",[3402,7093,3654],{"class":3669},[3402,7095,7096],{"class":3852},"AddPolicy",[3402,7098,4025],{"class":3669},[3402,7100,7101],{"class":3682},"\"CorsPolicy\"",[3402,7103,4698],{"class":3669},[3402,7105,7106],{"class":4037},"policy",[3402,7108,7082],{"class":3669},[3402,7110,7111],{"class":3404,"line":3511},[3402,7112,3699],{"class":3669},[3402,7114,7115,7118,7120,7123,7125,7128],{"class":3404,"line":3517},[3402,7116,7117],{"class":4037},"        policy",[3402,7119,3654],{"class":3669},[3402,7121,7122],{"class":3852},"WithOrigins",[3402,7124,4025],{"class":3669},[3402,7126,7127],{"class":3682},"\"http:\u002F\u002Flocalhost:5173\"",[3402,7129,4605],{"class":3669},[3402,7131,7132,7135,7138],{"class":3404,"line":3523},[3402,7133,7134],{"class":3669},"              .",[3402,7136,7137],{"class":3852},"AllowAnyHeader",[3402,7139,7140],{"class":3669},"()\n",[3402,7142,7143,7145,7148],{"class":3404,"line":3529},[3402,7144,7134],{"class":3669},[3402,7146,7147],{"class":3852},"AllowAnyMethod",[3402,7149,7140],{"class":3669},[3402,7151,7152,7154,7157],{"class":3404,"line":3535},[3402,7153,7134],{"class":3669},[3402,7155,7156],{"class":3852},"AllowCredentials",[3402,7158,5151],{"class":3669},[3402,7160,7161],{"class":3404,"line":3541},[3402,7162,7163],{"class":3669},"    });\n",[3402,7165,7166],{"class":3404,"line":3829},[3402,7167,7168],{"class":3669},"});\n",[3402,7170,7171],{"class":3404,"line":4327},[3402,7172,3427],{"emptyLinePlaceholder":3426},[3402,7174,7175,7177,7180,7182,7184,7186,7189],{"class":3404,"line":4350},[3402,7176,5942],{"class":3980},[3402,7178,7179],{"class":4037}," app",[3402,7181,4575],{"class":3669},[3402,7183,6939],{"class":4037},[3402,7185,3654],{"class":3669},[3402,7187,7188],{"class":3852},"Build",[3402,7190,5151],{"class":3669},[3402,7192,7193],{"class":3404,"line":4373},[3402,7194,3427],{"emptyLinePlaceholder":3426},[3402,7196,7197,7200,7202,7205,7207,7209],{"class":3404,"line":4402},[3402,7198,7199],{"class":4037},"app",[3402,7201,3654],{"class":3669},[3402,7203,7204],{"class":3852},"UseCors",[3402,7206,4025],{"class":3669},[3402,7208,7101],{"class":3682},[3402,7210,4075],{"class":3669},[3402,7212,7213,7215,7217,7220],{"class":3404,"line":4427},[3402,7214,7199],{"class":4037},[3402,7216,3654],{"class":3669},[3402,7218,7219],{"class":3852},"MapControllers",[3402,7221,5151],{"class":3669},[3402,7223,7224,7226,7228,7231],{"class":3404,"line":4453},[3402,7225,7199],{"class":4037},[3402,7227,3654],{"class":3669},[3402,7229,7230],{"class":3852},"Run",[3402,7232,5151],{"class":3669},[3546,7234],{},[3348,7236,7238],{"id":7237},"react-chat-ui-з-підтримкою-sse","React Chat UI з підтримкою SSE",[3353,7240,7241],{},"Створимо сучасний інтерфейс чату на React із використанням кастомного хука для обробки потокових даних.",[3864,7243,7245],{"id":7244},"_1-кастомний-хук-для-стрімінгу","1. Кастомний хук для стрімінгу",[3392,7247,7252],{"className":7248,"code":7249,"filename":7250,"language":7251,"meta":3397,"style":3397},"language-typescript shiki shiki-themes light-plus dark-plus dark-plus","import { useState, useCallback, useRef } from 'react';\n\nexport interface ChatMessageDto {\n  role: 'user' | 'assistant';\n  content: { type: 'text'; text: string }[];\n}\n\nexport interface UIResponse {\n  id: string;\n  role: 'user' | 'assistant';\n  text: string;\n}\n\nexport function useStreamingChat(apiUrl: string) {\n  const [messages, setMessages] = useState\u003CUIResponse[]>([]);\n  const [isGenerating, setIsGenerating] = useState(false);\n  const abortControllerRef = useRef\u003CAbortController | null>(null);\n\n  const sendMessage = useCallback(async (userText: string) => {\n    if (!userText.trim()) return;\n\n    const userMsg: UIResponse = {\n      id: crypto.randomUUID(),\n      role: 'user',\n      text: userText,\n    };\n\n    const assistantMsgId = crypto.randomUUID();\n    const assistantMsgPlaceholder: UIResponse = {\n      id: assistantMsgId,\n      role: 'assistant',\n      text: '',\n    };\n\n    setMessages((prev) => [...prev, userMsg, assistantMsgPlaceholder]);\n    setIsGenerating(true);\n\n    abortControllerRef.current = new AbortController();\n\n    \u002F\u002F Формуємо історію відповідно до формату Claude Messages API\n    const historyPayload: ChatMessageDto[] = [\n      ...messages.map((m) => ({\n        role: m.role,\n        content: [{ type: 'text' as const, text: m.text }],\n      })),\n      { role: 'user', content: [{ type: 'text' as const, text: userText }] },\n    ];\n\n    try {\n      const response = await fetch(apiUrl, {\n        method: 'POST',\n        headers: { 'Content-Type': 'application\u002Fjson' },\n        body: JSON.stringify(historyPayload),\n        signal: abortControllerRef.current.signal,\n      });\n\n      if (!response.ok || !response.body) {\n        throw new Error('Не вдалося розпочати потік відповідей.');\n      }\n\n      const reader = response.body.getReader();\n      const decoder = new TextDecoder();\n      let buffer = '';\n\n      while (true) {\n        const { done, value } = await reader.read();\n        if (done) break;\n\n        buffer += decoder.decode(value, { stream: true });\n        const lines = buffer.split('\\n');\n        buffer = lines.pop() ?? ''; \u002F\u002F Залишаємо неповний рядок у буфері\n\n        for (const line of lines) {\n          const cleanLine = line.trim();\n          if (!cleanLine.startsWith('data: ')) continue;\n          \n          const rawData = cleanLine.substring(6).trim();\n          if (rawData === '[DONE]') {\n            setIsGenerating(false);\n            return;\n          }\n\n          try {\n            const parsed = JSON.parse(rawData) as { text: string };\n            setMessages((prev) =>\n              prev.map((m) =>\n                m.id === assistantMsgId ? { ...m, text: m.text + parsed.text } : m\n              )\n            );\n          } catch {\n            \u002F\u002F Ігноруємо пошкоджені JSON-пакети\n          }\n        }\n      }\n    } catch (error) {\n      if ((error as Error).name !== 'AbortError') {\n        setMessages((prev) =>\n          prev.map((m) =>\n            m.id === assistantMsgId ? { ...m, text: 'Сталася помилка під час генерації відповіді.' } : m\n          )\n        );\n      }\n      setIsGenerating(false);\n    }\n  }, [messages, apiUrl]);\n\n  const stopGeneration = useCallback(() => {\n    if (abortControllerRef.current) {\n      abortControllerRef.current.abort();\n      setIsGenerating(false);\n    }\n  }, []);\n\n  const clearChat = useCallback(() => {\n    stopGeneration();\n    setMessages([]);\n  }, [stopGeneration]);\n\n  return { messages, isGenerating, sendMessage, stopGeneration, clearChat };\n}\n","src\u002Fhooks\u002FuseStreamingChat.ts","typescript",[3399,7253,7254,7285,7289,7303,7321,7349,7353,7357,7368,7379,7393,7404,7408,7412,7434,7464,7489,7515,7519,7552,7574,7578,7593,7609,7619,7629,7634,7638,7656,7669,7677,7686,7695,7699,7703,7736,7748,7752,7771,7775,7780,7795,7819,7834,7867,7872,7906,7911,7915,7922,7943,7953,7972,7993,8011,8016,8020,8046,8063,8068,8072,8093,8109,8124,8128,8139,8167,8183,8187,8218,8247,8271,8275,8295,8313,8341,8346,8374,8391,8402,8408,8413,8417,8424,8462,8476,8493,8539,8544,8549,8559,8564,8568,8572,8576,8590,8617,8631,8649,8678,8684,8689,8694,8706,8711,8725,8730,8749,8765,8782,8793,8798,8804,8809,8827,8835,8843,8853,8858,8888],{"__ignoreMap":3397},[3402,7255,7256,7259,7261,7264,7266,7269,7271,7274,7277,7280,7283],{"class":3404,"line":3405},[3402,7257,7258],{"class":3890},"import",[3402,7260,6707],{"class":3669},[3402,7262,7263],{"class":4037},"useState",[3402,7265,4698],{"class":3669},[3402,7267,7268],{"class":4037},"useCallback",[3402,7270,4698],{"class":3669},[3402,7272,7273],{"class":4037},"useRef",[3402,7275,7276],{"class":3669}," } ",[3402,7278,7279],{"class":3890},"from",[3402,7281,7282],{"class":3682}," 'react'",[3402,7284,3903],{"class":3669},[3402,7286,7287],{"class":3404,"line":3411},[3402,7288,3427],{"emptyLinePlaceholder":3426},[3402,7290,7291,7294,7297,7300],{"class":3404,"line":3417},[3402,7292,7293],{"class":3890},"export",[3402,7295,7296],{"class":3980}," interface",[3402,7298,7299],{"class":3894}," ChatMessageDto",[3402,7301,7302],{"class":3669}," {\n",[3402,7304,7305,7308,7310,7313,7316,7319],{"class":3404,"line":3423},[3402,7306,7307],{"class":4037},"  role",[3402,7309,3679],{"class":3669},[3402,7311,7312],{"class":3682},"'user'",[3402,7314,7315],{"class":3669}," | ",[3402,7317,7318],{"class":3682},"'assistant'",[3402,7320,3903],{"class":3669},[3402,7322,7323,7326,7329,7332,7334,7337,7340,7342,7344,7346],{"class":3404,"line":3430},[3402,7324,7325],{"class":4037},"  content",[3402,7327,7328],{"class":3669},": { ",[3402,7330,7331],{"class":4037},"type",[3402,7333,3679],{"class":3669},[3402,7335,7336],{"class":3682},"'text'",[3402,7338,7339],{"class":3669},"; ",[3402,7341,6256],{"class":4037},[3402,7343,3679],{"class":3669},[3402,7345,4034],{"class":3894},[3402,7347,7348],{"class":3669}," }[];\n",[3402,7350,7351],{"class":3404,"line":3436},[3402,7352,3497],{"class":3669},[3402,7354,7355],{"class":3404,"line":3441},[3402,7356,3427],{"emptyLinePlaceholder":3426},[3402,7358,7359,7361,7363,7366],{"class":3404,"line":3447},[3402,7360,7293],{"class":3890},[3402,7362,7296],{"class":3980},[3402,7364,7365],{"class":3894}," UIResponse",[3402,7367,7302],{"class":3669},[3402,7369,7370,7373,7375,7377],{"class":3404,"line":3453},[3402,7371,7372],{"class":4037},"  id",[3402,7374,3679],{"class":3669},[3402,7376,4034],{"class":3894},[3402,7378,3903],{"class":3669},[3402,7380,7381,7383,7385,7387,7389,7391],{"class":3404,"line":3459},[3402,7382,7307],{"class":4037},[3402,7384,3679],{"class":3669},[3402,7386,7312],{"class":3682},[3402,7388,7315],{"class":3669},[3402,7390,7318],{"class":3682},[3402,7392,3903],{"class":3669},[3402,7394,7395,7398,7400,7402],{"class":3404,"line":3465},[3402,7396,7397],{"class":4037},"  text",[3402,7399,3679],{"class":3669},[3402,7401,4034],{"class":3894},[3402,7403,3903],{"class":3669},[3402,7405,7406],{"class":3404,"line":3470},[3402,7407,3497],{"class":3669},[3402,7409,7410],{"class":3404,"line":3476},[3402,7411,3427],{"emptyLinePlaceholder":3426},[3402,7413,7414,7416,7419,7422,7424,7427,7429,7431],{"class":3404,"line":3482},[3402,7415,7293],{"class":3890},[3402,7417,7418],{"class":3980}," function",[3402,7420,7421],{"class":3852}," useStreamingChat",[3402,7423,4025],{"class":3669},[3402,7425,7426],{"class":4037},"apiUrl",[3402,7428,3679],{"class":3669},[3402,7430,4034],{"class":3894},[3402,7432,7433],{"class":3669},") {\n",[3402,7435,7436,7439,7442,7446,7448,7451,7454,7456,7458,7461],{"class":3404,"line":3488},[3402,7437,7438],{"class":3980},"  const",[3402,7440,7441],{"class":3669}," [",[3402,7443,7445],{"class":7444},"s-QsJ","messages",[3402,7447,4698],{"class":3669},[3402,7449,7450],{"class":7444},"setMessages",[3402,7452,7453],{"class":3669},"] = ",[3402,7455,7263],{"class":3852},[3402,7457,4063],{"class":3669},[3402,7459,7460],{"class":3894},"UIResponse",[3402,7462,7463],{"class":3669},"[]>([]);\n",[3402,7465,7466,7468,7470,7473,7475,7478,7480,7482,7484,7487],{"class":3404,"line":3494},[3402,7467,7438],{"class":3980},[3402,7469,7441],{"class":3669},[3402,7471,7472],{"class":7444},"isGenerating",[3402,7474,4698],{"class":3669},[3402,7476,7477],{"class":7444},"setIsGenerating",[3402,7479,7453],{"class":3669},[3402,7481,7263],{"class":3852},[3402,7483,4025],{"class":3669},[3402,7485,7486],{"class":3980},"false",[3402,7488,4075],{"class":3669},[3402,7490,7491,7493,7496,7498,7500,7502,7505,7507,7509,7511,7513],{"class":3404,"line":3500},[3402,7492,7438],{"class":3980},[3402,7494,7495],{"class":7444}," abortControllerRef",[3402,7497,4575],{"class":3669},[3402,7499,7273],{"class":3852},[3402,7501,4063],{"class":3669},[3402,7503,7504],{"class":3894},"AbortController",[3402,7506,7315],{"class":3669},[3402,7508,4710],{"class":3894},[3402,7510,5181],{"class":3669},[3402,7512,4710],{"class":3980},[3402,7514,4075],{"class":3669},[3402,7516,7517],{"class":3404,"line":3505},[3402,7518,3427],{"emptyLinePlaceholder":3426},[3402,7520,7521,7523,7526,7528,7530,7532,7535,7537,7540,7542,7544,7547,7550],{"class":3404,"line":3511},[3402,7522,7438],{"class":3980},[3402,7524,7525],{"class":7444}," sendMessage",[3402,7527,4575],{"class":3669},[3402,7529,7268],{"class":3852},[3402,7531,4025],{"class":3669},[3402,7533,7534],{"class":3980},"async",[3402,7536,5269],{"class":3669},[3402,7538,7539],{"class":4037},"userText",[3402,7541,3679],{"class":3669},[3402,7543,4034],{"class":3894},[3402,7545,7546],{"class":3669},") ",[3402,7548,7549],{"class":3980},"=>",[3402,7551,7302],{"class":3669},[3402,7553,7554,7557,7559,7561,7563,7566,7569,7572],{"class":3404,"line":3517},[3402,7555,7556],{"class":3890},"    if",[3402,7558,6244],{"class":3669},[3402,7560,7539],{"class":4037},[3402,7562,3654],{"class":3669},[3402,7564,7565],{"class":3852},"trim",[3402,7567,7568],{"class":3669},"()) ",[3402,7570,7571],{"class":3890},"return",[3402,7573,3903],{"class":3669},[3402,7575,7576],{"class":3404,"line":3523},[3402,7577,3427],{"emptyLinePlaceholder":3426},[3402,7579,7580,7583,7586,7588,7590],{"class":3404,"line":3529},[3402,7581,7582],{"class":3980},"    const",[3402,7584,7585],{"class":7444}," userMsg",[3402,7587,3679],{"class":3669},[3402,7589,7460],{"class":3894},[3402,7591,7592],{"class":3669}," = {\n",[3402,7594,7595,7598,7601,7603,7606],{"class":3404,"line":3535},[3402,7596,7597],{"class":4037},"      id:",[3402,7599,7600],{"class":4037}," crypto",[3402,7602,3654],{"class":3669},[3402,7604,7605],{"class":3852},"randomUUID",[3402,7607,7608],{"class":3669},"(),\n",[3402,7610,7611,7614,7617],{"class":3404,"line":3541},[3402,7612,7613],{"class":4037},"      role:",[3402,7615,7616],{"class":3682}," 'user'",[3402,7618,3686],{"class":3669},[3402,7620,7621,7624,7627],{"class":3404,"line":3829},[3402,7622,7623],{"class":4037},"      text:",[3402,7625,7626],{"class":4037}," userText",[3402,7628,3686],{"class":3669},[3402,7630,7631],{"class":3404,"line":4327},[3402,7632,7633],{"class":3669},"    };\n",[3402,7635,7636],{"class":3404,"line":4350},[3402,7637,3427],{"emptyLinePlaceholder":3426},[3402,7639,7640,7642,7645,7647,7650,7652,7654],{"class":3404,"line":4373},[3402,7641,7582],{"class":3980},[3402,7643,7644],{"class":7444}," assistantMsgId",[3402,7646,4575],{"class":3669},[3402,7648,7649],{"class":4037},"crypto",[3402,7651,3654],{"class":3669},[3402,7653,7605],{"class":3852},[3402,7655,5151],{"class":3669},[3402,7657,7658,7660,7663,7665,7667],{"class":3404,"line":4402},[3402,7659,7582],{"class":3980},[3402,7661,7662],{"class":7444}," assistantMsgPlaceholder",[3402,7664,3679],{"class":3669},[3402,7666,7460],{"class":3894},[3402,7668,7592],{"class":3669},[3402,7670,7671,7673,7675],{"class":3404,"line":4427},[3402,7672,7597],{"class":4037},[3402,7674,7644],{"class":4037},[3402,7676,3686],{"class":3669},[3402,7678,7679,7681,7684],{"class":3404,"line":4453},[3402,7680,7613],{"class":4037},[3402,7682,7683],{"class":3682}," 'assistant'",[3402,7685,3686],{"class":3669},[3402,7687,7688,7690,7693],{"class":3404,"line":4458},[3402,7689,7623],{"class":4037},[3402,7691,7692],{"class":3682}," ''",[3402,7694,3686],{"class":3669},[3402,7696,7697],{"class":3404,"line":4470},[3402,7698,7633],{"class":3669},[3402,7700,7701],{"class":3404,"line":4495},[3402,7702,3427],{"emptyLinePlaceholder":3426},[3402,7704,7705,7708,7711,7714,7716,7718,7721,7723,7725,7728,7730,7733],{"class":3404,"line":4520},[3402,7706,7707],{"class":3852},"    setMessages",[3402,7709,7710],{"class":3669},"((",[3402,7712,7713],{"class":4037},"prev",[3402,7715,7546],{"class":3669},[3402,7717,7549],{"class":3980},[3402,7719,7720],{"class":3669}," [...",[3402,7722,7713],{"class":4037},[3402,7724,4698],{"class":3669},[3402,7726,7727],{"class":4037},"userMsg",[3402,7729,4698],{"class":3669},[3402,7731,7732],{"class":4037},"assistantMsgPlaceholder",[3402,7734,7735],{"class":3669},"]);\n",[3402,7737,7738,7741,7743,7746],{"class":3404,"line":4525},[3402,7739,7740],{"class":3852},"    setIsGenerating",[3402,7742,4025],{"class":3669},[3402,7744,7745],{"class":3980},"true",[3402,7747,4075],{"class":3669},[3402,7749,7750],{"class":3404,"line":4539},[3402,7751,3427],{"emptyLinePlaceholder":3426},[3402,7753,7754,7757,7759,7762,7764,7766,7769],{"class":3404,"line":4544},[3402,7755,7756],{"class":4037},"    abortControllerRef",[3402,7758,3654],{"class":3669},[3402,7760,7761],{"class":4037},"current",[3402,7763,4575],{"class":3669},[3402,7765,4731],{"class":3980},[3402,7767,7768],{"class":3852}," AbortController",[3402,7770,5151],{"class":3669},[3402,7772,7773],{"class":3404,"line":4561},[3402,7774,3427],{"emptyLinePlaceholder":3426},[3402,7776,7777],{"class":3404,"line":4583},[3402,7778,7779],{"class":4639},"    \u002F\u002F Формуємо історію відповідно до формату Claude Messages API\n",[3402,7781,7782,7784,7787,7789,7792],{"class":3404,"line":4588},[3402,7783,7582],{"class":3980},[3402,7785,7786],{"class":7444}," historyPayload",[3402,7788,3679],{"class":3669},[3402,7790,7791],{"class":3894},"ChatMessageDto",[3402,7793,7794],{"class":3669},"[] = [\n",[3402,7796,7797,7800,7802,7804,7807,7809,7812,7814,7816],{"class":3404,"line":4608},[3402,7798,7799],{"class":3669},"      ...",[3402,7801,7445],{"class":4037},[3402,7803,3654],{"class":3669},[3402,7805,7806],{"class":3852},"map",[3402,7808,7710],{"class":3669},[3402,7810,7811],{"class":4037},"m",[3402,7813,7546],{"class":3669},[3402,7815,7549],{"class":3980},[3402,7817,7818],{"class":3669}," ({\n",[3402,7820,7821,7824,7827,7829,7832],{"class":3404,"line":4613},[3402,7822,7823],{"class":4037},"        role:",[3402,7825,7826],{"class":4037}," m",[3402,7828,3654],{"class":3669},[3402,7830,7831],{"class":4037},"role",[3402,7833,3686],{"class":3669},[3402,7835,7836,7839,7842,7845,7848,7851,7853,7855,7858,7860,7862,7864],{"class":3404,"line":4626},[3402,7837,7838],{"class":4037},"        content:",[3402,7840,7841],{"class":3669}," [{ ",[3402,7843,7844],{"class":4037},"type:",[3402,7846,7847],{"class":3682}," 'text'",[3402,7849,7850],{"class":3890}," as",[3402,7852,4566],{"class":3980},[3402,7854,4698],{"class":3669},[3402,7856,7857],{"class":4037},"text:",[3402,7859,7826],{"class":4037},[3402,7861,3654],{"class":3669},[3402,7863,6256],{"class":4037},[3402,7865,7866],{"class":3669}," }],\n",[3402,7868,7869],{"class":3404,"line":4631},[3402,7870,7871],{"class":3669},"      })),\n",[3402,7873,7874,7877,7880,7882,7884,7887,7889,7891,7893,7895,7897,7899,7901,7903],{"class":3404,"line":4636},[3402,7875,7876],{"class":3669},"      { ",[3402,7878,7879],{"class":4037},"role:",[3402,7881,7616],{"class":3682},[3402,7883,4698],{"class":3669},[3402,7885,7886],{"class":4037},"content:",[3402,7888,7841],{"class":3669},[3402,7890,7844],{"class":4037},[3402,7892,7847],{"class":3682},[3402,7894,7850],{"class":3890},[3402,7896,4566],{"class":3980},[3402,7898,4698],{"class":3669},[3402,7900,7857],{"class":4037},[3402,7902,7626],{"class":4037},[3402,7904,7905],{"class":3669}," }] },\n",[3402,7907,7908],{"class":3404,"line":4653},[3402,7909,7910],{"class":3669},"    ];\n",[3402,7912,7913],{"class":3404,"line":4659},[3402,7914,3427],{"emptyLinePlaceholder":3426},[3402,7916,7917,7920],{"class":3404,"line":4671},[3402,7918,7919],{"class":3890},"    try",[3402,7921,7302],{"class":3669},[3402,7923,7924,7927,7929,7931,7933,7936,7938,7940],{"class":3404,"line":4715},[3402,7925,7926],{"class":3980},"      const",[3402,7928,5075],{"class":7444},[3402,7930,4575],{"class":3669},[3402,7932,5080],{"class":3890},[3402,7934,7935],{"class":3852}," fetch",[3402,7937,4025],{"class":3669},[3402,7939,7426],{"class":4037},[3402,7941,7942],{"class":3669},", {\n",[3402,7944,7945,7948,7951],{"class":3404,"line":4720},[3402,7946,7947],{"class":4037},"        method:",[3402,7949,7950],{"class":3682}," 'POST'",[3402,7952,3686],{"class":3669},[3402,7954,7955,7958,7960,7963,7966,7969],{"class":3404,"line":4743},[3402,7956,7957],{"class":4037},"        headers:",[3402,7959,6707],{"class":3669},[3402,7961,7962],{"class":3682},"'Content-Type'",[3402,7964,7965],{"class":4037},":",[3402,7967,7968],{"class":3682}," 'application\u002Fjson'",[3402,7970,7971],{"class":3669}," },\n",[3402,7973,7974,7977,7980,7982,7985,7987,7990],{"class":3404,"line":4749},[3402,7975,7976],{"class":4037},"        body:",[3402,7978,7979],{"class":7444}," JSON",[3402,7981,3654],{"class":3669},[3402,7983,7984],{"class":3852},"stringify",[3402,7986,4025],{"class":3669},[3402,7988,7989],{"class":4037},"historyPayload",[3402,7991,7992],{"class":3669},"),\n",[3402,7994,7995,7998,8000,8002,8004,8006,8009],{"class":3404,"line":4777},[3402,7996,7997],{"class":4037},"        signal:",[3402,7999,7495],{"class":4037},[3402,8001,3654],{"class":3669},[3402,8003,7761],{"class":4037},[3402,8005,3654],{"class":3669},[3402,8007,8008],{"class":4037},"signal",[3402,8010,3686],{"class":3669},[3402,8012,8013],{"class":3404,"line":4783},[3402,8014,8015],{"class":3669},"      });\n",[3402,8017,8018],{"class":3404,"line":4788},[3402,8019,3427],{"emptyLinePlaceholder":3426},[3402,8021,8022,8025,8027,8029,8031,8034,8037,8039,8041,8044],{"class":3404,"line":4804},[3402,8023,8024],{"class":3890},"      if",[3402,8026,6244],{"class":3669},[3402,8028,5122],{"class":4037},[3402,8030,3654],{"class":3669},[3402,8032,8033],{"class":4037},"ok",[3402,8035,8036],{"class":3669}," || !",[3402,8038,5122],{"class":4037},[3402,8040,3654],{"class":3669},[3402,8042,8043],{"class":4037},"body",[3402,8045,7433],{"class":3669},[3402,8047,8048,8051,8053,8056,8058,8061],{"class":3404,"line":4817},[3402,8049,8050],{"class":3890},"        throw",[3402,8052,5244],{"class":3980},[3402,8054,8055],{"class":3852}," Error",[3402,8057,4025],{"class":3669},[3402,8059,8060],{"class":3682},"'Не вдалося розпочати потік відповідей.'",[3402,8062,4075],{"class":3669},[3402,8064,8065],{"class":3404,"line":4831},[3402,8066,8067],{"class":3669},"      }\n",[3402,8069,8070],{"class":3404,"line":4844},[3402,8071,3427],{"emptyLinePlaceholder":3426},[3402,8073,8074,8076,8078,8080,8082,8084,8086,8088,8091],{"class":3404,"line":4856},[3402,8075,7926],{"class":3980},[3402,8077,5110],{"class":7444},[3402,8079,4575],{"class":3669},[3402,8081,5122],{"class":4037},[3402,8083,3654],{"class":3669},[3402,8085,8043],{"class":4037},[3402,8087,3654],{"class":3669},[3402,8089,8090],{"class":3852},"getReader",[3402,8092,5151],{"class":3669},[3402,8094,8095,8097,8100,8102,8104,8107],{"class":3404,"line":4867},[3402,8096,7926],{"class":3980},[3402,8098,8099],{"class":7444}," decoder",[3402,8101,4575],{"class":3669},[3402,8103,4731],{"class":3980},[3402,8105,8106],{"class":3852}," TextDecoder",[3402,8108,5151],{"class":3669},[3402,8110,8111,8114,8117,8119,8122],{"class":3404,"line":4873},[3402,8112,8113],{"class":3980},"      let",[3402,8115,8116],{"class":4037}," buffer",[3402,8118,4575],{"class":3669},[3402,8120,8121],{"class":3682},"''",[3402,8123,3903],{"class":3669},[3402,8125,8126],{"class":3404,"line":4878},[3402,8127,3427],{"emptyLinePlaceholder":3426},[3402,8129,8130,8133,8135,8137],{"class":3404,"line":4893},[3402,8131,8132],{"class":3890},"      while",[3402,8134,5269],{"class":3669},[3402,8136,7745],{"class":3980},[3402,8138,7433],{"class":3669},[3402,8140,8141,8143,8145,8148,8150,8153,8156,8158,8160,8162,8165],{"class":3404,"line":4898},[3402,8142,6615],{"class":3980},[3402,8144,6707],{"class":3669},[3402,8146,8147],{"class":7444},"done",[3402,8149,4698],{"class":3669},[3402,8151,8152],{"class":7444},"value",[3402,8154,8155],{"class":3669}," } = ",[3402,8157,5080],{"class":3890},[3402,8159,5110],{"class":4037},[3402,8161,3654],{"class":3669},[3402,8163,8164],{"class":3852},"read",[3402,8166,5151],{"class":3669},[3402,8168,8169,8172,8174,8176,8178,8181],{"class":3404,"line":4914},[3402,8170,8171],{"class":3890},"        if",[3402,8173,5269],{"class":3669},[3402,8175,8147],{"class":4037},[3402,8177,7546],{"class":3669},[3402,8179,8180],{"class":3890},"break",[3402,8182,3903],{"class":3669},[3402,8184,8185],{"class":3404,"line":4919},[3402,8186,3427],{"emptyLinePlaceholder":3426},[3402,8188,8189,8192,8195,8198,8200,8203,8205,8207,8210,8213,8216],{"class":3404,"line":4949},[3402,8190,8191],{"class":4037},"        buffer",[3402,8193,8194],{"class":3669}," += ",[3402,8196,8197],{"class":4037},"decoder",[3402,8199,3654],{"class":3669},[3402,8201,8202],{"class":3852},"decode",[3402,8204,4025],{"class":3669},[3402,8206,8152],{"class":4037},[3402,8208,8209],{"class":3669},", { ",[3402,8211,8212],{"class":4037},"stream:",[3402,8214,8215],{"class":3980}," true",[3402,8217,6717],{"class":3669},[3402,8219,8220,8222,8225,8227,8230,8232,8235,8237,8240,8243,8245],{"class":3404,"line":4954},[3402,8221,6615],{"class":3980},[3402,8223,8224],{"class":7444}," lines",[3402,8226,4575],{"class":3669},[3402,8228,8229],{"class":4037},"buffer",[3402,8231,3654],{"class":3669},[3402,8233,8234],{"class":3852},"split",[3402,8236,4025],{"class":3669},[3402,8238,8239],{"class":3682},"'",[3402,8241,8242],{"class":6745},"\\n",[3402,8244,8239],{"class":3682},[3402,8246,4075],{"class":3669},[3402,8248,8249,8251,8253,8256,8258,8261,8264,8266,8268],{"class":3404,"line":4969},[3402,8250,8191],{"class":4037},[3402,8252,4575],{"class":3669},[3402,8254,8255],{"class":4037},"lines",[3402,8257,3654],{"class":3669},[3402,8259,8260],{"class":3852},"pop",[3402,8262,8263],{"class":3669},"() ?? ",[3402,8265,8121],{"class":3682},[3402,8267,7339],{"class":3669},[3402,8269,8270],{"class":4639},"\u002F\u002F Залишаємо неповний рядок у буфері\n",[3402,8272,8273],{"class":3404,"line":4974},[3402,8274,3427],{"emptyLinePlaceholder":3426},[3402,8276,8277,8280,8282,8285,8288,8291,8293],{"class":3404,"line":4987},[3402,8278,8279],{"class":3890},"        for",[3402,8281,5269],{"class":3669},[3402,8283,8284],{"class":3980},"const",[3402,8286,8287],{"class":7444}," line",[3402,8289,8290],{"class":3980}," of",[3402,8292,8224],{"class":4037},[3402,8294,7433],{"class":3669},[3402,8296,8297,8300,8303,8305,8307,8309,8311],{"class":3404,"line":5000},[3402,8298,8299],{"class":3980},"          const",[3402,8301,8302],{"class":7444}," cleanLine",[3402,8304,4575],{"class":3669},[3402,8306,3404],{"class":4037},[3402,8308,3654],{"class":3669},[3402,8310,7565],{"class":3852},[3402,8312,5151],{"class":3669},[3402,8314,8315,8318,8320,8323,8325,8328,8330,8333,8336,8339],{"class":3404,"line":5012},[3402,8316,8317],{"class":3890},"          if",[3402,8319,6244],{"class":3669},[3402,8321,8322],{"class":4037},"cleanLine",[3402,8324,3654],{"class":3669},[3402,8326,8327],{"class":3852},"startsWith",[3402,8329,4025],{"class":3669},[3402,8331,8332],{"class":3682},"'data: '",[3402,8334,8335],{"class":3669},")) ",[3402,8337,8338],{"class":3890},"continue",[3402,8340,3903],{"class":3669},[3402,8342,8343],{"class":3404,"line":5048},[3402,8344,8345],{"class":3669},"          \n",[3402,8347,8348,8350,8353,8355,8357,8359,8362,8364,8367,8370,8372],{"class":3404,"line":5053},[3402,8349,8299],{"class":3980},[3402,8351,8352],{"class":7444}," rawData",[3402,8354,4575],{"class":3669},[3402,8356,8322],{"class":4037},[3402,8358,3654],{"class":3669},[3402,8360,8361],{"class":3852},"substring",[3402,8363,4025],{"class":3669},[3402,8365,8366],{"class":4825},"6",[3402,8368,8369],{"class":3669},").",[3402,8371,7565],{"class":3852},[3402,8373,5151],{"class":3669},[3402,8375,8376,8378,8380,8383,8386,8389],{"class":3404,"line":5058},[3402,8377,8317],{"class":3890},[3402,8379,5269],{"class":3669},[3402,8381,8382],{"class":4037},"rawData",[3402,8384,8385],{"class":3669}," === ",[3402,8387,8388],{"class":3682},"'[DONE]'",[3402,8390,7433],{"class":3669},[3402,8392,8393,8396,8398,8400],{"class":3404,"line":5064},[3402,8394,8395],{"class":3852},"            setIsGenerating",[3402,8397,4025],{"class":3669},[3402,8399,7486],{"class":3980},[3402,8401,4075],{"class":3669},[3402,8403,8404,8406],{"class":3404,"line":5069},[3402,8405,5192],{"class":3890},[3402,8407,3903],{"class":3669},[3402,8409,8410],{"class":3404,"line":5096},[3402,8411,8412],{"class":3669},"          }\n",[3402,8414,8415],{"class":3404,"line":5101},[3402,8416,3427],{"emptyLinePlaceholder":3426},[3402,8418,8419,8422],{"class":3404,"line":5132},[3402,8420,8421],{"class":3890},"          try",[3402,8423,7302],{"class":3669},[3402,8425,8426,8429,8432,8434,8437,8439,8442,8444,8446,8448,8451,8453,8455,8457,8459],{"class":3404,"line":5154},[3402,8427,8428],{"class":3980},"            const",[3402,8430,8431],{"class":7444}," parsed",[3402,8433,4575],{"class":3669},[3402,8435,8436],{"class":7444},"JSON",[3402,8438,3654],{"class":3669},[3402,8440,8441],{"class":3852},"parse",[3402,8443,4025],{"class":3669},[3402,8445,8382],{"class":4037},[3402,8447,7546],{"class":3669},[3402,8449,8450],{"class":3890},"as",[3402,8452,6707],{"class":3669},[3402,8454,6256],{"class":4037},[3402,8456,3679],{"class":3669},[3402,8458,4034],{"class":3894},[3402,8460,8461],{"class":3669}," };\n",[3402,8463,8464,8467,8469,8471,8473],{"class":3404,"line":5159},[3402,8465,8466],{"class":3852},"            setMessages",[3402,8468,7710],{"class":3669},[3402,8470,7713],{"class":4037},[3402,8472,7546],{"class":3669},[3402,8474,8475],{"class":3980},"=>\n",[3402,8477,8478,8481,8483,8485,8487,8489,8491],{"class":3404,"line":5189},[3402,8479,8480],{"class":4037},"              prev",[3402,8482,3654],{"class":3669},[3402,8484,7806],{"class":3852},[3402,8486,7710],{"class":3669},[3402,8488,7811],{"class":4037},[3402,8490,7546],{"class":3669},[3402,8492,8475],{"class":3980},[3402,8494,8495,8498,8500,8503,8505,8508,8511,8513,8515,8517,8519,8521,8523,8526,8529,8531,8533,8536],{"class":3404,"line":5235},[3402,8496,8497],{"class":4037},"                m",[3402,8499,3654],{"class":3669},[3402,8501,8502],{"class":4037},"id",[3402,8504,8385],{"class":3669},[3402,8506,8507],{"class":4037},"assistantMsgId",[3402,8509,8510],{"class":3669}," ? { ...",[3402,8512,7811],{"class":4037},[3402,8514,4698],{"class":3669},[3402,8516,7857],{"class":4037},[3402,8518,7826],{"class":4037},[3402,8520,3654],{"class":3669},[3402,8522,6256],{"class":4037},[3402,8524,8525],{"class":3669}," + ",[3402,8527,8528],{"class":4037},"parsed",[3402,8530,3654],{"class":3669},[3402,8532,6256],{"class":4037},[3402,8534,8535],{"class":3669}," } : ",[3402,8537,8538],{"class":4037},"m\n",[3402,8540,8541],{"class":3404,"line":5257},[3402,8542,8543],{"class":3669},"              )\n",[3402,8545,8546],{"class":3404,"line":5263},[3402,8547,8548],{"class":3669},"            );\n",[3402,8550,8551,8554,8557],{"class":3404,"line":5280},[3402,8552,8553],{"class":3669},"          } ",[3402,8555,8556],{"class":3890},"catch",[3402,8558,7302],{"class":3669},[3402,8560,8561],{"class":3404,"line":5285},[3402,8562,8563],{"class":4639},"            \u002F\u002F Ігноруємо пошкоджені JSON-пакети\n",[3402,8565,8566],{"class":3404,"line":5291},[3402,8567,8412],{"class":3669},[3402,8569,8570],{"class":3404,"line":5331},[3402,8571,5260],{"class":3669},[3402,8573,8574],{"class":3404,"line":5336},[3402,8575,8067],{"class":3669},[3402,8577,8578,8581,8583,8585,8588],{"class":3404,"line":5341},[3402,8579,8580],{"class":3669},"    } ",[3402,8582,8556],{"class":3890},[3402,8584,5269],{"class":3669},[3402,8586,8587],{"class":4037},"error",[3402,8589,7433],{"class":3669},[3402,8591,8593,8595,8598,8600,8602,8604,8606,8609,8612,8615],{"class":3404,"line":8592},96,[3402,8594,8024],{"class":3890},[3402,8596,8597],{"class":3669}," ((",[3402,8599,8587],{"class":4037},[3402,8601,7850],{"class":3890},[3402,8603,8055],{"class":3894},[3402,8605,8369],{"class":3669},[3402,8607,8608],{"class":4037},"name",[3402,8610,8611],{"class":3669}," !== ",[3402,8613,8614],{"class":3682},"'AbortError'",[3402,8616,7433],{"class":3669},[3402,8618,8620,8623,8625,8627,8629],{"class":3404,"line":8619},97,[3402,8621,8622],{"class":3852},"        setMessages",[3402,8624,7710],{"class":3669},[3402,8626,7713],{"class":4037},[3402,8628,7546],{"class":3669},[3402,8630,8475],{"class":3980},[3402,8632,8634,8637,8639,8641,8643,8645,8647],{"class":3404,"line":8633},98,[3402,8635,8636],{"class":4037},"          prev",[3402,8638,3654],{"class":3669},[3402,8640,7806],{"class":3852},[3402,8642,7710],{"class":3669},[3402,8644,7811],{"class":4037},[3402,8646,7546],{"class":3669},[3402,8648,8475],{"class":3980},[3402,8650,8652,8655,8657,8659,8661,8663,8665,8667,8669,8671,8674,8676],{"class":3404,"line":8651},99,[3402,8653,8654],{"class":4037},"            m",[3402,8656,3654],{"class":3669},[3402,8658,8502],{"class":4037},[3402,8660,8385],{"class":3669},[3402,8662,8507],{"class":4037},[3402,8664,8510],{"class":3669},[3402,8666,7811],{"class":4037},[3402,8668,4698],{"class":3669},[3402,8670,7857],{"class":4037},[3402,8672,8673],{"class":3682}," 'Сталася помилка під час генерації відповіді.'",[3402,8675,8535],{"class":3669},[3402,8677,8538],{"class":4037},[3402,8679,8681],{"class":3404,"line":8680},100,[3402,8682,8683],{"class":3669},"          )\n",[3402,8685,8687],{"class":3404,"line":8686},101,[3402,8688,4870],{"class":3669},[3402,8690,8692],{"class":3404,"line":8691},102,[3402,8693,8067],{"class":3669},[3402,8695,8697,8700,8702,8704],{"class":3404,"line":8696},103,[3402,8698,8699],{"class":3852},"      setIsGenerating",[3402,8701,4025],{"class":3669},[3402,8703,7486],{"class":3980},[3402,8705,4075],{"class":3669},[3402,8707,8709],{"class":3404,"line":8708},104,[3402,8710,3821],{"class":3669},[3402,8712,8714,8717,8719,8721,8723],{"class":3404,"line":8713},105,[3402,8715,8716],{"class":3669},"  }, [",[3402,8718,7445],{"class":4037},[3402,8720,4698],{"class":3669},[3402,8722,7426],{"class":4037},[3402,8724,7735],{"class":3669},[3402,8726,8728],{"class":3404,"line":8727},106,[3402,8729,3427],{"emptyLinePlaceholder":3426},[3402,8731,8733,8735,8738,8740,8742,8745,8747],{"class":3404,"line":8732},107,[3402,8734,7438],{"class":3980},[3402,8736,8737],{"class":7444}," stopGeneration",[3402,8739,4575],{"class":3669},[3402,8741,7268],{"class":3852},[3402,8743,8744],{"class":3669},"(() ",[3402,8746,7549],{"class":3980},[3402,8748,7302],{"class":3669},[3402,8750,8752,8754,8756,8759,8761,8763],{"class":3404,"line":8751},108,[3402,8753,7556],{"class":3890},[3402,8755,5269],{"class":3669},[3402,8757,8758],{"class":4037},"abortControllerRef",[3402,8760,3654],{"class":3669},[3402,8762,7761],{"class":4037},[3402,8764,7433],{"class":3669},[3402,8766,8768,8771,8773,8775,8777,8780],{"class":3404,"line":8767},109,[3402,8769,8770],{"class":4037},"      abortControllerRef",[3402,8772,3654],{"class":3669},[3402,8774,7761],{"class":4037},[3402,8776,3654],{"class":3669},[3402,8778,8779],{"class":3852},"abort",[3402,8781,5151],{"class":3669},[3402,8783,8785,8787,8789,8791],{"class":3404,"line":8784},110,[3402,8786,8699],{"class":3852},[3402,8788,4025],{"class":3669},[3402,8790,7486],{"class":3980},[3402,8792,4075],{"class":3669},[3402,8794,8796],{"class":3404,"line":8795},111,[3402,8797,3821],{"class":3669},[3402,8799,8801],{"class":3404,"line":8800},112,[3402,8802,8803],{"class":3669},"  }, []);\n",[3402,8805,8807],{"class":3404,"line":8806},113,[3402,8808,3427],{"emptyLinePlaceholder":3426},[3402,8810,8812,8814,8817,8819,8821,8823,8825],{"class":3404,"line":8811},114,[3402,8813,7438],{"class":3980},[3402,8815,8816],{"class":7444}," clearChat",[3402,8818,4575],{"class":3669},[3402,8820,7268],{"class":3852},[3402,8822,8744],{"class":3669},[3402,8824,7549],{"class":3980},[3402,8826,7302],{"class":3669},[3402,8828,8830,8833],{"class":3404,"line":8829},115,[3402,8831,8832],{"class":3852},"    stopGeneration",[3402,8834,5151],{"class":3669},[3402,8836,8838,8840],{"class":3404,"line":8837},116,[3402,8839,7707],{"class":3852},[3402,8841,8842],{"class":3669},"([]);\n",[3402,8844,8846,8848,8851],{"class":3404,"line":8845},117,[3402,8847,8716],{"class":3669},[3402,8849,8850],{"class":4037},"stopGeneration",[3402,8852,7735],{"class":3669},[3402,8854,8856],{"class":3404,"line":8855},118,[3402,8857,3427],{"emptyLinePlaceholder":3426},[3402,8859,8861,8864,8866,8868,8870,8872,8874,8877,8879,8881,8883,8886],{"class":3404,"line":8860},119,[3402,8862,8863],{"class":3890},"  return",[3402,8865,6707],{"class":3669},[3402,8867,7445],{"class":4037},[3402,8869,4698],{"class":3669},[3402,8871,7472],{"class":4037},[3402,8873,4698],{"class":3669},[3402,8875,8876],{"class":4037},"sendMessage",[3402,8878,4698],{"class":3669},[3402,8880,8850],{"class":4037},[3402,8882,4698],{"class":3669},[3402,8884,8885],{"class":4037},"clearChat",[3402,8887,8461],{"class":3669},[3402,8889,8891],{"class":3404,"line":8890},120,[3402,8892,3497],{"class":3669},[3864,8894,8896],{"id":8895},"_2-react-компонент-чат-вікна","2. React Компонент Чат-вікна",[3353,8898,8899],{},"Для рендерингу форматованого тексту (Markdown) та красивого підсвічування коду встановимо необхідні бібліотеки:",[3392,8901,8903],{"className":3843,"code":8902,"language":3845,"meta":3397,"style":3397},"npm install react-markdown remark-gfm react-syntax-highlighter\nnpm install -D @types\u002Freact-syntax-highlighter\n",[3399,8904,8905,8922],{"__ignoreMap":3397},[3402,8906,8907,8910,8913,8916,8919],{"class":3404,"line":3405},[3402,8908,8909],{"class":3852},"npm",[3402,8911,8912],{"class":3682}," install",[3402,8914,8915],{"class":3682}," react-markdown",[3402,8917,8918],{"class":3682}," remark-gfm",[3402,8920,8921],{"class":3682}," react-syntax-highlighter\n",[3402,8923,8924,8926,8928,8931],{"class":3404,"line":3411},[3402,8925,8909],{"class":3852},[3402,8927,8912],{"class":3682},[3402,8929,8930],{"class":3980}," -D",[3402,8932,8933],{"class":3682}," @types\u002Freact-syntax-highlighter\n",[3392,8935,8940],{"className":8936,"code":8937,"filename":8938,"language":8939,"meta":3397,"style":3397},"language-tsx shiki shiki-themes light-plus dark-plus dark-plus","import React, { useState, useRef, useEffect } from 'react';\nimport ReactMarkdown from 'react-markdown';\nimport remarkGfm from 'remark-gfm';\nimport { Prism as SyntaxHighlighter } from 'react-syntax-highlighter';\nimport { oneDark } from 'react-syntax-highlighter\u002Fdist\u002Fesm\u002Fstyles\u002Fprism';\nimport { useStreamingChat } from '..\u002Fhooks\u002FuseStreamingChat';\nimport '.\u002FChatWindow.css';\n\nexport function ChatWindow() {\n  const [input, setInput] = useState('');\n  const { messages, isGenerating, sendMessage, stopGeneration, clearChat } = \n    useStreamingChat('http:\u002F\u002Flocalhost:5000\u002Fapi\u002Fchat\u002Fstream');\n  \n  const bottomRef = useRef\u003CHTMLDivElement>(null);\n\n  useEffect(() => {\n    bottomRef.current?.scrollIntoView({ behavior: 'smooth' });\n  }, [messages]);\n\n  const handleSend = (e: React.FormEvent) => {\n    e.preventDefault();\n    if (!input.trim() || isGenerating) return;\n    sendMessage(input);\n    setInput('');\n  };\n\n  return (\n    \u003Cdiv className=\"chat-container\">\n      \u003Cdiv className=\"chat-header\">\n        \u003Ch2>AWS Bedrock Chat Console\u003C\u002Fh2>\n        \u003Cbutton className=\"clear-btn\" onClick={clearChat}>Очистити історію\u003C\u002Fbutton>\n      \u003C\u002Fdiv>\n\n      \u003Cdiv className=\"messages-list\">\n        {messages.map((msg) => (\n          \u003Cdiv key={msg.id} className={`message-bubble ${msg.role}`}>\n            \u003Cdiv className=\"avatar\">{msg.role === 'user' ? '👤' : '🤖'}\u003C\u002Fdiv>\n            \u003Cdiv className=\"content\">\n              {msg.role === 'assistant' ? (\n                \u003CReactMarkdown\n                  remarkPlugins={[remarkGfm]}\n                  components={{\n                    code({ className, children, ...props }) {\n                      const match = \u002Flanguage-(\\w+)\u002F.exec(className || '');\n                      const isInline = !match;\n                      return isInline ? (\n                        \u003Ccode className=\"inline-code\" {...props}>{children}\u003C\u002Fcode>\n                      ) : (\n                        \u003CSyntaxHighlighter\n                          style={oneDark}\n                          language={match[1]}\n                          PreTag=\"div\"\n                          className=\"code-block\"\n                        >\n                          {String(children).replace(\u002F\\n$\u002F, '')}\n                        \u003C\u002FSyntaxHighlighter>\n                      );\n                    }\n                  }}\n                >\n                  {msg.text}\n                \u003C\u002FReactMarkdown>\n              ) : (\n                \u003Cp className=\"plain-text\">{msg.text}\u003C\u002Fp>\n              )}\n            \u003C\u002Fdiv>\n          \u003C\u002Fdiv>\n        ))}\n        \u003Cdiv ref={bottomRef} \u002F>\n      \u003C\u002Fdiv>\n\n      \u003Cform className=\"chat-input-form\" onSubmit={handleSend}>\n        \u003Cinput\n          type=\"text\"\n          value={input}\n          onChange={(e) => setInput(e.target.value)}\n          placeholder=\"Запитайте у Claude 3.5...\"\n          disabled={isGenerating}\n        \u002F>\n        {isGenerating ? (\n          \u003Cbutton type=\"button\" className=\"stop-btn\" onClick={stopGeneration}>Зупинити\u003C\u002Fbutton>\n        ) : (\n          \u003Cbutton type=\"submit\" className=\"send-btn\" disabled={!input.trim()}>Надіслати\u003C\u002Fbutton>\n        )}\n      \u003C\u002Fform>\n    \u003C\u002Fdiv>\n  );\n}\n","src\u002Fcomponents\u002FChatWindow.tsx","tsx",[3399,8941,8942,8970,8985,8999,9022,9040,9058,9067,9071,9083,9107,9134,9146,9151,9173,9177,9188,9213,9221,9225,9253,9265,9288,9299,9310,9315,9319,9326,9346,9362,9381,9417,9426,9430,9445,9467,9516,9565,9579,9598,9606,9625,9636,9662,9709,9726,9737,9774,9783,9790,9803,9823,9833,9843,9848,9884,9894,9899,9903,9910,9915,9928,9938,9947,9978,9985,9994,10003,10010,10031,10039,10043,10071,10078,10088,10101,10138,10148,10161,10166,10176,10218,10227,10279,10286,10294,10303,10308],{"__ignoreMap":3397},[3402,8943,8944,8946,8949,8951,8953,8955,8957,8959,8962,8964,8966,8968],{"class":3404,"line":3405},[3402,8945,7258],{"class":3890},[3402,8947,8948],{"class":4037}," React",[3402,8950,8209],{"class":3669},[3402,8952,7263],{"class":4037},[3402,8954,4698],{"class":3669},[3402,8956,7273],{"class":4037},[3402,8958,4698],{"class":3669},[3402,8960,8961],{"class":4037},"useEffect",[3402,8963,7276],{"class":3669},[3402,8965,7279],{"class":3890},[3402,8967,7282],{"class":3682},[3402,8969,3903],{"class":3669},[3402,8971,8972,8974,8977,8980,8983],{"class":3404,"line":3411},[3402,8973,7258],{"class":3890},[3402,8975,8976],{"class":4037}," ReactMarkdown",[3402,8978,8979],{"class":3890}," from",[3402,8981,8982],{"class":3682}," 'react-markdown'",[3402,8984,3903],{"class":3669},[3402,8986,8987,8989,8992,8994,8997],{"class":3404,"line":3417},[3402,8988,7258],{"class":3890},[3402,8990,8991],{"class":4037}," remarkGfm",[3402,8993,8979],{"class":3890},[3402,8995,8996],{"class":3682}," 'remark-gfm'",[3402,8998,3903],{"class":3669},[3402,9000,9001,9003,9005,9008,9010,9013,9015,9017,9020],{"class":3404,"line":3423},[3402,9002,7258],{"class":3890},[3402,9004,6707],{"class":3669},[3402,9006,9007],{"class":4037},"Prism",[3402,9009,7850],{"class":3890},[3402,9011,9012],{"class":4037}," SyntaxHighlighter",[3402,9014,7276],{"class":3669},[3402,9016,7279],{"class":3890},[3402,9018,9019],{"class":3682}," 'react-syntax-highlighter'",[3402,9021,3903],{"class":3669},[3402,9023,9024,9026,9028,9031,9033,9035,9038],{"class":3404,"line":3430},[3402,9025,7258],{"class":3890},[3402,9027,6707],{"class":3669},[3402,9029,9030],{"class":4037},"oneDark",[3402,9032,7276],{"class":3669},[3402,9034,7279],{"class":3890},[3402,9036,9037],{"class":3682}," 'react-syntax-highlighter\u002Fdist\u002Fesm\u002Fstyles\u002Fprism'",[3402,9039,3903],{"class":3669},[3402,9041,9042,9044,9046,9049,9051,9053,9056],{"class":3404,"line":3436},[3402,9043,7258],{"class":3890},[3402,9045,6707],{"class":3669},[3402,9047,9048],{"class":4037},"useStreamingChat",[3402,9050,7276],{"class":3669},[3402,9052,7279],{"class":3890},[3402,9054,9055],{"class":3682}," '..\u002Fhooks\u002FuseStreamingChat'",[3402,9057,3903],{"class":3669},[3402,9059,9060,9062,9065],{"class":3404,"line":3441},[3402,9061,7258],{"class":3890},[3402,9063,9064],{"class":3682}," '.\u002FChatWindow.css'",[3402,9066,3903],{"class":3669},[3402,9068,9069],{"class":3404,"line":3447},[3402,9070,3427],{"emptyLinePlaceholder":3426},[3402,9072,9073,9075,9077,9080],{"class":3404,"line":3453},[3402,9074,7293],{"class":3890},[3402,9076,7418],{"class":3980},[3402,9078,9079],{"class":3852}," ChatWindow",[3402,9081,9082],{"class":3669},"() {\n",[3402,9084,9085,9087,9089,9092,9094,9097,9099,9101,9103,9105],{"class":3404,"line":3459},[3402,9086,7438],{"class":3980},[3402,9088,7441],{"class":3669},[3402,9090,9091],{"class":7444},"input",[3402,9093,4698],{"class":3669},[3402,9095,9096],{"class":7444},"setInput",[3402,9098,7453],{"class":3669},[3402,9100,7263],{"class":3852},[3402,9102,4025],{"class":3669},[3402,9104,8121],{"class":3682},[3402,9106,4075],{"class":3669},[3402,9108,9109,9111,9113,9115,9117,9119,9121,9123,9125,9127,9129,9131],{"class":3404,"line":3465},[3402,9110,7438],{"class":3980},[3402,9112,6707],{"class":3669},[3402,9114,7445],{"class":7444},[3402,9116,4698],{"class":3669},[3402,9118,7472],{"class":7444},[3402,9120,4698],{"class":3669},[3402,9122,8876],{"class":7444},[3402,9124,4698],{"class":3669},[3402,9126,8850],{"class":7444},[3402,9128,4698],{"class":3669},[3402,9130,8885],{"class":7444},[3402,9132,9133],{"class":3669}," } = \n",[3402,9135,9136,9139,9141,9144],{"class":3404,"line":3470},[3402,9137,9138],{"class":3852},"    useStreamingChat",[3402,9140,4025],{"class":3669},[3402,9142,9143],{"class":3682},"'http:\u002F\u002Flocalhost:5000\u002Fapi\u002Fchat\u002Fstream'",[3402,9145,4075],{"class":3669},[3402,9147,9148],{"class":3404,"line":3476},[3402,9149,9150],{"class":3669},"  \n",[3402,9152,9153,9155,9158,9160,9162,9164,9167,9169,9171],{"class":3404,"line":3482},[3402,9154,7438],{"class":3980},[3402,9156,9157],{"class":7444}," bottomRef",[3402,9159,4575],{"class":3669},[3402,9161,7273],{"class":3852},[3402,9163,4063],{"class":3669},[3402,9165,9166],{"class":3894},"HTMLDivElement",[3402,9168,5181],{"class":3669},[3402,9170,4710],{"class":3980},[3402,9172,4075],{"class":3669},[3402,9174,9175],{"class":3404,"line":3488},[3402,9176,3427],{"emptyLinePlaceholder":3426},[3402,9178,9179,9182,9184,9186],{"class":3404,"line":3494},[3402,9180,9181],{"class":3852},"  useEffect",[3402,9183,8744],{"class":3669},[3402,9185,7549],{"class":3980},[3402,9187,7302],{"class":3669},[3402,9189,9190,9193,9195,9197,9199,9202,9205,9208,9211],{"class":3404,"line":3500},[3402,9191,9192],{"class":4037},"    bottomRef",[3402,9194,3654],{"class":3669},[3402,9196,7761],{"class":4037},[3402,9198,5197],{"class":3669},[3402,9200,9201],{"class":3852},"scrollIntoView",[3402,9203,9204],{"class":3669},"({ ",[3402,9206,9207],{"class":4037},"behavior:",[3402,9209,9210],{"class":3682}," 'smooth'",[3402,9212,6717],{"class":3669},[3402,9214,9215,9217,9219],{"class":3404,"line":3505},[3402,9216,8716],{"class":3669},[3402,9218,7445],{"class":4037},[3402,9220,7735],{"class":3669},[3402,9222,9223],{"class":3404,"line":3511},[3402,9224,3427],{"emptyLinePlaceholder":3426},[3402,9226,9227,9229,9232,9235,9238,9240,9242,9244,9247,9249,9251],{"class":3404,"line":3517},[3402,9228,7438],{"class":3980},[3402,9230,9231],{"class":3852}," handleSend",[3402,9233,9234],{"class":3669}," = (",[3402,9236,9237],{"class":4037},"e",[3402,9239,3679],{"class":3669},[3402,9241,2013],{"class":3894},[3402,9243,3654],{"class":3669},[3402,9245,9246],{"class":3894},"FormEvent",[3402,9248,7546],{"class":3669},[3402,9250,7549],{"class":3980},[3402,9252,7302],{"class":3669},[3402,9254,9255,9258,9260,9263],{"class":3404,"line":3523},[3402,9256,9257],{"class":4037},"    e",[3402,9259,3654],{"class":3669},[3402,9261,9262],{"class":3852},"preventDefault",[3402,9264,5151],{"class":3669},[3402,9266,9267,9269,9271,9273,9275,9277,9280,9282,9284,9286],{"class":3404,"line":3529},[3402,9268,7556],{"class":3890},[3402,9270,6244],{"class":3669},[3402,9272,9091],{"class":4037},[3402,9274,3654],{"class":3669},[3402,9276,7565],{"class":3852},[3402,9278,9279],{"class":3669},"() || ",[3402,9281,7472],{"class":4037},[3402,9283,7546],{"class":3669},[3402,9285,7571],{"class":3890},[3402,9287,3903],{"class":3669},[3402,9289,9290,9293,9295,9297],{"class":3404,"line":3535},[3402,9291,9292],{"class":3852},"    sendMessage",[3402,9294,4025],{"class":3669},[3402,9296,9091],{"class":4037},[3402,9298,4075],{"class":3669},[3402,9300,9301,9304,9306,9308],{"class":3404,"line":3541},[3402,9302,9303],{"class":3852},"    setInput",[3402,9305,4025],{"class":3669},[3402,9307,8121],{"class":3682},[3402,9309,4075],{"class":3669},[3402,9311,9312],{"class":3404,"line":3829},[3402,9313,9314],{"class":3669},"  };\n",[3402,9316,9317],{"class":3404,"line":4327},[3402,9318,3427],{"emptyLinePlaceholder":3426},[3402,9320,9321,9323],{"class":3404,"line":4350},[3402,9322,8863],{"class":3890},[3402,9324,9325],{"class":3669}," (\n",[3402,9327,9328,9331,9334,9338,9341,9344],{"class":3404,"line":4373},[3402,9329,9330],{"class":4643},"    \u003C",[3402,9332,9333],{"class":4646},"div",[3402,9335,9337],{"class":9336},"sa4r_"," className",[3402,9339,9340],{"class":3669},"=",[3402,9342,9343],{"class":3682},"\"chat-container\"",[3402,9345,4650],{"class":4643},[3402,9347,9348,9351,9353,9355,9357,9360],{"class":3404,"line":4402},[3402,9349,9350],{"class":4643},"      \u003C",[3402,9352,9333],{"class":4646},[3402,9354,9337],{"class":9336},[3402,9356,9340],{"class":3669},[3402,9358,9359],{"class":3682},"\"chat-header\"",[3402,9361,4650],{"class":4643},[3402,9363,9364,9367,9369,9372,9375,9377,9379],{"class":3404,"line":4427},[3402,9365,9366],{"class":4643},"        \u003C",[3402,9368,3348],{"class":4646},[3402,9370,9371],{"class":4643},">",[3402,9373,9374],{"class":3669},"AWS Bedrock Chat Console",[3402,9376,4664],{"class":4643},[3402,9378,3348],{"class":4646},[3402,9380,4650],{"class":4643},[3402,9382,9383,9385,9388,9390,9392,9395,9398,9400,9402,9404,9406,9408,9411,9413,9415],{"class":3404,"line":4453},[3402,9384,9366],{"class":4643},[3402,9386,9387],{"class":4646},"button",[3402,9389,9337],{"class":9336},[3402,9391,9340],{"class":3669},[3402,9393,9394],{"class":3682},"\"clear-btn\"",[3402,9396,9397],{"class":9336}," onClick",[3402,9399,9340],{"class":3669},[3402,9401,5308],{"class":3980},[3402,9403,8885],{"class":4037},[3402,9405,5319],{"class":3980},[3402,9407,9371],{"class":4643},[3402,9409,9410],{"class":3669},"Очистити історію",[3402,9412,4664],{"class":4643},[3402,9414,9387],{"class":4646},[3402,9416,4650],{"class":4643},[3402,9418,9419,9422,9424],{"class":3404,"line":4458},[3402,9420,9421],{"class":4643},"      \u003C\u002F",[3402,9423,9333],{"class":4646},[3402,9425,4650],{"class":4643},[3402,9427,9428],{"class":3404,"line":4470},[3402,9429,3427],{"emptyLinePlaceholder":3426},[3402,9431,9432,9434,9436,9438,9440,9443],{"class":3404,"line":4495},[3402,9433,9350],{"class":4643},[3402,9435,9333],{"class":4646},[3402,9437,9337],{"class":9336},[3402,9439,9340],{"class":3669},[3402,9441,9442],{"class":3682},"\"messages-list\"",[3402,9444,4650],{"class":4643},[3402,9446,9447,9450,9452,9454,9456,9458,9461,9463,9465],{"class":3404,"line":4520},[3402,9448,9449],{"class":3980},"        {",[3402,9451,7445],{"class":4037},[3402,9453,3654],{"class":5307},[3402,9455,7806],{"class":3852},[3402,9457,7710],{"class":5307},[3402,9459,9460],{"class":4037},"msg",[3402,9462,7546],{"class":5307},[3402,9464,7549],{"class":3980},[3402,9466,9325],{"class":5307},[3402,9468,9469,9472,9474,9477,9479,9481,9483,9485,9487,9489,9491,9493,9495,9498,9501,9503,9505,9507,9509,9512,9514],{"class":3404,"line":4525},[3402,9470,9471],{"class":4643},"          \u003C",[3402,9473,9333],{"class":4646},[3402,9475,9476],{"class":9336}," key",[3402,9478,9340],{"class":3669},[3402,9480,5308],{"class":3980},[3402,9482,9460],{"class":4037},[3402,9484,3654],{"class":5307},[3402,9486,8502],{"class":4037},[3402,9488,5319],{"class":3980},[3402,9490,9337],{"class":9336},[3402,9492,9340],{"class":3669},[3402,9494,5308],{"class":3980},[3402,9496,9497],{"class":3682},"`message-bubble ",[3402,9499,9500],{"class":3980},"${",[3402,9502,9460],{"class":4037},[3402,9504,3654],{"class":5307},[3402,9506,7831],{"class":4037},[3402,9508,5319],{"class":3980},[3402,9510,9511],{"class":3682},"`",[3402,9513,5319],{"class":3980},[3402,9515,4650],{"class":4643},[3402,9517,9518,9521,9523,9525,9527,9530,9532,9534,9536,9538,9540,9543,9545,9548,9551,9554,9557,9559,9561,9563],{"class":3404,"line":4539},[3402,9519,9520],{"class":4643},"            \u003C",[3402,9522,9333],{"class":4646},[3402,9524,9337],{"class":9336},[3402,9526,9340],{"class":3669},[3402,9528,9529],{"class":3682},"\"avatar\"",[3402,9531,9371],{"class":4643},[3402,9533,5308],{"class":3980},[3402,9535,9460],{"class":4037},[3402,9537,3654],{"class":5307},[3402,9539,7831],{"class":4037},[3402,9541,9542],{"class":3669}," ===",[3402,9544,7616],{"class":3682},[3402,9546,9547],{"class":3669}," ?",[3402,9549,9550],{"class":3682}," '👤'",[3402,9552,9553],{"class":3669}," :",[3402,9555,9556],{"class":3682}," '🤖'",[3402,9558,5319],{"class":3980},[3402,9560,4664],{"class":4643},[3402,9562,9333],{"class":4646},[3402,9564,4650],{"class":4643},[3402,9566,9567,9569,9571,9573,9575,9577],{"class":3404,"line":4544},[3402,9568,9520],{"class":4643},[3402,9570,9333],{"class":4646},[3402,9572,9337],{"class":9336},[3402,9574,9340],{"class":3669},[3402,9576,4055],{"class":3682},[3402,9578,4650],{"class":4643},[3402,9580,9581,9584,9586,9588,9590,9592,9594,9596],{"class":3404,"line":4561},[3402,9582,9583],{"class":3980},"              {",[3402,9585,9460],{"class":4037},[3402,9587,3654],{"class":5307},[3402,9589,7831],{"class":4037},[3402,9591,9542],{"class":3669},[3402,9593,7683],{"class":3682},[3402,9595,9547],{"class":3669},[3402,9597,9325],{"class":5307},[3402,9599,9600,9603],{"class":3404,"line":4583},[3402,9601,9602],{"class":4643},"                \u003C",[3402,9604,9605],{"class":3894},"ReactMarkdown\n",[3402,9607,9608,9611,9613,9615,9617,9620,9623],{"class":3404,"line":4588},[3402,9609,9610],{"class":9336},"                  remarkPlugins",[3402,9612,9340],{"class":3669},[3402,9614,5308],{"class":3980},[3402,9616,6376],{"class":5307},[3402,9618,9619],{"class":4037},"remarkGfm",[3402,9621,9622],{"class":5307},"]",[3402,9624,3497],{"class":3980},[3402,9626,9627,9630,9632,9634],{"class":3404,"line":4608},[3402,9628,9629],{"class":9336},"                  components",[3402,9631,9340],{"class":3669},[3402,9633,5308],{"class":3980},[3402,9635,3670],{"class":5307},[3402,9637,9638,9641,9643,9646,9648,9651,9653,9656,9659],{"class":3404,"line":4613},[3402,9639,9640],{"class":3852},"                    code",[3402,9642,9204],{"class":5307},[3402,9644,9645],{"class":4037},"className",[3402,9647,4698],{"class":5307},[3402,9649,9650],{"class":4037},"children",[3402,9652,4698],{"class":5307},[3402,9654,9655],{"class":3669},"...",[3402,9657,9658],{"class":4037},"props",[3402,9660,9661],{"class":5307}," }) {\n",[3402,9663,9664,9667,9670,9673,9677,9680,9683,9687,9690,9693,9695,9698,9700,9702,9705,9707],{"class":3404,"line":4626},[3402,9665,9666],{"class":3980},"                      const",[3402,9668,9669],{"class":7444}," match",[3402,9671,9672],{"class":3669}," =",[3402,9674,9676],{"class":9675},"shsrj"," \u002Flanguage-",[3402,9678,4025],{"class":9679},"sAV2Q",[3402,9681,9682],{"class":9675},"\\w",[3402,9684,9686],{"class":9685},"sYsli","+",[3402,9688,9689],{"class":9679},")",[3402,9691,9692],{"class":9675},"\u002F",[3402,9694,3654],{"class":5307},[3402,9696,9697],{"class":3852},"exec",[3402,9699,4025],{"class":5307},[3402,9701,9645],{"class":4037},[3402,9703,9704],{"class":3669}," ||",[3402,9706,7692],{"class":3682},[3402,9708,4075],{"class":5307},[3402,9710,9711,9713,9716,9718,9721,9724],{"class":3404,"line":4631},[3402,9712,9666],{"class":3980},[3402,9714,9715],{"class":7444}," isInline",[3402,9717,9672],{"class":3669},[3402,9719,9720],{"class":3669}," !",[3402,9722,9723],{"class":4037},"match",[3402,9725,3903],{"class":5307},[3402,9727,9728,9731,9733,9735],{"class":3404,"line":4636},[3402,9729,9730],{"class":3890},"                      return",[3402,9732,9715],{"class":4037},[3402,9734,9547],{"class":3669},[3402,9736,9325],{"class":5307},[3402,9738,9739,9742,9744,9746,9748,9751,9754,9756,9758,9760,9762,9764,9766,9768,9770,9772],{"class":3404,"line":4653},[3402,9740,9741],{"class":4643},"                        \u003C",[3402,9743,3399],{"class":4646},[3402,9745,9337],{"class":9336},[3402,9747,9340],{"class":3669},[3402,9749,9750],{"class":3682},"\"inline-code\"",[3402,9752,9753],{"class":3980}," {",[3402,9755,9655],{"class":3669},[3402,9757,9658],{"class":4037},[3402,9759,5319],{"class":3980},[3402,9761,9371],{"class":4643},[3402,9763,5308],{"class":3980},[3402,9765,9650],{"class":4037},[3402,9767,5319],{"class":3980},[3402,9769,4664],{"class":4643},[3402,9771,3399],{"class":4646},[3402,9773,4650],{"class":4643},[3402,9775,9776,9779,9781],{"class":3404,"line":4659},[3402,9777,9778],{"class":5307},"                      ) ",[3402,9780,7965],{"class":3669},[3402,9782,9325],{"class":5307},[3402,9784,9785,9787],{"class":3404,"line":4671},[3402,9786,9741],{"class":4643},[3402,9788,9789],{"class":3894},"SyntaxHighlighter\n",[3402,9791,9792,9795,9797,9799,9801],{"class":3404,"line":4715},[3402,9793,9794],{"class":9336},"                          style",[3402,9796,9340],{"class":3669},[3402,9798,5308],{"class":3980},[3402,9800,9030],{"class":4037},[3402,9802,3497],{"class":3980},[3402,9804,9805,9808,9810,9812,9814,9816,9819,9821],{"class":3404,"line":4720},[3402,9806,9807],{"class":9336},"                          language",[3402,9809,9340],{"class":3669},[3402,9811,5308],{"class":3980},[3402,9813,9723],{"class":4037},[3402,9815,6376],{"class":5307},[3402,9817,9818],{"class":4825},"1",[3402,9820,9622],{"class":5307},[3402,9822,3497],{"class":3980},[3402,9824,9825,9828,9830],{"class":3404,"line":4743},[3402,9826,9827],{"class":9336},"                          PreTag",[3402,9829,9340],{"class":3669},[3402,9831,9832],{"class":3682},"\"div\"\n",[3402,9834,9835,9838,9840],{"class":3404,"line":4749},[3402,9836,9837],{"class":9336},"                          className",[3402,9839,9340],{"class":3669},[3402,9841,9842],{"class":3682},"\"code-block\"\n",[3402,9844,9845],{"class":3404,"line":4777},[3402,9846,9847],{"class":4643},"                        >\n",[3402,9849,9850,9853,9856,9858,9860,9862,9865,9867,9870,9874,9876,9878,9880,9882],{"class":3404,"line":4783},[3402,9851,9852],{"class":3980},"                          {",[3402,9854,9855],{"class":3852},"String",[3402,9857,4025],{"class":5307},[3402,9859,9650],{"class":4037},[3402,9861,8369],{"class":5307},[3402,9863,9864],{"class":3852},"replace",[3402,9866,4025],{"class":5307},[3402,9868,9869],{"class":9675},"\u002F\\n",[3402,9871,9873],{"class":9872},"siofk","$",[3402,9875,9692],{"class":9675},[3402,9877,4698],{"class":5307},[3402,9879,8121],{"class":3682},[3402,9881,9689],{"class":5307},[3402,9883,3497],{"class":3980},[3402,9885,9886,9889,9892],{"class":3404,"line":4788},[3402,9887,9888],{"class":4643},"                        \u003C\u002F",[3402,9890,9891],{"class":3894},"SyntaxHighlighter",[3402,9893,4650],{"class":4643},[3402,9895,9896],{"class":3404,"line":4804},[3402,9897,9898],{"class":5307},"                      );\n",[3402,9900,9901],{"class":3404,"line":4817},[3402,9902,6284],{"class":5307},[3402,9904,9905,9908],{"class":3404,"line":4831},[3402,9906,9907],{"class":5307},"                  }",[3402,9909,3497],{"class":3980},[3402,9911,9912],{"class":3404,"line":4844},[3402,9913,9914],{"class":4643},"                >\n",[3402,9916,9917,9920,9922,9924,9926],{"class":3404,"line":4856},[3402,9918,9919],{"class":3980},"                  {",[3402,9921,9460],{"class":4037},[3402,9923,3654],{"class":5307},[3402,9925,6256],{"class":4037},[3402,9927,3497],{"class":3980},[3402,9929,9930,9933,9936],{"class":3404,"line":4867},[3402,9931,9932],{"class":4643},"                \u003C\u002F",[3402,9934,9935],{"class":3894},"ReactMarkdown",[3402,9937,4650],{"class":4643},[3402,9939,9940,9943,9945],{"class":3404,"line":4873},[3402,9941,9942],{"class":5307},"              ) ",[3402,9944,7965],{"class":3669},[3402,9946,9325],{"class":5307},[3402,9948,9949,9951,9953,9955,9957,9960,9962,9964,9966,9968,9970,9972,9974,9976],{"class":3404,"line":4878},[3402,9950,9602],{"class":4643},[3402,9952,3353],{"class":4646},[3402,9954,9337],{"class":9336},[3402,9956,9340],{"class":3669},[3402,9958,9959],{"class":3682},"\"plain-text\"",[3402,9961,9371],{"class":4643},[3402,9963,5308],{"class":3980},[3402,9965,9460],{"class":4037},[3402,9967,3654],{"class":5307},[3402,9969,6256],{"class":4037},[3402,9971,5319],{"class":3980},[3402,9973,4664],{"class":4643},[3402,9975,3353],{"class":4646},[3402,9977,4650],{"class":4643},[3402,9979,9980,9983],{"class":3404,"line":4893},[3402,9981,9982],{"class":5307},"              )",[3402,9984,3497],{"class":3980},[3402,9986,9987,9990,9992],{"class":3404,"line":4898},[3402,9988,9989],{"class":4643},"            \u003C\u002F",[3402,9991,9333],{"class":4646},[3402,9993,4650],{"class":4643},[3402,9995,9996,9999,10001],{"class":3404,"line":4914},[3402,9997,9998],{"class":4643},"          \u003C\u002F",[3402,10000,9333],{"class":4646},[3402,10002,4650],{"class":4643},[3402,10004,10005,10008],{"class":3404,"line":4919},[3402,10006,10007],{"class":5307},"        ))",[3402,10009,3497],{"class":3980},[3402,10011,10012,10014,10016,10019,10021,10023,10026,10028],{"class":3404,"line":4949},[3402,10013,9366],{"class":4643},[3402,10015,9333],{"class":4646},[3402,10017,10018],{"class":9336}," ref",[3402,10020,9340],{"class":3669},[3402,10022,5308],{"class":3980},[3402,10024,10025],{"class":4037},"bottomRef",[3402,10027,5319],{"class":3980},[3402,10029,10030],{"class":4643}," \u002F>\n",[3402,10032,10033,10035,10037],{"class":3404,"line":4954},[3402,10034,9421],{"class":4643},[3402,10036,9333],{"class":4646},[3402,10038,4650],{"class":4643},[3402,10040,10041],{"class":3404,"line":4969},[3402,10042,3427],{"emptyLinePlaceholder":3426},[3402,10044,10045,10047,10050,10052,10054,10057,10060,10062,10064,10067,10069],{"class":3404,"line":4974},[3402,10046,9350],{"class":4643},[3402,10048,10049],{"class":4646},"form",[3402,10051,9337],{"class":9336},[3402,10053,9340],{"class":3669},[3402,10055,10056],{"class":3682},"\"chat-input-form\"",[3402,10058,10059],{"class":9336}," onSubmit",[3402,10061,9340],{"class":3669},[3402,10063,5308],{"class":3980},[3402,10065,10066],{"class":4037},"handleSend",[3402,10068,5319],{"class":3980},[3402,10070,4650],{"class":4643},[3402,10072,10073,10075],{"class":3404,"line":4987},[3402,10074,9366],{"class":4643},[3402,10076,10077],{"class":4646},"input\n",[3402,10079,10080,10083,10085],{"class":3404,"line":5000},[3402,10081,10082],{"class":9336},"          type",[3402,10084,9340],{"class":3669},[3402,10086,10087],{"class":3682},"\"text\"\n",[3402,10089,10090,10093,10095,10097,10099],{"class":3404,"line":5012},[3402,10091,10092],{"class":9336},"          value",[3402,10094,9340],{"class":3669},[3402,10096,5308],{"class":3980},[3402,10098,9091],{"class":4037},[3402,10100,3497],{"class":3980},[3402,10102,10103,10106,10108,10110,10112,10114,10116,10118,10121,10123,10125,10127,10130,10132,10134,10136],{"class":3404,"line":5048},[3402,10104,10105],{"class":9336},"          onChange",[3402,10107,9340],{"class":3669},[3402,10109,5308],{"class":3980},[3402,10111,4025],{"class":5307},[3402,10113,9237],{"class":4037},[3402,10115,7546],{"class":5307},[3402,10117,7549],{"class":3980},[3402,10119,10120],{"class":3852}," setInput",[3402,10122,4025],{"class":5307},[3402,10124,9237],{"class":4037},[3402,10126,3654],{"class":5307},[3402,10128,10129],{"class":4037},"target",[3402,10131,3654],{"class":5307},[3402,10133,8152],{"class":4037},[3402,10135,9689],{"class":5307},[3402,10137,3497],{"class":3980},[3402,10139,10140,10143,10145],{"class":3404,"line":5053},[3402,10141,10142],{"class":9336},"          placeholder",[3402,10144,9340],{"class":3669},[3402,10146,10147],{"class":3682},"\"Запитайте у Claude 3.5...\"\n",[3402,10149,10150,10153,10155,10157,10159],{"class":3404,"line":5058},[3402,10151,10152],{"class":9336},"          disabled",[3402,10154,9340],{"class":3669},[3402,10156,5308],{"class":3980},[3402,10158,7472],{"class":4037},[3402,10160,3497],{"class":3980},[3402,10162,10163],{"class":3404,"line":5064},[3402,10164,10165],{"class":4643},"        \u002F>\n",[3402,10167,10168,10170,10172,10174],{"class":3404,"line":5069},[3402,10169,9449],{"class":3980},[3402,10171,7472],{"class":4037},[3402,10173,9547],{"class":3669},[3402,10175,9325],{"class":5307},[3402,10177,10178,10180,10182,10185,10187,10190,10192,10194,10197,10199,10201,10203,10205,10207,10209,10212,10214,10216],{"class":3404,"line":5096},[3402,10179,9471],{"class":4643},[3402,10181,9387],{"class":4646},[3402,10183,10184],{"class":9336}," type",[3402,10186,9340],{"class":3669},[3402,10188,10189],{"class":3682},"\"button\"",[3402,10191,9337],{"class":9336},[3402,10193,9340],{"class":3669},[3402,10195,10196],{"class":3682},"\"stop-btn\"",[3402,10198,9397],{"class":9336},[3402,10200,9340],{"class":3669},[3402,10202,5308],{"class":3980},[3402,10204,8850],{"class":4037},[3402,10206,5319],{"class":3980},[3402,10208,9371],{"class":4643},[3402,10210,10211],{"class":5307},"Зупинити",[3402,10213,4664],{"class":4643},[3402,10215,9387],{"class":4646},[3402,10217,4650],{"class":4643},[3402,10219,10220,10223,10225],{"class":3404,"line":5101},[3402,10221,10222],{"class":5307},"        ) ",[3402,10224,7965],{"class":3669},[3402,10226,9325],{"class":5307},[3402,10228,10229,10231,10233,10235,10237,10240,10242,10244,10247,10250,10252,10254,10257,10259,10261,10263,10266,10268,10270,10273,10275,10277],{"class":3404,"line":5132},[3402,10230,9471],{"class":4643},[3402,10232,9387],{"class":4646},[3402,10234,10184],{"class":9336},[3402,10236,9340],{"class":3669},[3402,10238,10239],{"class":3682},"\"submit\"",[3402,10241,9337],{"class":9336},[3402,10243,9340],{"class":3669},[3402,10245,10246],{"class":3682},"\"send-btn\"",[3402,10248,10249],{"class":9336}," disabled",[3402,10251,9340],{"class":3669},[3402,10253,5308],{"class":3980},[3402,10255,10256],{"class":3669},"!",[3402,10258,9091],{"class":4037},[3402,10260,3654],{"class":5307},[3402,10262,7565],{"class":3852},[3402,10264,10265],{"class":5307},"()",[3402,10267,5319],{"class":3980},[3402,10269,9371],{"class":4643},[3402,10271,10272],{"class":5307},"Надіслати",[3402,10274,4664],{"class":4643},[3402,10276,9387],{"class":4646},[3402,10278,4650],{"class":4643},[3402,10280,10281,10284],{"class":3404,"line":5154},[3402,10282,10283],{"class":5307},"        )",[3402,10285,3497],{"class":3980},[3402,10287,10288,10290,10292],{"class":3404,"line":5159},[3402,10289,9421],{"class":4643},[3402,10291,10049],{"class":4646},[3402,10293,4650],{"class":4643},[3402,10295,10296,10299,10301],{"class":3404,"line":5189},[3402,10297,10298],{"class":4643},"    \u003C\u002F",[3402,10300,9333],{"class":4646},[3402,10302,4650],{"class":4643},[3402,10304,10305],{"class":3404,"line":5235},[3402,10306,10307],{"class":3669},"  );\n",[3402,10309,10310],{"class":3404,"line":5257},[3402,10311,3497],{"class":3669},[3864,10313,10315],{"id":10314},"_3-css-стилі-для-преміум-дизайну-glassmorphism-та-sleek-dark-mode","3. CSS Стилі для преміум дизайну (glassmorphism та sleek dark mode)",[3392,10317,10322],{"className":10318,"code":10319,"filename":10320,"language":10321,"meta":3397,"style":3397},"language-css shiki shiki-themes light-plus dark-plus dark-plus",".chat-container {\n  display: flex;\n  flex-direction: column;\n  height: 80vh;\n  max-width: 900px;\n  margin: 20px auto;\n  background: rgba(17, 24, 39, 0.95);\n  border-radius: 16px;\n  border: 1px solid rgba(255, 255, 255, 0.1);\n  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);\n  overflow: hidden;\n  font-family: 'Inter', system-ui, sans-serif;\n  color: #f3f4f6;\n}\n\n.chat-header {\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 16px 24px;\n  background: rgba(31, 41, 55, 0.8);\n  border-bottom: 1px solid rgba(255, 255, 255, 0.05);\n}\n\n.chat-header h2 {\n  font-size: 1.25rem;\n  font-weight: 600;\n  margin: 0;\n  background: linear-gradient(90deg, #60a5fa, #a78bfa);\n  -webkit-background-clip: text;\n  -webkit-text-fill-color: transparent;\n}\n\n.clear-btn {\n  background: transparent;\n  border: 1px solid rgba(239, 68, 68, 0.4);\n  color: #ef4444;\n  padding: 6px 12px;\n  border-radius: 6px;\n  cursor: pointer;\n  font-size: 0.875rem;\n  transition: all 0.2s ease;\n}\n\n.clear-btn:hover {\n  background: rgba(239, 68, 68, 0.1);\n}\n\n.messages-list {\n  flex: 1;\n  padding: 24px;\n  overflow-y: auto;\n  display: flex;\n  flex-direction: column;\n  gap: 20px;\n}\n\n.message-bubble {\n  display: flex;\n  gap: 16px;\n  max-width: 85%;\n  align-self: flex-start;\n}\n\n.message-bubble.user {\n  align-self: flex-end;\n  flex-direction: row-reverse;\n}\n\n.avatar {\n  width: 40px;\n  height: 40px;\n  border-radius: 50%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  background: rgba(255, 255, 255, 0.05);\n  border: 1px solid rgba(255, 255, 255, 0.1);\n  font-size: 1.25rem;\n}\n\n.message-bubble.user .avatar {\n  background: rgba(96, 165, 250, 0.2);\n  border-color: rgba(96, 165, 250, 0.3);\n}\n\n.content {\n  background: rgba(31, 41, 55, 0.6);\n  padding: 12px 18px;\n  border-radius: 12px;\n  border: 1px solid rgba(255, 255, 255, 0.05);\n  line-height: 1.6;\n}\n\n.message-bubble.user .content {\n  background: rgba(59, 130, 246, 0.2);\n  border-color: rgba(59, 130, 246, 0.3);\n}\n\n.plain-text {\n  margin: 0;\n  white-space: pre-wrap;\n}\n\n.inline-code {\n  background: rgba(255, 255, 255, 0.1);\n  padding: 2px 6px;\n  border-radius: 4px;\n  font-family: monospace;\n}\n\n.code-block {\n  border-radius: 8px !important;\n  margin: 10px 0 !important;\n  font-size: 0.9rem;\n}\n\n.chat-input-form {\n  display: flex;\n  padding: 20px 24px;\n  background: rgba(31, 41, 55, 0.8);\n  border-top: 1px solid rgba(255, 255, 255, 0.05);\n  gap: 12px;\n}\n\n.chat-input-form input {\n  flex: 1;\n  background: rgba(17, 24, 39, 0.8);\n  border: 1px solid rgba(255, 255, 255, 0.1);\n  border-radius: 8px;\n  padding: 12px 16px;\n  color: #fff;\n  font-size: 1rem;\n  outline: none;\n  transition: border-color 0.2s;\n}\n\n.chat-input-form input:focus {\n  border-color: #3b82f6;\n}\n\n.send-btn, .stop-btn {\n  padding: 12px 24px;\n  border-radius: 8px;\n  border: none;\n  font-weight: 500;\n  cursor: pointer;\n  transition: opacity 0.2s;\n}\n\n.send-btn {\n  background: #3b82f6;\n  color: white;\n}\n\n.send-btn:disabled {\n  background: #4b5563;\n  cursor: not-allowed;\n}\n\n.stop-btn {\n  background: #ef4444;\n  color: white;\n}\n\n.send-btn:hover, .stop-btn:hover {\n  opacity: 0.9;\n}\n","src\u002Fcomponents\u002FChatWindow.css","css",[3399,10323,10324,10332,10345,10357,10369,10381,10396,10428,10440,10476,10513,10525,10547,10559,10563,10567,10574,10584,10596,10608,10622,10652,10684,10688,10692,10701,10713,10725,10735,10761,10772,10784,10788,10792,10799,10809,10842,10853,10867,10877,10889,10900,10918,10922,10926,10933,10959,10963,10967,10974,10985,10996,11008,11018,11028,11039,11043,11047,11054,11064,11074,11085,11097,11101,11105,11112,11123,11134,11138,11142,11149,11161,11171,11182,11192,11202,11212,11238,11268,11278,11282,11286,11295,11325,11353,11357,11361,11368,11395,11409,11419,11449,11461,11465,11469,11478,11507,11533,11537,11541,11548,11558,11570,11574,11578,11585,11611,11625,11636,11647,11651,11655,11662,11676,11692,11703,11707,11711,11718,11728,11740,11767,11799,11810,11815,11820,11830,11841,11868,11899,11910,11924,11936,11948,11961,11974,11979,11984,11994,12006,12011,12016,12029,12042,12053,12064,12076,12087,12099,12104,12109,12116,12127,12139,12144,12149,12157,12169,12181,12186,12191,12198,12209,12220,12225,12230,12243,12256],{"__ignoreMap":3397},[3402,10325,10326,10330],{"class":3404,"line":3405},[3402,10327,10329],{"class":10328},"sqdDX",".chat-container",[3402,10331,7302],{"class":3669},[3402,10333,10334,10337,10339,10343],{"class":3404,"line":3411},[3402,10335,10336],{"class":9336},"  display",[3402,10338,3679],{"class":3669},[3402,10340,10342],{"class":10341},"sDUd3","flex",[3402,10344,3903],{"class":3669},[3402,10346,10347,10350,10352,10355],{"class":3404,"line":3417},[3402,10348,10349],{"class":9336},"  flex-direction",[3402,10351,3679],{"class":3669},[3402,10353,10354],{"class":10341},"column",[3402,10356,3903],{"class":3669},[3402,10358,10359,10362,10364,10367],{"class":3404,"line":3423},[3402,10360,10361],{"class":9336},"  height",[3402,10363,3679],{"class":3669},[3402,10365,10366],{"class":4825},"80vh",[3402,10368,3903],{"class":3669},[3402,10370,10371,10374,10376,10379],{"class":3404,"line":3430},[3402,10372,10373],{"class":9336},"  max-width",[3402,10375,3679],{"class":3669},[3402,10377,10378],{"class":4825},"900px",[3402,10380,3903],{"class":3669},[3402,10382,10383,10386,10388,10391,10394],{"class":3404,"line":3436},[3402,10384,10385],{"class":9336},"  margin",[3402,10387,3679],{"class":3669},[3402,10389,10390],{"class":4825},"20px",[3402,10392,10393],{"class":10341}," auto",[3402,10395,3903],{"class":3669},[3402,10397,10398,10401,10403,10406,10408,10411,10413,10416,10418,10421,10423,10426],{"class":3404,"line":3441},[3402,10399,10400],{"class":9336},"  background",[3402,10402,3679],{"class":3669},[3402,10404,10405],{"class":3852},"rgba",[3402,10407,4025],{"class":3669},[3402,10409,10410],{"class":4825},"17",[3402,10412,4698],{"class":3669},[3402,10414,10415],{"class":4825},"24",[3402,10417,4698],{"class":3669},[3402,10419,10420],{"class":4825},"39",[3402,10422,4698],{"class":3669},[3402,10424,10425],{"class":4825},"0.95",[3402,10427,4075],{"class":3669},[3402,10429,10430,10433,10435,10438],{"class":3404,"line":3447},[3402,10431,10432],{"class":9336},"  border-radius",[3402,10434,3679],{"class":3669},[3402,10436,10437],{"class":4825},"16px",[3402,10439,3903],{"class":3669},[3402,10441,10442,10445,10447,10450,10453,10456,10458,10461,10463,10465,10467,10469,10471,10474],{"class":3404,"line":3453},[3402,10443,10444],{"class":9336},"  border",[3402,10446,3679],{"class":3669},[3402,10448,10449],{"class":4825},"1px",[3402,10451,10452],{"class":10341}," solid",[3402,10454,10455],{"class":3852}," rgba",[3402,10457,4025],{"class":3669},[3402,10459,10460],{"class":4825},"255",[3402,10462,4698],{"class":3669},[3402,10464,10460],{"class":4825},[3402,10466,4698],{"class":3669},[3402,10468,10460],{"class":4825},[3402,10470,4698],{"class":3669},[3402,10472,10473],{"class":4825},"0.1",[3402,10475,4075],{"class":3669},[3402,10477,10478,10481,10483,10486,10489,10492,10494,10496,10498,10500,10502,10504,10506,10508,10511],{"class":3404,"line":3459},[3402,10479,10480],{"class":9336},"  box-shadow",[3402,10482,3679],{"class":3669},[3402,10484,10485],{"class":4825},"0",[3402,10487,10488],{"class":4825}," 10px",[3402,10490,10491],{"class":4825}," 30px",[3402,10493,10455],{"class":3852},[3402,10495,4025],{"class":3669},[3402,10497,10485],{"class":4825},[3402,10499,4698],{"class":3669},[3402,10501,10485],{"class":4825},[3402,10503,4698],{"class":3669},[3402,10505,10485],{"class":4825},[3402,10507,4698],{"class":3669},[3402,10509,10510],{"class":4825},"0.5",[3402,10512,4075],{"class":3669},[3402,10514,10515,10518,10520,10523],{"class":3404,"line":3465},[3402,10516,10517],{"class":9336},"  overflow",[3402,10519,3679],{"class":3669},[3402,10521,10522],{"class":10341},"hidden",[3402,10524,3903],{"class":3669},[3402,10526,10527,10530,10532,10535,10537,10540,10542,10545],{"class":3404,"line":3470},[3402,10528,10529],{"class":9336},"  font-family",[3402,10531,3679],{"class":3669},[3402,10533,10534],{"class":3682},"'Inter'",[3402,10536,4698],{"class":3669},[3402,10538,10539],{"class":10341},"system-ui",[3402,10541,4698],{"class":3669},[3402,10543,10544],{"class":10341},"sans-serif",[3402,10546,3903],{"class":3669},[3402,10548,10549,10552,10554,10557],{"class":3404,"line":3476},[3402,10550,10551],{"class":9336},"  color",[3402,10553,3679],{"class":3669},[3402,10555,10556],{"class":10341},"#f3f4f6",[3402,10558,3903],{"class":3669},[3402,10560,10561],{"class":3404,"line":3482},[3402,10562,3497],{"class":3669},[3402,10564,10565],{"class":3404,"line":3488},[3402,10566,3427],{"emptyLinePlaceholder":3426},[3402,10568,10569,10572],{"class":3404,"line":3494},[3402,10570,10571],{"class":10328},".chat-header",[3402,10573,7302],{"class":3669},[3402,10575,10576,10578,10580,10582],{"class":3404,"line":3500},[3402,10577,10336],{"class":9336},[3402,10579,3679],{"class":3669},[3402,10581,10342],{"class":10341},[3402,10583,3903],{"class":3669},[3402,10585,10586,10589,10591,10594],{"class":3404,"line":3505},[3402,10587,10588],{"class":9336},"  justify-content",[3402,10590,3679],{"class":3669},[3402,10592,10593],{"class":10341},"space-between",[3402,10595,3903],{"class":3669},[3402,10597,10598,10601,10603,10606],{"class":3404,"line":3511},[3402,10599,10600],{"class":9336},"  align-items",[3402,10602,3679],{"class":3669},[3402,10604,10605],{"class":10341},"center",[3402,10607,3903],{"class":3669},[3402,10609,10610,10613,10615,10617,10620],{"class":3404,"line":3517},[3402,10611,10612],{"class":9336},"  padding",[3402,10614,3679],{"class":3669},[3402,10616,10437],{"class":4825},[3402,10618,10619],{"class":4825}," 24px",[3402,10621,3903],{"class":3669},[3402,10623,10624,10626,10628,10630,10632,10635,10637,10640,10642,10645,10647,10650],{"class":3404,"line":3523},[3402,10625,10400],{"class":9336},[3402,10627,3679],{"class":3669},[3402,10629,10405],{"class":3852},[3402,10631,4025],{"class":3669},[3402,10633,10634],{"class":4825},"31",[3402,10636,4698],{"class":3669},[3402,10638,10639],{"class":4825},"41",[3402,10641,4698],{"class":3669},[3402,10643,10644],{"class":4825},"55",[3402,10646,4698],{"class":3669},[3402,10648,10649],{"class":4825},"0.8",[3402,10651,4075],{"class":3669},[3402,10653,10654,10657,10659,10661,10663,10665,10667,10669,10671,10673,10675,10677,10679,10682],{"class":3404,"line":3529},[3402,10655,10656],{"class":9336},"  border-bottom",[3402,10658,3679],{"class":3669},[3402,10660,10449],{"class":4825},[3402,10662,10452],{"class":10341},[3402,10664,10455],{"class":3852},[3402,10666,4025],{"class":3669},[3402,10668,10460],{"class":4825},[3402,10670,4698],{"class":3669},[3402,10672,10460],{"class":4825},[3402,10674,4698],{"class":3669},[3402,10676,10460],{"class":4825},[3402,10678,4698],{"class":3669},[3402,10680,10681],{"class":4825},"0.05",[3402,10683,4075],{"class":3669},[3402,10685,10686],{"class":3404,"line":3535},[3402,10687,3497],{"class":3669},[3402,10689,10690],{"class":3404,"line":3541},[3402,10691,3427],{"emptyLinePlaceholder":3426},[3402,10693,10694,10696,10699],{"class":3404,"line":3829},[3402,10695,10571],{"class":10328},[3402,10697,10698],{"class":10328}," h2",[3402,10700,7302],{"class":3669},[3402,10702,10703,10706,10708,10711],{"class":3404,"line":4327},[3402,10704,10705],{"class":9336},"  font-size",[3402,10707,3679],{"class":3669},[3402,10709,10710],{"class":4825},"1.25rem",[3402,10712,3903],{"class":3669},[3402,10714,10715,10718,10720,10723],{"class":3404,"line":4350},[3402,10716,10717],{"class":9336},"  font-weight",[3402,10719,3679],{"class":3669},[3402,10721,10722],{"class":4825},"600",[3402,10724,3903],{"class":3669},[3402,10726,10727,10729,10731,10733],{"class":3404,"line":4373},[3402,10728,10385],{"class":9336},[3402,10730,3679],{"class":3669},[3402,10732,10485],{"class":4825},[3402,10734,3903],{"class":3669},[3402,10736,10737,10739,10741,10744,10746,10749,10751,10754,10756,10759],{"class":3404,"line":4402},[3402,10738,10400],{"class":9336},[3402,10740,3679],{"class":3669},[3402,10742,10743],{"class":3852},"linear-gradient",[3402,10745,4025],{"class":3669},[3402,10747,10748],{"class":4825},"90deg",[3402,10750,4698],{"class":3669},[3402,10752,10753],{"class":10341},"#60a5fa",[3402,10755,4698],{"class":3669},[3402,10757,10758],{"class":10341},"#a78bfa",[3402,10760,4075],{"class":3669},[3402,10762,10763,10766,10768,10770],{"class":3404,"line":4427},[3402,10764,10765],{"class":9336},"  -webkit-background-clip",[3402,10767,3679],{"class":3669},[3402,10769,6256],{"class":10341},[3402,10771,3903],{"class":3669},[3402,10773,10774,10777,10779,10782],{"class":3404,"line":4453},[3402,10775,10776],{"class":9336},"  -webkit-text-fill-color",[3402,10778,3679],{"class":3669},[3402,10780,10781],{"class":10341},"transparent",[3402,10783,3903],{"class":3669},[3402,10785,10786],{"class":3404,"line":4458},[3402,10787,3497],{"class":3669},[3402,10789,10790],{"class":3404,"line":4470},[3402,10791,3427],{"emptyLinePlaceholder":3426},[3402,10793,10794,10797],{"class":3404,"line":4495},[3402,10795,10796],{"class":10328},".clear-btn",[3402,10798,7302],{"class":3669},[3402,10800,10801,10803,10805,10807],{"class":3404,"line":4520},[3402,10802,10400],{"class":9336},[3402,10804,3679],{"class":3669},[3402,10806,10781],{"class":10341},[3402,10808,3903],{"class":3669},[3402,10810,10811,10813,10815,10817,10819,10821,10823,10826,10828,10831,10833,10835,10837,10840],{"class":3404,"line":4525},[3402,10812,10444],{"class":9336},[3402,10814,3679],{"class":3669},[3402,10816,10449],{"class":4825},[3402,10818,10452],{"class":10341},[3402,10820,10455],{"class":3852},[3402,10822,4025],{"class":3669},[3402,10824,10825],{"class":4825},"239",[3402,10827,4698],{"class":3669},[3402,10829,10830],{"class":4825},"68",[3402,10832,4698],{"class":3669},[3402,10834,10830],{"class":4825},[3402,10836,4698],{"class":3669},[3402,10838,10839],{"class":4825},"0.4",[3402,10841,4075],{"class":3669},[3402,10843,10844,10846,10848,10851],{"class":3404,"line":4539},[3402,10845,10551],{"class":9336},[3402,10847,3679],{"class":3669},[3402,10849,10850],{"class":10341},"#ef4444",[3402,10852,3903],{"class":3669},[3402,10854,10855,10857,10859,10862,10865],{"class":3404,"line":4544},[3402,10856,10612],{"class":9336},[3402,10858,3679],{"class":3669},[3402,10860,10861],{"class":4825},"6px",[3402,10863,10864],{"class":4825}," 12px",[3402,10866,3903],{"class":3669},[3402,10868,10869,10871,10873,10875],{"class":3404,"line":4561},[3402,10870,10432],{"class":9336},[3402,10872,3679],{"class":3669},[3402,10874,10861],{"class":4825},[3402,10876,3903],{"class":3669},[3402,10878,10879,10882,10884,10887],{"class":3404,"line":4583},[3402,10880,10881],{"class":9336},"  cursor",[3402,10883,3679],{"class":3669},[3402,10885,10886],{"class":10341},"pointer",[3402,10888,3903],{"class":3669},[3402,10890,10891,10893,10895,10898],{"class":3404,"line":4588},[3402,10892,10705],{"class":9336},[3402,10894,3679],{"class":3669},[3402,10896,10897],{"class":4825},"0.875rem",[3402,10899,3903],{"class":3669},[3402,10901,10902,10905,10907,10910,10913,10916],{"class":3404,"line":4608},[3402,10903,10904],{"class":9336},"  transition",[3402,10906,3679],{"class":3669},[3402,10908,10909],{"class":10341},"all",[3402,10911,10912],{"class":4825}," 0.2s",[3402,10914,10915],{"class":10341}," ease",[3402,10917,3903],{"class":3669},[3402,10919,10920],{"class":3404,"line":4613},[3402,10921,3497],{"class":3669},[3402,10923,10924],{"class":3404,"line":4626},[3402,10925,3427],{"emptyLinePlaceholder":3426},[3402,10927,10928,10931],{"class":3404,"line":4631},[3402,10929,10930],{"class":10328},".clear-btn:hover",[3402,10932,7302],{"class":3669},[3402,10934,10935,10937,10939,10941,10943,10945,10947,10949,10951,10953,10955,10957],{"class":3404,"line":4636},[3402,10936,10400],{"class":9336},[3402,10938,3679],{"class":3669},[3402,10940,10405],{"class":3852},[3402,10942,4025],{"class":3669},[3402,10944,10825],{"class":4825},[3402,10946,4698],{"class":3669},[3402,10948,10830],{"class":4825},[3402,10950,4698],{"class":3669},[3402,10952,10830],{"class":4825},[3402,10954,4698],{"class":3669},[3402,10956,10473],{"class":4825},[3402,10958,4075],{"class":3669},[3402,10960,10961],{"class":3404,"line":4653},[3402,10962,3497],{"class":3669},[3402,10964,10965],{"class":3404,"line":4659},[3402,10966,3427],{"emptyLinePlaceholder":3426},[3402,10968,10969,10972],{"class":3404,"line":4671},[3402,10970,10971],{"class":10328},".messages-list",[3402,10973,7302],{"class":3669},[3402,10975,10976,10979,10981,10983],{"class":3404,"line":4715},[3402,10977,10978],{"class":9336},"  flex",[3402,10980,3679],{"class":3669},[3402,10982,9818],{"class":4825},[3402,10984,3903],{"class":3669},[3402,10986,10987,10989,10991,10994],{"class":3404,"line":4720},[3402,10988,10612],{"class":9336},[3402,10990,3679],{"class":3669},[3402,10992,10993],{"class":4825},"24px",[3402,10995,3903],{"class":3669},[3402,10997,10998,11001,11003,11006],{"class":3404,"line":4743},[3402,10999,11000],{"class":9336},"  overflow-y",[3402,11002,3679],{"class":3669},[3402,11004,11005],{"class":10341},"auto",[3402,11007,3903],{"class":3669},[3402,11009,11010,11012,11014,11016],{"class":3404,"line":4749},[3402,11011,10336],{"class":9336},[3402,11013,3679],{"class":3669},[3402,11015,10342],{"class":10341},[3402,11017,3903],{"class":3669},[3402,11019,11020,11022,11024,11026],{"class":3404,"line":4777},[3402,11021,10349],{"class":9336},[3402,11023,3679],{"class":3669},[3402,11025,10354],{"class":10341},[3402,11027,3903],{"class":3669},[3402,11029,11030,11033,11035,11037],{"class":3404,"line":4783},[3402,11031,11032],{"class":9336},"  gap",[3402,11034,3679],{"class":3669},[3402,11036,10390],{"class":4825},[3402,11038,3903],{"class":3669},[3402,11040,11041],{"class":3404,"line":4788},[3402,11042,3497],{"class":3669},[3402,11044,11045],{"class":3404,"line":4804},[3402,11046,3427],{"emptyLinePlaceholder":3426},[3402,11048,11049,11052],{"class":3404,"line":4817},[3402,11050,11051],{"class":10328},".message-bubble",[3402,11053,7302],{"class":3669},[3402,11055,11056,11058,11060,11062],{"class":3404,"line":4831},[3402,11057,10336],{"class":9336},[3402,11059,3679],{"class":3669},[3402,11061,10342],{"class":10341},[3402,11063,3903],{"class":3669},[3402,11065,11066,11068,11070,11072],{"class":3404,"line":4844},[3402,11067,11032],{"class":9336},[3402,11069,3679],{"class":3669},[3402,11071,10437],{"class":4825},[3402,11073,3903],{"class":3669},[3402,11075,11076,11078,11080,11083],{"class":3404,"line":4856},[3402,11077,10373],{"class":9336},[3402,11079,3679],{"class":3669},[3402,11081,11082],{"class":4825},"85%",[3402,11084,3903],{"class":3669},[3402,11086,11087,11090,11092,11095],{"class":3404,"line":4867},[3402,11088,11089],{"class":9336},"  align-self",[3402,11091,3679],{"class":3669},[3402,11093,11094],{"class":10341},"flex-start",[3402,11096,3903],{"class":3669},[3402,11098,11099],{"class":3404,"line":4873},[3402,11100,3497],{"class":3669},[3402,11102,11103],{"class":3404,"line":4878},[3402,11104,3427],{"emptyLinePlaceholder":3426},[3402,11106,11107,11110],{"class":3404,"line":4893},[3402,11108,11109],{"class":10328},".message-bubble.user",[3402,11111,7302],{"class":3669},[3402,11113,11114,11116,11118,11121],{"class":3404,"line":4898},[3402,11115,11089],{"class":9336},[3402,11117,3679],{"class":3669},[3402,11119,11120],{"class":10341},"flex-end",[3402,11122,3903],{"class":3669},[3402,11124,11125,11127,11129,11132],{"class":3404,"line":4914},[3402,11126,10349],{"class":9336},[3402,11128,3679],{"class":3669},[3402,11130,11131],{"class":10341},"row-reverse",[3402,11133,3903],{"class":3669},[3402,11135,11136],{"class":3404,"line":4919},[3402,11137,3497],{"class":3669},[3402,11139,11140],{"class":3404,"line":4949},[3402,11141,3427],{"emptyLinePlaceholder":3426},[3402,11143,11144,11147],{"class":3404,"line":4954},[3402,11145,11146],{"class":10328},".avatar",[3402,11148,7302],{"class":3669},[3402,11150,11151,11154,11156,11159],{"class":3404,"line":4969},[3402,11152,11153],{"class":9336},"  width",[3402,11155,3679],{"class":3669},[3402,11157,11158],{"class":4825},"40px",[3402,11160,3903],{"class":3669},[3402,11162,11163,11165,11167,11169],{"class":3404,"line":4974},[3402,11164,10361],{"class":9336},[3402,11166,3679],{"class":3669},[3402,11168,11158],{"class":4825},[3402,11170,3903],{"class":3669},[3402,11172,11173,11175,11177,11180],{"class":3404,"line":4987},[3402,11174,10432],{"class":9336},[3402,11176,3679],{"class":3669},[3402,11178,11179],{"class":4825},"50%",[3402,11181,3903],{"class":3669},[3402,11183,11184,11186,11188,11190],{"class":3404,"line":5000},[3402,11185,10336],{"class":9336},[3402,11187,3679],{"class":3669},[3402,11189,10342],{"class":10341},[3402,11191,3903],{"class":3669},[3402,11193,11194,11196,11198,11200],{"class":3404,"line":5012},[3402,11195,10600],{"class":9336},[3402,11197,3679],{"class":3669},[3402,11199,10605],{"class":10341},[3402,11201,3903],{"class":3669},[3402,11203,11204,11206,11208,11210],{"class":3404,"line":5048},[3402,11205,10588],{"class":9336},[3402,11207,3679],{"class":3669},[3402,11209,10605],{"class":10341},[3402,11211,3903],{"class":3669},[3402,11213,11214,11216,11218,11220,11222,11224,11226,11228,11230,11232,11234,11236],{"class":3404,"line":5053},[3402,11215,10400],{"class":9336},[3402,11217,3679],{"class":3669},[3402,11219,10405],{"class":3852},[3402,11221,4025],{"class":3669},[3402,11223,10460],{"class":4825},[3402,11225,4698],{"class":3669},[3402,11227,10460],{"class":4825},[3402,11229,4698],{"class":3669},[3402,11231,10460],{"class":4825},[3402,11233,4698],{"class":3669},[3402,11235,10681],{"class":4825},[3402,11237,4075],{"class":3669},[3402,11239,11240,11242,11244,11246,11248,11250,11252,11254,11256,11258,11260,11262,11264,11266],{"class":3404,"line":5058},[3402,11241,10444],{"class":9336},[3402,11243,3679],{"class":3669},[3402,11245,10449],{"class":4825},[3402,11247,10452],{"class":10341},[3402,11249,10455],{"class":3852},[3402,11251,4025],{"class":3669},[3402,11253,10460],{"class":4825},[3402,11255,4698],{"class":3669},[3402,11257,10460],{"class":4825},[3402,11259,4698],{"class":3669},[3402,11261,10460],{"class":4825},[3402,11263,4698],{"class":3669},[3402,11265,10473],{"class":4825},[3402,11267,4075],{"class":3669},[3402,11269,11270,11272,11274,11276],{"class":3404,"line":5064},[3402,11271,10705],{"class":9336},[3402,11273,3679],{"class":3669},[3402,11275,10710],{"class":4825},[3402,11277,3903],{"class":3669},[3402,11279,11280],{"class":3404,"line":5069},[3402,11281,3497],{"class":3669},[3402,11283,11284],{"class":3404,"line":5096},[3402,11285,3427],{"emptyLinePlaceholder":3426},[3402,11287,11288,11290,11293],{"class":3404,"line":5101},[3402,11289,11109],{"class":10328},[3402,11291,11292],{"class":10328}," .avatar",[3402,11294,7302],{"class":3669},[3402,11296,11297,11299,11301,11303,11305,11308,11310,11313,11315,11318,11320,11323],{"class":3404,"line":5132},[3402,11298,10400],{"class":9336},[3402,11300,3679],{"class":3669},[3402,11302,10405],{"class":3852},[3402,11304,4025],{"class":3669},[3402,11306,11307],{"class":4825},"96",[3402,11309,4698],{"class":3669},[3402,11311,11312],{"class":4825},"165",[3402,11314,4698],{"class":3669},[3402,11316,11317],{"class":4825},"250",[3402,11319,4698],{"class":3669},[3402,11321,11322],{"class":4825},"0.2",[3402,11324,4075],{"class":3669},[3402,11326,11327,11330,11332,11334,11336,11338,11340,11342,11344,11346,11348,11351],{"class":3404,"line":5154},[3402,11328,11329],{"class":9336},"  border-color",[3402,11331,3679],{"class":3669},[3402,11333,10405],{"class":3852},[3402,11335,4025],{"class":3669},[3402,11337,11307],{"class":4825},[3402,11339,4698],{"class":3669},[3402,11341,11312],{"class":4825},[3402,11343,4698],{"class":3669},[3402,11345,11317],{"class":4825},[3402,11347,4698],{"class":3669},[3402,11349,11350],{"class":4825},"0.3",[3402,11352,4075],{"class":3669},[3402,11354,11355],{"class":3404,"line":5159},[3402,11356,3497],{"class":3669},[3402,11358,11359],{"class":3404,"line":5189},[3402,11360,3427],{"emptyLinePlaceholder":3426},[3402,11362,11363,11366],{"class":3404,"line":5235},[3402,11364,11365],{"class":10328},".content",[3402,11367,7302],{"class":3669},[3402,11369,11370,11372,11374,11376,11378,11380,11382,11384,11386,11388,11390,11393],{"class":3404,"line":5257},[3402,11371,10400],{"class":9336},[3402,11373,3679],{"class":3669},[3402,11375,10405],{"class":3852},[3402,11377,4025],{"class":3669},[3402,11379,10634],{"class":4825},[3402,11381,4698],{"class":3669},[3402,11383,10639],{"class":4825},[3402,11385,4698],{"class":3669},[3402,11387,10644],{"class":4825},[3402,11389,4698],{"class":3669},[3402,11391,11392],{"class":4825},"0.6",[3402,11394,4075],{"class":3669},[3402,11396,11397,11399,11401,11404,11407],{"class":3404,"line":5263},[3402,11398,10612],{"class":9336},[3402,11400,3679],{"class":3669},[3402,11402,11403],{"class":4825},"12px",[3402,11405,11406],{"class":4825}," 18px",[3402,11408,3903],{"class":3669},[3402,11410,11411,11413,11415,11417],{"class":3404,"line":5280},[3402,11412,10432],{"class":9336},[3402,11414,3679],{"class":3669},[3402,11416,11403],{"class":4825},[3402,11418,3903],{"class":3669},[3402,11420,11421,11423,11425,11427,11429,11431,11433,11435,11437,11439,11441,11443,11445,11447],{"class":3404,"line":5285},[3402,11422,10444],{"class":9336},[3402,11424,3679],{"class":3669},[3402,11426,10449],{"class":4825},[3402,11428,10452],{"class":10341},[3402,11430,10455],{"class":3852},[3402,11432,4025],{"class":3669},[3402,11434,10460],{"class":4825},[3402,11436,4698],{"class":3669},[3402,11438,10460],{"class":4825},[3402,11440,4698],{"class":3669},[3402,11442,10460],{"class":4825},[3402,11444,4698],{"class":3669},[3402,11446,10681],{"class":4825},[3402,11448,4075],{"class":3669},[3402,11450,11451,11454,11456,11459],{"class":3404,"line":5291},[3402,11452,11453],{"class":9336},"  line-height",[3402,11455,3679],{"class":3669},[3402,11457,11458],{"class":4825},"1.6",[3402,11460,3903],{"class":3669},[3402,11462,11463],{"class":3404,"line":5331},[3402,11464,3497],{"class":3669},[3402,11466,11467],{"class":3404,"line":5336},[3402,11468,3427],{"emptyLinePlaceholder":3426},[3402,11470,11471,11473,11476],{"class":3404,"line":5341},[3402,11472,11109],{"class":10328},[3402,11474,11475],{"class":10328}," .content",[3402,11477,7302],{"class":3669},[3402,11479,11480,11482,11484,11486,11488,11491,11493,11496,11498,11501,11503,11505],{"class":3404,"line":8592},[3402,11481,10400],{"class":9336},[3402,11483,3679],{"class":3669},[3402,11485,10405],{"class":3852},[3402,11487,4025],{"class":3669},[3402,11489,11490],{"class":4825},"59",[3402,11492,4698],{"class":3669},[3402,11494,11495],{"class":4825},"130",[3402,11497,4698],{"class":3669},[3402,11499,11500],{"class":4825},"246",[3402,11502,4698],{"class":3669},[3402,11504,11322],{"class":4825},[3402,11506,4075],{"class":3669},[3402,11508,11509,11511,11513,11515,11517,11519,11521,11523,11525,11527,11529,11531],{"class":3404,"line":8619},[3402,11510,11329],{"class":9336},[3402,11512,3679],{"class":3669},[3402,11514,10405],{"class":3852},[3402,11516,4025],{"class":3669},[3402,11518,11490],{"class":4825},[3402,11520,4698],{"class":3669},[3402,11522,11495],{"class":4825},[3402,11524,4698],{"class":3669},[3402,11526,11500],{"class":4825},[3402,11528,4698],{"class":3669},[3402,11530,11350],{"class":4825},[3402,11532,4075],{"class":3669},[3402,11534,11535],{"class":3404,"line":8633},[3402,11536,3497],{"class":3669},[3402,11538,11539],{"class":3404,"line":8651},[3402,11540,3427],{"emptyLinePlaceholder":3426},[3402,11542,11543,11546],{"class":3404,"line":8680},[3402,11544,11545],{"class":10328},".plain-text",[3402,11547,7302],{"class":3669},[3402,11549,11550,11552,11554,11556],{"class":3404,"line":8686},[3402,11551,10385],{"class":9336},[3402,11553,3679],{"class":3669},[3402,11555,10485],{"class":4825},[3402,11557,3903],{"class":3669},[3402,11559,11560,11563,11565,11568],{"class":3404,"line":8691},[3402,11561,11562],{"class":9336},"  white-space",[3402,11564,3679],{"class":3669},[3402,11566,11567],{"class":10341},"pre-wrap",[3402,11569,3903],{"class":3669},[3402,11571,11572],{"class":3404,"line":8696},[3402,11573,3497],{"class":3669},[3402,11575,11576],{"class":3404,"line":8708},[3402,11577,3427],{"emptyLinePlaceholder":3426},[3402,11579,11580,11583],{"class":3404,"line":8713},[3402,11581,11582],{"class":10328},".inline-code",[3402,11584,7302],{"class":3669},[3402,11586,11587,11589,11591,11593,11595,11597,11599,11601,11603,11605,11607,11609],{"class":3404,"line":8727},[3402,11588,10400],{"class":9336},[3402,11590,3679],{"class":3669},[3402,11592,10405],{"class":3852},[3402,11594,4025],{"class":3669},[3402,11596,10460],{"class":4825},[3402,11598,4698],{"class":3669},[3402,11600,10460],{"class":4825},[3402,11602,4698],{"class":3669},[3402,11604,10460],{"class":4825},[3402,11606,4698],{"class":3669},[3402,11608,10473],{"class":4825},[3402,11610,4075],{"class":3669},[3402,11612,11613,11615,11617,11620,11623],{"class":3404,"line":8732},[3402,11614,10612],{"class":9336},[3402,11616,3679],{"class":3669},[3402,11618,11619],{"class":4825},"2px",[3402,11621,11622],{"class":4825}," 6px",[3402,11624,3903],{"class":3669},[3402,11626,11627,11629,11631,11634],{"class":3404,"line":8751},[3402,11628,10432],{"class":9336},[3402,11630,3679],{"class":3669},[3402,11632,11633],{"class":4825},"4px",[3402,11635,3903],{"class":3669},[3402,11637,11638,11640,11642,11645],{"class":3404,"line":8767},[3402,11639,10529],{"class":9336},[3402,11641,3679],{"class":3669},[3402,11643,11644],{"class":10341},"monospace",[3402,11646,3903],{"class":3669},[3402,11648,11649],{"class":3404,"line":8784},[3402,11650,3497],{"class":3669},[3402,11652,11653],{"class":3404,"line":8795},[3402,11654,3427],{"emptyLinePlaceholder":3426},[3402,11656,11657,11660],{"class":3404,"line":8800},[3402,11658,11659],{"class":10328},".code-block",[3402,11661,7302],{"class":3669},[3402,11663,11664,11666,11668,11671,11674],{"class":3404,"line":8806},[3402,11665,10432],{"class":9336},[3402,11667,3679],{"class":3669},[3402,11669,11670],{"class":4825},"8px",[3402,11672,11673],{"class":3980}," !important",[3402,11675,3903],{"class":3669},[3402,11677,11678,11680,11682,11685,11688,11690],{"class":3404,"line":8811},[3402,11679,10385],{"class":9336},[3402,11681,3679],{"class":3669},[3402,11683,11684],{"class":4825},"10px",[3402,11686,11687],{"class":4825}," 0",[3402,11689,11673],{"class":3980},[3402,11691,3903],{"class":3669},[3402,11693,11694,11696,11698,11701],{"class":3404,"line":8829},[3402,11695,10705],{"class":9336},[3402,11697,3679],{"class":3669},[3402,11699,11700],{"class":4825},"0.9rem",[3402,11702,3903],{"class":3669},[3402,11704,11705],{"class":3404,"line":8837},[3402,11706,3497],{"class":3669},[3402,11708,11709],{"class":3404,"line":8845},[3402,11710,3427],{"emptyLinePlaceholder":3426},[3402,11712,11713,11716],{"class":3404,"line":8855},[3402,11714,11715],{"class":10328},".chat-input-form",[3402,11717,7302],{"class":3669},[3402,11719,11720,11722,11724,11726],{"class":3404,"line":8860},[3402,11721,10336],{"class":9336},[3402,11723,3679],{"class":3669},[3402,11725,10342],{"class":10341},[3402,11727,3903],{"class":3669},[3402,11729,11730,11732,11734,11736,11738],{"class":3404,"line":8890},[3402,11731,10612],{"class":9336},[3402,11733,3679],{"class":3669},[3402,11735,10390],{"class":4825},[3402,11737,10619],{"class":4825},[3402,11739,3903],{"class":3669},[3402,11741,11743,11745,11747,11749,11751,11753,11755,11757,11759,11761,11763,11765],{"class":3404,"line":11742},121,[3402,11744,10400],{"class":9336},[3402,11746,3679],{"class":3669},[3402,11748,10405],{"class":3852},[3402,11750,4025],{"class":3669},[3402,11752,10634],{"class":4825},[3402,11754,4698],{"class":3669},[3402,11756,10639],{"class":4825},[3402,11758,4698],{"class":3669},[3402,11760,10644],{"class":4825},[3402,11762,4698],{"class":3669},[3402,11764,10649],{"class":4825},[3402,11766,4075],{"class":3669},[3402,11768,11770,11773,11775,11777,11779,11781,11783,11785,11787,11789,11791,11793,11795,11797],{"class":3404,"line":11769},122,[3402,11771,11772],{"class":9336},"  border-top",[3402,11774,3679],{"class":3669},[3402,11776,10449],{"class":4825},[3402,11778,10452],{"class":10341},[3402,11780,10455],{"class":3852},[3402,11782,4025],{"class":3669},[3402,11784,10460],{"class":4825},[3402,11786,4698],{"class":3669},[3402,11788,10460],{"class":4825},[3402,11790,4698],{"class":3669},[3402,11792,10460],{"class":4825},[3402,11794,4698],{"class":3669},[3402,11796,10681],{"class":4825},[3402,11798,4075],{"class":3669},[3402,11800,11802,11804,11806,11808],{"class":3404,"line":11801},123,[3402,11803,11032],{"class":9336},[3402,11805,3679],{"class":3669},[3402,11807,11403],{"class":4825},[3402,11809,3903],{"class":3669},[3402,11811,11813],{"class":3404,"line":11812},124,[3402,11814,3497],{"class":3669},[3402,11816,11818],{"class":3404,"line":11817},125,[3402,11819,3427],{"emptyLinePlaceholder":3426},[3402,11821,11823,11825,11828],{"class":3404,"line":11822},126,[3402,11824,11715],{"class":10328},[3402,11826,11827],{"class":10328}," input",[3402,11829,7302],{"class":3669},[3402,11831,11833,11835,11837,11839],{"class":3404,"line":11832},127,[3402,11834,10978],{"class":9336},[3402,11836,3679],{"class":3669},[3402,11838,9818],{"class":4825},[3402,11840,3903],{"class":3669},[3402,11842,11844,11846,11848,11850,11852,11854,11856,11858,11860,11862,11864,11866],{"class":3404,"line":11843},128,[3402,11845,10400],{"class":9336},[3402,11847,3679],{"class":3669},[3402,11849,10405],{"class":3852},[3402,11851,4025],{"class":3669},[3402,11853,10410],{"class":4825},[3402,11855,4698],{"class":3669},[3402,11857,10415],{"class":4825},[3402,11859,4698],{"class":3669},[3402,11861,10420],{"class":4825},[3402,11863,4698],{"class":3669},[3402,11865,10649],{"class":4825},[3402,11867,4075],{"class":3669},[3402,11869,11871,11873,11875,11877,11879,11881,11883,11885,11887,11889,11891,11893,11895,11897],{"class":3404,"line":11870},129,[3402,11872,10444],{"class":9336},[3402,11874,3679],{"class":3669},[3402,11876,10449],{"class":4825},[3402,11878,10452],{"class":10341},[3402,11880,10455],{"class":3852},[3402,11882,4025],{"class":3669},[3402,11884,10460],{"class":4825},[3402,11886,4698],{"class":3669},[3402,11888,10460],{"class":4825},[3402,11890,4698],{"class":3669},[3402,11892,10460],{"class":4825},[3402,11894,4698],{"class":3669},[3402,11896,10473],{"class":4825},[3402,11898,4075],{"class":3669},[3402,11900,11902,11904,11906,11908],{"class":3404,"line":11901},130,[3402,11903,10432],{"class":9336},[3402,11905,3679],{"class":3669},[3402,11907,11670],{"class":4825},[3402,11909,3903],{"class":3669},[3402,11911,11913,11915,11917,11919,11922],{"class":3404,"line":11912},131,[3402,11914,10612],{"class":9336},[3402,11916,3679],{"class":3669},[3402,11918,11403],{"class":4825},[3402,11920,11921],{"class":4825}," 16px",[3402,11923,3903],{"class":3669},[3402,11925,11927,11929,11931,11934],{"class":3404,"line":11926},132,[3402,11928,10551],{"class":9336},[3402,11930,3679],{"class":3669},[3402,11932,11933],{"class":10341},"#fff",[3402,11935,3903],{"class":3669},[3402,11937,11939,11941,11943,11946],{"class":3404,"line":11938},133,[3402,11940,10705],{"class":9336},[3402,11942,3679],{"class":3669},[3402,11944,11945],{"class":4825},"1rem",[3402,11947,3903],{"class":3669},[3402,11949,11951,11954,11956,11959],{"class":3404,"line":11950},134,[3402,11952,11953],{"class":9336},"  outline",[3402,11955,3679],{"class":3669},[3402,11957,11958],{"class":10341},"none",[3402,11960,3903],{"class":3669},[3402,11962,11964,11966,11969,11972],{"class":3404,"line":11963},135,[3402,11965,10904],{"class":9336},[3402,11967,11968],{"class":3669},": border-color ",[3402,11970,11971],{"class":4825},"0.2s",[3402,11973,3903],{"class":3669},[3402,11975,11977],{"class":3404,"line":11976},136,[3402,11978,3497],{"class":3669},[3402,11980,11982],{"class":3404,"line":11981},137,[3402,11983,3427],{"emptyLinePlaceholder":3426},[3402,11985,11987,11989,11992],{"class":3404,"line":11986},138,[3402,11988,11715],{"class":10328},[3402,11990,11991],{"class":10328}," input:focus",[3402,11993,7302],{"class":3669},[3402,11995,11997,11999,12001,12004],{"class":3404,"line":11996},139,[3402,11998,11329],{"class":9336},[3402,12000,3679],{"class":3669},[3402,12002,12003],{"class":10341},"#3b82f6",[3402,12005,3903],{"class":3669},[3402,12007,12009],{"class":3404,"line":12008},140,[3402,12010,3497],{"class":3669},[3402,12012,12014],{"class":3404,"line":12013},141,[3402,12015,3427],{"emptyLinePlaceholder":3426},[3402,12017,12019,12022,12024,12027],{"class":3404,"line":12018},142,[3402,12020,12021],{"class":10328},".send-btn",[3402,12023,4698],{"class":3669},[3402,12025,12026],{"class":10328},".stop-btn",[3402,12028,7302],{"class":3669},[3402,12030,12032,12034,12036,12038,12040],{"class":3404,"line":12031},143,[3402,12033,10612],{"class":9336},[3402,12035,3679],{"class":3669},[3402,12037,11403],{"class":4825},[3402,12039,10619],{"class":4825},[3402,12041,3903],{"class":3669},[3402,12043,12045,12047,12049,12051],{"class":3404,"line":12044},144,[3402,12046,10432],{"class":9336},[3402,12048,3679],{"class":3669},[3402,12050,11670],{"class":4825},[3402,12052,3903],{"class":3669},[3402,12054,12056,12058,12060,12062],{"class":3404,"line":12055},145,[3402,12057,10444],{"class":9336},[3402,12059,3679],{"class":3669},[3402,12061,11958],{"class":10341},[3402,12063,3903],{"class":3669},[3402,12065,12067,12069,12071,12074],{"class":3404,"line":12066},146,[3402,12068,10717],{"class":9336},[3402,12070,3679],{"class":3669},[3402,12072,12073],{"class":4825},"500",[3402,12075,3903],{"class":3669},[3402,12077,12079,12081,12083,12085],{"class":3404,"line":12078},147,[3402,12080,10881],{"class":9336},[3402,12082,3679],{"class":3669},[3402,12084,10886],{"class":10341},[3402,12086,3903],{"class":3669},[3402,12088,12090,12092,12095,12097],{"class":3404,"line":12089},148,[3402,12091,10904],{"class":9336},[3402,12093,12094],{"class":3669},": opacity ",[3402,12096,11971],{"class":4825},[3402,12098,3903],{"class":3669},[3402,12100,12102],{"class":3404,"line":12101},149,[3402,12103,3497],{"class":3669},[3402,12105,12107],{"class":3404,"line":12106},150,[3402,12108,3427],{"emptyLinePlaceholder":3426},[3402,12110,12112,12114],{"class":3404,"line":12111},151,[3402,12113,12021],{"class":10328},[3402,12115,7302],{"class":3669},[3402,12117,12119,12121,12123,12125],{"class":3404,"line":12118},152,[3402,12120,10400],{"class":9336},[3402,12122,3679],{"class":3669},[3402,12124,12003],{"class":10341},[3402,12126,3903],{"class":3669},[3402,12128,12130,12132,12134,12137],{"class":3404,"line":12129},153,[3402,12131,10551],{"class":9336},[3402,12133,3679],{"class":3669},[3402,12135,12136],{"class":10341},"white",[3402,12138,3903],{"class":3669},[3402,12140,12142],{"class":3404,"line":12141},154,[3402,12143,3497],{"class":3669},[3402,12145,12147],{"class":3404,"line":12146},155,[3402,12148,3427],{"emptyLinePlaceholder":3426},[3402,12150,12152,12155],{"class":3404,"line":12151},156,[3402,12153,12154],{"class":10328},".send-btn:disabled",[3402,12156,7302],{"class":3669},[3402,12158,12160,12162,12164,12167],{"class":3404,"line":12159},157,[3402,12161,10400],{"class":9336},[3402,12163,3679],{"class":3669},[3402,12165,12166],{"class":10341},"#4b5563",[3402,12168,3903],{"class":3669},[3402,12170,12172,12174,12176,12179],{"class":3404,"line":12171},158,[3402,12173,10881],{"class":9336},[3402,12175,3679],{"class":3669},[3402,12177,12178],{"class":10341},"not-allowed",[3402,12180,3903],{"class":3669},[3402,12182,12184],{"class":3404,"line":12183},159,[3402,12185,3497],{"class":3669},[3402,12187,12189],{"class":3404,"line":12188},160,[3402,12190,3427],{"emptyLinePlaceholder":3426},[3402,12192,12194,12196],{"class":3404,"line":12193},161,[3402,12195,12026],{"class":10328},[3402,12197,7302],{"class":3669},[3402,12199,12201,12203,12205,12207],{"class":3404,"line":12200},162,[3402,12202,10400],{"class":9336},[3402,12204,3679],{"class":3669},[3402,12206,10850],{"class":10341},[3402,12208,3903],{"class":3669},[3402,12210,12212,12214,12216,12218],{"class":3404,"line":12211},163,[3402,12213,10551],{"class":9336},[3402,12215,3679],{"class":3669},[3402,12217,12136],{"class":10341},[3402,12219,3903],{"class":3669},[3402,12221,12223],{"class":3404,"line":12222},164,[3402,12224,3497],{"class":3669},[3402,12226,12228],{"class":3404,"line":12227},165,[3402,12229,3427],{"emptyLinePlaceholder":3426},[3402,12231,12233,12236,12238,12241],{"class":3404,"line":12232},166,[3402,12234,12235],{"class":10328},".send-btn:hover",[3402,12237,4698],{"class":3669},[3402,12239,12240],{"class":10328},".stop-btn:hover",[3402,12242,7302],{"class":3669},[3402,12244,12246,12249,12251,12254],{"class":3404,"line":12245},167,[3402,12247,12248],{"class":9336},"  opacity",[3402,12250,3679],{"class":3669},[3402,12252,12253],{"class":4825},"0.9",[3402,12255,3903],{"class":3669},[3402,12257,12259],{"class":3404,"line":12258},168,[3402,12260,3497],{"class":3669},[3546,12262],{},[3348,12264,12266],{"id":12265},"bedrock-knowledge-bases-rag-retrieval-augmented-generation","Bedrock Knowledge Bases: RAG (Retrieval-Augmented Generation)",[3353,12268,12269,12272],{},[3356,12270,12271],{},"RAG"," — це архітектурний патерн, який збагачує запити користувачів актуальним корпоративним контекстом із внутрішніх документів (PDF, Markdown, DOCX, CSV тощо), що дозволяє уникнути галюцинацій та обмежень у знаннях LLM.",[3353,12274,12275,12278],{},[3356,12276,12277],{},"Amazon Bedrock Knowledge Bases"," автоматизує весь конвеєр RAG:",[12280,12281,12282,12285,12288,12291],"ol",{},[3364,12283,12284],{},"Завантаження документів в S3.",[3364,12286,12287],{},"Розбиття на шматки (Chunking).",[3364,12289,12290],{},"Перетворення тексту у векторні представлення за допомогою моделей Embedding (наприклад, Titan Embeddings V2).",[3364,12292,12293],{},"Збереження та індексація у векторній базі даних (наприклад, Amazon OpenSearch Serverless).",[3864,12295,12297],{"id":12296},"net-8-сервіс-для-виконання-rag-запитів",".NET 8 сервіс для виконання RAG-запитів",[3353,12299,12300],{},"Для роботи з клієнтом Bedrock Agent Runtime потрібний такий NuGet-пакет:",[3392,12302,12304],{"className":3843,"code":12303,"language":3845,"meta":3397,"style":3397},"dotnet add package AWSSDK.BedrockAgentRuntime\n",[3399,12305,12306],{"__ignoreMap":3397},[3402,12307,12308,12310,12312,12314],{"class":3404,"line":3405},[3402,12309,3853],{"class":3852},[3402,12311,3856],{"class":3682},[3402,12313,3859],{"class":3682},[3402,12315,12316],{"class":3682}," AWSSDK.BedrockAgentRuntime\n",[3392,12318,12321],{"className":3880,"code":12319,"filename":12320,"language":3883,"meta":3397,"style":3397},"using Amazon.BedrockAgentRuntime;\nusing Amazon.BedrockAgentRuntime.Model;\n\nnamespace AwsAiPlayground.Services;\n\npublic record DocumentCitation(\n    string Content,\n    string SourceUri,\n    Dictionary\u003Cstring, string> Metadata);\n\npublic record RagResponse(\n    string Answer,\n    string SessionId,\n    List\u003CDocumentCitation> Citations);\n\npublic record RetrievedDocument(\n    string Content,\n    double Score,\n    string SourceUri);\n\npublic sealed class KnowledgeBaseService\n{\n    private readonly IAmazonBedrockAgentRuntime _agentRuntimeClient;\n    private readonly string _knowledgeBaseId;\n    private const string ClaudeArn = \"arn:aws:bedrock:us-east-1::foundation-model\u002Fanthropic.claude-3-5-sonnet-20241022-v2:0\";\n\n    public KnowledgeBaseService(\n        IAmazonBedrockAgentRuntime agentRuntimeClient, \n        string knowledgeBaseId)\n    {\n        _agentRuntimeClient = agentRuntimeClient;\n        _knowledgeBaseId = knowledgeBaseId;\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F Автоматичний RAG: Bedrock сам шукає інформацію у векторній БД та генерує відповідь за допомогою Claude.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async Task\u003CRagResponse> QueryKnowledgeBaseAsync(string question, string? sessionId = null)\n    {\n        var request = new RetrieveAndGenerateRequest\n        {\n            Input = new RetrieveAndGenerateInput { Text = question },\n            RetrieveAndGenerateConfiguration = new RetrieveAndGenerateConfiguration\n            {\n                Type = RetrieveAndGenerateType.KNOWLEDGE_BASE,\n                KnowledgeBaseConfiguration = new KnowledgeBaseRetrieveAndGenerateConfiguration\n                {\n                    KnowledgeBaseId = _knowledgeBaseId,\n                    ModelArn = ClaudeArn,\n                    GenerationConfiguration = new GenerationConfiguration\n                    {\n                        PromptTemplate = new PromptTemplate\n                        {\n                            TextPromptTemplate = \n                                \"\"\"\n                                Дай відповідь на запитання виключно на основі наданих документів.\n                                Якщо інформації у документах недостатньо, скажи \"Я не знайшов відповіді у внутрішній базі даних\".\n                                \n                                Документи:\n                                $search_results$\n                                \n                                Запитання:\n                                $query$\n                                \"\"\"\n                        }\n                    },\n                    RetrievalConfiguration = new KnowledgeBaseRetrievalConfiguration\n                    {\n                        VectorSearchConfiguration = new KnowledgeBaseVectorSearchConfiguration\n                        {\n                            NumberOfResults = 4 \u002F\u002F передати 4 найбільш релевантні фрагменти\n                        }\n                    }\n                }\n            },\n            SessionId = sessionId\n        };\n\n        var response = await _agentRuntimeClient.RetrieveAndGenerateAsync(request);\n\n        var citations = response.Citations\n            .SelectMany(c => c.RetrievedReferences)\n            .Select(r => new DocumentCitation(\n                Content: r.Content.Text,\n                SourceUri: r.Location.S3Location?.Uri ?? \"Unknown\",\n                Metadata: r.Metadata.ToDictionary(kv => kv.Key, kv => kv.Value.ToString() ?? \"\")\n            ))\n            .DistinctBy(c => c.SourceUri)\n            .ToList();\n\n        return new RagResponse(\n            Answer: response.Output.Text,\n            SessionId: response.SessionId,\n            Citations: citations\n        );\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F Тільки пошук: повертає релевантні шматки документів без генерації відповіді.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async Task\u003CList\u003CRetrievedDocument>> RetrieveDocumentsOnlyAsync(string query, int maxResults = 5)\n    {\n        var request = new RetrieveRequest\n        {\n            KnowledgeBaseId = _knowledgeBaseId,\n            RetrievalQuery = new KnowledgeBaseQuery { Text = query },\n            RetrievalConfiguration = new KnowledgeBaseRetrievalConfiguration\n            {\n                VectorSearchConfiguration = new KnowledgeBaseVectorSearchConfiguration\n                {\n                    NumberOfResults = maxResults\n                }\n            }\n        };\n\n        var response = await _agentRuntimeClient.RetrieveAsync(request);\n\n        return response.RetrievalResults\n            .Select(r => new RetrievedDocument(\n                Content: r.Content.Text,\n                Score: r.Score,\n                SourceUri: r.Location.S3Location?.Uri ?? \"Unknown\"\n            ))\n            .ToList();\n    }\n}\n","Services\u002FKnowledgeBaseService.cs",[3399,12322,12323,12336,12352,12356,12368,12372,12383,12393,12402,12422,12426,12437,12446,12455,12472,12476,12487,12495,12505,12513,12517,12528,12532,12546,12559,12577,12581,12590,12601,12610,12614,12626,12638,12642,12646,12656,12661,12671,12711,12715,12728,12732,12755,12767,12771,12788,12800,12804,12816,12828,12840,12844,12856,12860,12868,12873,12878,12883,12888,12893,12898,12902,12907,12912,12916,12920,12925,12937,12941,12953,12957,12970,12974,12978,12982,12987,12997,13001,13005,13028,13032,13048,13071,13091,13110,13142,13199,13204,13226,13235,13239,13250,13270,13285,13295,13299,13303,13307,13317,13322,13332,13376,13380,13393,13397,13408,13431,13442,13446,13457,13461,13471,13475,13479,13483,13487,13510,13514,13525,13543,13561,13577,13602,13606,13614,13618],{"__ignoreMap":3397},[3402,12324,12325,12327,12329,12331,12334],{"class":3404,"line":3405},[3402,12326,3891],{"class":3890},[3402,12328,3621],{"class":3894},[3402,12330,3654],{"class":3669},[3402,12332,12333],{"class":3894},"BedrockAgentRuntime",[3402,12335,3903],{"class":3669},[3402,12337,12338,12340,12342,12344,12346,12348,12350],{"class":3404,"line":3411},[3402,12339,3891],{"class":3890},[3402,12341,3621],{"class":3894},[3402,12343,3654],{"class":3669},[3402,12345,12333],{"class":3894},[3402,12347,3654],{"class":3669},[3402,12349,3969],{"class":3894},[3402,12351,3903],{"class":3669},[3402,12353,12354],{"class":3404,"line":3417},[3402,12355,3427],{"emptyLinePlaceholder":3426},[3402,12357,12358,12360,12362,12364,12366],{"class":3404,"line":3423},[3402,12359,3981],{"class":3980},[3402,12361,3984],{"class":3894},[3402,12363,3654],{"class":3669},[3402,12365,3989],{"class":3894},[3402,12367,3903],{"class":3669},[3402,12369,12370],{"class":3404,"line":3430},[3402,12371,3427],{"emptyLinePlaceholder":3426},[3402,12373,12374,12376,12378,12381],{"class":3404,"line":3436},[3402,12375,4000],{"class":3980},[3402,12377,4003],{"class":3980},[3402,12379,12380],{"class":3894}," DocumentCitation",[3402,12382,4009],{"class":3669},[3402,12384,12385,12388,12391],{"class":3404,"line":3441},[3402,12386,12387],{"class":3980},"    string",[3402,12389,12390],{"class":4037}," Content",[3402,12392,3686],{"class":3669},[3402,12394,12395,12397,12400],{"class":3404,"line":3447},[3402,12396,12387],{"class":3980},[3402,12398,12399],{"class":4037}," SourceUri",[3402,12401,3686],{"class":3669},[3402,12403,12404,12407,12409,12411,12413,12415,12417,12420],{"class":3404,"line":3453},[3402,12405,12406],{"class":3894},"    Dictionary",[3402,12408,4063],{"class":3669},[3402,12410,4034],{"class":3980},[3402,12412,4698],{"class":3669},[3402,12414,4034],{"class":3980},[3402,12416,4069],{"class":3669},[3402,12418,12419],{"class":4037},"Metadata",[3402,12421,4075],{"class":3669},[3402,12423,12424],{"class":3404,"line":3459},[3402,12425,3427],{"emptyLinePlaceholder":3426},[3402,12427,12428,12430,12432,12435],{"class":3404,"line":3465},[3402,12429,4000],{"class":3980},[3402,12431,4003],{"class":3980},[3402,12433,12434],{"class":3894}," RagResponse",[3402,12436,4009],{"class":3669},[3402,12438,12439,12441,12444],{"class":3404,"line":3470},[3402,12440,12387],{"class":3980},[3402,12442,12443],{"class":4037}," Answer",[3402,12445,3686],{"class":3669},[3402,12447,12448,12450,12453],{"class":3404,"line":3476},[3402,12449,12387],{"class":3980},[3402,12451,12452],{"class":4037}," SessionId",[3402,12454,3686],{"class":3669},[3402,12456,12457,12460,12462,12465,12467,12470],{"class":3404,"line":3482},[3402,12458,12459],{"class":3894},"    List",[3402,12461,4063],{"class":3669},[3402,12463,12464],{"class":3894},"DocumentCitation",[3402,12466,4069],{"class":3669},[3402,12468,12469],{"class":4037},"Citations",[3402,12471,4075],{"class":3669},[3402,12473,12474],{"class":3404,"line":3488},[3402,12475,3427],{"emptyLinePlaceholder":3426},[3402,12477,12478,12480,12482,12485],{"class":3404,"line":3494},[3402,12479,4000],{"class":3980},[3402,12481,4003],{"class":3980},[3402,12483,12484],{"class":3894}," RetrievedDocument",[3402,12486,4009],{"class":3669},[3402,12488,12489,12491,12493],{"class":3404,"line":3500},[3402,12490,12387],{"class":3980},[3402,12492,12390],{"class":4037},[3402,12494,3686],{"class":3669},[3402,12496,12497,12500,12503],{"class":3404,"line":3505},[3402,12498,12499],{"class":3980},"    double",[3402,12501,12502],{"class":4037}," Score",[3402,12504,3686],{"class":3669},[3402,12506,12507,12509,12511],{"class":3404,"line":3511},[3402,12508,12387],{"class":3980},[3402,12510,12399],{"class":4037},[3402,12512,4075],{"class":3669},[3402,12514,12515],{"class":3404,"line":3517},[3402,12516,3427],{"emptyLinePlaceholder":3426},[3402,12518,12519,12521,12523,12525],{"class":3404,"line":3523},[3402,12520,4000],{"class":3980},[3402,12522,4530],{"class":3980},[3402,12524,4533],{"class":3980},[3402,12526,12527],{"class":3894}," KnowledgeBaseService\n",[3402,12529,12530],{"class":3404,"line":3529},[3402,12531,3670],{"class":3669},[3402,12533,12534,12536,12538,12541,12544],{"class":3404,"line":3535},[3402,12535,4547],{"class":3980},[3402,12537,4550],{"class":3980},[3402,12539,12540],{"class":3894}," IAmazonBedrockAgentRuntime",[3402,12542,12543],{"class":4037}," _agentRuntimeClient",[3402,12545,3903],{"class":3669},[3402,12547,12548,12550,12552,12554,12557],{"class":3404,"line":3541},[3402,12549,4547],{"class":3980},[3402,12551,4550],{"class":3980},[3402,12553,4569],{"class":3980},[3402,12555,12556],{"class":4037}," _knowledgeBaseId",[3402,12558,3903],{"class":3669},[3402,12560,12561,12563,12565,12567,12570,12572,12575],{"class":3404,"line":3829},[3402,12562,4547],{"class":3980},[3402,12564,4566],{"class":3980},[3402,12566,4569],{"class":3980},[3402,12568,12569],{"class":4037}," ClaudeArn",[3402,12571,4575],{"class":3669},[3402,12573,12574],{"class":3682},"\"arn:aws:bedrock:us-east-1::foundation-model\u002Fanthropic.claude-3-5-sonnet-20241022-v2:0\"",[3402,12576,3903],{"class":3669},[3402,12578,12579],{"class":3404,"line":4327},[3402,12580,3427],{"emptyLinePlaceholder":3426},[3402,12582,12583,12585,12588],{"class":3404,"line":4350},[3402,12584,4591],{"class":3980},[3402,12586,12587],{"class":3852}," KnowledgeBaseService",[3402,12589,4009],{"class":3669},[3402,12591,12592,12595,12598],{"class":3404,"line":4373},[3402,12593,12594],{"class":3894},"        IAmazonBedrockAgentRuntime",[3402,12596,12597],{"class":4037}," agentRuntimeClient",[3402,12599,12600],{"class":3669},", \n",[3402,12602,12603,12605,12608],{"class":3404,"line":4402},[3402,12604,5606],{"class":3980},[3402,12606,12607],{"class":4037}," knowledgeBaseId",[3402,12609,4605],{"class":3669},[3402,12611,12612],{"class":3404,"line":4427},[3402,12613,3699],{"class":3669},[3402,12615,12616,12619,12621,12624],{"class":3404,"line":4453},[3402,12617,12618],{"class":4037},"        _agentRuntimeClient",[3402,12620,4575],{"class":3669},[3402,12622,12623],{"class":4037},"agentRuntimeClient",[3402,12625,3903],{"class":3669},[3402,12627,12628,12631,12633,12636],{"class":3404,"line":4458},[3402,12629,12630],{"class":4037},"        _knowledgeBaseId",[3402,12632,4575],{"class":3669},[3402,12634,12635],{"class":4037},"knowledgeBaseId",[3402,12637,3903],{"class":3669},[3402,12639,12640],{"class":3404,"line":4470},[3402,12641,3821],{"class":3669},[3402,12643,12644],{"class":3404,"line":4495},[3402,12645,3427],{"emptyLinePlaceholder":3426},[3402,12647,12648,12650,12652,12654],{"class":3404,"line":4520},[3402,12649,4640],{"class":4639},[3402,12651,4063],{"class":4643},[3402,12653,4647],{"class":4646},[3402,12655,4650],{"class":4643},[3402,12657,12658],{"class":3404,"line":4525},[3402,12659,12660],{"class":4639},"    \u002F\u002F\u002F Автоматичний RAG: Bedrock сам шукає інформацію у векторній БД та генерує відповідь за допомогою Claude.\n",[3402,12662,12663,12665,12667,12669],{"class":3404,"line":4539},[3402,12664,4640],{"class":4639},[3402,12666,4664],{"class":4643},[3402,12668,4647],{"class":4646},[3402,12670,4650],{"class":4643},[3402,12672,12673,12675,12677,12679,12681,12684,12686,12689,12691,12693,12696,12698,12700,12702,12705,12707,12709],{"class":3404,"line":4544},[3402,12674,4591],{"class":3980},[3402,12676,4676],{"class":3980},[3402,12678,4679],{"class":3894},[3402,12680,4063],{"class":3669},[3402,12682,12683],{"class":3894},"RagResponse",[3402,12685,4069],{"class":3669},[3402,12687,12688],{"class":3852},"QueryKnowledgeBaseAsync",[3402,12690,4025],{"class":3669},[3402,12692,4034],{"class":3980},[3402,12694,12695],{"class":4037}," question",[3402,12697,4698],{"class":3669},[3402,12699,4034],{"class":3980},[3402,12701,4249],{"class":3669},[3402,12703,12704],{"class":4037},"sessionId",[3402,12706,4575],{"class":3669},[3402,12708,4710],{"class":3980},[3402,12710,4605],{"class":3669},[3402,12712,12713],{"class":3404,"line":4561},[3402,12714,3699],{"class":3669},[3402,12716,12717,12719,12721,12723,12725],{"class":3404,"line":4583},[3402,12718,4723],{"class":3980},[3402,12720,4959],{"class":4037},[3402,12722,4575],{"class":3669},[3402,12724,4731],{"class":3980},[3402,12726,12727],{"class":3894}," RetrieveAndGenerateRequest\n",[3402,12729,12730],{"class":3404,"line":4588},[3402,12731,4746],{"class":3669},[3402,12733,12734,12737,12739,12741,12744,12746,12748,12750,12753],{"class":3404,"line":4608},[3402,12735,12736],{"class":4037},"            Input",[3402,12738,4575],{"class":3669},[3402,12740,4731],{"class":3980},[3402,12742,12743],{"class":3894}," RetrieveAndGenerateInput",[3402,12745,6707],{"class":3669},[3402,12747,3900],{"class":4037},[3402,12749,4575],{"class":3669},[3402,12751,12752],{"class":4037},"question",[3402,12754,7971],{"class":3669},[3402,12756,12757,12760,12762,12764],{"class":3404,"line":4613},[3402,12758,12759],{"class":4037},"            RetrieveAndGenerateConfiguration",[3402,12761,4575],{"class":3669},[3402,12763,4731],{"class":3980},[3402,12765,12766],{"class":3894}," RetrieveAndGenerateConfiguration\n",[3402,12768,12769],{"class":3404,"line":4626},[3402,12770,5995],{"class":3669},[3402,12772,12773,12776,12778,12781,12783,12786],{"class":3404,"line":4631},[3402,12774,12775],{"class":4037},"                Type",[3402,12777,4575],{"class":3669},[3402,12779,12780],{"class":4037},"RetrieveAndGenerateType",[3402,12782,3654],{"class":3669},[3402,12784,12785],{"class":4037},"KNOWLEDGE_BASE",[3402,12787,3686],{"class":3669},[3402,12789,12790,12793,12795,12797],{"class":3404,"line":4636},[3402,12791,12792],{"class":4037},"                KnowledgeBaseConfiguration",[3402,12794,4575],{"class":3669},[3402,12796,4731],{"class":3980},[3402,12798,12799],{"class":3894}," KnowledgeBaseRetrieveAndGenerateConfiguration\n",[3402,12801,12802],{"class":3404,"line":4653},[3402,12803,6159],{"class":3669},[3402,12805,12806,12809,12811,12814],{"class":3404,"line":4659},[3402,12807,12808],{"class":4037},"                    KnowledgeBaseId",[3402,12810,4575],{"class":3669},[3402,12812,12813],{"class":4037},"_knowledgeBaseId",[3402,12815,3686],{"class":3669},[3402,12817,12818,12821,12823,12826],{"class":3404,"line":4671},[3402,12819,12820],{"class":4037},"                    ModelArn",[3402,12822,4575],{"class":3669},[3402,12824,12825],{"class":4037},"ClaudeArn",[3402,12827,3686],{"class":3669},[3402,12829,12830,12833,12835,12837],{"class":3404,"line":4715},[3402,12831,12832],{"class":4037},"                    GenerationConfiguration",[3402,12834,4575],{"class":3669},[3402,12836,4731],{"class":3980},[3402,12838,12839],{"class":3894}," GenerationConfiguration\n",[3402,12841,12842],{"class":3404,"line":4720},[3402,12843,6217],{"class":3669},[3402,12845,12846,12849,12851,12853],{"class":3404,"line":4743},[3402,12847,12848],{"class":4037},"                        PromptTemplate",[3402,12850,4575],{"class":3669},[3402,12852,4731],{"class":3980},[3402,12854,12855],{"class":3894}," PromptTemplate\n",[3402,12857,12858],{"class":3404,"line":4749},[3402,12859,6263],{"class":3669},[3402,12861,12862,12865],{"class":3404,"line":4777},[3402,12863,12864],{"class":4037},"                            TextPromptTemplate",[3402,12866,12867],{"class":3669}," = \n",[3402,12869,12870],{"class":3404,"line":4783},[3402,12871,12872],{"class":3682},"                                \"\"\"\n",[3402,12874,12875],{"class":3404,"line":4788},[3402,12876,12877],{"class":3682},"                                Дай відповідь на запитання виключно на основі наданих документів.\n",[3402,12879,12880],{"class":3404,"line":4804},[3402,12881,12882],{"class":3682},"                                Якщо інформації у документах недостатньо, скажи \"Я не знайшов відповіді у внутрішній базі даних\".\n",[3402,12884,12885],{"class":3404,"line":4817},[3402,12886,12887],{"class":3682},"                                \n",[3402,12889,12890],{"class":3404,"line":4831},[3402,12891,12892],{"class":3682},"                                Документи:\n",[3402,12894,12895],{"class":3404,"line":4844},[3402,12896,12897],{"class":3682},"                                $search_results$\n",[3402,12899,12900],{"class":3404,"line":4856},[3402,12901,12887],{"class":3682},[3402,12903,12904],{"class":3404,"line":4867},[3402,12905,12906],{"class":3682},"                                Запитання:\n",[3402,12908,12909],{"class":3404,"line":4873},[3402,12910,12911],{"class":3682},"                                $query$\n",[3402,12913,12914],{"class":3404,"line":4878},[3402,12915,12872],{"class":3682},[3402,12917,12918],{"class":3404,"line":4893},[3402,12919,6279],{"class":3669},[3402,12921,12922],{"class":3404,"line":4898},[3402,12923,12924],{"class":3669},"                    },\n",[3402,12926,12927,12930,12932,12934],{"class":3404,"line":4914},[3402,12928,12929],{"class":4037},"                    RetrievalConfiguration",[3402,12931,4575],{"class":3669},[3402,12933,4731],{"class":3980},[3402,12935,12936],{"class":3894}," KnowledgeBaseRetrievalConfiguration\n",[3402,12938,12939],{"class":3404,"line":4919},[3402,12940,6217],{"class":3669},[3402,12942,12943,12946,12948,12950],{"class":3404,"line":4949},[3402,12944,12945],{"class":4037},"                        VectorSearchConfiguration",[3402,12947,4575],{"class":3669},[3402,12949,4731],{"class":3980},[3402,12951,12952],{"class":3894}," KnowledgeBaseVectorSearchConfiguration\n",[3402,12954,12955],{"class":3404,"line":4954},[3402,12956,6263],{"class":3669},[3402,12958,12959,12962,12964,12967],{"class":3404,"line":4969},[3402,12960,12961],{"class":4037},"                            NumberOfResults",[3402,12963,4575],{"class":3669},[3402,12965,12966],{"class":4825},"4",[3402,12968,12969],{"class":4639}," \u002F\u002F передати 4 найбільш релевантні фрагменти\n",[3402,12971,12972],{"class":3404,"line":4974},[3402,12973,6279],{"class":3669},[3402,12975,12976],{"class":3404,"line":4987},[3402,12977,6284],{"class":3669},[3402,12979,12980],{"class":3404,"line":5000},[3402,12981,6289],{"class":3669},[3402,12983,12984],{"class":3404,"line":5012},[3402,12985,12986],{"class":3669},"            },\n",[3402,12988,12989,12992,12994],{"class":3404,"line":5048},[3402,12990,12991],{"class":4037},"            SessionId",[3402,12993,4575],{"class":3669},[3402,12995,12996],{"class":4037},"sessionId\n",[3402,12998,12999],{"class":3404,"line":5053},[3402,13000,4780],{"class":3669},[3402,13002,13003],{"class":3404,"line":5058},[3402,13004,3427],{"emptyLinePlaceholder":3426},[3402,13006,13007,13009,13011,13013,13015,13017,13019,13022,13024,13026],{"class":3404,"line":5064},[3402,13008,4723],{"class":3980},[3402,13010,5075],{"class":4037},[3402,13012,4575],{"class":3669},[3402,13014,5080],{"class":3980},[3402,13016,12543],{"class":4037},[3402,13018,3654],{"class":3669},[3402,13020,13021],{"class":3852},"RetrieveAndGenerateAsync",[3402,13023,4025],{"class":3669},[3402,13025,5091],{"class":4037},[3402,13027,4075],{"class":3669},[3402,13029,13030],{"class":3404,"line":5069},[3402,13031,3427],{"emptyLinePlaceholder":3426},[3402,13033,13034,13036,13039,13041,13043,13045],{"class":3404,"line":5096},[3402,13035,4723],{"class":3980},[3402,13037,13038],{"class":4037}," citations",[3402,13040,4575],{"class":3669},[3402,13042,5122],{"class":4037},[3402,13044,3654],{"class":3669},[3402,13046,13047],{"class":4037},"Citations\n",[3402,13049,13050,13053,13056,13058,13060,13062,13064,13066,13069],{"class":3404,"line":5101},[3402,13051,13052],{"class":3669},"            .",[3402,13054,13055],{"class":3852},"SelectMany",[3402,13057,4025],{"class":3669},[3402,13059,5209],{"class":4037},[3402,13061,5212],{"class":3669},[3402,13063,5209],{"class":4037},[3402,13065,3654],{"class":3669},[3402,13067,13068],{"class":4037},"RetrievedReferences",[3402,13070,4605],{"class":3669},[3402,13072,13073,13075,13078,13080,13083,13085,13087,13089],{"class":3404,"line":5132},[3402,13074,13052],{"class":3669},[3402,13076,13077],{"class":3852},"Select",[3402,13079,4025],{"class":3669},[3402,13081,13082],{"class":4037},"r",[3402,13084,5212],{"class":3669},[3402,13086,4731],{"class":3980},[3402,13088,12380],{"class":3894},[3402,13090,4009],{"class":3669},[3402,13092,13093,13096,13098,13100,13102,13104,13106,13108],{"class":3404,"line":5154},[3402,13094,13095],{"class":4037},"                Content",[3402,13097,3679],{"class":3669},[3402,13099,13082],{"class":4037},[3402,13101,3654],{"class":3669},[3402,13103,4072],{"class":4037},[3402,13105,3654],{"class":3669},[3402,13107,3900],{"class":4037},[3402,13109,3686],{"class":3669},[3402,13111,13112,13115,13117,13119,13121,13124,13126,13129,13131,13134,13137,13140],{"class":3404,"line":5159},[3402,13113,13114],{"class":4037},"                SourceUri",[3402,13116,3679],{"class":3669},[3402,13118,13082],{"class":4037},[3402,13120,3654],{"class":3669},[3402,13122,13123],{"class":4037},"Location",[3402,13125,3654],{"class":3669},[3402,13127,13128],{"class":4037},"S3Location",[3402,13130,5197],{"class":3669},[3402,13132,13133],{"class":4037},"Uri",[3402,13135,13136],{"class":3669}," ?? ",[3402,13138,13139],{"class":3682},"\"Unknown\"",[3402,13141,3686],{"class":3669},[3402,13143,13144,13147,13149,13151,13153,13155,13157,13160,13162,13165,13167,13169,13171,13174,13176,13178,13180,13182,13184,13187,13189,13192,13194,13197],{"class":3404,"line":5189},[3402,13145,13146],{"class":4037},"                Metadata",[3402,13148,3679],{"class":3669},[3402,13150,13082],{"class":4037},[3402,13152,3654],{"class":3669},[3402,13154,12419],{"class":4037},[3402,13156,3654],{"class":3669},[3402,13158,13159],{"class":3852},"ToDictionary",[3402,13161,4025],{"class":3669},[3402,13163,13164],{"class":4037},"kv",[3402,13166,5212],{"class":3669},[3402,13168,13164],{"class":4037},[3402,13170,3654],{"class":3669},[3402,13172,13173],{"class":4037},"Key",[3402,13175,4698],{"class":3669},[3402,13177,13164],{"class":4037},[3402,13179,5212],{"class":3669},[3402,13181,13164],{"class":4037},[3402,13183,3654],{"class":3669},[3402,13185,13186],{"class":4037},"Value",[3402,13188,3654],{"class":3669},[3402,13190,13191],{"class":3852},"ToString",[3402,13193,8263],{"class":3669},[3402,13195,13196],{"class":3682},"\"\"",[3402,13198,4605],{"class":3669},[3402,13200,13201],{"class":3404,"line":5235},[3402,13202,13203],{"class":3669},"            ))\n",[3402,13205,13206,13208,13211,13213,13215,13217,13219,13221,13224],{"class":3404,"line":5257},[3402,13207,13052],{"class":3669},[3402,13209,13210],{"class":3852},"DistinctBy",[3402,13212,4025],{"class":3669},[3402,13214,5209],{"class":4037},[3402,13216,5212],{"class":3669},[3402,13218,5209],{"class":4037},[3402,13220,3654],{"class":3669},[3402,13222,13223],{"class":4037},"SourceUri",[3402,13225,4605],{"class":3669},[3402,13227,13228,13230,13233],{"class":3404,"line":5263},[3402,13229,13052],{"class":3669},[3402,13231,13232],{"class":3852},"ToList",[3402,13234,5151],{"class":3669},[3402,13236,13237],{"class":3404,"line":5280},[3402,13238,3427],{"emptyLinePlaceholder":3426},[3402,13240,13241,13244,13246,13248],{"class":3404,"line":5285},[3402,13242,13243],{"class":3890},"        return",[3402,13245,5244],{"class":3980},[3402,13247,12434],{"class":3894},[3402,13249,4009],{"class":3669},[3402,13251,13252,13255,13257,13259,13261,13264,13266,13268],{"class":3404,"line":5291},[3402,13253,13254],{"class":4037},"            Answer",[3402,13256,3679],{"class":3669},[3402,13258,5122],{"class":4037},[3402,13260,3654],{"class":3669},[3402,13262,13263],{"class":4037},"Output",[3402,13265,3654],{"class":3669},[3402,13267,3900],{"class":4037},[3402,13269,3686],{"class":3669},[3402,13271,13272,13274,13276,13278,13280,13283],{"class":3404,"line":5331},[3402,13273,12991],{"class":4037},[3402,13275,3679],{"class":3669},[3402,13277,5122],{"class":4037},[3402,13279,3654],{"class":3669},[3402,13281,13282],{"class":4037},"SessionId",[3402,13284,3686],{"class":3669},[3402,13286,13287,13290,13292],{"class":3404,"line":5336},[3402,13288,13289],{"class":4037},"            Citations",[3402,13291,3679],{"class":3669},[3402,13293,13294],{"class":4037},"citations\n",[3402,13296,13297],{"class":3404,"line":5341},[3402,13298,4870],{"class":3669},[3402,13300,13301],{"class":3404,"line":8592},[3402,13302,3821],{"class":3669},[3402,13304,13305],{"class":3404,"line":8619},[3402,13306,3427],{"emptyLinePlaceholder":3426},[3402,13308,13309,13311,13313,13315],{"class":3404,"line":8633},[3402,13310,4640],{"class":4639},[3402,13312,4063],{"class":4643},[3402,13314,4647],{"class":4646},[3402,13316,4650],{"class":4643},[3402,13318,13319],{"class":3404,"line":8651},[3402,13320,13321],{"class":4639},"    \u002F\u002F\u002F Тільки пошук: повертає релевантні шматки документів без генерації відповіді.\n",[3402,13323,13324,13326,13328,13330],{"class":3404,"line":8680},[3402,13325,4640],{"class":4639},[3402,13327,4664],{"class":4643},[3402,13329,4647],{"class":4646},[3402,13331,4650],{"class":4643},[3402,13333,13334,13336,13338,13340,13342,13344,13346,13349,13352,13355,13357,13359,13362,13364,13366,13369,13371,13374],{"class":3404,"line":8686},[3402,13335,4591],{"class":3980},[3402,13337,4676],{"class":3980},[3402,13339,4679],{"class":3894},[3402,13341,4063],{"class":3669},[3402,13343,4060],{"class":3894},[3402,13345,4063],{"class":3669},[3402,13347,13348],{"class":3894},"RetrievedDocument",[3402,13350,13351],{"class":3669},">> ",[3402,13353,13354],{"class":3852},"RetrieveDocumentsOnlyAsync",[3402,13356,4025],{"class":3669},[3402,13358,4034],{"class":3980},[3402,13360,13361],{"class":4037}," query",[3402,13363,4698],{"class":3669},[3402,13365,4197],{"class":3980},[3402,13367,13368],{"class":4037}," maxResults",[3402,13370,4575],{"class":3669},[3402,13372,13373],{"class":4825},"5",[3402,13375,4605],{"class":3669},[3402,13377,13378],{"class":3404,"line":8691},[3402,13379,3699],{"class":3669},[3402,13381,13382,13384,13386,13388,13390],{"class":3404,"line":8696},[3402,13383,4723],{"class":3980},[3402,13385,4959],{"class":4037},[3402,13387,4575],{"class":3669},[3402,13389,4731],{"class":3980},[3402,13391,13392],{"class":3894}," RetrieveRequest\n",[3402,13394,13395],{"class":3404,"line":8708},[3402,13396,4746],{"class":3669},[3402,13398,13399,13402,13404,13406],{"class":3404,"line":8713},[3402,13400,13401],{"class":4037},"            KnowledgeBaseId",[3402,13403,4575],{"class":3669},[3402,13405,12813],{"class":4037},[3402,13407,3686],{"class":3669},[3402,13409,13410,13413,13415,13417,13420,13422,13424,13426,13429],{"class":3404,"line":8727},[3402,13411,13412],{"class":4037},"            RetrievalQuery",[3402,13414,4575],{"class":3669},[3402,13416,4731],{"class":3980},[3402,13418,13419],{"class":3894}," KnowledgeBaseQuery",[3402,13421,6707],{"class":3669},[3402,13423,3900],{"class":4037},[3402,13425,4575],{"class":3669},[3402,13427,13428],{"class":4037},"query",[3402,13430,7971],{"class":3669},[3402,13432,13433,13436,13438,13440],{"class":3404,"line":8732},[3402,13434,13435],{"class":4037},"            RetrievalConfiguration",[3402,13437,4575],{"class":3669},[3402,13439,4731],{"class":3980},[3402,13441,12936],{"class":3894},[3402,13443,13444],{"class":3404,"line":8751},[3402,13445,5995],{"class":3669},[3402,13447,13448,13451,13453,13455],{"class":3404,"line":8767},[3402,13449,13450],{"class":4037},"                VectorSearchConfiguration",[3402,13452,4575],{"class":3669},[3402,13454,4731],{"class":3980},[3402,13456,12952],{"class":3894},[3402,13458,13459],{"class":3404,"line":8784},[3402,13460,6159],{"class":3669},[3402,13462,13463,13466,13468],{"class":3404,"line":8795},[3402,13464,13465],{"class":4037},"                    NumberOfResults",[3402,13467,4575],{"class":3669},[3402,13469,13470],{"class":4037},"maxResults\n",[3402,13472,13473],{"class":3404,"line":8800},[3402,13474,6289],{"class":3669},[3402,13476,13477],{"class":3404,"line":8806},[3402,13478,6294],{"class":3669},[3402,13480,13481],{"class":3404,"line":8811},[3402,13482,4780],{"class":3669},[3402,13484,13485],{"class":3404,"line":8829},[3402,13486,3427],{"emptyLinePlaceholder":3426},[3402,13488,13489,13491,13493,13495,13497,13499,13501,13504,13506,13508],{"class":3404,"line":8837},[3402,13490,4723],{"class":3980},[3402,13492,5075],{"class":4037},[3402,13494,4575],{"class":3669},[3402,13496,5080],{"class":3980},[3402,13498,12543],{"class":4037},[3402,13500,3654],{"class":3669},[3402,13502,13503],{"class":3852},"RetrieveAsync",[3402,13505,4025],{"class":3669},[3402,13507,5091],{"class":4037},[3402,13509,4075],{"class":3669},[3402,13511,13512],{"class":3404,"line":8845},[3402,13513,3427],{"emptyLinePlaceholder":3426},[3402,13515,13516,13518,13520,13522],{"class":3404,"line":8855},[3402,13517,13243],{"class":3890},[3402,13519,5075],{"class":4037},[3402,13521,3654],{"class":3669},[3402,13523,13524],{"class":4037},"RetrievalResults\n",[3402,13526,13527,13529,13531,13533,13535,13537,13539,13541],{"class":3404,"line":8860},[3402,13528,13052],{"class":3669},[3402,13530,13077],{"class":3852},[3402,13532,4025],{"class":3669},[3402,13534,13082],{"class":4037},[3402,13536,5212],{"class":3669},[3402,13538,4731],{"class":3980},[3402,13540,12484],{"class":3894},[3402,13542,4009],{"class":3669},[3402,13544,13545,13547,13549,13551,13553,13555,13557,13559],{"class":3404,"line":8890},[3402,13546,13095],{"class":4037},[3402,13548,3679],{"class":3669},[3402,13550,13082],{"class":4037},[3402,13552,3654],{"class":3669},[3402,13554,4072],{"class":4037},[3402,13556,3654],{"class":3669},[3402,13558,3900],{"class":4037},[3402,13560,3686],{"class":3669},[3402,13562,13563,13566,13568,13570,13572,13575],{"class":3404,"line":11742},[3402,13564,13565],{"class":4037},"                Score",[3402,13567,3679],{"class":3669},[3402,13569,13082],{"class":4037},[3402,13571,3654],{"class":3669},[3402,13573,13574],{"class":4037},"Score",[3402,13576,3686],{"class":3669},[3402,13578,13579,13581,13583,13585,13587,13589,13591,13593,13595,13597,13599],{"class":3404,"line":11769},[3402,13580,13114],{"class":4037},[3402,13582,3679],{"class":3669},[3402,13584,13082],{"class":4037},[3402,13586,3654],{"class":3669},[3402,13588,13123],{"class":4037},[3402,13590,3654],{"class":3669},[3402,13592,13128],{"class":4037},[3402,13594,5197],{"class":3669},[3402,13596,13133],{"class":4037},[3402,13598,13136],{"class":3669},[3402,13600,13601],{"class":3682},"\"Unknown\"\n",[3402,13603,13604],{"class":3404,"line":11801},[3402,13605,13203],{"class":3669},[3402,13607,13608,13610,13612],{"class":3404,"line":11812},[3402,13609,13052],{"class":3669},[3402,13611,13232],{"class":3852},[3402,13613,5151],{"class":3669},[3402,13615,13616],{"class":3404,"line":11817},[3402,13617,3821],{"class":3669},[3402,13619,13620],{"class":3404,"line":11822},[3402,13621,3497],{"class":3669},[3546,13623],{},[3348,13625,13627],{"id":13626},"bedrock-guardrails-безпека-та-фільтрація","Bedrock Guardrails: безпека та фільтрація",[3353,13629,13630,13633],{},[3356,13631,13632],{},"Bedrock Guardrails"," використовуються для встановлення правил фільтрації контенту, виявлення конфіденційних даних (PII), блокування заборонених тем або запобігання атакам типу prompt injection. Правила безпеки конфігуруються у консолі AWS Bedrock, після чого Guardrail застосовується до кожного запиту.",[3864,13635,13637],{"id":13636},"net-8-сервіс-з-модерацією-через-guardrails",".NET 8 сервіс з модерацією через Guardrails",[3392,13639,13642],{"className":3880,"code":13640,"filename":13641,"language":3883,"meta":3397,"style":3397},"using System.Text;\nusing System.Text.Json;\nusing Amazon.BedrockRuntime;\nusing Amazon.BedrockRuntime.Model;\n\nnamespace AwsAiPlayground.Services;\n\npublic record GuardrailResult(\n    string ResponseText,\n    bool WasBlocked,\n    string? BlockedReason);\n\npublic sealed class BedrockGuardrailService\n{\n    private readonly IAmazonBedrockRuntime _bedrockClient;\n    private readonly string _guardrailId;\n    private readonly string _guardrailVersion;\n    private const string ClaudeSonnetId = \"anthropic.claude-3-5-sonnet-20241022-v2:0\";\n\n    public BedrockGuardrailService(\n        IAmazonBedrockRuntime bedrockClient, \n        string guardrailId, \n        string guardrailVersion)\n    {\n        _bedrockClient = bedrockClient;\n        _guardrailId = guardrailId;\n        _guardrailVersion = guardrailVersion;\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F Викликає Claude 3.5 Sonnet із застосуванням налаштованого Guardrail.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async Task\u003CGuardrailResult> InvokeWithGuardrailAsync(string userMessage)\n    {\n        var messages = new List\u003CChatMessage>\n        {\n            new(\"user\", [new(\"text\", userMessage)])\n        };\n\n        var requestBody = new ClaudeRequestBody(\n            AnthropicVersion: \"bedrock-2023-05-31\",\n            MaxTokens: 1000,\n            Temperature: 0.5f,\n            System: \"Ти корисний віртуальний помічник банку.\",\n            Messages: messages\n        );\n\n        var serializedBody = JsonSerializer.Serialize(requestBody);\n\n        var request = new InvokeModelRequest\n        {\n            ModelId = ClaudeSonnetId,\n            ContentType = \"application\u002Fjson\",\n            Accept = \"application\u002Fjson\",\n            Body = new MemoryStream(Encoding.UTF8.GetBytes(serializedBody)),\n            \n            \u002F\u002F Налаштування Guardrail\n            GuardrailIdentifier = _guardrailId,\n            GuardrailVersion = _guardrailVersion\n        };\n\n        try\n        {\n            var response = await _bedrockClient.InvokeModelAsync(request);\n\n            \u002F\u002F Перевіряємо заголовок відповіді про втручання Guardrail\n            bool isIntervened = response.ResponseMetadata.Metadata\n                .TryGetValue(\"X-Amzn-Bedrock-Guardrail-Intervention\", out var isBlockedStr) \n                && isBlockedStr == \"true\";\n\n            using var reader = new StreamReader(response.Body);\n            var responseJson = await reader.ReadToEndAsync();\n\n            var result = JsonSerializer.Deserialize\u003CClaudeResponseBody>(responseJson);\n            var text = result?.Content.FirstOrDefault(c => c.Type == \"text\")?.Text ?? \"\";\n\n            if (isIntervened)\n            {\n                return new GuardrailResult(text, WasBlocked: true, \"Content was blocked or masked by Guardrail policies.\");\n            }\n\n            return new GuardrailResult(text, WasBlocked: false, BlockedReason: null);\n        }\n        catch (AmazonBedrockRuntimeException ex)\n        {\n            throw new Exception($\"AWS Bedrock Runtime Error: {ex.Message}\", ex);\n        }\n    }\n}\n","Services\u002FBedrockGuardrailService.cs",[3399,13643,13644,13656,13672,13684,13700,13704,13716,13720,13731,13740,13750,13761,13765,13776,13780,13792,13805,13818,13834,13838,13847,13856,13865,13874,13878,13888,13900,13912,13916,13920,13930,13935,13945,13972,13976,13994,13998,14021,14025,14029,14043,14053,14064,14075,14086,14094,14098,14102,14122,14126,14138,14142,14152,14162,14172,14201,14205,14210,14222,14232,14236,14240,14244,14248,14270,14274,14279,14301,14326,14341,14345,14369,14388,14392,14417,14462,14466,14477,14481,14510,14514,14518,14548,14552,14564,14568,14598,14602,14606],{"__ignoreMap":3397},[3402,13645,13646,13648,13650,13652,13654],{"class":3404,"line":3405},[3402,13647,3891],{"class":3890},[3402,13649,3895],{"class":3894},[3402,13651,3654],{"class":3669},[3402,13653,3900],{"class":3894},[3402,13655,3903],{"class":3669},[3402,13657,13658,13660,13662,13664,13666,13668,13670],{"class":3404,"line":3411},[3402,13659,3891],{"class":3890},[3402,13661,3895],{"class":3894},[3402,13663,3654],{"class":3669},[3402,13665,3900],{"class":3894},[3402,13667,3654],{"class":3669},[3402,13669,3918],{"class":3894},[3402,13671,3903],{"class":3669},[3402,13673,13674,13676,13678,13680,13682],{"class":3404,"line":3417},[3402,13675,3891],{"class":3890},[3402,13677,3621],{"class":3894},[3402,13679,3654],{"class":3669},[3402,13681,3952],{"class":3894},[3402,13683,3903],{"class":3669},[3402,13685,13686,13688,13690,13692,13694,13696,13698],{"class":3404,"line":3423},[3402,13687,3891],{"class":3890},[3402,13689,3621],{"class":3894},[3402,13691,3654],{"class":3669},[3402,13693,3952],{"class":3894},[3402,13695,3654],{"class":3669},[3402,13697,3969],{"class":3894},[3402,13699,3903],{"class":3669},[3402,13701,13702],{"class":3404,"line":3430},[3402,13703,3427],{"emptyLinePlaceholder":3426},[3402,13705,13706,13708,13710,13712,13714],{"class":3404,"line":3436},[3402,13707,3981],{"class":3980},[3402,13709,3984],{"class":3894},[3402,13711,3654],{"class":3669},[3402,13713,3989],{"class":3894},[3402,13715,3903],{"class":3669},[3402,13717,13718],{"class":3404,"line":3441},[3402,13719,3427],{"emptyLinePlaceholder":3426},[3402,13721,13722,13724,13726,13729],{"class":3404,"line":3447},[3402,13723,4000],{"class":3980},[3402,13725,4003],{"class":3980},[3402,13727,13728],{"class":3894}," GuardrailResult",[3402,13730,4009],{"class":3669},[3402,13732,13733,13735,13738],{"class":3404,"line":3453},[3402,13734,12387],{"class":3980},[3402,13736,13737],{"class":4037}," ResponseText",[3402,13739,3686],{"class":3669},[3402,13741,13742,13745,13748],{"class":3404,"line":3459},[3402,13743,13744],{"class":3980},"    bool",[3402,13746,13747],{"class":4037}," WasBlocked",[3402,13749,3686],{"class":3669},[3402,13751,13752,13754,13756,13759],{"class":3404,"line":3465},[3402,13753,12387],{"class":3980},[3402,13755,4249],{"class":3669},[3402,13757,13758],{"class":4037},"BlockedReason",[3402,13760,4075],{"class":3669},[3402,13762,13763],{"class":3404,"line":3470},[3402,13764,3427],{"emptyLinePlaceholder":3426},[3402,13766,13767,13769,13771,13773],{"class":3404,"line":3476},[3402,13768,4000],{"class":3980},[3402,13770,4530],{"class":3980},[3402,13772,4533],{"class":3980},[3402,13774,13775],{"class":3894}," BedrockGuardrailService\n",[3402,13777,13778],{"class":3404,"line":3482},[3402,13779,3670],{"class":3669},[3402,13781,13782,13784,13786,13788,13790],{"class":3404,"line":3488},[3402,13783,4547],{"class":3980},[3402,13785,4550],{"class":3980},[3402,13787,4553],{"class":3894},[3402,13789,4556],{"class":4037},[3402,13791,3903],{"class":3669},[3402,13793,13794,13796,13798,13800,13803],{"class":3404,"line":3494},[3402,13795,4547],{"class":3980},[3402,13797,4550],{"class":3980},[3402,13799,4569],{"class":3980},[3402,13801,13802],{"class":4037}," _guardrailId",[3402,13804,3903],{"class":3669},[3402,13806,13807,13809,13811,13813,13816],{"class":3404,"line":3500},[3402,13808,4547],{"class":3980},[3402,13810,4550],{"class":3980},[3402,13812,4569],{"class":3980},[3402,13814,13815],{"class":4037}," _guardrailVersion",[3402,13817,3903],{"class":3669},[3402,13819,13820,13822,13824,13826,13828,13830,13832],{"class":3404,"line":3505},[3402,13821,4547],{"class":3980},[3402,13823,4566],{"class":3980},[3402,13825,4569],{"class":3980},[3402,13827,4572],{"class":4037},[3402,13829,4575],{"class":3669},[3402,13831,4578],{"class":3682},[3402,13833,3903],{"class":3669},[3402,13835,13836],{"class":3404,"line":3511},[3402,13837,3427],{"emptyLinePlaceholder":3426},[3402,13839,13840,13842,13845],{"class":3404,"line":3517},[3402,13841,4591],{"class":3980},[3402,13843,13844],{"class":3852}," BedrockGuardrailService",[3402,13846,4009],{"class":3669},[3402,13848,13849,13852,13854],{"class":3404,"line":3523},[3402,13850,13851],{"class":3894},"        IAmazonBedrockRuntime",[3402,13853,4602],{"class":4037},[3402,13855,12600],{"class":3669},[3402,13857,13858,13860,13863],{"class":3404,"line":3529},[3402,13859,5606],{"class":3980},[3402,13861,13862],{"class":4037}," guardrailId",[3402,13864,12600],{"class":3669},[3402,13866,13867,13869,13872],{"class":3404,"line":3535},[3402,13868,5606],{"class":3980},[3402,13870,13871],{"class":4037}," guardrailVersion",[3402,13873,4605],{"class":3669},[3402,13875,13876],{"class":3404,"line":3541},[3402,13877,3699],{"class":3669},[3402,13879,13880,13882,13884,13886],{"class":3404,"line":3829},[3402,13881,4616],{"class":4037},[3402,13883,4575],{"class":3669},[3402,13885,4621],{"class":4037},[3402,13887,3903],{"class":3669},[3402,13889,13890,13893,13895,13898],{"class":3404,"line":4327},[3402,13891,13892],{"class":4037},"        _guardrailId",[3402,13894,4575],{"class":3669},[3402,13896,13897],{"class":4037},"guardrailId",[3402,13899,3903],{"class":3669},[3402,13901,13902,13905,13907,13910],{"class":3404,"line":4350},[3402,13903,13904],{"class":4037},"        _guardrailVersion",[3402,13906,4575],{"class":3669},[3402,13908,13909],{"class":4037},"guardrailVersion",[3402,13911,3903],{"class":3669},[3402,13913,13914],{"class":3404,"line":4373},[3402,13915,3821],{"class":3669},[3402,13917,13918],{"class":3404,"line":4402},[3402,13919,3427],{"emptyLinePlaceholder":3426},[3402,13921,13922,13924,13926,13928],{"class":3404,"line":4427},[3402,13923,4640],{"class":4639},[3402,13925,4063],{"class":4643},[3402,13927,4647],{"class":4646},[3402,13929,4650],{"class":4643},[3402,13931,13932],{"class":3404,"line":4453},[3402,13933,13934],{"class":4639},"    \u002F\u002F\u002F Викликає Claude 3.5 Sonnet із застосуванням налаштованого Guardrail.\n",[3402,13936,13937,13939,13941,13943],{"class":3404,"line":4458},[3402,13938,4640],{"class":4639},[3402,13940,4664],{"class":4643},[3402,13942,4647],{"class":4646},[3402,13944,4650],{"class":4643},[3402,13946,13947,13949,13951,13953,13955,13958,13960,13963,13965,13967,13970],{"class":3404,"line":4470},[3402,13948,4591],{"class":3980},[3402,13950,4676],{"class":3980},[3402,13952,4679],{"class":3894},[3402,13954,4063],{"class":3669},[3402,13956,13957],{"class":3894},"GuardrailResult",[3402,13959,4069],{"class":3669},[3402,13961,13962],{"class":3852},"InvokeWithGuardrailAsync",[3402,13964,4025],{"class":3669},[3402,13966,4034],{"class":3980},[3402,13968,13969],{"class":4037}," userMessage",[3402,13971,4605],{"class":3669},[3402,13973,13974],{"class":3404,"line":4495},[3402,13975,3699],{"class":3669},[3402,13977,13978,13980,13982,13984,13986,13988,13990,13992],{"class":3404,"line":4520},[3402,13979,4723],{"class":3980},[3402,13981,4726],{"class":4037},[3402,13983,4575],{"class":3669},[3402,13985,4731],{"class":3980},[3402,13987,4734],{"class":3894},[3402,13989,4063],{"class":3669},[3402,13991,4278],{"class":3894},[3402,13993,4650],{"class":3669},[3402,13995,13996],{"class":3404,"line":4525},[3402,13997,4746],{"class":3669},[3402,13999,14000,14002,14004,14006,14008,14010,14012,14014,14016,14019],{"class":3404,"line":4539},[3402,14001,4752],{"class":3980},[3402,14003,4025],{"class":3669},[3402,14005,4757],{"class":3682},[3402,14007,4760],{"class":3669},[3402,14009,4731],{"class":3980},[3402,14011,4025],{"class":3669},[3402,14013,4129],{"class":3682},[3402,14015,4698],{"class":3669},[3402,14017,14018],{"class":4037},"userMessage",[3402,14020,4774],{"class":3669},[3402,14022,14023],{"class":3404,"line":4544},[3402,14024,4780],{"class":3669},[3402,14026,14027],{"class":3404,"line":4561},[3402,14028,3427],{"emptyLinePlaceholder":3426},[3402,14030,14031,14033,14035,14037,14039,14041],{"class":3404,"line":4583},[3402,14032,4723],{"class":3980},[3402,14034,4793],{"class":4037},[3402,14036,4575],{"class":3669},[3402,14038,4731],{"class":3980},[3402,14040,4151],{"class":3894},[3402,14042,4009],{"class":3669},[3402,14044,14045,14047,14049,14051],{"class":3404,"line":4588},[3402,14046,4807],{"class":4037},[3402,14048,3679],{"class":3669},[3402,14050,4812],{"class":3682},[3402,14052,3686],{"class":3669},[3402,14054,14055,14057,14059,14062],{"class":3404,"line":4608},[3402,14056,4820],{"class":4037},[3402,14058,3679],{"class":3669},[3402,14060,14061],{"class":4825},"1000",[3402,14063,3686],{"class":3669},[3402,14065,14066,14068,14070,14073],{"class":3404,"line":4613},[3402,14067,4834],{"class":4037},[3402,14069,3679],{"class":3669},[3402,14071,14072],{"class":4825},"0.5f",[3402,14074,3686],{"class":3669},[3402,14076,14077,14079,14081,14084],{"class":3404,"line":4626},[3402,14078,4847],{"class":4037},[3402,14080,3679],{"class":3669},[3402,14082,14083],{"class":3682},"\"Ти корисний віртуальний помічник банку.\"",[3402,14085,3686],{"class":3669},[3402,14087,14088,14090,14092],{"class":3404,"line":4631},[3402,14089,4859],{"class":4037},[3402,14091,3679],{"class":3669},[3402,14093,4864],{"class":4037},[3402,14095,14096],{"class":3404,"line":4636},[3402,14097,4870],{"class":3669},[3402,14099,14100],{"class":3404,"line":4653},[3402,14101,3427],{"emptyLinePlaceholder":3426},[3402,14103,14104,14106,14108,14110,14112,14114,14116,14118,14120],{"class":3404,"line":4659},[3402,14105,4723],{"class":3980},[3402,14107,4924],{"class":4037},[3402,14109,4575],{"class":3669},[3402,14111,4929],{"class":4037},[3402,14113,3654],{"class":3669},[3402,14115,4934],{"class":3852},[3402,14117,4025],{"class":3669},[3402,14119,4939],{"class":4037},[3402,14121,4075],{"class":3669},[3402,14123,14124],{"class":3404,"line":4671},[3402,14125,3427],{"emptyLinePlaceholder":3426},[3402,14127,14128,14130,14132,14134,14136],{"class":3404,"line":4715},[3402,14129,4723],{"class":3980},[3402,14131,4959],{"class":4037},[3402,14133,4575],{"class":3669},[3402,14135,4731],{"class":3980},[3402,14137,4966],{"class":3894},[3402,14139,14140],{"class":3404,"line":4720},[3402,14141,4746],{"class":3669},[3402,14143,14144,14146,14148,14150],{"class":3404,"line":4743},[3402,14145,4977],{"class":4037},[3402,14147,4575],{"class":3669},[3402,14149,4982],{"class":4037},[3402,14151,3686],{"class":3669},[3402,14153,14154,14156,14158,14160],{"class":3404,"line":4749},[3402,14155,4990],{"class":4037},[3402,14157,4575],{"class":3669},[3402,14159,4995],{"class":3682},[3402,14161,3686],{"class":3669},[3402,14163,14164,14166,14168,14170],{"class":3404,"line":4777},[3402,14165,5003],{"class":4037},[3402,14167,4575],{"class":3669},[3402,14169,4995],{"class":3682},[3402,14171,3686],{"class":3669},[3402,14173,14174,14176,14178,14180,14182,14184,14186,14188,14190,14192,14194,14196,14198],{"class":3404,"line":4783},[3402,14175,5015],{"class":4037},[3402,14177,4575],{"class":3669},[3402,14179,4731],{"class":3980},[3402,14181,5022],{"class":3894},[3402,14183,4025],{"class":3669},[3402,14185,5027],{"class":4037},[3402,14187,3654],{"class":3669},[3402,14189,5032],{"class":4037},[3402,14191,3654],{"class":3669},[3402,14193,5037],{"class":3852},[3402,14195,4025],{"class":3669},[3402,14197,5042],{"class":4037},[3402,14199,14200],{"class":3669},")),\n",[3402,14202,14203],{"class":3404,"line":4788},[3402,14204,6784],{"class":3669},[3402,14206,14207],{"class":3404,"line":4804},[3402,14208,14209],{"class":4639},"            \u002F\u002F Налаштування Guardrail\n",[3402,14211,14212,14215,14217,14220],{"class":3404,"line":4817},[3402,14213,14214],{"class":4037},"            GuardrailIdentifier",[3402,14216,4575],{"class":3669},[3402,14218,14219],{"class":4037},"_guardrailId",[3402,14221,3686],{"class":3669},[3402,14223,14224,14227,14229],{"class":3404,"line":4831},[3402,14225,14226],{"class":4037},"            GuardrailVersion",[3402,14228,4575],{"class":3669},[3402,14230,14231],{"class":4037},"_guardrailVersion\n",[3402,14233,14234],{"class":3404,"line":4844},[3402,14235,4780],{"class":3669},[3402,14237,14238],{"class":3404,"line":4856},[3402,14239,3427],{"emptyLinePlaceholder":3426},[3402,14241,14242],{"class":3404,"line":4867},[3402,14243,5061],{"class":3890},[3402,14245,14246],{"class":3404,"line":4873},[3402,14247,4746],{"class":3669},[3402,14249,14250,14252,14254,14256,14258,14260,14262,14264,14266,14268],{"class":3404,"line":4878},[3402,14251,5072],{"class":3980},[3402,14253,5075],{"class":4037},[3402,14255,4575],{"class":3669},[3402,14257,5080],{"class":3980},[3402,14259,4556],{"class":4037},[3402,14261,3654],{"class":3669},[3402,14263,3873],{"class":3852},[3402,14265,4025],{"class":3669},[3402,14267,5091],{"class":4037},[3402,14269,4075],{"class":3669},[3402,14271,14272],{"class":3404,"line":4893},[3402,14273,3427],{"emptyLinePlaceholder":3426},[3402,14275,14276],{"class":3404,"line":4898},[3402,14277,14278],{"class":4639},"            \u002F\u002F Перевіряємо заголовок відповіді про втручання Guardrail\n",[3402,14280,14281,14284,14287,14289,14291,14293,14296,14298],{"class":3404,"line":4914},[3402,14282,14283],{"class":3980},"            bool",[3402,14285,14286],{"class":4037}," isIntervened",[3402,14288,4575],{"class":3669},[3402,14290,5122],{"class":4037},[3402,14292,3654],{"class":3669},[3402,14294,14295],{"class":4037},"ResponseMetadata",[3402,14297,3654],{"class":3669},[3402,14299,14300],{"class":4037},"Metadata\n",[3402,14302,14303,14306,14309,14311,14314,14316,14318,14320,14323],{"class":3404,"line":4919},[3402,14304,14305],{"class":3669},"                .",[3402,14307,14308],{"class":3852},"TryGetValue",[3402,14310,4025],{"class":3669},[3402,14312,14313],{"class":3682},"\"X-Amzn-Bedrock-Guardrail-Intervention\"",[3402,14315,4698],{"class":3669},[3402,14317,6128],{"class":3980},[3402,14319,5107],{"class":3980},[3402,14321,14322],{"class":4037}," isBlockedStr",[3402,14324,14325],{"class":3669},") \n",[3402,14327,14328,14331,14334,14336,14339],{"class":3404,"line":4949},[3402,14329,14330],{"class":3669},"                && ",[3402,14332,14333],{"class":4037},"isBlockedStr",[3402,14335,5222],{"class":3669},[3402,14337,14338],{"class":3682},"\"true\"",[3402,14340,3903],{"class":3669},[3402,14342,14343],{"class":3404,"line":4954},[3402,14344,3427],{"emptyLinePlaceholder":3426},[3402,14346,14347,14349,14351,14353,14355,14357,14359,14361,14363,14365,14367],{"class":3404,"line":4969},[3402,14348,5104],{"class":3890},[3402,14350,5107],{"class":3980},[3402,14352,5110],{"class":4037},[3402,14354,4575],{"class":3669},[3402,14356,4731],{"class":3980},[3402,14358,5117],{"class":3894},[3402,14360,4025],{"class":3669},[3402,14362,5122],{"class":4037},[3402,14364,3654],{"class":3669},[3402,14366,5127],{"class":4037},[3402,14368,4075],{"class":3669},[3402,14370,14371,14373,14376,14378,14380,14382,14384,14386],{"class":3404,"line":4974},[3402,14372,5072],{"class":3980},[3402,14374,14375],{"class":4037}," responseJson",[3402,14377,4575],{"class":3669},[3402,14379,5080],{"class":3980},[3402,14381,5110],{"class":4037},[3402,14383,3654],{"class":3669},[3402,14385,5148],{"class":3852},[3402,14387,5151],{"class":3669},[3402,14389,14390],{"class":3404,"line":4987},[3402,14391,3427],{"emptyLinePlaceholder":3426},[3402,14393,14394,14396,14398,14400,14402,14404,14406,14408,14410,14412,14415],{"class":3404,"line":5000},[3402,14395,5072],{"class":3980},[3402,14397,5164],{"class":4037},[3402,14399,4575],{"class":3669},[3402,14401,4929],{"class":4037},[3402,14403,3654],{"class":3669},[3402,14405,5173],{"class":3852},[3402,14407,4063],{"class":3669},[3402,14409,5178],{"class":3894},[3402,14411,5181],{"class":3669},[3402,14413,14414],{"class":4037},"responseJson",[3402,14416,4075],{"class":3669},[3402,14418,14419,14421,14423,14425,14428,14430,14432,14434,14436,14438,14440,14442,14444,14446,14448,14450,14452,14454,14456,14458,14460],{"class":3404,"line":5012},[3402,14420,5072],{"class":3980},[3402,14422,6225],{"class":4037},[3402,14424,4575],{"class":3669},[3402,14426,14427],{"class":4037},"result",[3402,14429,5197],{"class":3669},[3402,14431,4072],{"class":4037},[3402,14433,3654],{"class":3669},[3402,14435,5204],{"class":3852},[3402,14437,4025],{"class":3669},[3402,14439,5209],{"class":4037},[3402,14441,5212],{"class":3669},[3402,14443,5209],{"class":4037},[3402,14445,3654],{"class":3669},[3402,14447,5219],{"class":4037},[3402,14449,5222],{"class":3669},[3402,14451,4129],{"class":3682},[3402,14453,5227],{"class":3669},[3402,14455,3900],{"class":4037},[3402,14457,13136],{"class":3669},[3402,14459,13196],{"class":3682},[3402,14461,3903],{"class":3669},[3402,14463,14464],{"class":3404,"line":5048},[3402,14465,3427],{"emptyLinePlaceholder":3426},[3402,14467,14468,14470,14472,14475],{"class":3404,"line":5053},[3402,14469,5974],{"class":3890},[3402,14471,5269],{"class":3669},[3402,14473,14474],{"class":4037},"isIntervened",[3402,14476,4605],{"class":3669},[3402,14478,14479],{"class":3404,"line":5058},[3402,14480,5995],{"class":3669},[3402,14482,14483,14486,14488,14490,14492,14494,14496,14499,14501,14503,14505,14508],{"class":3404,"line":5064},[3402,14484,14485],{"class":3890},"                return",[3402,14487,5244],{"class":3980},[3402,14489,13728],{"class":3894},[3402,14491,4025],{"class":3669},[3402,14493,6256],{"class":4037},[3402,14495,4698],{"class":3669},[3402,14497,14498],{"class":4037},"WasBlocked",[3402,14500,3679],{"class":3669},[3402,14502,7745],{"class":3980},[3402,14504,4698],{"class":3669},[3402,14506,14507],{"class":3682},"\"Content was blocked or masked by Guardrail policies.\"",[3402,14509,4075],{"class":3669},[3402,14511,14512],{"class":3404,"line":5069},[3402,14513,6294],{"class":3669},[3402,14515,14516],{"class":3404,"line":5096},[3402,14517,3427],{"emptyLinePlaceholder":3426},[3402,14519,14520,14522,14524,14526,14528,14530,14532,14534,14536,14538,14540,14542,14544,14546],{"class":3404,"line":5101},[3402,14521,5192],{"class":3890},[3402,14523,5244],{"class":3980},[3402,14525,13728],{"class":3894},[3402,14527,4025],{"class":3669},[3402,14529,6256],{"class":4037},[3402,14531,4698],{"class":3669},[3402,14533,14498],{"class":4037},[3402,14535,3679],{"class":3669},[3402,14537,7486],{"class":3980},[3402,14539,4698],{"class":3669},[3402,14541,13758],{"class":4037},[3402,14543,3679],{"class":3669},[3402,14545,4710],{"class":3980},[3402,14547,4075],{"class":3669},[3402,14549,14550],{"class":3404,"line":5132},[3402,14551,5260],{"class":3669},[3402,14553,14554,14556,14558,14560,14562],{"class":3404,"line":5154},[3402,14555,5266],{"class":3890},[3402,14557,5269],{"class":3669},[3402,14559,5272],{"class":3894},[3402,14561,5275],{"class":4037},[3402,14563,4605],{"class":3669},[3402,14565,14566],{"class":3404,"line":5159},[3402,14567,4746],{"class":3669},[3402,14569,14570,14572,14574,14576,14578,14580,14582,14584,14586,14588,14590,14592,14594,14596],{"class":3404,"line":5189},[3402,14571,5294],{"class":3890},[3402,14573,5244],{"class":3980},[3402,14575,5299],{"class":3894},[3402,14577,4025],{"class":3669},[3402,14579,5304],{"class":3682},[3402,14581,5308],{"class":5307},[3402,14583,5311],{"class":4037},[3402,14585,3654],{"class":5307},[3402,14587,5316],{"class":4037},[3402,14589,5319],{"class":5307},[3402,14591,5322],{"class":3682},[3402,14593,4698],{"class":3669},[3402,14595,5311],{"class":4037},[3402,14597,4075],{"class":3669},[3402,14599,14600],{"class":3404,"line":5235},[3402,14601,5260],{"class":3669},[3402,14603,14604],{"class":3404,"line":5257},[3402,14605,3821],{"class":3669},[3402,14607,14608],{"class":3404,"line":5263},[3402,14609,3497],{"class":3669},[3546,14611],{},[3348,14613,14615],{"id":14614},"bedrock-agents-побудова-автономних-ai-воркфлоу","Bedrock Agents: побудова автономних AI-воркфлоу",[3353,14617,14618,14621],{},[3356,14619,14620],{},"Bedrock Agents"," дають можливість створювати автономних агентів, які вміють планувати виконання складних завдань, викликати бізнес-API (через Lambda) та отримувати дані з баз знань.",[3353,14623,14624],{},"Агент працює за циклом ReAct (Reasoning + Acting):",[12280,14626,14627,14630,14633,14636],{},[3364,14628,14629],{},"Користувач ставить складну задачу.",[3364,14631,14632],{},"Агент вирішує, які інструменти (Action Groups) потрібні для виконання.",[3364,14634,14635],{},"Викликається відповідний інструмент (Lambda-функція).",[3364,14637,14638],{},"Агент аналізує отриманий результат та вирішує, яка наступна дія потрібна для досягнення цілі.",[3864,14640,14642],{"id":14641},"реалізація-action-group-lambda-функції-у-net-8","Реалізація Action Group Lambda-функції у .NET 8",[3353,14644,14645],{},"Коли ви налаштовуєте Action Group для агента, ви вказуєте схему OpenAPI. Bedrock викликає відповідну Lambda-функцію із визначеною структурою JSON.",[3392,14647,14650],{"className":3880,"code":14648,"filename":14649,"language":3883,"meta":3397,"style":3397},"using Amazon.Lambda.Core;\n\n\u002F\u002F Необхідно додати NuGet пакети для Lambda:\n\u002F\u002F dotnet add package Amazon.Lambda.Core\n\u002F\u002F dotnet add package Amazon.Lambda.Serialization.SystemTextJson\n\n[assembly: LambdaSerializer(typeof(Amazon.Lambda.Serialization.SystemTextJson.DefaultLambdaJsonSerializer))]\n\nnamespace BedrockAgentActions;\n\npublic record AgentParameter(string Name, string Type, string Value);\n\npublic record AgentActionRequest(\n    string MessageVersion,\n    string Agent,\n    string ActionGroup,\n    string Function,\n    List\u003CAgentParameter> Parameters);\n\npublic record AgentResponseContent(string Body);\n\npublic record AgentActionResponse(\n    string MessageVersion,\n    Dictionary\u003Cstring, AgentResponseContent> ResponseBody);\n\npublic class OrderManagementFunction\n{\n    public async Task\u003CAgentActionResponse> FunctionHandler(AgentActionRequest request, ILambdaContext context)\n    {\n        context.Logger.LogLine($\"Received agent request for action: {request.ActionGroup}, function: {request.Function}\");\n\n        object executionResult = request.Function switch\n        {\n            \"CreateOrder\" => CreateOrder(request.Parameters),\n            \"GetOrderStatus\" => GetOrderStatus(request.Parameters),\n            _ => new { error = $\"Function {request.Function} is not supported.\" }\n        };\n\n        var responseString = System.Text.Json.JsonSerializer.Serialize(executionResult);\n\n        return new AgentActionResponse(\n            MessageVersion: request.MessageVersion,\n            ResponseBody: new Dictionary\u003Cstring, AgentResponseContent>\n            {\n                [\"application\u002Fjson\"] = new AgentResponseContent(responseString)\n            }\n        );\n    }\n\n    private object CreateOrder(List\u003CAgentParameter> parameters)\n    {\n        var sku = parameters.FirstOrDefault(p => p.Name == \"sku\")?.Value ?? \"unknown\";\n        var qtyStr = parameters.FirstOrDefault(p => p.Name == \"quantity\")?.Value ?? \"1\";\n        int.TryParse(qtyStr, out var qty);\n\n        return new\n        {\n            OrderId = $\"ORD-{Guid.NewGuid().ToString()[..8].ToUpper()}\",\n            Status = \"Created\",\n            Sku = sku,\n            Quantity = qty,\n            EstimatedDelivery = DateTime.UtcNow.AddDays(3).ToString(\"yyyy-MM-dd\")\n        };\n    }\n\n    private object GetOrderStatus(List\u003CAgentParameter> parameters)\n    {\n        var orderId = parameters.FirstOrDefault(p => p.Name == \"orderId\")?.Value ?? \"unknown\";\n\n        return new\n        {\n            OrderId = orderId,\n            Status = \"InTransit\",\n            Location = \"Hub-Kyiv\",\n            LastUpdated = DateTime.UtcNow.AddHours(-2).ToString(\"yyyy-MM-dd HH:mm:ss\")\n        };\n    }\n}\n","Lambda\u002FOrderManagementFunction.cs",[3399,14651,14652,14670,14674,14679,14684,14689,14693,14735,14739,14748,14752,14783,14787,14798,14807,14816,14825,14834,14850,14854,14872,14876,14887,14895,14915,14919,14928,14932,14967,14971,15020,15024,15043,15047,15067,15087,15121,15125,15129,15163,15167,15177,15193,15215,15219,15239,15243,15247,15251,15255,15280,15284,15328,15371,15397,15401,15408,15412,15459,15471,15483,15495,15531,15535,15539,15543,15566,15570,15612,15616,15622,15626,15637,15648,15660,15695,15699,15703],{"__ignoreMap":3397},[3402,14653,14654,14656,14658,14660,14663,14665,14668],{"class":3404,"line":3405},[3402,14655,3891],{"class":3890},[3402,14657,3621],{"class":3894},[3402,14659,3654],{"class":3669},[3402,14661,14662],{"class":3894},"Lambda",[3402,14664,3654],{"class":3669},[3402,14666,14667],{"class":3894},"Core",[3402,14669,3903],{"class":3669},[3402,14671,14672],{"class":3404,"line":3411},[3402,14673,3427],{"emptyLinePlaceholder":3426},[3402,14675,14676],{"class":3404,"line":3417},[3402,14677,14678],{"class":4639},"\u002F\u002F Необхідно додати NuGet пакети для Lambda:\n",[3402,14680,14681],{"class":3404,"line":3423},[3402,14682,14683],{"class":4639},"\u002F\u002F dotnet add package Amazon.Lambda.Core\n",[3402,14685,14686],{"class":3404,"line":3430},[3402,14687,14688],{"class":4639},"\u002F\u002F dotnet add package Amazon.Lambda.Serialization.SystemTextJson\n",[3402,14690,14691],{"class":3404,"line":3436},[3402,14692,3427],{"emptyLinePlaceholder":3426},[3402,14694,14695,14697,14700,14702,14705,14707,14710,14712,14714,14716,14718,14720,14722,14724,14727,14729,14732],{"class":3404,"line":3441},[3402,14696,6376],{"class":3669},[3402,14698,14699],{"class":3980},"assembly",[3402,14701,3679],{"class":3669},[3402,14703,14704],{"class":3894},"LambdaSerializer",[3402,14706,4025],{"class":3669},[3402,14708,14709],{"class":3980},"typeof",[3402,14711,4025],{"class":3669},[3402,14713,6997],{"class":3894},[3402,14715,3654],{"class":3669},[3402,14717,14662],{"class":3894},[3402,14719,3654],{"class":3669},[3402,14721,3939],{"class":3894},[3402,14723,3654],{"class":3669},[3402,14725,14726],{"class":3894},"SystemTextJson",[3402,14728,3654],{"class":3669},[3402,14730,14731],{"class":3894},"DefaultLambdaJsonSerializer",[3402,14733,14734],{"class":3669},"))]\n",[3402,14736,14737],{"class":3404,"line":3447},[3402,14738,3427],{"emptyLinePlaceholder":3426},[3402,14740,14741,14743,14746],{"class":3404,"line":3453},[3402,14742,3981],{"class":3980},[3402,14744,14745],{"class":3894}," BedrockAgentActions",[3402,14747,3903],{"class":3669},[3402,14749,14750],{"class":3404,"line":3459},[3402,14751,3427],{"emptyLinePlaceholder":3426},[3402,14753,14754,14756,14758,14761,14763,14765,14768,14770,14772,14774,14776,14778,14781],{"class":3404,"line":3465},[3402,14755,4000],{"class":3980},[3402,14757,4003],{"class":3980},[3402,14759,14760],{"class":3894}," AgentParameter",[3402,14762,4025],{"class":3669},[3402,14764,4034],{"class":3980},[3402,14766,14767],{"class":4037}," Name",[3402,14769,4698],{"class":3669},[3402,14771,4034],{"class":3980},[3402,14773,4112],{"class":4037},[3402,14775,4698],{"class":3669},[3402,14777,4034],{"class":3980},[3402,14779,14780],{"class":4037}," Value",[3402,14782,4075],{"class":3669},[3402,14784,14785],{"class":3404,"line":3470},[3402,14786,3427],{"emptyLinePlaceholder":3426},[3402,14788,14789,14791,14793,14796],{"class":3404,"line":3476},[3402,14790,4000],{"class":3980},[3402,14792,4003],{"class":3980},[3402,14794,14795],{"class":3894}," AgentActionRequest",[3402,14797,4009],{"class":3669},[3402,14799,14800,14802,14805],{"class":3404,"line":3482},[3402,14801,12387],{"class":3980},[3402,14803,14804],{"class":4037}," MessageVersion",[3402,14806,3686],{"class":3669},[3402,14808,14809,14811,14814],{"class":3404,"line":3488},[3402,14810,12387],{"class":3980},[3402,14812,14813],{"class":4037}," Agent",[3402,14815,3686],{"class":3669},[3402,14817,14818,14820,14823],{"class":3404,"line":3494},[3402,14819,12387],{"class":3980},[3402,14821,14822],{"class":4037}," ActionGroup",[3402,14824,3686],{"class":3669},[3402,14826,14827,14829,14832],{"class":3404,"line":3500},[3402,14828,12387],{"class":3980},[3402,14830,14831],{"class":4037}," Function",[3402,14833,3686],{"class":3669},[3402,14835,14836,14838,14840,14843,14845,14848],{"class":3404,"line":3505},[3402,14837,12459],{"class":3894},[3402,14839,4063],{"class":3669},[3402,14841,14842],{"class":3894},"AgentParameter",[3402,14844,4069],{"class":3669},[3402,14846,14847],{"class":4037},"Parameters",[3402,14849,4075],{"class":3669},[3402,14851,14852],{"class":3404,"line":3511},[3402,14853,3427],{"emptyLinePlaceholder":3426},[3402,14855,14856,14858,14860,14863,14865,14867,14870],{"class":3404,"line":3517},[3402,14857,4000],{"class":3980},[3402,14859,4003],{"class":3980},[3402,14861,14862],{"class":3894}," AgentResponseContent",[3402,14864,4025],{"class":3669},[3402,14866,4034],{"class":3980},[3402,14868,14869],{"class":4037}," Body",[3402,14871,4075],{"class":3669},[3402,14873,14874],{"class":3404,"line":3523},[3402,14875,3427],{"emptyLinePlaceholder":3426},[3402,14877,14878,14880,14882,14885],{"class":3404,"line":3529},[3402,14879,4000],{"class":3980},[3402,14881,4003],{"class":3980},[3402,14883,14884],{"class":3894}," AgentActionResponse",[3402,14886,4009],{"class":3669},[3402,14888,14889,14891,14893],{"class":3404,"line":3535},[3402,14890,12387],{"class":3980},[3402,14892,14804],{"class":4037},[3402,14894,3686],{"class":3669},[3402,14896,14897,14899,14901,14903,14905,14908,14910,14913],{"class":3404,"line":3541},[3402,14898,12406],{"class":3894},[3402,14900,4063],{"class":3669},[3402,14902,4034],{"class":3980},[3402,14904,4698],{"class":3669},[3402,14906,14907],{"class":3894},"AgentResponseContent",[3402,14909,4069],{"class":3669},[3402,14911,14912],{"class":4037},"ResponseBody",[3402,14914,4075],{"class":3669},[3402,14916,14917],{"class":3404,"line":3829},[3402,14918,3427],{"emptyLinePlaceholder":3426},[3402,14920,14921,14923,14925],{"class":3404,"line":4327},[3402,14922,4000],{"class":3980},[3402,14924,4533],{"class":3980},[3402,14926,14927],{"class":3894}," OrderManagementFunction\n",[3402,14929,14930],{"class":3404,"line":4350},[3402,14931,3670],{"class":3669},[3402,14933,14934,14936,14938,14940,14942,14945,14947,14950,14952,14955,14957,14959,14962,14965],{"class":3404,"line":4373},[3402,14935,4591],{"class":3980},[3402,14937,4676],{"class":3980},[3402,14939,4679],{"class":3894},[3402,14941,4063],{"class":3669},[3402,14943,14944],{"class":3894},"AgentActionResponse",[3402,14946,4069],{"class":3669},[3402,14948,14949],{"class":3852},"FunctionHandler",[3402,14951,4025],{"class":3669},[3402,14953,14954],{"class":3894},"AgentActionRequest",[3402,14956,4959],{"class":4037},[3402,14958,4698],{"class":3669},[3402,14960,14961],{"class":3894},"ILambdaContext",[3402,14963,14964],{"class":4037}," context",[3402,14966,4605],{"class":3669},[3402,14968,14969],{"class":3404,"line":4402},[3402,14970,3699],{"class":3669},[3402,14972,14973,14976,14978,14981,14983,14986,14988,14991,14993,14995,14997,15000,15002,15005,15007,15009,15011,15014,15016,15018],{"class":3404,"line":4427},[3402,14974,14975],{"class":4037},"        context",[3402,14977,3654],{"class":3669},[3402,14979,14980],{"class":4037},"Logger",[3402,14982,3654],{"class":3669},[3402,14984,14985],{"class":3852},"LogLine",[3402,14987,4025],{"class":3669},[3402,14989,14990],{"class":3682},"$\"Received agent request for action: ",[3402,14992,5308],{"class":5307},[3402,14994,5091],{"class":4037},[3402,14996,3654],{"class":5307},[3402,14998,14999],{"class":4037},"ActionGroup",[3402,15001,5319],{"class":5307},[3402,15003,15004],{"class":3682},", function: ",[3402,15006,5308],{"class":5307},[3402,15008,5091],{"class":4037},[3402,15010,3654],{"class":5307},[3402,15012,15013],{"class":4037},"Function",[3402,15015,5319],{"class":5307},[3402,15017,5322],{"class":3682},[3402,15019,4075],{"class":3669},[3402,15021,15022],{"class":3404,"line":4453},[3402,15023,3427],{"emptyLinePlaceholder":3426},[3402,15025,15026,15029,15032,15034,15036,15038,15040],{"class":3404,"line":4458},[3402,15027,15028],{"class":3980},"        object",[3402,15030,15031],{"class":4037}," executionResult",[3402,15033,4575],{"class":3669},[3402,15035,5091],{"class":4037},[3402,15037,3654],{"class":3669},[3402,15039,15013],{"class":4037},[3402,15041,15042],{"class":3890}," switch\n",[3402,15044,15045],{"class":3404,"line":4470},[3402,15046,4746],{"class":3669},[3402,15048,15049,15052,15054,15057,15059,15061,15063,15065],{"class":3404,"line":4495},[3402,15050,15051],{"class":3682},"            \"CreateOrder\"",[3402,15053,5212],{"class":3669},[3402,15055,15056],{"class":3852},"CreateOrder",[3402,15058,4025],{"class":3669},[3402,15060,5091],{"class":4037},[3402,15062,3654],{"class":3669},[3402,15064,14847],{"class":4037},[3402,15066,7992],{"class":3669},[3402,15068,15069,15072,15074,15077,15079,15081,15083,15085],{"class":3404,"line":4520},[3402,15070,15071],{"class":3682},"            \"GetOrderStatus\"",[3402,15073,5212],{"class":3669},[3402,15075,15076],{"class":3852},"GetOrderStatus",[3402,15078,4025],{"class":3669},[3402,15080,5091],{"class":4037},[3402,15082,3654],{"class":3669},[3402,15084,14847],{"class":4037},[3402,15086,7992],{"class":3669},[3402,15088,15089,15092,15094,15096,15098,15100,15102,15105,15107,15109,15111,15113,15115,15118],{"class":3404,"line":4525},[3402,15090,15091],{"class":3980},"            _",[3402,15093,5212],{"class":3669},[3402,15095,4731],{"class":3980},[3402,15097,6707],{"class":3669},[3402,15099,8587],{"class":4037},[3402,15101,4575],{"class":3669},[3402,15103,15104],{"class":3682},"$\"Function ",[3402,15106,5308],{"class":5307},[3402,15108,5091],{"class":4037},[3402,15110,3654],{"class":5307},[3402,15112,15013],{"class":4037},[3402,15114,5319],{"class":5307},[3402,15116,15117],{"class":3682}," is not supported.\"",[3402,15119,15120],{"class":3669}," }\n",[3402,15122,15123],{"class":3404,"line":4539},[3402,15124,4780],{"class":3669},[3402,15126,15127],{"class":3404,"line":4544},[3402,15128,3427],{"emptyLinePlaceholder":3426},[3402,15130,15131,15133,15136,15138,15140,15142,15144,15146,15148,15150,15152,15154,15156,15158,15161],{"class":3404,"line":4561},[3402,15132,4723],{"class":3980},[3402,15134,15135],{"class":4037}," responseString",[3402,15137,4575],{"class":3669},[3402,15139,4252],{"class":4037},[3402,15141,3654],{"class":3669},[3402,15143,3900],{"class":4037},[3402,15145,3654],{"class":3669},[3402,15147,3918],{"class":4037},[3402,15149,3654],{"class":3669},[3402,15151,4929],{"class":4037},[3402,15153,3654],{"class":3669},[3402,15155,4934],{"class":3852},[3402,15157,4025],{"class":3669},[3402,15159,15160],{"class":4037},"executionResult",[3402,15162,4075],{"class":3669},[3402,15164,15165],{"class":3404,"line":4583},[3402,15166,3427],{"emptyLinePlaceholder":3426},[3402,15168,15169,15171,15173,15175],{"class":3404,"line":4588},[3402,15170,13243],{"class":3890},[3402,15172,5244],{"class":3980},[3402,15174,14884],{"class":3894},[3402,15176,4009],{"class":3669},[3402,15178,15179,15182,15184,15186,15188,15191],{"class":3404,"line":4608},[3402,15180,15181],{"class":4037},"            MessageVersion",[3402,15183,3679],{"class":3669},[3402,15185,5091],{"class":4037},[3402,15187,3654],{"class":3669},[3402,15189,15190],{"class":4037},"MessageVersion",[3402,15192,3686],{"class":3669},[3402,15194,15195,15198,15200,15202,15205,15207,15209,15211,15213],{"class":3404,"line":4613},[3402,15196,15197],{"class":4037},"            ResponseBody",[3402,15199,3679],{"class":3669},[3402,15201,4731],{"class":3980},[3402,15203,15204],{"class":3894}," Dictionary",[3402,15206,4063],{"class":3669},[3402,15208,4034],{"class":3980},[3402,15210,4698],{"class":3669},[3402,15212,14907],{"class":3894},[3402,15214,4650],{"class":3669},[3402,15216,15217],{"class":3404,"line":4626},[3402,15218,5995],{"class":3669},[3402,15220,15221,15224,15226,15228,15230,15232,15234,15237],{"class":3404,"line":4631},[3402,15222,15223],{"class":3669},"                [",[3402,15225,4995],{"class":3682},[3402,15227,7453],{"class":3669},[3402,15229,4731],{"class":3980},[3402,15231,14862],{"class":3894},[3402,15233,4025],{"class":3669},[3402,15235,15236],{"class":4037},"responseString",[3402,15238,4605],{"class":3669},[3402,15240,15241],{"class":3404,"line":4636},[3402,15242,6294],{"class":3669},[3402,15244,15245],{"class":3404,"line":4653},[3402,15246,4870],{"class":3669},[3402,15248,15249],{"class":3404,"line":4659},[3402,15250,3821],{"class":3669},[3402,15252,15253],{"class":3404,"line":4671},[3402,15254,3427],{"emptyLinePlaceholder":3426},[3402,15256,15257,15259,15262,15265,15267,15269,15271,15273,15275,15278],{"class":3404,"line":4715},[3402,15258,4547],{"class":3980},[3402,15260,15261],{"class":3980}," object",[3402,15263,15264],{"class":3852}," CreateOrder",[3402,15266,4025],{"class":3669},[3402,15268,4060],{"class":3894},[3402,15270,4063],{"class":3669},[3402,15272,14842],{"class":3894},[3402,15274,4069],{"class":3669},[3402,15276,15277],{"class":4037},"parameters",[3402,15279,4605],{"class":3669},[3402,15281,15282],{"class":3404,"line":4720},[3402,15283,3699],{"class":3669},[3402,15285,15286,15288,15291,15293,15295,15297,15299,15301,15303,15305,15307,15309,15312,15314,15317,15319,15321,15323,15326],{"class":3404,"line":4743},[3402,15287,4723],{"class":3980},[3402,15289,15290],{"class":4037}," sku",[3402,15292,4575],{"class":3669},[3402,15294,15277],{"class":4037},[3402,15296,3654],{"class":3669},[3402,15298,5204],{"class":3852},[3402,15300,4025],{"class":3669},[3402,15302,3353],{"class":4037},[3402,15304,5212],{"class":3669},[3402,15306,3353],{"class":4037},[3402,15308,3654],{"class":3669},[3402,15310,15311],{"class":4037},"Name",[3402,15313,5222],{"class":3669},[3402,15315,15316],{"class":3682},"\"sku\"",[3402,15318,5227],{"class":3669},[3402,15320,13186],{"class":4037},[3402,15322,13136],{"class":3669},[3402,15324,15325],{"class":3682},"\"unknown\"",[3402,15327,3903],{"class":3669},[3402,15329,15330,15332,15335,15337,15339,15341,15343,15345,15347,15349,15351,15353,15355,15357,15360,15362,15364,15366,15369],{"class":3404,"line":4749},[3402,15331,4723],{"class":3980},[3402,15333,15334],{"class":4037}," qtyStr",[3402,15336,4575],{"class":3669},[3402,15338,15277],{"class":4037},[3402,15340,3654],{"class":3669},[3402,15342,5204],{"class":3852},[3402,15344,4025],{"class":3669},[3402,15346,3353],{"class":4037},[3402,15348,5212],{"class":3669},[3402,15350,3353],{"class":4037},[3402,15352,3654],{"class":3669},[3402,15354,15311],{"class":4037},[3402,15356,5222],{"class":3669},[3402,15358,15359],{"class":3682},"\"quantity\"",[3402,15361,5227],{"class":3669},[3402,15363,13186],{"class":4037},[3402,15365,13136],{"class":3669},[3402,15367,15368],{"class":3682},"\"1\"",[3402,15370,3903],{"class":3669},[3402,15372,15373,15376,15378,15381,15383,15386,15388,15390,15392,15395],{"class":3404,"line":4777},[3402,15374,15375],{"class":3980},"        int",[3402,15377,3654],{"class":3669},[3402,15379,15380],{"class":3852},"TryParse",[3402,15382,4025],{"class":3669},[3402,15384,15385],{"class":4037},"qtyStr",[3402,15387,4698],{"class":3669},[3402,15389,6128],{"class":3980},[3402,15391,5107],{"class":3980},[3402,15393,15394],{"class":4037}," qty",[3402,15396,4075],{"class":3669},[3402,15398,15399],{"class":3404,"line":4783},[3402,15400,3427],{"emptyLinePlaceholder":3426},[3402,15402,15403,15405],{"class":3404,"line":4788},[3402,15404,13243],{"class":3890},[3402,15406,15407],{"class":3980}," new\n",[3402,15409,15410],{"class":3404,"line":4804},[3402,15411,4746],{"class":3669},[3402,15413,15414,15417,15419,15422,15424,15427,15429,15432,15435,15437,15440,15443,15446,15449,15452,15455,15457],{"class":3404,"line":4817},[3402,15415,15416],{"class":4037},"            OrderId",[3402,15418,4575],{"class":3669},[3402,15420,15421],{"class":3682},"$\"ORD-",[3402,15423,5308],{"class":5307},[3402,15425,15426],{"class":4037},"Guid",[3402,15428,3654],{"class":5307},[3402,15430,15431],{"class":3852},"NewGuid",[3402,15433,15434],{"class":5307},"().",[3402,15436,13191],{"class":3852},[3402,15438,15439],{"class":5307},"()[",[3402,15441,15442],{"class":3669},"..",[3402,15444,15445],{"class":4825},"8",[3402,15447,15448],{"class":5307},"].",[3402,15450,15451],{"class":3852},"ToUpper",[3402,15453,15454],{"class":5307},"()}",[3402,15456,5322],{"class":3682},[3402,15458,3686],{"class":3669},[3402,15460,15461,15464,15466,15469],{"class":3404,"line":4831},[3402,15462,15463],{"class":4037},"            Status",[3402,15465,4575],{"class":3669},[3402,15467,15468],{"class":3682},"\"Created\"",[3402,15470,3686],{"class":3669},[3402,15472,15473,15476,15478,15481],{"class":3404,"line":4844},[3402,15474,15475],{"class":4037},"            Sku",[3402,15477,4575],{"class":3669},[3402,15479,15480],{"class":4037},"sku",[3402,15482,3686],{"class":3669},[3402,15484,15485,15488,15490,15493],{"class":3404,"line":4856},[3402,15486,15487],{"class":4037},"            Quantity",[3402,15489,4575],{"class":3669},[3402,15491,15492],{"class":4037},"qty",[3402,15494,3686],{"class":3669},[3402,15496,15497,15500,15502,15505,15507,15510,15512,15515,15517,15520,15522,15524,15526,15529],{"class":3404,"line":4867},[3402,15498,15499],{"class":4037},"            EstimatedDelivery",[3402,15501,4575],{"class":3669},[3402,15503,15504],{"class":4037},"DateTime",[3402,15506,3654],{"class":3669},[3402,15508,15509],{"class":4037},"UtcNow",[3402,15511,3654],{"class":3669},[3402,15513,15514],{"class":3852},"AddDays",[3402,15516,4025],{"class":3669},[3402,15518,15519],{"class":4825},"3",[3402,15521,8369],{"class":3669},[3402,15523,13191],{"class":3852},[3402,15525,4025],{"class":3669},[3402,15527,15528],{"class":3682},"\"yyyy-MM-dd\"",[3402,15530,4605],{"class":3669},[3402,15532,15533],{"class":3404,"line":4873},[3402,15534,4780],{"class":3669},[3402,15536,15537],{"class":3404,"line":4878},[3402,15538,3821],{"class":3669},[3402,15540,15541],{"class":3404,"line":4893},[3402,15542,3427],{"emptyLinePlaceholder":3426},[3402,15544,15545,15547,15549,15552,15554,15556,15558,15560,15562,15564],{"class":3404,"line":4898},[3402,15546,4547],{"class":3980},[3402,15548,15261],{"class":3980},[3402,15550,15551],{"class":3852}," GetOrderStatus",[3402,15553,4025],{"class":3669},[3402,15555,4060],{"class":3894},[3402,15557,4063],{"class":3669},[3402,15559,14842],{"class":3894},[3402,15561,4069],{"class":3669},[3402,15563,15277],{"class":4037},[3402,15565,4605],{"class":3669},[3402,15567,15568],{"class":3404,"line":4914},[3402,15569,3699],{"class":3669},[3402,15571,15572,15574,15577,15579,15581,15583,15585,15587,15589,15591,15593,15595,15597,15599,15602,15604,15606,15608,15610],{"class":3404,"line":4919},[3402,15573,4723],{"class":3980},[3402,15575,15576],{"class":4037}," orderId",[3402,15578,4575],{"class":3669},[3402,15580,15277],{"class":4037},[3402,15582,3654],{"class":3669},[3402,15584,5204],{"class":3852},[3402,15586,4025],{"class":3669},[3402,15588,3353],{"class":4037},[3402,15590,5212],{"class":3669},[3402,15592,3353],{"class":4037},[3402,15594,3654],{"class":3669},[3402,15596,15311],{"class":4037},[3402,15598,5222],{"class":3669},[3402,15600,15601],{"class":3682},"\"orderId\"",[3402,15603,5227],{"class":3669},[3402,15605,13186],{"class":4037},[3402,15607,13136],{"class":3669},[3402,15609,15325],{"class":3682},[3402,15611,3903],{"class":3669},[3402,15613,15614],{"class":3404,"line":4949},[3402,15615,3427],{"emptyLinePlaceholder":3426},[3402,15617,15618,15620],{"class":3404,"line":4954},[3402,15619,13243],{"class":3890},[3402,15621,15407],{"class":3980},[3402,15623,15624],{"class":3404,"line":4969},[3402,15625,4746],{"class":3669},[3402,15627,15628,15630,15632,15635],{"class":3404,"line":4974},[3402,15629,15416],{"class":4037},[3402,15631,4575],{"class":3669},[3402,15633,15634],{"class":4037},"orderId",[3402,15636,3686],{"class":3669},[3402,15638,15639,15641,15643,15646],{"class":3404,"line":4987},[3402,15640,15463],{"class":4037},[3402,15642,4575],{"class":3669},[3402,15644,15645],{"class":3682},"\"InTransit\"",[3402,15647,3686],{"class":3669},[3402,15649,15650,15653,15655,15658],{"class":3404,"line":5000},[3402,15651,15652],{"class":4037},"            Location",[3402,15654,4575],{"class":3669},[3402,15656,15657],{"class":3682},"\"Hub-Kyiv\"",[3402,15659,3686],{"class":3669},[3402,15661,15662,15665,15667,15669,15671,15673,15675,15678,15681,15684,15686,15688,15690,15693],{"class":3404,"line":5012},[3402,15663,15664],{"class":4037},"            LastUpdated",[3402,15666,4575],{"class":3669},[3402,15668,15504],{"class":4037},[3402,15670,3654],{"class":3669},[3402,15672,15509],{"class":4037},[3402,15674,3654],{"class":3669},[3402,15676,15677],{"class":3852},"AddHours",[3402,15679,15680],{"class":3669},"(-",[3402,15682,15683],{"class":4825},"2",[3402,15685,8369],{"class":3669},[3402,15687,13191],{"class":3852},[3402,15689,4025],{"class":3669},[3402,15691,15692],{"class":3682},"\"yyyy-MM-dd HH:mm:ss\"",[3402,15694,4605],{"class":3669},[3402,15696,15697],{"class":3404,"line":5048},[3402,15698,4780],{"class":3669},[3402,15700,15701],{"class":3404,"line":5053},[3402,15702,3821],{"class":3669},[3402,15704,15705],{"class":3404,"line":5058},[3402,15706,3497],{"class":3669},[3546,15708],{},[3348,15710,15712],{"id":15711},"вибір-технологій-коли-що-використовувати","Вибір технологій: коли що використовувати",[3353,15714,15715],{},"Для кращого розуміння, як інтегрувати сервіси сімейства AWS AI\u002FML у архітектуру рішень, використовуйте наступну таблицю:",[15717,15718,15719,15735],"table",{},[15720,15721,15722],"thead",{},[15723,15724,15725,15729,15732],"tr",{},[15726,15727,15728],"th",{},"Задача",[15726,15730,15731],{},"Рекомендований підхід",[15726,15733,15734],{},"Сервіс",[15736,15737,15738,15752,15765,15778,15790,15802,15823,15840],"tbody",{},[15723,15739,15740,15744,15747],{},[15741,15742,15743],"td",{},"Генерація тексту, кодинг, складне логічне мислення, чат",[15741,15745,15746],{},"LLM Foundation Models",[15741,15748,15749],{},[3356,15750,15751],{},"Amazon Bedrock (Claude 3.5 Sonnet)",[15723,15753,15754,15757,15760],{},[15741,15755,15756],{},"Швидка класифікація, форматування невеликих текстів, дешевий аналіз",[15741,15758,15759],{},"LLM Foundation Models (економ)",[15741,15761,15762],{},[3356,15763,15764],{},"Amazon Bedrock (Claude 3.5 Haiku)",[15723,15766,15767,15770,15773],{},[15741,15768,15769],{},"Питання на основі корпоративних файлів та документів",[15741,15771,15772],{},"RAG архітектура",[15741,15774,15775],{},[3356,15776,15777],{},"Bedrock Knowledge Bases",[15723,15779,15780,15783,15786],{},[15741,15781,15782],{},"Створення складних діалогових помічників з доступом до API",[15741,15784,15785],{},"AI Agents",[15741,15787,15788],{},[3356,15789,14620],{},[15723,15791,15792,15795,15798],{},[15741,15793,15794],{},"Маскування PII, блокування токсичності, безпека ШІ",[15741,15796,15797],{},"Контроль вмісту",[15741,15799,15800],{},[3356,15801,13632],{},[15723,15803,15804,15807,15810],{},[15741,15805,15806],{},"Комп'ютерний зір (пошук об'єктів, облич, OCR)",[15741,15808,15809],{},"Готовий AI API",[15741,15811,15812,15815,15816,9689],{},[3356,15813,15814],{},"Amazon Rekognition"," (див. ",[15817,15818,15822],"a",{"href":15819,"rel":15820},"\u002F\u002F\u002F\u002FWork\u002Fkostyl.dev\u002Fcontent\u002Faws\u002Frekognition",[15821],"nofollow","Rekognition",[15723,15824,15825,15828,15830],{},[15741,15826,15827],{},"Інтелектуальний розбір таблиць та форм з PDF\u002Fзображень",[15741,15829,15809],{},[15741,15831,15832,15815,15835,9689],{},[3356,15833,15834],{},"Amazon Textract",[15817,15836,15839],{"href":15837,"rel":15838},"\u002F\u002F\u002F\u002FWork\u002Fkostyl.dev\u002Fcontent\u002Faws\u002Ftextract",[15821],"Textract",[15723,15841,15842,15845,15847],{},[15741,15843,15844],{},"Озвучування тексту або розпізнавання аудіофайлів",[15741,15846,15809],{},[15741,15848,15849,15815,15852,9689],{},[3356,15850,15851],{},"Amazon Polly \u002F Transcribe",[15817,15853,15856],{"href":15854,"rel":15855},"\u002F\u002F\u002F\u002FWork\u002Fkostyl.dev\u002Fcontent\u002Faws\u002Faudio-nlp-services",[15821],"Audio & NLP",[15858,15859,15860],"style",{},"html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .sLwNe, html code.shiki .sLwNe{--shiki-light:#0451A5;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .s8Opu, html code.shiki .s8Opu{--shiki-light:#795E26;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .s8xlr, html code.shiki .s8xlr{--shiki-light:#AF00DB;--shiki-default:#C586C0;--shiki-dark:#C586C0}html pre.shiki code .sN1BT, html code.shiki .sN1BT{--shiki-light:#267F99;--shiki-default:#4EC9B0;--shiki-dark:#4EC9B0}html pre.shiki code .su1O8, html code.shiki .su1O8{--shiki-light:#0000FF;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .siwwj, html code.shiki .siwwj{--shiki-light:#001080;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .s0P7L, html code.shiki .s0P7L{--shiki-light:#800000;--shiki-default:#808080;--shiki-dark:#808080}html pre.shiki code .sKtos, html code.shiki .sKtos{--shiki-light:#800000;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .sJj4R, html code.shiki .sJj4R{--shiki-light:#098658;--shiki-default:#B5CEA8;--shiki-dark:#B5CEA8}html pre.shiki code .sD7JJ, html code.shiki .sD7JJ{--shiki-light:#000000FF;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .sjcCO, html code.shiki .sjcCO{--shiki-light:#EE0000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .s-QsJ, html code.shiki .s-QsJ{--shiki-light:#0070C1;--shiki-default:#4FC1FF;--shiki-dark:#4FC1FF}html pre.shiki code .sa4r_, html code.shiki .sa4r_{--shiki-light:#E50000;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}html pre.shiki code .shsrj, html code.shiki .shsrj{--shiki-light:#811F3F;--shiki-default:#D16969;--shiki-dark:#D16969}html pre.shiki code .sAV2Q, html code.shiki .sAV2Q{--shiki-light:#D16969;--shiki-default:#CE9178;--shiki-dark:#CE9178}html pre.shiki code .sYsli, html code.shiki .sYsli{--shiki-light:#000000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .siofk, html code.shiki .siofk{--shiki-light:#EE0000;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .sqdDX, html code.shiki .sqdDX{--shiki-light:#800000;--shiki-default:#D7BA7D;--shiki-dark:#D7BA7D}html pre.shiki code .sDUd3, html code.shiki .sDUd3{--shiki-light:#0451A5;--shiki-default:#CE9178;--shiki-dark:#CE9178}",{"title":3397,"searchDepth":3411,"depth":3411,"links":15862},[15863,15864,15865,15866,15869,15874,15879,15882,15885,15888],{"id":3350,"depth":3411,"text":3351},{"id":3550,"depth":3411,"text":3551},{"id":3636,"depth":3411,"text":3637},{"id":3836,"depth":3411,"text":3837,"children":15867},[15868],{"id":3866,"depth":3417,"text":3867},{"id":5348,"depth":3411,"text":5349,"children":15870},[15871,15872,15873],{"id":5355,"depth":3417,"text":5356},{"id":6309,"depth":3417,"text":6310},{"id":6868,"depth":3417,"text":6869},{"id":7237,"depth":3411,"text":7238,"children":15875},[15876,15877,15878],{"id":7244,"depth":3417,"text":7245},{"id":8895,"depth":3417,"text":8896},{"id":10314,"depth":3417,"text":10315},{"id":12265,"depth":3411,"text":12266,"children":15880},[15881],{"id":12296,"depth":3417,"text":12297},{"id":13626,"depth":3411,"text":13627,"children":15883},[15884],{"id":13636,"depth":3417,"text":13637},{"id":14614,"depth":3411,"text":14615,"children":15886},[15887],{"id":14641,"depth":3417,"text":14642},{"id":15711,"depth":3411,"text":15712},"Глибоке занурення в Amazon Bedrock. Практична інтеграція великих мовних моделей Claude, Llama та Titan з .NET 8 та React. Реалізація Streaming, побудова Knowledge Bases для RAG, налаштування Guardrails безпеки та розробка автономних AI Agents.","md",null,{},{"title":3266,"description":15889},"_Hs_Z09xU_UvKCex2SKiIN5XaPo0OzqqZar0M2rLhzo",[15896,15898],{"title":3262,"path":3263,"stem":3264,"description":15897,"children":-1},"Глибоке дослідження AWS Lambda — від фундаментальних принципів serverless архітектури до продакшн-оптимізації .NET функцій. Runtimes, Layers, Triggers, Cold Start, Provisioned Concurrency, Lambda Destinations та повна інтеграція з екосистемою AWS для .NET 10 розробників.",{"title":3270,"path":3271,"stem":3272,"description":15899,"children":-1},"Глибоке занурення в Amazon Rekognition. Повна інструкція з інтеграції аналізу зображень, виявлення об'єктів, облич, OCR та модерації контенту з .NET 8 та React. Повноцінний код з малюванням bounding boxes на Canvas.",1782371307534]