[{"data":1,"prerenderedAt":8237},["ShallowReactive",2],{"navigation_docs":3,"-aws-rekognition":3338,"-aws-rekognition-surround":8232},[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":3270,"body":3340,"description":8226,"extension":8227,"links":8228,"meta":8229,"navigation":3576,"path":3271,"seo":8230,"stem":3272,"__hash__":8231},"docs\u002F13.aws\u002F23.rekognition.md",{"type":3341,"value":3342,"toc":8219},"minimark",[3343,3347,3355,3360,3405,3408,3412,3415,3443,3450,5896,5898,5902,5908,5911,5916,8215],[3344,3345,3270],"h1",{"id":3346},"amazon-rekognition-компютерний-зір",[3348,3349,3350,3354],"p",{},[3351,3352,3353],"strong",{},"Amazon Rekognition"," — це хмарний сервіс комп'ютерного зору (Computer Vision), який працює на базі готових навчених моделей глибокого навчання від AWS. Він не потребує від розробника експертизи в Data Science. Ви передаєте зображення (як потік байтів або посилання на об'єкт в S3) і отримуєте структуровану JSON-відповідь про об'єкти, обличчя, тексти та сцени.",[3356,3357,3359],"h2",{"id":3358},"можливості-amazon-rekognition","Можливості Amazon Rekognition",[3361,3362,3363,3390,3395,3400],"card-group",{},[3364,3365,3368,3369,3373,3374,3377,3378,3381,3382,3385,3386,3389],"card",{"icon":3366,"title":3367},"i-heroicons-photo","Детекція об'єктів та сцен (Labels)","Аналізує зображення та повертає список міток (",[3370,3371,3372],"code",{},"Label",") із рівнем впевненості (",[3370,3375,3376],{},"Confidence",") та координатами об'єктів (",[3370,3379,3380],{},"BoundingBox","). Наприклад: ",[3370,3383,3384],{},"Car (99%)",", ",[3370,3387,3388],{},"Tree (95%)",".",[3364,3391,3394],{"icon":3392,"title":3393},"i-heroicons-user-circle","Аналіз та порівняння облич","Знаходить обличчя на фото, визначає стать, віковий діапазон, наявність окулярів чи бороди, а також емоції (радість, смуток тощо). Дозволяє порівнювати два фото на схожість облич.",[3364,3396,3399],{"icon":3397,"title":3398},"i-heroicons-document-text","Розпізнавання тексту (OCR)","Виявляє та зчитує друкований та рукописний текст на фотографіях (вивіски, автомобільні номери, документи) у складних умовах (під кутом, при поганому освітленні).",[3364,3401,3404],{"icon":3402,"title":3403},"i-heroicons-shield-check","Модерація контенту","Автоматично маркує неприйнятний, агресивний чи відвертий контент, повертаючи ієрархію категорій з рівнем впевненості. Запобігає публікації небажаного вмісту.",[3406,3407],"hr",{},[3356,3409,3411],{"id":3410},"реалізація-сервісу-на-net-8","Реалізація сервісу на .NET 8",[3348,3413,3414],{},"Для роботи встановіть NuGet-пакет:",[3416,3417,3422],"pre",{"className":3418,"code":3419,"language":3420,"meta":3421,"style":3421},"language-bash shiki shiki-themes light-plus dark-plus dark-plus","dotnet add package AWSSDK.Rekognition\n","bash","",[3370,3423,3424],{"__ignoreMap":3421},[3425,3426,3429,3433,3437,3440],"span",{"class":3427,"line":3428},"line",1,[3425,3430,3432],{"class":3431},"s8Opu","dotnet",[3425,3434,3436],{"class":3435},"sbdoH"," add",[3425,3438,3439],{"class":3435}," package",[3425,3441,3442],{"class":3435}," AWSSDK.Rekognition\n",[3348,3444,3445,3446,3449],{},"Нижче наведено повний та готовий до використання клас сервісу ",[3370,3447,3448],{},"RekognitionService.cs"," зі всіма DTO та методами для обробки зображень.",[3416,3451,3456],{"className":3452,"code":3453,"filename":3454,"language":3455,"meta":3421,"style":3421},"language-csharp shiki shiki-themes light-plus dark-plus dark-plus","using System;\nusing System.Collections.Generic;\nusing System.IO;\nusing System.Linq;\nusing System.Threading.Tasks;\nusing Amazon.Rekognition;\nusing Amazon.Rekognition.Model;\n\nnamespace AwsAiPlayground.Services;\n\n\u002F\u002F DTO для об'єктів\npublic record BoundingBoxDto(float Left, float Top, float Width, float Height);\n\npublic record DetectedLabelDto(\n    string Name,\n    float Confidence,\n    List\u003Cstring> Categories,\n    BoundingBoxDto? BoundingBox);\n\n\u002F\u002F DTO для модерації\npublic record ModerationViolationDto(string Category, string SubCategory, float Confidence);\n\npublic record ContentModerationResultDto(\n    bool IsSafe,\n    List\u003CModerationViolationDto> Violations);\n\n\u002F\u002F DTO для облич\npublic record FaceDetailDto(\n    string Gender,\n    string AgeRange,\n    string Emotion,\n    float Confidence,\n    BoundingBoxDto BoundingBox);\n\npublic record FaceComparisonResultDto(\n    float Similarity,\n    BoundingBoxDto TargetBoundingBox);\n\npublic sealed class RekognitionService\n{\n    private readonly IAmazonRekognition _rekognitionClient;\n\n    public RekognitionService(IAmazonRekognition rekognitionClient)\n    {\n        _rekognitionClient = rekognitionClient;\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F Детектує об'єкти на зображенні з S3.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async Task\u003CList\u003CDetectedLabelDto>> DetectLabelsAsync(\n        string bucketName, \n        string imageKey, \n        float minConfidence = 70f)\n    {\n        var request = new DetectLabelsRequest\n        {\n            Image = new Image\n            {\n                S3Object = new S3Object { Bucket = bucketName, Name = imageKey }\n            },\n            MaxLabels = 50,\n            MinConfidence = minConfidence\n        };\n\n        try\n        {\n            var response = await _rekognitionClient.DetectLabelsAsync(request);\n\n            return response.Labels.Select(l => new DetectedLabelDto(\n                Name: l.Name,\n                Confidence: l.Confidence,\n                Categories: l.Categories.Select(c => c.Name).ToList(),\n                BoundingBox: l.Instances.FirstOrDefault()?.BoundingBox is { } bb\n                    ? new BoundingBoxDto(bb.Left, bb.Top, bb.Width, bb.Height)\n                    : null\n            )).ToList();\n        }\n        catch (AmazonRekognitionException ex)\n        {\n            throw new Exception($\"Error calling Amazon Rekognition DetectLabels: {ex.Message}\", ex);\n        }\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F Перевіряє зображення на наявність небажаного вмісту.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async Task\u003CContentModerationResultDto> ModerateImageAsync(string bucketName, string imageKey)\n    {\n        var request = new DetectModerationLabelsRequest\n        {\n            Image = new Image\n            {\n                S3Object = new S3Object { Bucket = bucketName, Name = imageKey }\n            },\n            MinConfidence = 50f\n        };\n\n        try\n        {\n            var response = await _rekognitionClient.DetectModerationLabelsAsync(request);\n\n            var violations = response.ModerationLabels.Select(ml => new ModerationViolationDto(\n                Category: ml.ParentName ?? ml.Name,\n                SubCategory: ml.Name,\n                Confidence: ml.Confidence\n            )).ToList();\n\n            return new ContentModerationResultDto(\n                IsSafe: violations.Count == 0,\n                Violations: violations\n            );\n        }\n        catch (AmazonRekognitionException ex)\n        {\n            throw new Exception($\"Error calling Amazon Rekognition ModerateImage: {ex.Message}\", ex);\n        }\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F OCR розпізнавання тексту на фотографії з S3.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async Task\u003Cstring> ExtractTextAsync(string bucketName, string imageKey)\n    {\n        var request = new DetectTextRequest\n        {\n            Image = new Image\n            {\n                S3Object = new S3Object { Bucket = bucketName, Name = imageKey }\n            }\n        };\n\n        try\n        {\n            var response = await _rekognitionClient.DetectTextAsync(request);\n            \n            \u002F\u002F Фільтруємо лише цілі рядки (LINES), ігноруючи окремі слова\n            var lines = response.TextDetections\n                .Where(t => t.Type == TextTypes.LINE)\n                .OrderBy(t => t.Geometry.BoundingBox.Top)\n                .Select(t => t.DetectedText);\n\n            return string.Join(\"\\n\", lines);\n        }\n        catch (AmazonRekognitionException ex)\n        {\n            throw new Exception($\"Error calling Amazon Rekognition DetectText: {ex.Message}\", ex);\n        }\n    }\n\n    \u002F\u002F\u002F \u003Csummary>\n    \u002F\u002F\u002F Порівнює обличчя на джерельному фото з обличчями на цільовому фото.\n    \u002F\u002F\u002F \u003C\u002Fsummary>\n    public async Task\u003CList\u003CFaceComparisonResultDto>> CompareFacesAsync(\n        string sourceBucket, string sourceKey,\n        string targetBucket, string targetKey,\n        float similarityThreshold = 80f)\n    {\n        var request = new CompareFacesRequest\n        {\n            SourceImage = new Image { S3Object = new S3Object { Bucket = sourceBucket, Name = sourceKey } },\n            TargetImage = new Image { S3Object = new S3Object { Bucket = targetBucket, Name = targetKey } },\n            SimilarityThreshold = similarityThreshold\n        };\n\n        try\n        {\n            var response = await _rekognitionClient.CompareFacesAsync(request);\n\n            return response.FaceMatches.Select(m => new FaceComparisonResultDto(\n                Similarity: m.Similarity,\n                TargetBoundingBox: new BoundingBoxDto(\n                    m.Face.BoundingBox.Left,\n                    m.Face.BoundingBox.Top,\n                    m.Face.BoundingBox.Width,\n                    m.Face.BoundingBox.Height)\n            )).ToList();\n        }\n        catch (AmazonRekognitionException ex)\n        {\n            throw new Exception($\"Error calling Amazon Rekognition CompareFaces: {ex.Message}\", ex);\n        }\n    }\n}\n","Services\u002FRekognitionService.cs","csharp",[3370,3457,3458,3472,3491,3505,3519,3538,3553,3571,3578,3595,3600,3607,3653,3658,3671,3683,3694,3714,3727,3732,3738,3770,3775,3787,3798,3815,3820,3826,3838,3848,3858,3868,3877,3887,3892,3904,3914,3924,3929,3943,3949,3966,3971,3991,3997,4011,4017,4022,4038,4044,4056,4085,4097,4107,4124,4129,4146,4152,4165,4171,4208,4214,4227,4238,4244,4249,4255,4260,4287,4292,4324,4341,4357,4397,4431,4480,4489,4500,4506,4523,4528,4569,4574,4579,4584,4595,4601,4612,4645,4650,4664,4669,4680,4685,4714,4719,4729,4734,4739,4744,4749,4773,4778,4813,4839,4855,4869,4878,4883,4894,4918,4929,4935,4940,4953,4958,4990,4995,5000,5005,5016,5022,5033,5065,5070,5084,5089,5100,5105,5134,5140,5145,5150,5155,5160,5184,5190,5196,5213,5248,5279,5301,5306,5336,5341,5354,5359,5391,5396,5401,5406,5417,5423,5434,5459,5476,5493,5508,5513,5527,5532,5577,5619,5630,5635,5640,5645,5650,5673,5678,5707,5724,5738,5759,5778,5797,5816,5825,5830,5843,5848,5880,5885,5890],{"__ignoreMap":3421},[3425,3459,3460,3464,3468],{"class":3427,"line":3428},[3425,3461,3463],{"class":3462},"s8xlr","using",[3425,3465,3467],{"class":3466},"sN1BT"," System",[3425,3469,3471],{"class":3470},"sHH4Y",";\n",[3425,3473,3475,3477,3479,3481,3484,3486,3489],{"class":3427,"line":3474},2,[3425,3476,3463],{"class":3462},[3425,3478,3467],{"class":3466},[3425,3480,3389],{"class":3470},[3425,3482,3483],{"class":3466},"Collections",[3425,3485,3389],{"class":3470},[3425,3487,3488],{"class":3466},"Generic",[3425,3490,3471],{"class":3470},[3425,3492,3494,3496,3498,3500,3503],{"class":3427,"line":3493},3,[3425,3495,3463],{"class":3462},[3425,3497,3467],{"class":3466},[3425,3499,3389],{"class":3470},[3425,3501,3502],{"class":3466},"IO",[3425,3504,3471],{"class":3470},[3425,3506,3508,3510,3512,3514,3517],{"class":3427,"line":3507},4,[3425,3509,3463],{"class":3462},[3425,3511,3467],{"class":3466},[3425,3513,3389],{"class":3470},[3425,3515,3516],{"class":3466},"Linq",[3425,3518,3471],{"class":3470},[3425,3520,3522,3524,3526,3528,3531,3533,3536],{"class":3427,"line":3521},5,[3425,3523,3463],{"class":3462},[3425,3525,3467],{"class":3466},[3425,3527,3389],{"class":3470},[3425,3529,3530],{"class":3466},"Threading",[3425,3532,3389],{"class":3470},[3425,3534,3535],{"class":3466},"Tasks",[3425,3537,3471],{"class":3470},[3425,3539,3541,3543,3546,3548,3551],{"class":3427,"line":3540},6,[3425,3542,3463],{"class":3462},[3425,3544,3545],{"class":3466}," Amazon",[3425,3547,3389],{"class":3470},[3425,3549,3550],{"class":3466},"Rekognition",[3425,3552,3471],{"class":3470},[3425,3554,3556,3558,3560,3562,3564,3566,3569],{"class":3427,"line":3555},7,[3425,3557,3463],{"class":3462},[3425,3559,3545],{"class":3466},[3425,3561,3389],{"class":3470},[3425,3563,3550],{"class":3466},[3425,3565,3389],{"class":3470},[3425,3567,3568],{"class":3466},"Model",[3425,3570,3471],{"class":3470},[3425,3572,3574],{"class":3427,"line":3573},8,[3425,3575,3577],{"emptyLinePlaceholder":3576},true,"\n",[3425,3579,3581,3585,3588,3590,3593],{"class":3427,"line":3580},9,[3425,3582,3584],{"class":3583},"su1O8","namespace",[3425,3586,3587],{"class":3466}," AwsAiPlayground",[3425,3589,3389],{"class":3470},[3425,3591,3592],{"class":3466},"Services",[3425,3594,3471],{"class":3470},[3425,3596,3598],{"class":3427,"line":3597},10,[3425,3599,3577],{"emptyLinePlaceholder":3576},[3425,3601,3603],{"class":3427,"line":3602},11,[3425,3604,3606],{"class":3605},"spJ8K","\u002F\u002F DTO для об'єктів\n",[3425,3608,3610,3613,3616,3619,3622,3625,3629,3631,3633,3636,3638,3640,3643,3645,3647,3650],{"class":3427,"line":3609},12,[3425,3611,3612],{"class":3583},"public",[3425,3614,3615],{"class":3583}," record",[3425,3617,3618],{"class":3466}," BoundingBoxDto",[3425,3620,3621],{"class":3470},"(",[3425,3623,3624],{"class":3583},"float",[3425,3626,3628],{"class":3627},"siwwj"," Left",[3425,3630,3385],{"class":3470},[3425,3632,3624],{"class":3583},[3425,3634,3635],{"class":3627}," Top",[3425,3637,3385],{"class":3470},[3425,3639,3624],{"class":3583},[3425,3641,3642],{"class":3627}," Width",[3425,3644,3385],{"class":3470},[3425,3646,3624],{"class":3583},[3425,3648,3649],{"class":3627}," Height",[3425,3651,3652],{"class":3470},");\n",[3425,3654,3656],{"class":3427,"line":3655},13,[3425,3657,3577],{"emptyLinePlaceholder":3576},[3425,3659,3661,3663,3665,3668],{"class":3427,"line":3660},14,[3425,3662,3612],{"class":3583},[3425,3664,3615],{"class":3583},[3425,3666,3667],{"class":3466}," DetectedLabelDto",[3425,3669,3670],{"class":3470},"(\n",[3425,3672,3674,3677,3680],{"class":3427,"line":3673},15,[3425,3675,3676],{"class":3583},"    string",[3425,3678,3679],{"class":3627}," Name",[3425,3681,3682],{"class":3470},",\n",[3425,3684,3686,3689,3692],{"class":3427,"line":3685},16,[3425,3687,3688],{"class":3583},"    float",[3425,3690,3691],{"class":3627}," Confidence",[3425,3693,3682],{"class":3470},[3425,3695,3697,3700,3703,3706,3709,3712],{"class":3427,"line":3696},17,[3425,3698,3699],{"class":3466},"    List",[3425,3701,3702],{"class":3470},"\u003C",[3425,3704,3705],{"class":3583},"string",[3425,3707,3708],{"class":3470},"> ",[3425,3710,3711],{"class":3627},"Categories",[3425,3713,3682],{"class":3470},[3425,3715,3717,3720,3723,3725],{"class":3427,"line":3716},18,[3425,3718,3719],{"class":3466},"    BoundingBoxDto",[3425,3721,3722],{"class":3470},"? ",[3425,3724,3380],{"class":3627},[3425,3726,3652],{"class":3470},[3425,3728,3730],{"class":3427,"line":3729},19,[3425,3731,3577],{"emptyLinePlaceholder":3576},[3425,3733,3735],{"class":3427,"line":3734},20,[3425,3736,3737],{"class":3605},"\u002F\u002F DTO для модерації\n",[3425,3739,3741,3743,3745,3748,3750,3752,3755,3757,3759,3762,3764,3766,3768],{"class":3427,"line":3740},21,[3425,3742,3612],{"class":3583},[3425,3744,3615],{"class":3583},[3425,3746,3747],{"class":3466}," ModerationViolationDto",[3425,3749,3621],{"class":3470},[3425,3751,3705],{"class":3583},[3425,3753,3754],{"class":3627}," Category",[3425,3756,3385],{"class":3470},[3425,3758,3705],{"class":3583},[3425,3760,3761],{"class":3627}," SubCategory",[3425,3763,3385],{"class":3470},[3425,3765,3624],{"class":3583},[3425,3767,3691],{"class":3627},[3425,3769,3652],{"class":3470},[3425,3771,3773],{"class":3427,"line":3772},22,[3425,3774,3577],{"emptyLinePlaceholder":3576},[3425,3776,3778,3780,3782,3785],{"class":3427,"line":3777},23,[3425,3779,3612],{"class":3583},[3425,3781,3615],{"class":3583},[3425,3783,3784],{"class":3466}," ContentModerationResultDto",[3425,3786,3670],{"class":3470},[3425,3788,3790,3793,3796],{"class":3427,"line":3789},24,[3425,3791,3792],{"class":3583},"    bool",[3425,3794,3795],{"class":3627}," IsSafe",[3425,3797,3682],{"class":3470},[3425,3799,3801,3803,3805,3808,3810,3813],{"class":3427,"line":3800},25,[3425,3802,3699],{"class":3466},[3425,3804,3702],{"class":3470},[3425,3806,3807],{"class":3466},"ModerationViolationDto",[3425,3809,3708],{"class":3470},[3425,3811,3812],{"class":3627},"Violations",[3425,3814,3652],{"class":3470},[3425,3816,3818],{"class":3427,"line":3817},26,[3425,3819,3577],{"emptyLinePlaceholder":3576},[3425,3821,3823],{"class":3427,"line":3822},27,[3425,3824,3825],{"class":3605},"\u002F\u002F DTO для облич\n",[3425,3827,3829,3831,3833,3836],{"class":3427,"line":3828},28,[3425,3830,3612],{"class":3583},[3425,3832,3615],{"class":3583},[3425,3834,3835],{"class":3466}," FaceDetailDto",[3425,3837,3670],{"class":3470},[3425,3839,3841,3843,3846],{"class":3427,"line":3840},29,[3425,3842,3676],{"class":3583},[3425,3844,3845],{"class":3627}," Gender",[3425,3847,3682],{"class":3470},[3425,3849,3851,3853,3856],{"class":3427,"line":3850},30,[3425,3852,3676],{"class":3583},[3425,3854,3855],{"class":3627}," AgeRange",[3425,3857,3682],{"class":3470},[3425,3859,3861,3863,3866],{"class":3427,"line":3860},31,[3425,3862,3676],{"class":3583},[3425,3864,3865],{"class":3627}," Emotion",[3425,3867,3682],{"class":3470},[3425,3869,3871,3873,3875],{"class":3427,"line":3870},32,[3425,3872,3688],{"class":3583},[3425,3874,3691],{"class":3627},[3425,3876,3682],{"class":3470},[3425,3878,3880,3882,3885],{"class":3427,"line":3879},33,[3425,3881,3719],{"class":3466},[3425,3883,3884],{"class":3627}," BoundingBox",[3425,3886,3652],{"class":3470},[3425,3888,3890],{"class":3427,"line":3889},34,[3425,3891,3577],{"emptyLinePlaceholder":3576},[3425,3893,3895,3897,3899,3902],{"class":3427,"line":3894},35,[3425,3896,3612],{"class":3583},[3425,3898,3615],{"class":3583},[3425,3900,3901],{"class":3466}," FaceComparisonResultDto",[3425,3903,3670],{"class":3470},[3425,3905,3907,3909,3912],{"class":3427,"line":3906},36,[3425,3908,3688],{"class":3583},[3425,3910,3911],{"class":3627}," Similarity",[3425,3913,3682],{"class":3470},[3425,3915,3917,3919,3922],{"class":3427,"line":3916},37,[3425,3918,3719],{"class":3466},[3425,3920,3921],{"class":3627}," TargetBoundingBox",[3425,3923,3652],{"class":3470},[3425,3925,3927],{"class":3427,"line":3926},38,[3425,3928,3577],{"emptyLinePlaceholder":3576},[3425,3930,3932,3934,3937,3940],{"class":3427,"line":3931},39,[3425,3933,3612],{"class":3583},[3425,3935,3936],{"class":3583}," sealed",[3425,3938,3939],{"class":3583}," class",[3425,3941,3942],{"class":3466}," RekognitionService\n",[3425,3944,3946],{"class":3427,"line":3945},40,[3425,3947,3948],{"class":3470},"{\n",[3425,3950,3952,3955,3958,3961,3964],{"class":3427,"line":3951},41,[3425,3953,3954],{"class":3583},"    private",[3425,3956,3957],{"class":3583}," readonly",[3425,3959,3960],{"class":3466}," IAmazonRekognition",[3425,3962,3963],{"class":3627}," _rekognitionClient",[3425,3965,3471],{"class":3470},[3425,3967,3969],{"class":3427,"line":3968},42,[3425,3970,3577],{"emptyLinePlaceholder":3576},[3425,3972,3974,3977,3980,3982,3985,3988],{"class":3427,"line":3973},43,[3425,3975,3976],{"class":3583},"    public",[3425,3978,3979],{"class":3431}," RekognitionService",[3425,3981,3621],{"class":3470},[3425,3983,3984],{"class":3466},"IAmazonRekognition",[3425,3986,3987],{"class":3627}," rekognitionClient",[3425,3989,3990],{"class":3470},")\n",[3425,3992,3994],{"class":3427,"line":3993},44,[3425,3995,3996],{"class":3470},"    {\n",[3425,3998,4000,4003,4006,4009],{"class":3427,"line":3999},45,[3425,4001,4002],{"class":3627},"        _rekognitionClient",[3425,4004,4005],{"class":3470}," = ",[3425,4007,4008],{"class":3627},"rekognitionClient",[3425,4010,3471],{"class":3470},[3425,4012,4014],{"class":3427,"line":4013},46,[3425,4015,4016],{"class":3470},"    }\n",[3425,4018,4020],{"class":3427,"line":4019},47,[3425,4021,3577],{"emptyLinePlaceholder":3576},[3425,4023,4025,4028,4031,4035],{"class":3427,"line":4024},48,[3425,4026,4027],{"class":3605},"    \u002F\u002F\u002F ",[3425,4029,3702],{"class":4030},"s0P7L",[3425,4032,4034],{"class":4033},"sKtos","summary",[3425,4036,4037],{"class":4030},">\n",[3425,4039,4041],{"class":3427,"line":4040},49,[3425,4042,4043],{"class":3605},"    \u002F\u002F\u002F Детектує об'єкти на зображенні з S3.\n",[3425,4045,4047,4049,4052,4054],{"class":3427,"line":4046},50,[3425,4048,4027],{"class":3605},[3425,4050,4051],{"class":4030},"\u003C\u002F",[3425,4053,4034],{"class":4033},[3425,4055,4037],{"class":4030},[3425,4057,4059,4061,4064,4067,4069,4072,4074,4077,4080,4083],{"class":3427,"line":4058},51,[3425,4060,3976],{"class":3583},[3425,4062,4063],{"class":3583}," async",[3425,4065,4066],{"class":3466}," Task",[3425,4068,3702],{"class":3470},[3425,4070,4071],{"class":3466},"List",[3425,4073,3702],{"class":3470},[3425,4075,4076],{"class":3466},"DetectedLabelDto",[3425,4078,4079],{"class":3470},">> ",[3425,4081,4082],{"class":3431},"DetectLabelsAsync",[3425,4084,3670],{"class":3470},[3425,4086,4088,4091,4094],{"class":3427,"line":4087},52,[3425,4089,4090],{"class":3583},"        string",[3425,4092,4093],{"class":3627}," bucketName",[3425,4095,4096],{"class":3470},", \n",[3425,4098,4100,4102,4105],{"class":3427,"line":4099},53,[3425,4101,4090],{"class":3583},[3425,4103,4104],{"class":3627}," imageKey",[3425,4106,4096],{"class":3470},[3425,4108,4110,4113,4116,4118,4122],{"class":3427,"line":4109},54,[3425,4111,4112],{"class":3583},"        float",[3425,4114,4115],{"class":3627}," minConfidence",[3425,4117,4005],{"class":3470},[3425,4119,4121],{"class":4120},"sJj4R","70f",[3425,4123,3990],{"class":3470},[3425,4125,4127],{"class":3427,"line":4126},55,[3425,4128,3996],{"class":3470},[3425,4130,4132,4135,4138,4140,4143],{"class":3427,"line":4131},56,[3425,4133,4134],{"class":3583},"        var",[3425,4136,4137],{"class":3627}," request",[3425,4139,4005],{"class":3470},[3425,4141,4142],{"class":3583},"new",[3425,4144,4145],{"class":3466}," DetectLabelsRequest\n",[3425,4147,4149],{"class":3427,"line":4148},57,[3425,4150,4151],{"class":3470},"        {\n",[3425,4153,4155,4158,4160,4162],{"class":3427,"line":4154},58,[3425,4156,4157],{"class":3627},"            Image",[3425,4159,4005],{"class":3470},[3425,4161,4142],{"class":3583},[3425,4163,4164],{"class":3466}," Image\n",[3425,4166,4168],{"class":3427,"line":4167},59,[3425,4169,4170],{"class":3470},"            {\n",[3425,4172,4174,4177,4179,4181,4184,4187,4190,4192,4195,4197,4200,4202,4205],{"class":3427,"line":4173},60,[3425,4175,4176],{"class":3627},"                S3Object",[3425,4178,4005],{"class":3470},[3425,4180,4142],{"class":3583},[3425,4182,4183],{"class":3466}," S3Object",[3425,4185,4186],{"class":3470}," { ",[3425,4188,4189],{"class":3627},"Bucket",[3425,4191,4005],{"class":3470},[3425,4193,4194],{"class":3627},"bucketName",[3425,4196,3385],{"class":3470},[3425,4198,4199],{"class":3627},"Name",[3425,4201,4005],{"class":3470},[3425,4203,4204],{"class":3627},"imageKey",[3425,4206,4207],{"class":3470}," }\n",[3425,4209,4211],{"class":3427,"line":4210},61,[3425,4212,4213],{"class":3470},"            },\n",[3425,4215,4217,4220,4222,4225],{"class":3427,"line":4216},62,[3425,4218,4219],{"class":3627},"            MaxLabels",[3425,4221,4005],{"class":3470},[3425,4223,4224],{"class":4120},"50",[3425,4226,3682],{"class":3470},[3425,4228,4230,4233,4235],{"class":3427,"line":4229},63,[3425,4231,4232],{"class":3627},"            MinConfidence",[3425,4234,4005],{"class":3470},[3425,4236,4237],{"class":3627},"minConfidence\n",[3425,4239,4241],{"class":3427,"line":4240},64,[3425,4242,4243],{"class":3470},"        };\n",[3425,4245,4247],{"class":3427,"line":4246},65,[3425,4248,3577],{"emptyLinePlaceholder":3576},[3425,4250,4252],{"class":3427,"line":4251},66,[3425,4253,4254],{"class":3462},"        try\n",[3425,4256,4258],{"class":3427,"line":4257},67,[3425,4259,4151],{"class":3470},[3425,4261,4263,4266,4269,4271,4274,4276,4278,4280,4282,4285],{"class":3427,"line":4262},68,[3425,4264,4265],{"class":3583},"            var",[3425,4267,4268],{"class":3627}," response",[3425,4270,4005],{"class":3470},[3425,4272,4273],{"class":3583},"await",[3425,4275,3963],{"class":3627},[3425,4277,3389],{"class":3470},[3425,4279,4082],{"class":3431},[3425,4281,3621],{"class":3470},[3425,4283,4284],{"class":3627},"request",[3425,4286,3652],{"class":3470},[3425,4288,4290],{"class":3427,"line":4289},69,[3425,4291,3577],{"emptyLinePlaceholder":3576},[3425,4293,4295,4298,4300,4302,4305,4307,4310,4312,4315,4318,4320,4322],{"class":3427,"line":4294},70,[3425,4296,4297],{"class":3462},"            return",[3425,4299,4268],{"class":3627},[3425,4301,3389],{"class":3470},[3425,4303,4304],{"class":3627},"Labels",[3425,4306,3389],{"class":3470},[3425,4308,4309],{"class":3431},"Select",[3425,4311,3621],{"class":3470},[3425,4313,4314],{"class":3627},"l",[3425,4316,4317],{"class":3470}," => ",[3425,4319,4142],{"class":3583},[3425,4321,3667],{"class":3466},[3425,4323,3670],{"class":3470},[3425,4325,4327,4330,4333,4335,4337,4339],{"class":3427,"line":4326},71,[3425,4328,4329],{"class":3627},"                Name",[3425,4331,4332],{"class":3470},": ",[3425,4334,4314],{"class":3627},[3425,4336,3389],{"class":3470},[3425,4338,4199],{"class":3627},[3425,4340,3682],{"class":3470},[3425,4342,4344,4347,4349,4351,4353,4355],{"class":3427,"line":4343},72,[3425,4345,4346],{"class":3627},"                Confidence",[3425,4348,4332],{"class":3470},[3425,4350,4314],{"class":3627},[3425,4352,3389],{"class":3470},[3425,4354,3376],{"class":3627},[3425,4356,3682],{"class":3470},[3425,4358,4360,4363,4365,4367,4369,4371,4373,4375,4377,4380,4382,4384,4386,4388,4391,4394],{"class":3427,"line":4359},73,[3425,4361,4362],{"class":3627},"                Categories",[3425,4364,4332],{"class":3470},[3425,4366,4314],{"class":3627},[3425,4368,3389],{"class":3470},[3425,4370,3711],{"class":3627},[3425,4372,3389],{"class":3470},[3425,4374,4309],{"class":3431},[3425,4376,3621],{"class":3470},[3425,4378,4379],{"class":3627},"c",[3425,4381,4317],{"class":3470},[3425,4383,4379],{"class":3627},[3425,4385,3389],{"class":3470},[3425,4387,4199],{"class":3627},[3425,4389,4390],{"class":3470},").",[3425,4392,4393],{"class":3431},"ToList",[3425,4395,4396],{"class":3470},"(),\n",[3425,4398,4400,4403,4405,4407,4409,4412,4414,4417,4420,4422,4425,4428],{"class":3427,"line":4399},74,[3425,4401,4402],{"class":3627},"                BoundingBox",[3425,4404,4332],{"class":3470},[3425,4406,4314],{"class":3627},[3425,4408,3389],{"class":3470},[3425,4410,4411],{"class":3627},"Instances",[3425,4413,3389],{"class":3470},[3425,4415,4416],{"class":3431},"FirstOrDefault",[3425,4418,4419],{"class":3470},"()?.",[3425,4421,3380],{"class":3627},[3425,4423,4424],{"class":3583}," is",[3425,4426,4427],{"class":3470}," { } ",[3425,4429,4430],{"class":3627},"bb\n",[3425,4432,4434,4437,4439,4441,4443,4446,4448,4451,4453,4455,4457,4460,4462,4464,4466,4469,4471,4473,4475,4478],{"class":3427,"line":4433},75,[3425,4435,4436],{"class":3470},"                    ? ",[3425,4438,4142],{"class":3583},[3425,4440,3618],{"class":3466},[3425,4442,3621],{"class":3470},[3425,4444,4445],{"class":3627},"bb",[3425,4447,3389],{"class":3470},[3425,4449,4450],{"class":3627},"Left",[3425,4452,3385],{"class":3470},[3425,4454,4445],{"class":3627},[3425,4456,3389],{"class":3470},[3425,4458,4459],{"class":3627},"Top",[3425,4461,3385],{"class":3470},[3425,4463,4445],{"class":3627},[3425,4465,3389],{"class":3470},[3425,4467,4468],{"class":3627},"Width",[3425,4470,3385],{"class":3470},[3425,4472,4445],{"class":3627},[3425,4474,3389],{"class":3470},[3425,4476,4477],{"class":3627},"Height",[3425,4479,3990],{"class":3470},[3425,4481,4483,4486],{"class":3427,"line":4482},76,[3425,4484,4485],{"class":3470},"                    : ",[3425,4487,4488],{"class":3583},"null\n",[3425,4490,4492,4495,4497],{"class":3427,"line":4491},77,[3425,4493,4494],{"class":3470},"            )).",[3425,4496,4393],{"class":3431},[3425,4498,4499],{"class":3470},"();\n",[3425,4501,4503],{"class":3427,"line":4502},78,[3425,4504,4505],{"class":3470},"        }\n",[3425,4507,4509,4512,4515,4518,4521],{"class":3427,"line":4508},79,[3425,4510,4511],{"class":3462},"        catch",[3425,4513,4514],{"class":3470}," (",[3425,4516,4517],{"class":3466},"AmazonRekognitionException",[3425,4519,4520],{"class":3627}," ex",[3425,4522,3990],{"class":3470},[3425,4524,4526],{"class":3427,"line":4525},80,[3425,4527,4151],{"class":3470},[3425,4529,4531,4534,4537,4540,4542,4545,4549,4552,4554,4557,4560,4563,4565,4567],{"class":3427,"line":4530},81,[3425,4532,4533],{"class":3462},"            throw",[3425,4535,4536],{"class":3583}," new",[3425,4538,4539],{"class":3466}," Exception",[3425,4541,3621],{"class":3470},[3425,4543,4544],{"class":3435},"$\"Error calling Amazon Rekognition DetectLabels: ",[3425,4546,4548],{"class":4547},"sD7JJ","{",[3425,4550,4551],{"class":3627},"ex",[3425,4553,3389],{"class":4547},[3425,4555,4556],{"class":3627},"Message",[3425,4558,4559],{"class":4547},"}",[3425,4561,4562],{"class":3435},"\"",[3425,4564,3385],{"class":3470},[3425,4566,4551],{"class":3627},[3425,4568,3652],{"class":3470},[3425,4570,4572],{"class":3427,"line":4571},82,[3425,4573,4505],{"class":3470},[3425,4575,4577],{"class":3427,"line":4576},83,[3425,4578,4016],{"class":3470},[3425,4580,4582],{"class":3427,"line":4581},84,[3425,4583,3577],{"emptyLinePlaceholder":3576},[3425,4585,4587,4589,4591,4593],{"class":3427,"line":4586},85,[3425,4588,4027],{"class":3605},[3425,4590,3702],{"class":4030},[3425,4592,4034],{"class":4033},[3425,4594,4037],{"class":4030},[3425,4596,4598],{"class":3427,"line":4597},86,[3425,4599,4600],{"class":3605},"    \u002F\u002F\u002F Перевіряє зображення на наявність небажаного вмісту.\n",[3425,4602,4604,4606,4608,4610],{"class":3427,"line":4603},87,[3425,4605,4027],{"class":3605},[3425,4607,4051],{"class":4030},[3425,4609,4034],{"class":4033},[3425,4611,4037],{"class":4030},[3425,4613,4615,4617,4619,4621,4623,4626,4628,4631,4633,4635,4637,4639,4641,4643],{"class":3427,"line":4614},88,[3425,4616,3976],{"class":3583},[3425,4618,4063],{"class":3583},[3425,4620,4066],{"class":3466},[3425,4622,3702],{"class":3470},[3425,4624,4625],{"class":3466},"ContentModerationResultDto",[3425,4627,3708],{"class":3470},[3425,4629,4630],{"class":3431},"ModerateImageAsync",[3425,4632,3621],{"class":3470},[3425,4634,3705],{"class":3583},[3425,4636,4093],{"class":3627},[3425,4638,3385],{"class":3470},[3425,4640,3705],{"class":3583},[3425,4642,4104],{"class":3627},[3425,4644,3990],{"class":3470},[3425,4646,4648],{"class":3427,"line":4647},89,[3425,4649,3996],{"class":3470},[3425,4651,4653,4655,4657,4659,4661],{"class":3427,"line":4652},90,[3425,4654,4134],{"class":3583},[3425,4656,4137],{"class":3627},[3425,4658,4005],{"class":3470},[3425,4660,4142],{"class":3583},[3425,4662,4663],{"class":3466}," DetectModerationLabelsRequest\n",[3425,4665,4667],{"class":3427,"line":4666},91,[3425,4668,4151],{"class":3470},[3425,4670,4672,4674,4676,4678],{"class":3427,"line":4671},92,[3425,4673,4157],{"class":3627},[3425,4675,4005],{"class":3470},[3425,4677,4142],{"class":3583},[3425,4679,4164],{"class":3466},[3425,4681,4683],{"class":3427,"line":4682},93,[3425,4684,4170],{"class":3470},[3425,4686,4688,4690,4692,4694,4696,4698,4700,4702,4704,4706,4708,4710,4712],{"class":3427,"line":4687},94,[3425,4689,4176],{"class":3627},[3425,4691,4005],{"class":3470},[3425,4693,4142],{"class":3583},[3425,4695,4183],{"class":3466},[3425,4697,4186],{"class":3470},[3425,4699,4189],{"class":3627},[3425,4701,4005],{"class":3470},[3425,4703,4194],{"class":3627},[3425,4705,3385],{"class":3470},[3425,4707,4199],{"class":3627},[3425,4709,4005],{"class":3470},[3425,4711,4204],{"class":3627},[3425,4713,4207],{"class":3470},[3425,4715,4717],{"class":3427,"line":4716},95,[3425,4718,4213],{"class":3470},[3425,4720,4722,4724,4726],{"class":3427,"line":4721},96,[3425,4723,4232],{"class":3627},[3425,4725,4005],{"class":3470},[3425,4727,4728],{"class":4120},"50f\n",[3425,4730,4732],{"class":3427,"line":4731},97,[3425,4733,4243],{"class":3470},[3425,4735,4737],{"class":3427,"line":4736},98,[3425,4738,3577],{"emptyLinePlaceholder":3576},[3425,4740,4742],{"class":3427,"line":4741},99,[3425,4743,4254],{"class":3462},[3425,4745,4747],{"class":3427,"line":4746},100,[3425,4748,4151],{"class":3470},[3425,4750,4752,4754,4756,4758,4760,4762,4764,4767,4769,4771],{"class":3427,"line":4751},101,[3425,4753,4265],{"class":3583},[3425,4755,4268],{"class":3627},[3425,4757,4005],{"class":3470},[3425,4759,4273],{"class":3583},[3425,4761,3963],{"class":3627},[3425,4763,3389],{"class":3470},[3425,4765,4766],{"class":3431},"DetectModerationLabelsAsync",[3425,4768,3621],{"class":3470},[3425,4770,4284],{"class":3627},[3425,4772,3652],{"class":3470},[3425,4774,4776],{"class":3427,"line":4775},102,[3425,4777,3577],{"emptyLinePlaceholder":3576},[3425,4779,4781,4783,4786,4788,4791,4793,4796,4798,4800,4802,4805,4807,4809,4811],{"class":3427,"line":4780},103,[3425,4782,4265],{"class":3583},[3425,4784,4785],{"class":3627}," violations",[3425,4787,4005],{"class":3470},[3425,4789,4790],{"class":3627},"response",[3425,4792,3389],{"class":3470},[3425,4794,4795],{"class":3627},"ModerationLabels",[3425,4797,3389],{"class":3470},[3425,4799,4309],{"class":3431},[3425,4801,3621],{"class":3470},[3425,4803,4804],{"class":3627},"ml",[3425,4806,4317],{"class":3470},[3425,4808,4142],{"class":3583},[3425,4810,3747],{"class":3466},[3425,4812,3670],{"class":3470},[3425,4814,4816,4819,4821,4823,4825,4828,4831,4833,4835,4837],{"class":3427,"line":4815},104,[3425,4817,4818],{"class":3627},"                Category",[3425,4820,4332],{"class":3470},[3425,4822,4804],{"class":3627},[3425,4824,3389],{"class":3470},[3425,4826,4827],{"class":3627},"ParentName",[3425,4829,4830],{"class":3470}," ?? ",[3425,4832,4804],{"class":3627},[3425,4834,3389],{"class":3470},[3425,4836,4199],{"class":3627},[3425,4838,3682],{"class":3470},[3425,4840,4842,4845,4847,4849,4851,4853],{"class":3427,"line":4841},105,[3425,4843,4844],{"class":3627},"                SubCategory",[3425,4846,4332],{"class":3470},[3425,4848,4804],{"class":3627},[3425,4850,3389],{"class":3470},[3425,4852,4199],{"class":3627},[3425,4854,3682],{"class":3470},[3425,4856,4858,4860,4862,4864,4866],{"class":3427,"line":4857},106,[3425,4859,4346],{"class":3627},[3425,4861,4332],{"class":3470},[3425,4863,4804],{"class":3627},[3425,4865,3389],{"class":3470},[3425,4867,4868],{"class":3627},"Confidence\n",[3425,4870,4872,4874,4876],{"class":3427,"line":4871},107,[3425,4873,4494],{"class":3470},[3425,4875,4393],{"class":3431},[3425,4877,4499],{"class":3470},[3425,4879,4881],{"class":3427,"line":4880},108,[3425,4882,3577],{"emptyLinePlaceholder":3576},[3425,4884,4886,4888,4890,4892],{"class":3427,"line":4885},109,[3425,4887,4297],{"class":3462},[3425,4889,4536],{"class":3583},[3425,4891,3784],{"class":3466},[3425,4893,3670],{"class":3470},[3425,4895,4897,4900,4902,4905,4907,4910,4913,4916],{"class":3427,"line":4896},110,[3425,4898,4899],{"class":3627},"                IsSafe",[3425,4901,4332],{"class":3470},[3425,4903,4904],{"class":3627},"violations",[3425,4906,3389],{"class":3470},[3425,4908,4909],{"class":3627},"Count",[3425,4911,4912],{"class":3470}," == ",[3425,4914,4915],{"class":4120},"0",[3425,4917,3682],{"class":3470},[3425,4919,4921,4924,4926],{"class":3427,"line":4920},111,[3425,4922,4923],{"class":3627},"                Violations",[3425,4925,4332],{"class":3470},[3425,4927,4928],{"class":3627},"violations\n",[3425,4930,4932],{"class":3427,"line":4931},112,[3425,4933,4934],{"class":3470},"            );\n",[3425,4936,4938],{"class":3427,"line":4937},113,[3425,4939,4505],{"class":3470},[3425,4941,4943,4945,4947,4949,4951],{"class":3427,"line":4942},114,[3425,4944,4511],{"class":3462},[3425,4946,4514],{"class":3470},[3425,4948,4517],{"class":3466},[3425,4950,4520],{"class":3627},[3425,4952,3990],{"class":3470},[3425,4954,4956],{"class":3427,"line":4955},115,[3425,4957,4151],{"class":3470},[3425,4959,4961,4963,4965,4967,4969,4972,4974,4976,4978,4980,4982,4984,4986,4988],{"class":3427,"line":4960},116,[3425,4962,4533],{"class":3462},[3425,4964,4536],{"class":3583},[3425,4966,4539],{"class":3466},[3425,4968,3621],{"class":3470},[3425,4970,4971],{"class":3435},"$\"Error calling Amazon Rekognition ModerateImage: ",[3425,4973,4548],{"class":4547},[3425,4975,4551],{"class":3627},[3425,4977,3389],{"class":4547},[3425,4979,4556],{"class":3627},[3425,4981,4559],{"class":4547},[3425,4983,4562],{"class":3435},[3425,4985,3385],{"class":3470},[3425,4987,4551],{"class":3627},[3425,4989,3652],{"class":3470},[3425,4991,4993],{"class":3427,"line":4992},117,[3425,4994,4505],{"class":3470},[3425,4996,4998],{"class":3427,"line":4997},118,[3425,4999,4016],{"class":3470},[3425,5001,5003],{"class":3427,"line":5002},119,[3425,5004,3577],{"emptyLinePlaceholder":3576},[3425,5006,5008,5010,5012,5014],{"class":3427,"line":5007},120,[3425,5009,4027],{"class":3605},[3425,5011,3702],{"class":4030},[3425,5013,4034],{"class":4033},[3425,5015,4037],{"class":4030},[3425,5017,5019],{"class":3427,"line":5018},121,[3425,5020,5021],{"class":3605},"    \u002F\u002F\u002F OCR розпізнавання тексту на фотографії з S3.\n",[3425,5023,5025,5027,5029,5031],{"class":3427,"line":5024},122,[3425,5026,4027],{"class":3605},[3425,5028,4051],{"class":4030},[3425,5030,4034],{"class":4033},[3425,5032,4037],{"class":4030},[3425,5034,5036,5038,5040,5042,5044,5046,5048,5051,5053,5055,5057,5059,5061,5063],{"class":3427,"line":5035},123,[3425,5037,3976],{"class":3583},[3425,5039,4063],{"class":3583},[3425,5041,4066],{"class":3466},[3425,5043,3702],{"class":3470},[3425,5045,3705],{"class":3583},[3425,5047,3708],{"class":3470},[3425,5049,5050],{"class":3431},"ExtractTextAsync",[3425,5052,3621],{"class":3470},[3425,5054,3705],{"class":3583},[3425,5056,4093],{"class":3627},[3425,5058,3385],{"class":3470},[3425,5060,3705],{"class":3583},[3425,5062,4104],{"class":3627},[3425,5064,3990],{"class":3470},[3425,5066,5068],{"class":3427,"line":5067},124,[3425,5069,3996],{"class":3470},[3425,5071,5073,5075,5077,5079,5081],{"class":3427,"line":5072},125,[3425,5074,4134],{"class":3583},[3425,5076,4137],{"class":3627},[3425,5078,4005],{"class":3470},[3425,5080,4142],{"class":3583},[3425,5082,5083],{"class":3466}," DetectTextRequest\n",[3425,5085,5087],{"class":3427,"line":5086},126,[3425,5088,4151],{"class":3470},[3425,5090,5092,5094,5096,5098],{"class":3427,"line":5091},127,[3425,5093,4157],{"class":3627},[3425,5095,4005],{"class":3470},[3425,5097,4142],{"class":3583},[3425,5099,4164],{"class":3466},[3425,5101,5103],{"class":3427,"line":5102},128,[3425,5104,4170],{"class":3470},[3425,5106,5108,5110,5112,5114,5116,5118,5120,5122,5124,5126,5128,5130,5132],{"class":3427,"line":5107},129,[3425,5109,4176],{"class":3627},[3425,5111,4005],{"class":3470},[3425,5113,4142],{"class":3583},[3425,5115,4183],{"class":3466},[3425,5117,4186],{"class":3470},[3425,5119,4189],{"class":3627},[3425,5121,4005],{"class":3470},[3425,5123,4194],{"class":3627},[3425,5125,3385],{"class":3470},[3425,5127,4199],{"class":3627},[3425,5129,4005],{"class":3470},[3425,5131,4204],{"class":3627},[3425,5133,4207],{"class":3470},[3425,5135,5137],{"class":3427,"line":5136},130,[3425,5138,5139],{"class":3470},"            }\n",[3425,5141,5143],{"class":3427,"line":5142},131,[3425,5144,4243],{"class":3470},[3425,5146,5148],{"class":3427,"line":5147},132,[3425,5149,3577],{"emptyLinePlaceholder":3576},[3425,5151,5153],{"class":3427,"line":5152},133,[3425,5154,4254],{"class":3462},[3425,5156,5158],{"class":3427,"line":5157},134,[3425,5159,4151],{"class":3470},[3425,5161,5163,5165,5167,5169,5171,5173,5175,5178,5180,5182],{"class":3427,"line":5162},135,[3425,5164,4265],{"class":3583},[3425,5166,4268],{"class":3627},[3425,5168,4005],{"class":3470},[3425,5170,4273],{"class":3583},[3425,5172,3963],{"class":3627},[3425,5174,3389],{"class":3470},[3425,5176,5177],{"class":3431},"DetectTextAsync",[3425,5179,3621],{"class":3470},[3425,5181,4284],{"class":3627},[3425,5183,3652],{"class":3470},[3425,5185,5187],{"class":3427,"line":5186},136,[3425,5188,5189],{"class":3470},"            \n",[3425,5191,5193],{"class":3427,"line":5192},137,[3425,5194,5195],{"class":3605},"            \u002F\u002F Фільтруємо лише цілі рядки (LINES), ігноруючи окремі слова\n",[3425,5197,5199,5201,5204,5206,5208,5210],{"class":3427,"line":5198},138,[3425,5200,4265],{"class":3583},[3425,5202,5203],{"class":3627}," lines",[3425,5205,4005],{"class":3470},[3425,5207,4790],{"class":3627},[3425,5209,3389],{"class":3470},[3425,5211,5212],{"class":3627},"TextDetections\n",[3425,5214,5216,5219,5222,5224,5227,5229,5231,5233,5236,5238,5241,5243,5246],{"class":3427,"line":5215},139,[3425,5217,5218],{"class":3470},"                .",[3425,5220,5221],{"class":3431},"Where",[3425,5223,3621],{"class":3470},[3425,5225,5226],{"class":3627},"t",[3425,5228,4317],{"class":3470},[3425,5230,5226],{"class":3627},[3425,5232,3389],{"class":3470},[3425,5234,5235],{"class":3627},"Type",[3425,5237,4912],{"class":3470},[3425,5239,5240],{"class":3627},"TextTypes",[3425,5242,3389],{"class":3470},[3425,5244,5245],{"class":3627},"LINE",[3425,5247,3990],{"class":3470},[3425,5249,5251,5253,5256,5258,5260,5262,5264,5266,5269,5271,5273,5275,5277],{"class":3427,"line":5250},140,[3425,5252,5218],{"class":3470},[3425,5254,5255],{"class":3431},"OrderBy",[3425,5257,3621],{"class":3470},[3425,5259,5226],{"class":3627},[3425,5261,4317],{"class":3470},[3425,5263,5226],{"class":3627},[3425,5265,3389],{"class":3470},[3425,5267,5268],{"class":3627},"Geometry",[3425,5270,3389],{"class":3470},[3425,5272,3380],{"class":3627},[3425,5274,3389],{"class":3470},[3425,5276,4459],{"class":3627},[3425,5278,3990],{"class":3470},[3425,5280,5282,5284,5286,5288,5290,5292,5294,5296,5299],{"class":3427,"line":5281},141,[3425,5283,5218],{"class":3470},[3425,5285,4309],{"class":3431},[3425,5287,3621],{"class":3470},[3425,5289,5226],{"class":3627},[3425,5291,4317],{"class":3470},[3425,5293,5226],{"class":3627},[3425,5295,3389],{"class":3470},[3425,5297,5298],{"class":3627},"DetectedText",[3425,5300,3652],{"class":3470},[3425,5302,5304],{"class":3427,"line":5303},142,[3425,5305,3577],{"emptyLinePlaceholder":3576},[3425,5307,5309,5311,5314,5316,5319,5321,5323,5327,5329,5331,5334],{"class":3427,"line":5308},143,[3425,5310,4297],{"class":3462},[3425,5312,5313],{"class":3583}," string",[3425,5315,3389],{"class":3470},[3425,5317,5318],{"class":3431},"Join",[3425,5320,3621],{"class":3470},[3425,5322,4562],{"class":3435},[3425,5324,5326],{"class":5325},"sjcCO","\\n",[3425,5328,4562],{"class":3435},[3425,5330,3385],{"class":3470},[3425,5332,5333],{"class":3627},"lines",[3425,5335,3652],{"class":3470},[3425,5337,5339],{"class":3427,"line":5338},144,[3425,5340,4505],{"class":3470},[3425,5342,5344,5346,5348,5350,5352],{"class":3427,"line":5343},145,[3425,5345,4511],{"class":3462},[3425,5347,4514],{"class":3470},[3425,5349,4517],{"class":3466},[3425,5351,4520],{"class":3627},[3425,5353,3990],{"class":3470},[3425,5355,5357],{"class":3427,"line":5356},146,[3425,5358,4151],{"class":3470},[3425,5360,5362,5364,5366,5368,5370,5373,5375,5377,5379,5381,5383,5385,5387,5389],{"class":3427,"line":5361},147,[3425,5363,4533],{"class":3462},[3425,5365,4536],{"class":3583},[3425,5367,4539],{"class":3466},[3425,5369,3621],{"class":3470},[3425,5371,5372],{"class":3435},"$\"Error calling Amazon Rekognition DetectText: ",[3425,5374,4548],{"class":4547},[3425,5376,4551],{"class":3627},[3425,5378,3389],{"class":4547},[3425,5380,4556],{"class":3627},[3425,5382,4559],{"class":4547},[3425,5384,4562],{"class":3435},[3425,5386,3385],{"class":3470},[3425,5388,4551],{"class":3627},[3425,5390,3652],{"class":3470},[3425,5392,5394],{"class":3427,"line":5393},148,[3425,5395,4505],{"class":3470},[3425,5397,5399],{"class":3427,"line":5398},149,[3425,5400,4016],{"class":3470},[3425,5402,5404],{"class":3427,"line":5403},150,[3425,5405,3577],{"emptyLinePlaceholder":3576},[3425,5407,5409,5411,5413,5415],{"class":3427,"line":5408},151,[3425,5410,4027],{"class":3605},[3425,5412,3702],{"class":4030},[3425,5414,4034],{"class":4033},[3425,5416,4037],{"class":4030},[3425,5418,5420],{"class":3427,"line":5419},152,[3425,5421,5422],{"class":3605},"    \u002F\u002F\u002F Порівнює обличчя на джерельному фото з обличчями на цільовому фото.\n",[3425,5424,5426,5428,5430,5432],{"class":3427,"line":5425},153,[3425,5427,4027],{"class":3605},[3425,5429,4051],{"class":4030},[3425,5431,4034],{"class":4033},[3425,5433,4037],{"class":4030},[3425,5435,5437,5439,5441,5443,5445,5447,5449,5452,5454,5457],{"class":3427,"line":5436},154,[3425,5438,3976],{"class":3583},[3425,5440,4063],{"class":3583},[3425,5442,4066],{"class":3466},[3425,5444,3702],{"class":3470},[3425,5446,4071],{"class":3466},[3425,5448,3702],{"class":3470},[3425,5450,5451],{"class":3466},"FaceComparisonResultDto",[3425,5453,4079],{"class":3470},[3425,5455,5456],{"class":3431},"CompareFacesAsync",[3425,5458,3670],{"class":3470},[3425,5460,5462,5464,5467,5469,5471,5474],{"class":3427,"line":5461},155,[3425,5463,4090],{"class":3583},[3425,5465,5466],{"class":3627}," sourceBucket",[3425,5468,3385],{"class":3470},[3425,5470,3705],{"class":3583},[3425,5472,5473],{"class":3627}," sourceKey",[3425,5475,3682],{"class":3470},[3425,5477,5479,5481,5484,5486,5488,5491],{"class":3427,"line":5478},156,[3425,5480,4090],{"class":3583},[3425,5482,5483],{"class":3627}," targetBucket",[3425,5485,3385],{"class":3470},[3425,5487,3705],{"class":3583},[3425,5489,5490],{"class":3627}," targetKey",[3425,5492,3682],{"class":3470},[3425,5494,5496,5498,5501,5503,5506],{"class":3427,"line":5495},157,[3425,5497,4112],{"class":3583},[3425,5499,5500],{"class":3627}," similarityThreshold",[3425,5502,4005],{"class":3470},[3425,5504,5505],{"class":4120},"80f",[3425,5507,3990],{"class":3470},[3425,5509,5511],{"class":3427,"line":5510},158,[3425,5512,3996],{"class":3470},[3425,5514,5516,5518,5520,5522,5524],{"class":3427,"line":5515},159,[3425,5517,4134],{"class":3583},[3425,5519,4137],{"class":3627},[3425,5521,4005],{"class":3470},[3425,5523,4142],{"class":3583},[3425,5525,5526],{"class":3466}," CompareFacesRequest\n",[3425,5528,5530],{"class":3427,"line":5529},160,[3425,5531,4151],{"class":3470},[3425,5533,5535,5538,5540,5542,5545,5547,5550,5552,5554,5556,5558,5560,5562,5565,5567,5569,5571,5574],{"class":3427,"line":5534},161,[3425,5536,5537],{"class":3627},"            SourceImage",[3425,5539,4005],{"class":3470},[3425,5541,4142],{"class":3583},[3425,5543,5544],{"class":3466}," Image",[3425,5546,4186],{"class":3470},[3425,5548,5549],{"class":3627},"S3Object",[3425,5551,4005],{"class":3470},[3425,5553,4142],{"class":3583},[3425,5555,4183],{"class":3466},[3425,5557,4186],{"class":3470},[3425,5559,4189],{"class":3627},[3425,5561,4005],{"class":3470},[3425,5563,5564],{"class":3627},"sourceBucket",[3425,5566,3385],{"class":3470},[3425,5568,4199],{"class":3627},[3425,5570,4005],{"class":3470},[3425,5572,5573],{"class":3627},"sourceKey",[3425,5575,5576],{"class":3470}," } },\n",[3425,5578,5580,5583,5585,5587,5589,5591,5593,5595,5597,5599,5601,5603,5605,5608,5610,5612,5614,5617],{"class":3427,"line":5579},162,[3425,5581,5582],{"class":3627},"            TargetImage",[3425,5584,4005],{"class":3470},[3425,5586,4142],{"class":3583},[3425,5588,5544],{"class":3466},[3425,5590,4186],{"class":3470},[3425,5592,5549],{"class":3627},[3425,5594,4005],{"class":3470},[3425,5596,4142],{"class":3583},[3425,5598,4183],{"class":3466},[3425,5600,4186],{"class":3470},[3425,5602,4189],{"class":3627},[3425,5604,4005],{"class":3470},[3425,5606,5607],{"class":3627},"targetBucket",[3425,5609,3385],{"class":3470},[3425,5611,4199],{"class":3627},[3425,5613,4005],{"class":3470},[3425,5615,5616],{"class":3627},"targetKey",[3425,5618,5576],{"class":3470},[3425,5620,5622,5625,5627],{"class":3427,"line":5621},163,[3425,5623,5624],{"class":3627},"            SimilarityThreshold",[3425,5626,4005],{"class":3470},[3425,5628,5629],{"class":3627},"similarityThreshold\n",[3425,5631,5633],{"class":3427,"line":5632},164,[3425,5634,4243],{"class":3470},[3425,5636,5638],{"class":3427,"line":5637},165,[3425,5639,3577],{"emptyLinePlaceholder":3576},[3425,5641,5643],{"class":3427,"line":5642},166,[3425,5644,4254],{"class":3462},[3425,5646,5648],{"class":3427,"line":5647},167,[3425,5649,4151],{"class":3470},[3425,5651,5653,5655,5657,5659,5661,5663,5665,5667,5669,5671],{"class":3427,"line":5652},168,[3425,5654,4265],{"class":3583},[3425,5656,4268],{"class":3627},[3425,5658,4005],{"class":3470},[3425,5660,4273],{"class":3583},[3425,5662,3963],{"class":3627},[3425,5664,3389],{"class":3470},[3425,5666,5456],{"class":3431},[3425,5668,3621],{"class":3470},[3425,5670,4284],{"class":3627},[3425,5672,3652],{"class":3470},[3425,5674,5676],{"class":3427,"line":5675},169,[3425,5677,3577],{"emptyLinePlaceholder":3576},[3425,5679,5681,5683,5685,5687,5690,5692,5694,5696,5699,5701,5703,5705],{"class":3427,"line":5680},170,[3425,5682,4297],{"class":3462},[3425,5684,4268],{"class":3627},[3425,5686,3389],{"class":3470},[3425,5688,5689],{"class":3627},"FaceMatches",[3425,5691,3389],{"class":3470},[3425,5693,4309],{"class":3431},[3425,5695,3621],{"class":3470},[3425,5697,5698],{"class":3627},"m",[3425,5700,4317],{"class":3470},[3425,5702,4142],{"class":3583},[3425,5704,3901],{"class":3466},[3425,5706,3670],{"class":3470},[3425,5708,5710,5713,5715,5717,5719,5722],{"class":3427,"line":5709},171,[3425,5711,5712],{"class":3627},"                Similarity",[3425,5714,4332],{"class":3470},[3425,5716,5698],{"class":3627},[3425,5718,3389],{"class":3470},[3425,5720,5721],{"class":3627},"Similarity",[3425,5723,3682],{"class":3470},[3425,5725,5727,5730,5732,5734,5736],{"class":3427,"line":5726},172,[3425,5728,5729],{"class":3627},"                TargetBoundingBox",[3425,5731,4332],{"class":3470},[3425,5733,4142],{"class":3583},[3425,5735,3618],{"class":3466},[3425,5737,3670],{"class":3470},[3425,5739,5741,5744,5746,5749,5751,5753,5755,5757],{"class":3427,"line":5740},173,[3425,5742,5743],{"class":3627},"                    m",[3425,5745,3389],{"class":3470},[3425,5747,5748],{"class":3627},"Face",[3425,5750,3389],{"class":3470},[3425,5752,3380],{"class":3627},[3425,5754,3389],{"class":3470},[3425,5756,4450],{"class":3627},[3425,5758,3682],{"class":3470},[3425,5760,5762,5764,5766,5768,5770,5772,5774,5776],{"class":3427,"line":5761},174,[3425,5763,5743],{"class":3627},[3425,5765,3389],{"class":3470},[3425,5767,5748],{"class":3627},[3425,5769,3389],{"class":3470},[3425,5771,3380],{"class":3627},[3425,5773,3389],{"class":3470},[3425,5775,4459],{"class":3627},[3425,5777,3682],{"class":3470},[3425,5779,5781,5783,5785,5787,5789,5791,5793,5795],{"class":3427,"line":5780},175,[3425,5782,5743],{"class":3627},[3425,5784,3389],{"class":3470},[3425,5786,5748],{"class":3627},[3425,5788,3389],{"class":3470},[3425,5790,3380],{"class":3627},[3425,5792,3389],{"class":3470},[3425,5794,4468],{"class":3627},[3425,5796,3682],{"class":3470},[3425,5798,5800,5802,5804,5806,5808,5810,5812,5814],{"class":3427,"line":5799},176,[3425,5801,5743],{"class":3627},[3425,5803,3389],{"class":3470},[3425,5805,5748],{"class":3627},[3425,5807,3389],{"class":3470},[3425,5809,3380],{"class":3627},[3425,5811,3389],{"class":3470},[3425,5813,4477],{"class":3627},[3425,5815,3990],{"class":3470},[3425,5817,5819,5821,5823],{"class":3427,"line":5818},177,[3425,5820,4494],{"class":3470},[3425,5822,4393],{"class":3431},[3425,5824,4499],{"class":3470},[3425,5826,5828],{"class":3427,"line":5827},178,[3425,5829,4505],{"class":3470},[3425,5831,5833,5835,5837,5839,5841],{"class":3427,"line":5832},179,[3425,5834,4511],{"class":3462},[3425,5836,4514],{"class":3470},[3425,5838,4517],{"class":3466},[3425,5840,4520],{"class":3627},[3425,5842,3990],{"class":3470},[3425,5844,5846],{"class":3427,"line":5845},180,[3425,5847,4151],{"class":3470},[3425,5849,5851,5853,5855,5857,5859,5862,5864,5866,5868,5870,5872,5874,5876,5878],{"class":3427,"line":5850},181,[3425,5852,4533],{"class":3462},[3425,5854,4536],{"class":3583},[3425,5856,4539],{"class":3466},[3425,5858,3621],{"class":3470},[3425,5860,5861],{"class":3435},"$\"Error calling Amazon Rekognition CompareFaces: ",[3425,5863,4548],{"class":4547},[3425,5865,4551],{"class":3627},[3425,5867,3389],{"class":4547},[3425,5869,4556],{"class":3627},[3425,5871,4559],{"class":4547},[3425,5873,4562],{"class":3435},[3425,5875,3385],{"class":3470},[3425,5877,4551],{"class":3627},[3425,5879,3652],{"class":3470},[3425,5881,5883],{"class":3427,"line":5882},182,[3425,5884,4505],{"class":3470},[3425,5886,5888],{"class":3427,"line":5887},183,[3425,5889,4016],{"class":3470},[3425,5891,5893],{"class":3427,"line":5892},184,[3425,5894,5895],{"class":3470},"}\n",[3406,5897],{},[3356,5899,5901],{"id":5900},"інтеграція-з-react-візуалізація-bounding-boxes-на-canvas","Інтеграція з React: Візуалізація Bounding Boxes на Canvas",[3348,5903,5904,5905,3389],{},"Для того щоб відобразити результати виявлення Rekognition (об'єкти, обличчя) поверх оригінального фото, координати Bounding Box перераховуються у пікселі та малюються на елементі ",[3370,5906,5907],{},"\u003Ccanvas>",[3348,5909,5910],{},"Координати від AWS Rekognition є відносними (значення від 0 до 1 відносно ширини та висоти зображення).",[5912,5913,5915],"h3",{"id":5914},"повний-react-компонент-imageanalyzer","Повний React компонент ImageAnalyzer",[3416,5917,5922],{"className":5918,"code":5919,"filename":5920,"language":5921,"meta":3421,"style":3421},"language-tsx shiki shiki-themes light-plus dark-plus dark-plus","import React, { useRef, useState, useEffect } from 'react';\n\nexport interface BoundingBox {\n  left: number;\n  top: number;\n  width: number;\n  height: number;\n}\n\nexport interface DetectedLabel {\n  name: string;\n  confidence: number;\n  boundingBox?: BoundingBox | null;\n}\n\ninterface ImageAnalyzerProps {\n  imageUrl: string;\n  labels: DetectedLabel[];\n}\n\nexport function ImageAnalyzer({ imageUrl, labels }: ImageAnalyzerProps) {\n  const canvasRef = useRef\u003CHTMLCanvasElement>(null);\n  const imageRef = useRef\u003CHTMLImageElement | null>(null);\n  const [imgLoaded, setImgLoaded] = useState(false);\n\n  useEffect(() => {\n    \u002F\u002F Створюємо та завантажуємо зображення\n    const img = new Image();\n    img.src = imageUrl;\n    img.crossOrigin = 'anonymous'; \u002F\u002F дозволяє читання пікселів при CORS\n    img.onload = () => {\n      imageRef.current = img;\n      setImgLoaded(true);\n    };\n    img.onerror = () => {\n      console.error('Не вдалося завантажити зображення.');\n    };\n  }, [imageUrl]);\n\n  useEffect(() => {\n    if (!imgLoaded || !imageRef.current || !canvasRef.current) return;\n\n    const canvas = canvasRef.current;\n    const ctx = canvas.getContext('2d');\n    if (!ctx) return;\n\n    const img = imageRef.current;\n    \n    \u002F\u002F Встановлюємо розміри canvas відповідно до реальних розмірів зображення\n    canvas.width = img.naturalWidth;\n    canvas.height = img.naturalHeight;\n\n    \u002F\u002F Малюємо оригінальне зображення\n    ctx.drawImage(img, 0, 0);\n\n    \u002F\u002F Малюємо Bounding Boxes для кожного об'єкта\n    labels.forEach((label) => {\n      if (!label.boundingBox) return;\n\n      const { left, top, width, height } = label.boundingBox;\n\n      \u002F\u002F Конвертуємо відносні координати (0..1) в пікселі\n      const x = left * canvas.width;\n      const y = top * canvas.height;\n      const w = width * canvas.width;\n      const h = height * canvas.height;\n\n      \u002F\u002F Налаштовуємо стилі рамки\n      ctx.strokeStyle = '#00ffcc';\n      ctx.lineWidth = Math.max(3, canvas.width * 0.003); \u002F\u002F товщина рамки адаптується під роздільну здатність\n      ctx.strokeRect(x, y, w, h);\n\n      \u002F\u002F Малюємо плашку для тексту\n      ctx.fillStyle = 'rgba(0, 255, 204, 0.85)';\n      const fontSize = Math.max(14, canvas.width * 0.015);\n      ctx.font = `bold ${fontSize}px sans-serif`;\n      \n      const text = `${label.name} (${Math.round(label.confidence)}%)`;\n      const textWidth = ctx.measureText(text).width;\n      const padding = 6;\n      \n      \u002F\u002F Запобігаємо виходу плашки за верхній край\n      const labelY = y - fontSize - padding > 0 ? y - fontSize - padding : y;\n      \n      ctx.fillRect(x, labelY, textWidth + padding * 2, fontSize + padding);\n\n      \u002F\u002F Малюємо сам текст\n      ctx.fillStyle = '#000000';\n      ctx.fillText(text, x + padding, labelY + fontSize);\n    });\n  }, [imgLoaded, labels]);\n\n  return (\n    \u003Cdiv style={styles.container}>\n      \u003Cdiv style={styles.canvasWrapper}>\n        \u003Ccanvas ref={canvasRef} style={styles.canvas} \u002F>\n      \u003C\u002Fdiv>\n      \u003Cdiv style={styles.detailsList}>\n        \u003Ch3 style={styles.listTitle}>Виявлені об'єкти:\u003C\u002Fh3>\n        \u003Cul style={styles.list}>\n          {labels.map((l, index) => (\n            \u003Cli key={index} style={styles.listItem}>\n              \u003Cspan style={styles.labelName}>{l.name}\u003C\u002Fspan>\n              \u003Cspan style={styles.confidenceBadge}>{Math.round(l.confidence)}%\u003C\u002Fspan>\n            \u003C\u002Fli>\n          ))}\n        \u003C\u002Ful>\n      \u003C\u002Fdiv>\n    \u003C\u002Fdiv>\n  );\n}\n\nconst styles = {\n  container: {\n    display: 'flex',\n    flexDirection: 'row' as const,\n    gap: '24px',\n    background: '#1f2937',\n    padding: '24px',\n    borderRadius: '12px',\n    boxShadow: '0 4px 20px rgba(0, 0, 0, 0.3)',\n    color: '#f3f4f6',\n    flexWrap: 'wrap' as const,\n  },\n  canvasWrapper: {\n    flex: '2 1 500px',\n    position: 'relative' as const,\n    background: '#111827',\n    borderRadius: '8px',\n    overflow: 'hidden',\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n  },\n  canvas: {\n    maxWidth: '100%',\n    maxHeight: '550px',\n    objectFit: 'contain' as const,\n  },\n  detailsList: {\n    flex: '1 1 250px',\n    background: '#111827',\n    padding: '16px',\n    borderRadius: '8px',\n    border: '1px solid rgba(255, 255, 255, 0.05)',\n  },\n  listTitle: {\n    marginTop: 0,\n    borderBottom: '1px solid rgba(255, 255, 255, 0.1)',\n    paddingBottom: '8px',\n    color: '#60a5fa',\n  },\n  list: {\n    listStyleType: 'none',\n    padding: 0,\n    margin: 0,\n    maxHeight: '400px',\n    overflowY: 'auto' as const,\n  },\n  listItem: {\n    display: 'flex',\n    justifyContent: 'space-between',\n    padding: '8px 4px',\n    borderBottom: '1px solid rgba(255, 255, 255, 0.03)',\n  },\n  labelName: {\n    fontWeight: 500,\n  },\n  confidenceBadge: {\n    background: '#10b981',\n    color: '#fff',\n    padding: '2px 8px',\n    borderRadius: '12px',\n    fontSize: '0.85rem',\n  },\n};\n","src\u002Fcomponents\u002FImageAnalyzer.tsx","tsx",[3370,5923,5924,5959,5963,5976,5988,5999,6010,6021,6025,6029,6040,6051,6062,6080,6084,6088,6098,6109,6122,6126,6130,6160,6185,6211,6238,6242,6255,6260,6276,6292,6312,6328,6345,6357,6362,6377,6394,6398,6408,6412,6422,6459,6463,6480,6504,6519,6523,6539,6544,6549,6570,6590,6594,6599,6623,6627,6632,6654,6674,6678,6712,6716,6721,6743,6764,6785,6806,6810,6815,6832,6875,6906,6910,6915,6931,6966,6993,6998,7051,7078,7092,7096,7101,7147,7151,7194,7198,7203,7218,7249,7254,7266,7270,7278,7307,7331,7366,7375,7398,7431,7455,7482,7518,7558,7610,7619,7626,7635,7643,7652,7657,7661,7665,7676,7683,7693,7709,7719,7729,7738,7748,7758,7768,7782,7787,7794,7804,7818,7827,7836,7846,7854,7864,7873,7877,7884,7894,7904,7918,7922,7929,7938,7946,7955,7963,7973,7977,7984,7994,8004,8013,8022,8026,8033,8043,8051,8060,8069,8083,8087,8094,8102,8111,8120,8129,8133,8140,8150,8154,8161,8170,8179,8188,8196,8206,8210],{"__ignoreMap":3421},[3425,5925,5926,5929,5932,5935,5938,5940,5943,5945,5948,5951,5954,5957],{"class":3427,"line":3428},[3425,5927,5928],{"class":3462},"import",[3425,5930,5931],{"class":3627}," React",[3425,5933,5934],{"class":3470},", { ",[3425,5936,5937],{"class":3627},"useRef",[3425,5939,3385],{"class":3470},[3425,5941,5942],{"class":3627},"useState",[3425,5944,3385],{"class":3470},[3425,5946,5947],{"class":3627},"useEffect",[3425,5949,5950],{"class":3470}," } ",[3425,5952,5953],{"class":3462},"from",[3425,5955,5956],{"class":3435}," 'react'",[3425,5958,3471],{"class":3470},[3425,5960,5961],{"class":3427,"line":3474},[3425,5962,3577],{"emptyLinePlaceholder":3576},[3425,5964,5965,5968,5971,5973],{"class":3427,"line":3493},[3425,5966,5967],{"class":3462},"export",[3425,5969,5970],{"class":3583}," interface",[3425,5972,3884],{"class":3466},[3425,5974,5975],{"class":3470}," {\n",[3425,5977,5978,5981,5983,5986],{"class":3427,"line":3507},[3425,5979,5980],{"class":3627},"  left",[3425,5982,4332],{"class":3470},[3425,5984,5985],{"class":3466},"number",[3425,5987,3471],{"class":3470},[3425,5989,5990,5993,5995,5997],{"class":3427,"line":3521},[3425,5991,5992],{"class":3627},"  top",[3425,5994,4332],{"class":3470},[3425,5996,5985],{"class":3466},[3425,5998,3471],{"class":3470},[3425,6000,6001,6004,6006,6008],{"class":3427,"line":3540},[3425,6002,6003],{"class":3627},"  width",[3425,6005,4332],{"class":3470},[3425,6007,5985],{"class":3466},[3425,6009,3471],{"class":3470},[3425,6011,6012,6015,6017,6019],{"class":3427,"line":3555},[3425,6013,6014],{"class":3627},"  height",[3425,6016,4332],{"class":3470},[3425,6018,5985],{"class":3466},[3425,6020,3471],{"class":3470},[3425,6022,6023],{"class":3427,"line":3573},[3425,6024,5895],{"class":3470},[3425,6026,6027],{"class":3427,"line":3580},[3425,6028,3577],{"emptyLinePlaceholder":3576},[3425,6030,6031,6033,6035,6038],{"class":3427,"line":3597},[3425,6032,5967],{"class":3462},[3425,6034,5970],{"class":3583},[3425,6036,6037],{"class":3466}," DetectedLabel",[3425,6039,5975],{"class":3470},[3425,6041,6042,6045,6047,6049],{"class":3427,"line":3602},[3425,6043,6044],{"class":3627},"  name",[3425,6046,4332],{"class":3470},[3425,6048,3705],{"class":3466},[3425,6050,3471],{"class":3470},[3425,6052,6053,6056,6058,6060],{"class":3427,"line":3609},[3425,6054,6055],{"class":3627},"  confidence",[3425,6057,4332],{"class":3470},[3425,6059,5985],{"class":3466},[3425,6061,3471],{"class":3470},[3425,6063,6064,6067,6070,6072,6075,6078],{"class":3427,"line":3655},[3425,6065,6066],{"class":3627},"  boundingBox",[3425,6068,6069],{"class":3470},"?: ",[3425,6071,3380],{"class":3466},[3425,6073,6074],{"class":3470}," | ",[3425,6076,6077],{"class":3466},"null",[3425,6079,3471],{"class":3470},[3425,6081,6082],{"class":3427,"line":3660},[3425,6083,5895],{"class":3470},[3425,6085,6086],{"class":3427,"line":3673},[3425,6087,3577],{"emptyLinePlaceholder":3576},[3425,6089,6090,6093,6096],{"class":3427,"line":3685},[3425,6091,6092],{"class":3583},"interface",[3425,6094,6095],{"class":3466}," ImageAnalyzerProps",[3425,6097,5975],{"class":3470},[3425,6099,6100,6103,6105,6107],{"class":3427,"line":3696},[3425,6101,6102],{"class":3627},"  imageUrl",[3425,6104,4332],{"class":3470},[3425,6106,3705],{"class":3466},[3425,6108,3471],{"class":3470},[3425,6110,6111,6114,6116,6119],{"class":3427,"line":3716},[3425,6112,6113],{"class":3627},"  labels",[3425,6115,4332],{"class":3470},[3425,6117,6118],{"class":3466},"DetectedLabel",[3425,6120,6121],{"class":3470},"[];\n",[3425,6123,6124],{"class":3427,"line":3729},[3425,6125,5895],{"class":3470},[3425,6127,6128],{"class":3427,"line":3734},[3425,6129,3577],{"emptyLinePlaceholder":3576},[3425,6131,6132,6134,6137,6140,6143,6146,6148,6151,6154,6157],{"class":3427,"line":3740},[3425,6133,5967],{"class":3462},[3425,6135,6136],{"class":3583}," function",[3425,6138,6139],{"class":3431}," ImageAnalyzer",[3425,6141,6142],{"class":3470},"({ ",[3425,6144,6145],{"class":3627},"imageUrl",[3425,6147,3385],{"class":3470},[3425,6149,6150],{"class":3627},"labels",[3425,6152,6153],{"class":3470}," }: ",[3425,6155,6156],{"class":3466},"ImageAnalyzerProps",[3425,6158,6159],{"class":3470},") {\n",[3425,6161,6162,6165,6169,6171,6173,6175,6178,6181,6183],{"class":3427,"line":3772},[3425,6163,6164],{"class":3583},"  const",[3425,6166,6168],{"class":6167},"s-QsJ"," canvasRef",[3425,6170,4005],{"class":3470},[3425,6172,5937],{"class":3431},[3425,6174,3702],{"class":3470},[3425,6176,6177],{"class":3466},"HTMLCanvasElement",[3425,6179,6180],{"class":3470},">(",[3425,6182,6077],{"class":3583},[3425,6184,3652],{"class":3470},[3425,6186,6187,6189,6192,6194,6196,6198,6201,6203,6205,6207,6209],{"class":3427,"line":3777},[3425,6188,6164],{"class":3583},[3425,6190,6191],{"class":6167}," imageRef",[3425,6193,4005],{"class":3470},[3425,6195,5937],{"class":3431},[3425,6197,3702],{"class":3470},[3425,6199,6200],{"class":3466},"HTMLImageElement",[3425,6202,6074],{"class":3470},[3425,6204,6077],{"class":3466},[3425,6206,6180],{"class":3470},[3425,6208,6077],{"class":3583},[3425,6210,3652],{"class":3470},[3425,6212,6213,6215,6218,6221,6223,6226,6229,6231,6233,6236],{"class":3427,"line":3789},[3425,6214,6164],{"class":3583},[3425,6216,6217],{"class":3470}," [",[3425,6219,6220],{"class":6167},"imgLoaded",[3425,6222,3385],{"class":3470},[3425,6224,6225],{"class":6167},"setImgLoaded",[3425,6227,6228],{"class":3470},"] = ",[3425,6230,5942],{"class":3431},[3425,6232,3621],{"class":3470},[3425,6234,6235],{"class":3583},"false",[3425,6237,3652],{"class":3470},[3425,6239,6240],{"class":3427,"line":3800},[3425,6241,3577],{"emptyLinePlaceholder":3576},[3425,6243,6244,6247,6250,6253],{"class":3427,"line":3817},[3425,6245,6246],{"class":3431},"  useEffect",[3425,6248,6249],{"class":3470},"(() ",[3425,6251,6252],{"class":3583},"=>",[3425,6254,5975],{"class":3470},[3425,6256,6257],{"class":3427,"line":3822},[3425,6258,6259],{"class":3605},"    \u002F\u002F Створюємо та завантажуємо зображення\n",[3425,6261,6262,6265,6268,6270,6272,6274],{"class":3427,"line":3828},[3425,6263,6264],{"class":3583},"    const",[3425,6266,6267],{"class":6167}," img",[3425,6269,4005],{"class":3470},[3425,6271,4142],{"class":3583},[3425,6273,5544],{"class":3431},[3425,6275,4499],{"class":3470},[3425,6277,6278,6281,6283,6286,6288,6290],{"class":3427,"line":3840},[3425,6279,6280],{"class":3627},"    img",[3425,6282,3389],{"class":3470},[3425,6284,6285],{"class":3627},"src",[3425,6287,4005],{"class":3470},[3425,6289,6145],{"class":3627},[3425,6291,3471],{"class":3470},[3425,6293,6294,6296,6298,6301,6303,6306,6309],{"class":3427,"line":3850},[3425,6295,6280],{"class":3627},[3425,6297,3389],{"class":3470},[3425,6299,6300],{"class":3627},"crossOrigin",[3425,6302,4005],{"class":3470},[3425,6304,6305],{"class":3435},"'anonymous'",[3425,6307,6308],{"class":3470},"; ",[3425,6310,6311],{"class":3605},"\u002F\u002F дозволяє читання пікселів при CORS\n",[3425,6313,6314,6316,6318,6321,6324,6326],{"class":3427,"line":3860},[3425,6315,6280],{"class":3627},[3425,6317,3389],{"class":3470},[3425,6319,6320],{"class":3431},"onload",[3425,6322,6323],{"class":3470}," = () ",[3425,6325,6252],{"class":3583},[3425,6327,5975],{"class":3470},[3425,6329,6330,6333,6335,6338,6340,6343],{"class":3427,"line":3870},[3425,6331,6332],{"class":3627},"      imageRef",[3425,6334,3389],{"class":3470},[3425,6336,6337],{"class":3627},"current",[3425,6339,4005],{"class":3470},[3425,6341,6342],{"class":3627},"img",[3425,6344,3471],{"class":3470},[3425,6346,6347,6350,6352,6355],{"class":3427,"line":3879},[3425,6348,6349],{"class":3431},"      setImgLoaded",[3425,6351,3621],{"class":3470},[3425,6353,6354],{"class":3583},"true",[3425,6356,3652],{"class":3470},[3425,6358,6359],{"class":3427,"line":3889},[3425,6360,6361],{"class":3470},"    };\n",[3425,6363,6364,6366,6368,6371,6373,6375],{"class":3427,"line":3894},[3425,6365,6280],{"class":3627},[3425,6367,3389],{"class":3470},[3425,6369,6370],{"class":3431},"onerror",[3425,6372,6323],{"class":3470},[3425,6374,6252],{"class":3583},[3425,6376,5975],{"class":3470},[3425,6378,6379,6382,6384,6387,6389,6392],{"class":3427,"line":3906},[3425,6380,6381],{"class":3627},"      console",[3425,6383,3389],{"class":3470},[3425,6385,6386],{"class":3431},"error",[3425,6388,3621],{"class":3470},[3425,6390,6391],{"class":3435},"'Не вдалося завантажити зображення.'",[3425,6393,3652],{"class":3470},[3425,6395,6396],{"class":3427,"line":3916},[3425,6397,6361],{"class":3470},[3425,6399,6400,6403,6405],{"class":3427,"line":3926},[3425,6401,6402],{"class":3470},"  }, [",[3425,6404,6145],{"class":3627},[3425,6406,6407],{"class":3470},"]);\n",[3425,6409,6410],{"class":3427,"line":3931},[3425,6411,3577],{"emptyLinePlaceholder":3576},[3425,6413,6414,6416,6418,6420],{"class":3427,"line":3945},[3425,6415,6246],{"class":3431},[3425,6417,6249],{"class":3470},[3425,6419,6252],{"class":3583},[3425,6421,5975],{"class":3470},[3425,6423,6424,6427,6430,6432,6435,6438,6440,6442,6444,6447,6449,6451,6454,6457],{"class":3427,"line":3951},[3425,6425,6426],{"class":3462},"    if",[3425,6428,6429],{"class":3470}," (!",[3425,6431,6220],{"class":3627},[3425,6433,6434],{"class":3470}," || !",[3425,6436,6437],{"class":3627},"imageRef",[3425,6439,3389],{"class":3470},[3425,6441,6337],{"class":3627},[3425,6443,6434],{"class":3470},[3425,6445,6446],{"class":3627},"canvasRef",[3425,6448,3389],{"class":3470},[3425,6450,6337],{"class":3627},[3425,6452,6453],{"class":3470},") ",[3425,6455,6456],{"class":3462},"return",[3425,6458,3471],{"class":3470},[3425,6460,6461],{"class":3427,"line":3968},[3425,6462,3577],{"emptyLinePlaceholder":3576},[3425,6464,6465,6467,6470,6472,6474,6476,6478],{"class":3427,"line":3973},[3425,6466,6264],{"class":3583},[3425,6468,6469],{"class":6167}," canvas",[3425,6471,4005],{"class":3470},[3425,6473,6446],{"class":3627},[3425,6475,3389],{"class":3470},[3425,6477,6337],{"class":3627},[3425,6479,3471],{"class":3470},[3425,6481,6482,6484,6487,6489,6492,6494,6497,6499,6502],{"class":3427,"line":3993},[3425,6483,6264],{"class":3583},[3425,6485,6486],{"class":6167}," ctx",[3425,6488,4005],{"class":3470},[3425,6490,6491],{"class":3627},"canvas",[3425,6493,3389],{"class":3470},[3425,6495,6496],{"class":3431},"getContext",[3425,6498,3621],{"class":3470},[3425,6500,6501],{"class":3435},"'2d'",[3425,6503,3652],{"class":3470},[3425,6505,6506,6508,6510,6513,6515,6517],{"class":3427,"line":3999},[3425,6507,6426],{"class":3462},[3425,6509,6429],{"class":3470},[3425,6511,6512],{"class":3627},"ctx",[3425,6514,6453],{"class":3470},[3425,6516,6456],{"class":3462},[3425,6518,3471],{"class":3470},[3425,6520,6521],{"class":3427,"line":4013},[3425,6522,3577],{"emptyLinePlaceholder":3576},[3425,6524,6525,6527,6529,6531,6533,6535,6537],{"class":3427,"line":4019},[3425,6526,6264],{"class":3583},[3425,6528,6267],{"class":6167},[3425,6530,4005],{"class":3470},[3425,6532,6437],{"class":3627},[3425,6534,3389],{"class":3470},[3425,6536,6337],{"class":3627},[3425,6538,3471],{"class":3470},[3425,6540,6541],{"class":3427,"line":4024},[3425,6542,6543],{"class":3470},"    \n",[3425,6545,6546],{"class":3427,"line":4040},[3425,6547,6548],{"class":3605},"    \u002F\u002F Встановлюємо розміри canvas відповідно до реальних розмірів зображення\n",[3425,6550,6551,6554,6556,6559,6561,6563,6565,6568],{"class":3427,"line":4046},[3425,6552,6553],{"class":3627},"    canvas",[3425,6555,3389],{"class":3470},[3425,6557,6558],{"class":3627},"width",[3425,6560,4005],{"class":3470},[3425,6562,6342],{"class":3627},[3425,6564,3389],{"class":3470},[3425,6566,6567],{"class":3627},"naturalWidth",[3425,6569,3471],{"class":3470},[3425,6571,6572,6574,6576,6579,6581,6583,6585,6588],{"class":3427,"line":4058},[3425,6573,6553],{"class":3627},[3425,6575,3389],{"class":3470},[3425,6577,6578],{"class":3627},"height",[3425,6580,4005],{"class":3470},[3425,6582,6342],{"class":3627},[3425,6584,3389],{"class":3470},[3425,6586,6587],{"class":3627},"naturalHeight",[3425,6589,3471],{"class":3470},[3425,6591,6592],{"class":3427,"line":4087},[3425,6593,3577],{"emptyLinePlaceholder":3576},[3425,6595,6596],{"class":3427,"line":4099},[3425,6597,6598],{"class":3605},"    \u002F\u002F Малюємо оригінальне зображення\n",[3425,6600,6601,6604,6606,6609,6611,6613,6615,6617,6619,6621],{"class":3427,"line":4109},[3425,6602,6603],{"class":3627},"    ctx",[3425,6605,3389],{"class":3470},[3425,6607,6608],{"class":3431},"drawImage",[3425,6610,3621],{"class":3470},[3425,6612,6342],{"class":3627},[3425,6614,3385],{"class":3470},[3425,6616,4915],{"class":4120},[3425,6618,3385],{"class":3470},[3425,6620,4915],{"class":4120},[3425,6622,3652],{"class":3470},[3425,6624,6625],{"class":3427,"line":4126},[3425,6626,3577],{"emptyLinePlaceholder":3576},[3425,6628,6629],{"class":3427,"line":4131},[3425,6630,6631],{"class":3605},"    \u002F\u002F Малюємо Bounding Boxes для кожного об'єкта\n",[3425,6633,6634,6637,6639,6642,6645,6648,6650,6652],{"class":3427,"line":4148},[3425,6635,6636],{"class":3627},"    labels",[3425,6638,3389],{"class":3470},[3425,6640,6641],{"class":3431},"forEach",[3425,6643,6644],{"class":3470},"((",[3425,6646,6647],{"class":3627},"label",[3425,6649,6453],{"class":3470},[3425,6651,6252],{"class":3583},[3425,6653,5975],{"class":3470},[3425,6655,6656,6659,6661,6663,6665,6668,6670,6672],{"class":3427,"line":4154},[3425,6657,6658],{"class":3462},"      if",[3425,6660,6429],{"class":3470},[3425,6662,6647],{"class":3627},[3425,6664,3389],{"class":3470},[3425,6666,6667],{"class":3627},"boundingBox",[3425,6669,6453],{"class":3470},[3425,6671,6456],{"class":3462},[3425,6673,3471],{"class":3470},[3425,6675,6676],{"class":3427,"line":4167},[3425,6677,3577],{"emptyLinePlaceholder":3576},[3425,6679,6680,6683,6685,6688,6690,6693,6695,6697,6699,6701,6704,6706,6708,6710],{"class":3427,"line":4173},[3425,6681,6682],{"class":3583},"      const",[3425,6684,4186],{"class":3470},[3425,6686,6687],{"class":6167},"left",[3425,6689,3385],{"class":3470},[3425,6691,6692],{"class":6167},"top",[3425,6694,3385],{"class":3470},[3425,6696,6558],{"class":6167},[3425,6698,3385],{"class":3470},[3425,6700,6578],{"class":6167},[3425,6702,6703],{"class":3470}," } = ",[3425,6705,6647],{"class":3627},[3425,6707,3389],{"class":3470},[3425,6709,6667],{"class":3627},[3425,6711,3471],{"class":3470},[3425,6713,6714],{"class":3427,"line":4210},[3425,6715,3577],{"emptyLinePlaceholder":3576},[3425,6717,6718],{"class":3427,"line":4216},[3425,6719,6720],{"class":3605},"      \u002F\u002F Конвертуємо відносні координати (0..1) в пікселі\n",[3425,6722,6723,6725,6728,6730,6732,6735,6737,6739,6741],{"class":3427,"line":4229},[3425,6724,6682],{"class":3583},[3425,6726,6727],{"class":6167}," x",[3425,6729,4005],{"class":3470},[3425,6731,6687],{"class":3627},[3425,6733,6734],{"class":3470}," * ",[3425,6736,6491],{"class":3627},[3425,6738,3389],{"class":3470},[3425,6740,6558],{"class":3627},[3425,6742,3471],{"class":3470},[3425,6744,6745,6747,6750,6752,6754,6756,6758,6760,6762],{"class":3427,"line":4240},[3425,6746,6682],{"class":3583},[3425,6748,6749],{"class":6167}," y",[3425,6751,4005],{"class":3470},[3425,6753,6692],{"class":3627},[3425,6755,6734],{"class":3470},[3425,6757,6491],{"class":3627},[3425,6759,3389],{"class":3470},[3425,6761,6578],{"class":3627},[3425,6763,3471],{"class":3470},[3425,6765,6766,6768,6771,6773,6775,6777,6779,6781,6783],{"class":3427,"line":4246},[3425,6767,6682],{"class":3583},[3425,6769,6770],{"class":6167}," w",[3425,6772,4005],{"class":3470},[3425,6774,6558],{"class":3627},[3425,6776,6734],{"class":3470},[3425,6778,6491],{"class":3627},[3425,6780,3389],{"class":3470},[3425,6782,6558],{"class":3627},[3425,6784,3471],{"class":3470},[3425,6786,6787,6789,6792,6794,6796,6798,6800,6802,6804],{"class":3427,"line":4251},[3425,6788,6682],{"class":3583},[3425,6790,6791],{"class":6167}," h",[3425,6793,4005],{"class":3470},[3425,6795,6578],{"class":3627},[3425,6797,6734],{"class":3470},[3425,6799,6491],{"class":3627},[3425,6801,3389],{"class":3470},[3425,6803,6578],{"class":3627},[3425,6805,3471],{"class":3470},[3425,6807,6808],{"class":3427,"line":4257},[3425,6809,3577],{"emptyLinePlaceholder":3576},[3425,6811,6812],{"class":3427,"line":4262},[3425,6813,6814],{"class":3605},"      \u002F\u002F Налаштовуємо стилі рамки\n",[3425,6816,6817,6820,6822,6825,6827,6830],{"class":3427,"line":4289},[3425,6818,6819],{"class":3627},"      ctx",[3425,6821,3389],{"class":3470},[3425,6823,6824],{"class":3627},"strokeStyle",[3425,6826,4005],{"class":3470},[3425,6828,6829],{"class":3435},"'#00ffcc'",[3425,6831,3471],{"class":3470},[3425,6833,6834,6836,6838,6841,6843,6846,6848,6851,6853,6856,6858,6860,6862,6864,6866,6869,6872],{"class":3427,"line":4294},[3425,6835,6819],{"class":3627},[3425,6837,3389],{"class":3470},[3425,6839,6840],{"class":3627},"lineWidth",[3425,6842,4005],{"class":3470},[3425,6844,6845],{"class":3627},"Math",[3425,6847,3389],{"class":3470},[3425,6849,6850],{"class":3431},"max",[3425,6852,3621],{"class":3470},[3425,6854,6855],{"class":4120},"3",[3425,6857,3385],{"class":3470},[3425,6859,6491],{"class":3627},[3425,6861,3389],{"class":3470},[3425,6863,6558],{"class":3627},[3425,6865,6734],{"class":3470},[3425,6867,6868],{"class":4120},"0.003",[3425,6870,6871],{"class":3470},"); ",[3425,6873,6874],{"class":3605},"\u002F\u002F товщина рамки адаптується під роздільну здатність\n",[3425,6876,6877,6879,6881,6884,6886,6889,6891,6894,6896,6899,6901,6904],{"class":3427,"line":4326},[3425,6878,6819],{"class":3627},[3425,6880,3389],{"class":3470},[3425,6882,6883],{"class":3431},"strokeRect",[3425,6885,3621],{"class":3470},[3425,6887,6888],{"class":3627},"x",[3425,6890,3385],{"class":3470},[3425,6892,6893],{"class":3627},"y",[3425,6895,3385],{"class":3470},[3425,6897,6898],{"class":3627},"w",[3425,6900,3385],{"class":3470},[3425,6902,6903],{"class":3627},"h",[3425,6905,3652],{"class":3470},[3425,6907,6908],{"class":3427,"line":4343},[3425,6909,3577],{"emptyLinePlaceholder":3576},[3425,6911,6912],{"class":3427,"line":4359},[3425,6913,6914],{"class":3605},"      \u002F\u002F Малюємо плашку для тексту\n",[3425,6916,6917,6919,6921,6924,6926,6929],{"class":3427,"line":4399},[3425,6918,6819],{"class":3627},[3425,6920,3389],{"class":3470},[3425,6922,6923],{"class":3627},"fillStyle",[3425,6925,4005],{"class":3470},[3425,6927,6928],{"class":3435},"'rgba(0, 255, 204, 0.85)'",[3425,6930,3471],{"class":3470},[3425,6932,6933,6935,6938,6940,6942,6944,6946,6948,6951,6953,6955,6957,6959,6961,6964],{"class":3427,"line":4433},[3425,6934,6682],{"class":3583},[3425,6936,6937],{"class":6167}," fontSize",[3425,6939,4005],{"class":3470},[3425,6941,6845],{"class":3627},[3425,6943,3389],{"class":3470},[3425,6945,6850],{"class":3431},[3425,6947,3621],{"class":3470},[3425,6949,6950],{"class":4120},"14",[3425,6952,3385],{"class":3470},[3425,6954,6491],{"class":3627},[3425,6956,3389],{"class":3470},[3425,6958,6558],{"class":3627},[3425,6960,6734],{"class":3470},[3425,6962,6963],{"class":4120},"0.015",[3425,6965,3652],{"class":3470},[3425,6967,6968,6970,6972,6975,6977,6980,6983,6986,6988,6991],{"class":3427,"line":4482},[3425,6969,6819],{"class":3627},[3425,6971,3389],{"class":3470},[3425,6973,6974],{"class":3627},"font",[3425,6976,4005],{"class":3470},[3425,6978,6979],{"class":3435},"`bold ",[3425,6981,6982],{"class":3583},"${",[3425,6984,6985],{"class":3627},"fontSize",[3425,6987,4559],{"class":3583},[3425,6989,6990],{"class":3435},"px sans-serif`",[3425,6992,3471],{"class":3470},[3425,6994,6995],{"class":3427,"line":4491},[3425,6996,6997],{"class":3470},"      \n",[3425,6999,7000,7002,7005,7007,7010,7012,7014,7016,7019,7021,7023,7025,7027,7029,7032,7034,7036,7038,7041,7044,7046,7049],{"class":3427,"line":4502},[3425,7001,6682],{"class":3583},[3425,7003,7004],{"class":6167}," text",[3425,7006,4005],{"class":3470},[3425,7008,7009],{"class":3435},"`",[3425,7011,6982],{"class":3583},[3425,7013,6647],{"class":3627},[3425,7015,3389],{"class":4547},[3425,7017,7018],{"class":3627},"name",[3425,7020,4559],{"class":3583},[3425,7022,4514],{"class":3435},[3425,7024,6982],{"class":3583},[3425,7026,6845],{"class":3627},[3425,7028,3389],{"class":4547},[3425,7030,7031],{"class":3431},"round",[3425,7033,3621],{"class":4547},[3425,7035,6647],{"class":3627},[3425,7037,3389],{"class":4547},[3425,7039,7040],{"class":3627},"confidence",[3425,7042,7043],{"class":4547},")",[3425,7045,4559],{"class":3583},[3425,7047,7048],{"class":3435},"%)`",[3425,7050,3471],{"class":3470},[3425,7052,7053,7055,7058,7060,7062,7064,7067,7069,7072,7074,7076],{"class":3427,"line":4508},[3425,7054,6682],{"class":3583},[3425,7056,7057],{"class":6167}," textWidth",[3425,7059,4005],{"class":3470},[3425,7061,6512],{"class":3627},[3425,7063,3389],{"class":3470},[3425,7065,7066],{"class":3431},"measureText",[3425,7068,3621],{"class":3470},[3425,7070,7071],{"class":3627},"text",[3425,7073,4390],{"class":3470},[3425,7075,6558],{"class":3627},[3425,7077,3471],{"class":3470},[3425,7079,7080,7082,7085,7087,7090],{"class":3427,"line":4525},[3425,7081,6682],{"class":3583},[3425,7083,7084],{"class":6167}," padding",[3425,7086,4005],{"class":3470},[3425,7088,7089],{"class":4120},"6",[3425,7091,3471],{"class":3470},[3425,7093,7094],{"class":3427,"line":4530},[3425,7095,6997],{"class":3470},[3425,7097,7098],{"class":3427,"line":4571},[3425,7099,7100],{"class":3605},"      \u002F\u002F Запобігаємо виходу плашки за верхній край\n",[3425,7102,7103,7105,7108,7110,7112,7115,7117,7119,7122,7125,7127,7130,7132,7134,7136,7138,7140,7143,7145],{"class":3427,"line":4576},[3425,7104,6682],{"class":3583},[3425,7106,7107],{"class":6167}," labelY",[3425,7109,4005],{"class":3470},[3425,7111,6893],{"class":3627},[3425,7113,7114],{"class":3470}," - ",[3425,7116,6985],{"class":3627},[3425,7118,7114],{"class":3470},[3425,7120,7121],{"class":3627},"padding",[3425,7123,7124],{"class":3470}," > ",[3425,7126,4915],{"class":4120},[3425,7128,7129],{"class":3470}," ? ",[3425,7131,6893],{"class":3627},[3425,7133,7114],{"class":3470},[3425,7135,6985],{"class":3627},[3425,7137,7114],{"class":3470},[3425,7139,7121],{"class":3627},[3425,7141,7142],{"class":3470}," : ",[3425,7144,6893],{"class":3627},[3425,7146,3471],{"class":3470},[3425,7148,7149],{"class":3427,"line":4581},[3425,7150,6997],{"class":3470},[3425,7152,7153,7155,7157,7160,7162,7164,7166,7169,7171,7174,7177,7179,7181,7184,7186,7188,7190,7192],{"class":3427,"line":4586},[3425,7154,6819],{"class":3627},[3425,7156,3389],{"class":3470},[3425,7158,7159],{"class":3431},"fillRect",[3425,7161,3621],{"class":3470},[3425,7163,6888],{"class":3627},[3425,7165,3385],{"class":3470},[3425,7167,7168],{"class":3627},"labelY",[3425,7170,3385],{"class":3470},[3425,7172,7173],{"class":3627},"textWidth",[3425,7175,7176],{"class":3470}," + ",[3425,7178,7121],{"class":3627},[3425,7180,6734],{"class":3470},[3425,7182,7183],{"class":4120},"2",[3425,7185,3385],{"class":3470},[3425,7187,6985],{"class":3627},[3425,7189,7176],{"class":3470},[3425,7191,7121],{"class":3627},[3425,7193,3652],{"class":3470},[3425,7195,7196],{"class":3427,"line":4597},[3425,7197,3577],{"emptyLinePlaceholder":3576},[3425,7199,7200],{"class":3427,"line":4603},[3425,7201,7202],{"class":3605},"      \u002F\u002F Малюємо сам текст\n",[3425,7204,7205,7207,7209,7211,7213,7216],{"class":3427,"line":4614},[3425,7206,6819],{"class":3627},[3425,7208,3389],{"class":3470},[3425,7210,6923],{"class":3627},[3425,7212,4005],{"class":3470},[3425,7214,7215],{"class":3435},"'#000000'",[3425,7217,3471],{"class":3470},[3425,7219,7220,7222,7224,7227,7229,7231,7233,7235,7237,7239,7241,7243,7245,7247],{"class":3427,"line":4647},[3425,7221,6819],{"class":3627},[3425,7223,3389],{"class":3470},[3425,7225,7226],{"class":3431},"fillText",[3425,7228,3621],{"class":3470},[3425,7230,7071],{"class":3627},[3425,7232,3385],{"class":3470},[3425,7234,6888],{"class":3627},[3425,7236,7176],{"class":3470},[3425,7238,7121],{"class":3627},[3425,7240,3385],{"class":3470},[3425,7242,7168],{"class":3627},[3425,7244,7176],{"class":3470},[3425,7246,6985],{"class":3627},[3425,7248,3652],{"class":3470},[3425,7250,7251],{"class":3427,"line":4652},[3425,7252,7253],{"class":3470},"    });\n",[3425,7255,7256,7258,7260,7262,7264],{"class":3427,"line":4666},[3425,7257,6402],{"class":3470},[3425,7259,6220],{"class":3627},[3425,7261,3385],{"class":3470},[3425,7263,6150],{"class":3627},[3425,7265,6407],{"class":3470},[3425,7267,7268],{"class":3427,"line":4671},[3425,7269,3577],{"emptyLinePlaceholder":3576},[3425,7271,7272,7275],{"class":3427,"line":4682},[3425,7273,7274],{"class":3462},"  return",[3425,7276,7277],{"class":3470}," (\n",[3425,7279,7280,7283,7286,7290,7293,7295,7298,7300,7303,7305],{"class":3427,"line":4687},[3425,7281,7282],{"class":4030},"    \u003C",[3425,7284,7285],{"class":4033},"div",[3425,7287,7289],{"class":7288},"sa4r_"," style",[3425,7291,7292],{"class":3470},"=",[3425,7294,4548],{"class":3583},[3425,7296,7297],{"class":3627},"styles",[3425,7299,3389],{"class":4547},[3425,7301,7302],{"class":3627},"container",[3425,7304,4559],{"class":3583},[3425,7306,4037],{"class":4030},[3425,7308,7309,7312,7314,7316,7318,7320,7322,7324,7327,7329],{"class":3427,"line":4716},[3425,7310,7311],{"class":4030},"      \u003C",[3425,7313,7285],{"class":4033},[3425,7315,7289],{"class":7288},[3425,7317,7292],{"class":3470},[3425,7319,4548],{"class":3583},[3425,7321,7297],{"class":3627},[3425,7323,3389],{"class":4547},[3425,7325,7326],{"class":3627},"canvasWrapper",[3425,7328,4559],{"class":3583},[3425,7330,4037],{"class":4030},[3425,7332,7333,7336,7338,7341,7343,7345,7347,7349,7351,7353,7355,7357,7359,7361,7363],{"class":3427,"line":4721},[3425,7334,7335],{"class":4030},"        \u003C",[3425,7337,6491],{"class":4033},[3425,7339,7340],{"class":7288}," ref",[3425,7342,7292],{"class":3470},[3425,7344,4548],{"class":3583},[3425,7346,6446],{"class":3627},[3425,7348,4559],{"class":3583},[3425,7350,7289],{"class":7288},[3425,7352,7292],{"class":3470},[3425,7354,4548],{"class":3583},[3425,7356,7297],{"class":3627},[3425,7358,3389],{"class":4547},[3425,7360,6491],{"class":3627},[3425,7362,4559],{"class":3583},[3425,7364,7365],{"class":4030}," \u002F>\n",[3425,7367,7368,7371,7373],{"class":3427,"line":4731},[3425,7369,7370],{"class":4030},"      \u003C\u002F",[3425,7372,7285],{"class":4033},[3425,7374,4037],{"class":4030},[3425,7376,7377,7379,7381,7383,7385,7387,7389,7391,7394,7396],{"class":3427,"line":4736},[3425,7378,7311],{"class":4030},[3425,7380,7285],{"class":4033},[3425,7382,7289],{"class":7288},[3425,7384,7292],{"class":3470},[3425,7386,4548],{"class":3583},[3425,7388,7297],{"class":3627},[3425,7390,3389],{"class":4547},[3425,7392,7393],{"class":3627},"detailsList",[3425,7395,4559],{"class":3583},[3425,7397,4037],{"class":4030},[3425,7399,7400,7402,7404,7406,7408,7410,7412,7414,7417,7419,7422,7425,7427,7429],{"class":3427,"line":4741},[3425,7401,7335],{"class":4030},[3425,7403,5912],{"class":4033},[3425,7405,7289],{"class":7288},[3425,7407,7292],{"class":3470},[3425,7409,4548],{"class":3583},[3425,7411,7297],{"class":3627},[3425,7413,3389],{"class":4547},[3425,7415,7416],{"class":3627},"listTitle",[3425,7418,4559],{"class":3583},[3425,7420,7421],{"class":4030},">",[3425,7423,7424],{"class":3470},"Виявлені об'єкти:",[3425,7426,4051],{"class":4030},[3425,7428,5912],{"class":4033},[3425,7430,4037],{"class":4030},[3425,7432,7433,7435,7438,7440,7442,7444,7446,7448,7451,7453],{"class":3427,"line":4746},[3425,7434,7335],{"class":4030},[3425,7436,7437],{"class":4033},"ul",[3425,7439,7289],{"class":7288},[3425,7441,7292],{"class":3470},[3425,7443,4548],{"class":3583},[3425,7445,7297],{"class":3627},[3425,7447,3389],{"class":4547},[3425,7449,7450],{"class":3627},"list",[3425,7452,4559],{"class":3583},[3425,7454,4037],{"class":4030},[3425,7456,7457,7460,7462,7464,7467,7469,7471,7473,7476,7478,7480],{"class":3427,"line":4751},[3425,7458,7459],{"class":3583},"          {",[3425,7461,6150],{"class":3627},[3425,7463,3389],{"class":4547},[3425,7465,7466],{"class":3431},"map",[3425,7468,6644],{"class":4547},[3425,7470,4314],{"class":3627},[3425,7472,3385],{"class":4547},[3425,7474,7475],{"class":3627},"index",[3425,7477,6453],{"class":4547},[3425,7479,6252],{"class":3583},[3425,7481,7277],{"class":4547},[3425,7483,7484,7487,7490,7493,7495,7497,7499,7501,7503,7505,7507,7509,7511,7514,7516],{"class":3427,"line":4775},[3425,7485,7486],{"class":4030},"            \u003C",[3425,7488,7489],{"class":4033},"li",[3425,7491,7492],{"class":7288}," key",[3425,7494,7292],{"class":3470},[3425,7496,4548],{"class":3583},[3425,7498,7475],{"class":3627},[3425,7500,4559],{"class":3583},[3425,7502,7289],{"class":7288},[3425,7504,7292],{"class":3470},[3425,7506,4548],{"class":3583},[3425,7508,7297],{"class":3627},[3425,7510,3389],{"class":4547},[3425,7512,7513],{"class":3627},"listItem",[3425,7515,4559],{"class":3583},[3425,7517,4037],{"class":4030},[3425,7519,7520,7523,7525,7527,7529,7531,7533,7535,7538,7540,7542,7544,7546,7548,7550,7552,7554,7556],{"class":3427,"line":4780},[3425,7521,7522],{"class":4030},"              \u003C",[3425,7524,3425],{"class":4033},[3425,7526,7289],{"class":7288},[3425,7528,7292],{"class":3470},[3425,7530,4548],{"class":3583},[3425,7532,7297],{"class":3627},[3425,7534,3389],{"class":4547},[3425,7536,7537],{"class":3627},"labelName",[3425,7539,4559],{"class":3583},[3425,7541,7421],{"class":4030},[3425,7543,4548],{"class":3583},[3425,7545,4314],{"class":3627},[3425,7547,3389],{"class":4547},[3425,7549,7018],{"class":3627},[3425,7551,4559],{"class":3583},[3425,7553,4051],{"class":4030},[3425,7555,3425],{"class":4033},[3425,7557,4037],{"class":4030},[3425,7559,7560,7562,7564,7566,7568,7570,7572,7574,7577,7579,7581,7583,7585,7587,7589,7591,7593,7595,7597,7599,7601,7604,7606,7608],{"class":3427,"line":4815},[3425,7561,7522],{"class":4030},[3425,7563,3425],{"class":4033},[3425,7565,7289],{"class":7288},[3425,7567,7292],{"class":3470},[3425,7569,4548],{"class":3583},[3425,7571,7297],{"class":3627},[3425,7573,3389],{"class":4547},[3425,7575,7576],{"class":3627},"confidenceBadge",[3425,7578,4559],{"class":3583},[3425,7580,7421],{"class":4030},[3425,7582,4548],{"class":3583},[3425,7584,6845],{"class":3627},[3425,7586,3389],{"class":4547},[3425,7588,7031],{"class":3431},[3425,7590,3621],{"class":4547},[3425,7592,4314],{"class":3627},[3425,7594,3389],{"class":4547},[3425,7596,7040],{"class":3627},[3425,7598,7043],{"class":4547},[3425,7600,4559],{"class":3583},[3425,7602,7603],{"class":4547},"%",[3425,7605,4051],{"class":4030},[3425,7607,3425],{"class":4033},[3425,7609,4037],{"class":4030},[3425,7611,7612,7615,7617],{"class":3427,"line":4841},[3425,7613,7614],{"class":4030},"            \u003C\u002F",[3425,7616,7489],{"class":4033},[3425,7618,4037],{"class":4030},[3425,7620,7621,7624],{"class":3427,"line":4857},[3425,7622,7623],{"class":4547},"          ))",[3425,7625,5895],{"class":3583},[3425,7627,7628,7631,7633],{"class":3427,"line":4871},[3425,7629,7630],{"class":4030},"        \u003C\u002F",[3425,7632,7437],{"class":4033},[3425,7634,4037],{"class":4030},[3425,7636,7637,7639,7641],{"class":3427,"line":4880},[3425,7638,7370],{"class":4030},[3425,7640,7285],{"class":4033},[3425,7642,4037],{"class":4030},[3425,7644,7645,7648,7650],{"class":3427,"line":4885},[3425,7646,7647],{"class":4030},"    \u003C\u002F",[3425,7649,7285],{"class":4033},[3425,7651,4037],{"class":4030},[3425,7653,7654],{"class":3427,"line":4896},[3425,7655,7656],{"class":3470},"  );\n",[3425,7658,7659],{"class":3427,"line":4920},[3425,7660,5895],{"class":3470},[3425,7662,7663],{"class":3427,"line":4931},[3425,7664,3577],{"emptyLinePlaceholder":3576},[3425,7666,7667,7670,7673],{"class":3427,"line":4937},[3425,7668,7669],{"class":3583},"const",[3425,7671,7672],{"class":6167}," styles",[3425,7674,7675],{"class":3470}," = {\n",[3425,7677,7678,7681],{"class":3427,"line":4942},[3425,7679,7680],{"class":3627},"  container:",[3425,7682,5975],{"class":3470},[3425,7684,7685,7688,7691],{"class":3427,"line":4955},[3425,7686,7687],{"class":3627},"    display:",[3425,7689,7690],{"class":3435}," 'flex'",[3425,7692,3682],{"class":3470},[3425,7694,7695,7698,7701,7704,7707],{"class":3427,"line":4960},[3425,7696,7697],{"class":3627},"    flexDirection:",[3425,7699,7700],{"class":3435}," 'row'",[3425,7702,7703],{"class":3462}," as",[3425,7705,7706],{"class":3583}," const",[3425,7708,3682],{"class":3470},[3425,7710,7711,7714,7717],{"class":3427,"line":4992},[3425,7712,7713],{"class":3627},"    gap:",[3425,7715,7716],{"class":3435}," '24px'",[3425,7718,3682],{"class":3470},[3425,7720,7721,7724,7727],{"class":3427,"line":4997},[3425,7722,7723],{"class":3627},"    background:",[3425,7725,7726],{"class":3435}," '#1f2937'",[3425,7728,3682],{"class":3470},[3425,7730,7731,7734,7736],{"class":3427,"line":5002},[3425,7732,7733],{"class":3627},"    padding:",[3425,7735,7716],{"class":3435},[3425,7737,3682],{"class":3470},[3425,7739,7740,7743,7746],{"class":3427,"line":5007},[3425,7741,7742],{"class":3627},"    borderRadius:",[3425,7744,7745],{"class":3435}," '12px'",[3425,7747,3682],{"class":3470},[3425,7749,7750,7753,7756],{"class":3427,"line":5018},[3425,7751,7752],{"class":3627},"    boxShadow:",[3425,7754,7755],{"class":3435}," '0 4px 20px rgba(0, 0, 0, 0.3)'",[3425,7757,3682],{"class":3470},[3425,7759,7760,7763,7766],{"class":3427,"line":5024},[3425,7761,7762],{"class":3627},"    color:",[3425,7764,7765],{"class":3435}," '#f3f4f6'",[3425,7767,3682],{"class":3470},[3425,7769,7770,7773,7776,7778,7780],{"class":3427,"line":5035},[3425,7771,7772],{"class":3627},"    flexWrap:",[3425,7774,7775],{"class":3435}," 'wrap'",[3425,7777,7703],{"class":3462},[3425,7779,7706],{"class":3583},[3425,7781,3682],{"class":3470},[3425,7783,7784],{"class":3427,"line":5067},[3425,7785,7786],{"class":3470},"  },\n",[3425,7788,7789,7792],{"class":3427,"line":5072},[3425,7790,7791],{"class":3627},"  canvasWrapper:",[3425,7793,5975],{"class":3470},[3425,7795,7796,7799,7802],{"class":3427,"line":5086},[3425,7797,7798],{"class":3627},"    flex:",[3425,7800,7801],{"class":3435}," '2 1 500px'",[3425,7803,3682],{"class":3470},[3425,7805,7806,7809,7812,7814,7816],{"class":3427,"line":5091},[3425,7807,7808],{"class":3627},"    position:",[3425,7810,7811],{"class":3435}," 'relative'",[3425,7813,7703],{"class":3462},[3425,7815,7706],{"class":3583},[3425,7817,3682],{"class":3470},[3425,7819,7820,7822,7825],{"class":3427,"line":5102},[3425,7821,7723],{"class":3627},[3425,7823,7824],{"class":3435}," '#111827'",[3425,7826,3682],{"class":3470},[3425,7828,7829,7831,7834],{"class":3427,"line":5107},[3425,7830,7742],{"class":3627},[3425,7832,7833],{"class":3435}," '8px'",[3425,7835,3682],{"class":3470},[3425,7837,7838,7841,7844],{"class":3427,"line":5136},[3425,7839,7840],{"class":3627},"    overflow:",[3425,7842,7843],{"class":3435}," 'hidden'",[3425,7845,3682],{"class":3470},[3425,7847,7848,7850,7852],{"class":3427,"line":5142},[3425,7849,7687],{"class":3627},[3425,7851,7690],{"class":3435},[3425,7853,3682],{"class":3470},[3425,7855,7856,7859,7862],{"class":3427,"line":5147},[3425,7857,7858],{"class":3627},"    alignItems:",[3425,7860,7861],{"class":3435}," 'center'",[3425,7863,3682],{"class":3470},[3425,7865,7866,7869,7871],{"class":3427,"line":5152},[3425,7867,7868],{"class":3627},"    justifyContent:",[3425,7870,7861],{"class":3435},[3425,7872,3682],{"class":3470},[3425,7874,7875],{"class":3427,"line":5157},[3425,7876,7786],{"class":3470},[3425,7878,7879,7882],{"class":3427,"line":5162},[3425,7880,7881],{"class":3627},"  canvas:",[3425,7883,5975],{"class":3470},[3425,7885,7886,7889,7892],{"class":3427,"line":5186},[3425,7887,7888],{"class":3627},"    maxWidth:",[3425,7890,7891],{"class":3435}," '100%'",[3425,7893,3682],{"class":3470},[3425,7895,7896,7899,7902],{"class":3427,"line":5192},[3425,7897,7898],{"class":3627},"    maxHeight:",[3425,7900,7901],{"class":3435}," '550px'",[3425,7903,3682],{"class":3470},[3425,7905,7906,7909,7912,7914,7916],{"class":3427,"line":5198},[3425,7907,7908],{"class":3627},"    objectFit:",[3425,7910,7911],{"class":3435}," 'contain'",[3425,7913,7703],{"class":3462},[3425,7915,7706],{"class":3583},[3425,7917,3682],{"class":3470},[3425,7919,7920],{"class":3427,"line":5215},[3425,7921,7786],{"class":3470},[3425,7923,7924,7927],{"class":3427,"line":5250},[3425,7925,7926],{"class":3627},"  detailsList:",[3425,7928,5975],{"class":3470},[3425,7930,7931,7933,7936],{"class":3427,"line":5281},[3425,7932,7798],{"class":3627},[3425,7934,7935],{"class":3435}," '1 1 250px'",[3425,7937,3682],{"class":3470},[3425,7939,7940,7942,7944],{"class":3427,"line":5303},[3425,7941,7723],{"class":3627},[3425,7943,7824],{"class":3435},[3425,7945,3682],{"class":3470},[3425,7947,7948,7950,7953],{"class":3427,"line":5308},[3425,7949,7733],{"class":3627},[3425,7951,7952],{"class":3435}," '16px'",[3425,7954,3682],{"class":3470},[3425,7956,7957,7959,7961],{"class":3427,"line":5338},[3425,7958,7742],{"class":3627},[3425,7960,7833],{"class":3435},[3425,7962,3682],{"class":3470},[3425,7964,7965,7968,7971],{"class":3427,"line":5343},[3425,7966,7967],{"class":3627},"    border:",[3425,7969,7970],{"class":3435}," '1px solid rgba(255, 255, 255, 0.05)'",[3425,7972,3682],{"class":3470},[3425,7974,7975],{"class":3427,"line":5356},[3425,7976,7786],{"class":3470},[3425,7978,7979,7982],{"class":3427,"line":5361},[3425,7980,7981],{"class":3627},"  listTitle:",[3425,7983,5975],{"class":3470},[3425,7985,7986,7989,7992],{"class":3427,"line":5393},[3425,7987,7988],{"class":3627},"    marginTop:",[3425,7990,7991],{"class":4120}," 0",[3425,7993,3682],{"class":3470},[3425,7995,7996,7999,8002],{"class":3427,"line":5398},[3425,7997,7998],{"class":3627},"    borderBottom:",[3425,8000,8001],{"class":3435}," '1px solid rgba(255, 255, 255, 0.1)'",[3425,8003,3682],{"class":3470},[3425,8005,8006,8009,8011],{"class":3427,"line":5403},[3425,8007,8008],{"class":3627},"    paddingBottom:",[3425,8010,7833],{"class":3435},[3425,8012,3682],{"class":3470},[3425,8014,8015,8017,8020],{"class":3427,"line":5408},[3425,8016,7762],{"class":3627},[3425,8018,8019],{"class":3435}," '#60a5fa'",[3425,8021,3682],{"class":3470},[3425,8023,8024],{"class":3427,"line":5419},[3425,8025,7786],{"class":3470},[3425,8027,8028,8031],{"class":3427,"line":5425},[3425,8029,8030],{"class":3627},"  list:",[3425,8032,5975],{"class":3470},[3425,8034,8035,8038,8041],{"class":3427,"line":5436},[3425,8036,8037],{"class":3627},"    listStyleType:",[3425,8039,8040],{"class":3435}," 'none'",[3425,8042,3682],{"class":3470},[3425,8044,8045,8047,8049],{"class":3427,"line":5461},[3425,8046,7733],{"class":3627},[3425,8048,7991],{"class":4120},[3425,8050,3682],{"class":3470},[3425,8052,8053,8056,8058],{"class":3427,"line":5478},[3425,8054,8055],{"class":3627},"    margin:",[3425,8057,7991],{"class":4120},[3425,8059,3682],{"class":3470},[3425,8061,8062,8064,8067],{"class":3427,"line":5495},[3425,8063,7898],{"class":3627},[3425,8065,8066],{"class":3435}," '400px'",[3425,8068,3682],{"class":3470},[3425,8070,8071,8074,8077,8079,8081],{"class":3427,"line":5510},[3425,8072,8073],{"class":3627},"    overflowY:",[3425,8075,8076],{"class":3435}," 'auto'",[3425,8078,7703],{"class":3462},[3425,8080,7706],{"class":3583},[3425,8082,3682],{"class":3470},[3425,8084,8085],{"class":3427,"line":5515},[3425,8086,7786],{"class":3470},[3425,8088,8089,8092],{"class":3427,"line":5529},[3425,8090,8091],{"class":3627},"  listItem:",[3425,8093,5975],{"class":3470},[3425,8095,8096,8098,8100],{"class":3427,"line":5534},[3425,8097,7687],{"class":3627},[3425,8099,7690],{"class":3435},[3425,8101,3682],{"class":3470},[3425,8103,8104,8106,8109],{"class":3427,"line":5579},[3425,8105,7868],{"class":3627},[3425,8107,8108],{"class":3435}," 'space-between'",[3425,8110,3682],{"class":3470},[3425,8112,8113,8115,8118],{"class":3427,"line":5621},[3425,8114,7733],{"class":3627},[3425,8116,8117],{"class":3435}," '8px 4px'",[3425,8119,3682],{"class":3470},[3425,8121,8122,8124,8127],{"class":3427,"line":5632},[3425,8123,7998],{"class":3627},[3425,8125,8126],{"class":3435}," '1px solid rgba(255, 255, 255, 0.03)'",[3425,8128,3682],{"class":3470},[3425,8130,8131],{"class":3427,"line":5637},[3425,8132,7786],{"class":3470},[3425,8134,8135,8138],{"class":3427,"line":5642},[3425,8136,8137],{"class":3627},"  labelName:",[3425,8139,5975],{"class":3470},[3425,8141,8142,8145,8148],{"class":3427,"line":5647},[3425,8143,8144],{"class":3627},"    fontWeight:",[3425,8146,8147],{"class":4120}," 500",[3425,8149,3682],{"class":3470},[3425,8151,8152],{"class":3427,"line":5652},[3425,8153,7786],{"class":3470},[3425,8155,8156,8159],{"class":3427,"line":5675},[3425,8157,8158],{"class":3627},"  confidenceBadge:",[3425,8160,5975],{"class":3470},[3425,8162,8163,8165,8168],{"class":3427,"line":5680},[3425,8164,7723],{"class":3627},[3425,8166,8167],{"class":3435}," '#10b981'",[3425,8169,3682],{"class":3470},[3425,8171,8172,8174,8177],{"class":3427,"line":5709},[3425,8173,7762],{"class":3627},[3425,8175,8176],{"class":3435}," '#fff'",[3425,8178,3682],{"class":3470},[3425,8180,8181,8183,8186],{"class":3427,"line":5726},[3425,8182,7733],{"class":3627},[3425,8184,8185],{"class":3435}," '2px 8px'",[3425,8187,3682],{"class":3470},[3425,8189,8190,8192,8194],{"class":3427,"line":5740},[3425,8191,7742],{"class":3627},[3425,8193,7745],{"class":3435},[3425,8195,3682],{"class":3470},[3425,8197,8198,8201,8204],{"class":3427,"line":5761},[3425,8199,8200],{"class":3627},"    fontSize:",[3425,8202,8203],{"class":3435}," '0.85rem'",[3425,8205,3682],{"class":3470},[3425,8207,8208],{"class":3427,"line":5780},[3425,8209,7786],{"class":3470},[3425,8211,8212],{"class":3427,"line":5799},[3425,8213,8214],{"class":3470},"};\n",[8216,8217,8218],"style",{},"html pre.shiki code .s8Opu, html code.shiki .s8Opu{--shiki-light:#795E26;--shiki-default:#DCDCAA;--shiki-dark:#DCDCAA}html pre.shiki code .sbdoH, html code.shiki .sbdoH{--shiki-light:#A31515;--shiki-default:#CE9178;--shiki-dark:#CE9178}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 .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 .sHH4Y, html code.shiki .sHH4Y{--shiki-light:#000000;--shiki-default:#D4D4D4;--shiki-dark:#D4D4D4}html pre.shiki code .su1O8, html code.shiki .su1O8{--shiki-light:#0000FF;--shiki-default:#569CD6;--shiki-dark:#569CD6}html pre.shiki code .spJ8K, html code.shiki .spJ8K{--shiki-light:#008000;--shiki-default:#6A9955;--shiki-dark:#6A9955}html pre.shiki code .siwwj, html code.shiki .siwwj{--shiki-light:#001080;--shiki-default:#9CDCFE;--shiki-dark:#9CDCFE}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}",{"title":3421,"searchDepth":3474,"depth":3474,"links":8220},[8221,8222,8223],{"id":3358,"depth":3474,"text":3359},{"id":3410,"depth":3474,"text":3411},{"id":5900,"depth":3474,"text":5901,"children":8224},[8225],{"id":5914,"depth":3493,"text":5915},"Глибоке занурення в Amazon Rekognition. Повна інструкція з інтеграції аналізу зображень, виявлення об'єктів, облич, OCR та модерації контенту з .NET 8 та React. Повноцінний код з малюванням bounding boxes на Canvas.","md",null,{},{"title":3270,"description":8226},"L2R1sMcCwTITxzEtihOavcOs_uBRHK1kTnSAKWrEiqA",[8233,8235],{"title":3266,"path":3267,"stem":3268,"description":8234,"children":-1},"Глибоке занурення в Amazon Bedrock. Практична інтеграція великих мовних моделей Claude, Llama та Titan з .NET 8 та React. Реалізація Streaming, побудова Knowledge Bases для RAG, налаштування Guardrails безпеки та розробка автономних AI Agents.",{"title":3274,"path":3275,"stem":3276,"description":8236,"children":-1},"Практичний посібник з використання Amazon Textract. Повна реалізація аналізу форм та таблиць з PDF\u002Fзображень у .NET 8. Клієнтський React-компонент для відображення структур документів.",1782371307982]