duck-dev-lib 0.0.47 → 0.0.49

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -180,6 +180,26 @@ var notifications = {
180
180
  var slider = {
181
181
  title: "Duck Dev UI Library - Slider",
182
182
  required: "required",
183
+ tabs: {
184
+ flip: "Flip (Raindrops)",
185
+ classic: "Classic"
186
+ },
187
+ tip: {
188
+ title: "Tip:",
189
+ flipText: "Use ng-template with #slide reference variable to define slides. The slider collects them automatically via viewChildren. Pass rich content — cards, forms, images — not just text.",
190
+ classicText: "Classic slider stretches to the container width. Use aspect-ratio on the host element or wrap it in a fixed-height container for consistent sizing."
191
+ },
192
+ integration: {
193
+ title: "Integration",
194
+ description: "Both slider variants follow the same pattern — define slide templates, collect them with viewChildren, and pass to the slider via signal.",
195
+ accordionTitle: "Full component example",
196
+ templatesEyebrow: "ng-template",
197
+ templatesTitle: "Template-driven slides",
198
+ templatesText: "Each slide is an ng-template with a #slide reference. You can put any content inside — components, forms, images, rich layouts.",
199
+ signalsEyebrow: "Angular Signals",
200
+ signalsTitle: "Signal-based collection",
201
+ signalsText: "viewChildren collects templates, signal stores them. The slider reacts to changes automatically — no manual subscription needed."
202
+ },
183
203
  raindrops: {
184
204
  title: "Raindrops slider",
185
205
  description: "A flip-style slider with a blurred previous slide and smooth transitions.",
@@ -290,15 +310,21 @@ var buttons = {
290
310
  exampleGray: "Gray",
291
311
  exampleDark: "Dark"
292
312
  },
313
+ classicTip: {
314
+ title: "Tip:",
315
+ text: "All classic buttons accept AccentEnumColor for consistent theming. Use Violet for primary actions, Orange for CTA, Gray for secondary, and Dark for contrast-heavy layouts."
316
+ },
293
317
  neobrutal: {
294
318
  title: "Neobrutalism Buttons",
295
- description: "Three loud button variants with thick borders, contrasting shadows, and intentionally rough geometry. Useful for hero sections, CTA areas, and any action that should feel visually dominant.",
319
+ description: "Six loud button variants with thick borders, contrasting shadows, and intentionally rough geometry. Useful for hero sections, CTA areas, and any action that should feel visually dominant.",
296
320
  usage: "Usage:",
297
321
  inputs: "Input Parameters:",
298
322
  inputText: "main button label",
299
- inputSubtext: "small sticker label for the burst variant",
323
+ inputSubtext: "small sticker label for the burst/sticker variants",
300
324
  inputHelperText: "secondary caption for the slab variant",
301
325
  inputTag: "short tag or sequence marker for the tag variant",
326
+ inputLabel: "inline badge text for the zigzag variant",
327
+ inputIcon: "trailing icon/symbol for the tape variant (e.g. '>>')",
302
328
  inputColorButton: "color scheme (White, Gray, Dark, Violet, Orange)",
303
329
  inputIsDisabled: "disables the button and removes active interaction",
304
330
  examples: "Examples:",
@@ -310,7 +336,16 @@ var buttons = {
310
336
  exampleSlabDisabled: "Slab / Disabled",
311
337
  exampleTagOrange: "Tag / Orange",
312
338
  exampleTagViolet: "Tag / Violet",
313
- exampleTagDark: "Tag / Dark"
339
+ exampleTagDark: "Tag / Dark",
340
+ exampleStickerViolet: "Sticker / Violet",
341
+ exampleStickerOrange: "Sticker / Orange",
342
+ exampleStickerDark: "Sticker / Dark",
343
+ exampleZigzagOrange: "Zigzag / Orange",
344
+ exampleZigzagViolet: "Zigzag / Violet",
345
+ exampleZigzagWhite: "Zigzag / White",
346
+ exampleTapeWhite: "Tape / White",
347
+ exampleTapeViolet: "Tape / Violet",
348
+ exampleTapeDark: "Tape / Dark"
314
349
  }
315
350
  };
316
351
  var segmentDoc = {
@@ -397,23 +432,17 @@ var loaders = {
397
432
  }
398
433
  };
399
434
  var tabsComponent = {
400
- title: "Duck Dev UI Library - Tabs Component",
435
+ title: "Duck Dev UI Library - Tabs",
401
436
  tab: {
402
437
  title: "Duck Dev Tab",
403
- description: "Tab component with animated transitions between content. Supports signal-based input/output, automatic switching with left/right animation depending on direction. Perfect for organizing content into categories and creating interactive interfaces.",
404
- usage: "Usage:",
405
- usageText1: "To use the component, import DuckDevTab and DuckDevTabItem from 'duck-dev-lib' library.",
406
- usageText2: "Create an array of tabs with id and label fields, pass it to the component via input [tabs].",
407
- usageText3: "Use ng-content to place tab content inside the component.",
408
- inputs: "Input Parameters:",
409
- inputTabs: "array of objects of type DuckDevTabItem[] with fields:",
410
- inputTabsId: "unique tab identifier",
411
- inputTabsLabel: "text on tab button",
412
- inputTabsContent: "additional data",
438
+ description: "Tab component with animated transitions between content. Supports signal-based input/output, automatic switching with left/right animation depending on direction. Available in horizontal and vertical variants.",
439
+ usage: "Usage",
440
+ inputs: "Inputs & Outputs",
441
+ inputTabs: "array of DuckDevTabItem[]",
413
442
  required: "required",
414
443
  optional: "optional",
415
444
  outputs: "Output Events:",
416
- outputTabChange: "event that fires when switching tabs. Returns the current active tab object (DuckDevTabItem)",
445
+ outputTabChange: "fires when switching tabs, returns DuckDevTabItem",
417
446
  features: "Features:",
418
447
  feature1: "Animated transitions between tabs (slide left/right)",
419
448
  feature2: "Animated active tab indicator",
@@ -425,13 +454,38 @@ var tabsComponent = {
425
454
  api: "TypeScript interface DuckDevTabItem:",
426
455
  apiId: "unique tab identifier",
427
456
  apiLabel: "text on tab button",
428
- apiContent: "optional additional data",
429
- implementation: "Integration Example:",
430
- implementation1: "Import DuckDevTab and DuckDevTabItem from 'duck-dev-lib'",
431
- implementation2: "Create an array of tabs in the component",
432
- implementation3: "Use signal to store active tab",
433
- implementation4: "Handle tabChange event to switch content",
434
- implementation5: "Place tab content inside the component using conditional blocks"
457
+ apiContent: "optional additional data"
458
+ },
459
+ classicHighlights: {
460
+ animationEyebrow: "Animation",
461
+ animationTitle: "Smooth transitions",
462
+ animationText: "Slide left/right with blur effect and automatic direction detection based on tab index.",
463
+ signalsEyebrow: "Architecture",
464
+ signalsTitle: "Signal-based API",
465
+ signalsText: "Uses input() / output() signals instead of decorators. Active tab tracked via signal().",
466
+ contentEyebrow: "Content",
467
+ contentTitle: "ng-content projection",
468
+ contentText: "Place any content inside the tab component. Use @if blocks to conditionally render per tab."
469
+ },
470
+ classicCode: {
471
+ templateTitle: "Template (HTML)",
472
+ componentTitle: "Component (TypeScript)"
473
+ },
474
+ classicDemo: {
475
+ title: "Live demo",
476
+ tab1: "Overview",
477
+ tab2: "Features",
478
+ tab3: "API",
479
+ overviewTitle: "Tab component overview",
480
+ overviewText: "This is a live example of the DuckDevTab component. Click the tabs above to see animated transitions between content panels. The animation direction is detected automatically.",
481
+ featuresTitle: "Key features",
482
+ featuresText: "Animated slide transitions with blur effect, signal-based architecture, automatic direction detection, ng-content support, responsive design, and full keyboard accessibility.",
483
+ apiTitle: "Simple API",
484
+ apiText: "Pass an array of DuckDevTabItem objects via [tabs] input. Listen to (tabChange) output to react to tab switches. Use signal() to track the active tab and render content conditionally."
485
+ },
486
+ classicTip: {
487
+ title: "Tip:",
488
+ text: "The tab component is used throughout this documentation to switch between Classic and Neobrutalism styles. You're looking at it right now — it's the same DuckDevTab component."
435
489
  },
436
490
  neobrutal: {
437
491
  usage: "Neobrutalism variants:",
@@ -828,4 +882,4 @@ var en = {
828
882
  };
829
883
 
830
884
  export { accordionDoc, badgeDoc, buttons, cardDoc, en as default, directivesDoc, documentationStyleTabs, inputComponent, loaders, modalDoc, notifications, progressDoc, quickStart, segmentDoc, slider, speakerBubbleDoc, svgComponent, tabs, tabsComponent, tooltipDoc };
831
- //# sourceMappingURL=duck-dev-lib-en-BXgJr6gM.mjs.map
885
+ //# sourceMappingURL=duck-dev-lib-en-BC4APcVW.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"duck-dev-lib-ru-BezMvMFU.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"duck-dev-lib-en-BC4APcVW.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -146,6 +146,26 @@ var notifications = {
146
146
  var slider = {
147
147
  title: "Duck Dev UI Library - Слайдер",
148
148
  required: "обязательный",
149
+ tabs: {
150
+ flip: "Flip (Капли)",
151
+ classic: "Классический"
152
+ },
153
+ tip: {
154
+ title: "Совет:",
155
+ flipText: "Используйте ng-template с переменной #slide для определения слайдов. Слайдер собирает их автоматически через viewChildren. Передавайте сложный контент — карточки, формы, изображения — а не только текст.",
156
+ classicText: "Классический слайдер растягивается на ширину контейнера. Используйте aspect-ratio на host-элементе или оберните в контейнер фиксированной высоты для единообразного размера."
157
+ },
158
+ integration: {
159
+ title: "Интеграция",
160
+ description: "Оба варианта слайдера следуют одному паттерну — определите шаблоны слайдов, соберите их через viewChildren и передайте в слайдер через signal.",
161
+ accordionTitle: "Полный пример компонента",
162
+ templatesEyebrow: "ng-template",
163
+ templatesTitle: "Слайды через шаблоны",
164
+ templatesText: "Каждый слайд — это ng-template с ссылкой #slide. Внутрь можно поместить что угодно — компоненты, формы, изображения, сложные раскладки.",
165
+ signalsEyebrow: "Angular Signals",
166
+ signalsTitle: "Коллекция через Signals",
167
+ signalsText: "viewChildren собирает шаблоны, signal хранит их. Слайдер реагирует на изменения автоматически — ручная подписка не нужна."
168
+ },
149
169
  raindrops: {
150
170
  title: "Слайдер капли дождя",
151
171
  description: "Слайдер в стиле flip с размытием предыдущего слайда и плавными переходами.",
@@ -256,15 +276,21 @@ var buttons = {
256
276
  exampleGray: "Серая",
257
277
  exampleDark: "Тёмная"
258
278
  },
279
+ classicTip: {
280
+ title: "Совет:",
281
+ text: "Все классические кнопки принимают AccentEnumColor для единообразной темизации. Используйте Violet для основных действий, Orange для CTA, Gray для вторичных и Dark для контрастных раскладок."
282
+ },
259
283
  neobrutal: {
260
284
  title: "Neobrutalism Buttons",
261
- description: "Три агрессивных варианта кнопок с толстыми границами, контрастными тенями и нарочито грубой геометрией. Подходят для hero-блоков, CTA и акцентных действий, где интерфейс должен выглядеть дерзко.",
285
+ description: "Шесть агрессивных вариантов кнопок с толстыми границами, контрастными тенями и нарочито грубой геометрией. Подходят для hero-блоков, CTA и акцентных действий, где интерфейс должен выглядеть дерзко.",
262
286
  usage: "Использование:",
263
287
  inputs: "Входные параметры:",
264
288
  inputText: "основной текст кнопки",
265
- inputSubtext: "маленький ярлык для burst-варианта",
289
+ inputSubtext: "маленький ярлык для burst/sticker-вариантов",
266
290
  inputHelperText: "вторичная подпись для slab-варианта",
267
291
  inputTag: "короткий тег или номер для tag-варианта",
292
+ inputLabel: "текст инлайн-бейджа для zigzag-варианта",
293
+ inputIcon: "завершающий символ/иконка для tape-варианта (например '>>')",
268
294
  inputColorButton: "цветовая схема (White, Gray, Dark, Violet, Orange)",
269
295
  inputIsDisabled: "отключает кнопку и гасит интерактивные эффекты",
270
296
  examples: "Примеры:",
@@ -276,7 +302,16 @@ var buttons = {
276
302
  exampleSlabDisabled: "Slab / Disabled",
277
303
  exampleTagOrange: "Tag / Orange",
278
304
  exampleTagViolet: "Tag / Violet",
279
- exampleTagDark: "Tag / Dark"
305
+ exampleTagDark: "Tag / Dark",
306
+ exampleStickerViolet: "Sticker / Violet",
307
+ exampleStickerOrange: "Sticker / Orange",
308
+ exampleStickerDark: "Sticker / Dark",
309
+ exampleZigzagOrange: "Zigzag / Orange",
310
+ exampleZigzagViolet: "Zigzag / Violet",
311
+ exampleZigzagWhite: "Zigzag / White",
312
+ exampleTapeWhite: "Tape / White",
313
+ exampleTapeViolet: "Tape / Violet",
314
+ exampleTapeDark: "Tape / Dark"
280
315
  }
281
316
  };
282
317
  var segmentDoc = {
@@ -363,41 +398,50 @@ var loaders = {
363
398
  }
364
399
  };
365
400
  var tabsComponent = {
366
- title: "Duck Dev UI Library - Компонент вкладок (Tabs)",
401
+ title: "Duck Dev UI Library - Вкладки",
367
402
  tab: {
368
403
  title: "Duck Dev Tab",
369
- description: "Компонент вкладок с анимированными переходами между контентом. Поддерживает signal-based input/output, автоматическое переключение с анимацией влево/вправо в зависимости от направления. Идеально подходит для организации контента в категории и создания интерактивных интерфейсов.",
370
- usage: "Использование:",
371
- usageText1: "Для использования компонента импортируйте DuckDevTab и DuckDevTabItem из библиотеки 'duck-dev-lib'.",
372
- usageText2: "Создайте массив вкладок с полями id и label, передайте его в компонент через input [tabs].",
373
- usageText3: "Используйте ng-content для размещения контента вкладок внутри компонента.",
374
- inputs: "Входные параметры:",
375
- inputTabs: "массив объектов типа DuckDevTabItem[] с полями:",
376
- inputTabsId: "уникальный идентификатор вкладки",
377
- inputTabsLabel: "текст на кнопке вкладки",
378
- inputTabsContent: "дополнительные данные",
404
+ description: "Компонент вкладок с анимированными переходами между контентом. Поддерживает signal-based input/output, автоматическое переключение с анимацией влево/вправо. Доступен в горизонтальном и вертикальном вариантах.",
405
+ usage: "Использование",
406
+ inputs: "Входы и выходы",
407
+ inputTabs: "массив DuckDevTabItem[]",
379
408
  required: "обязательный",
380
409
  optional: "опционально",
381
- outputs: "Выходные события:",
382
- outputTabChange: "событие, которое срабатывает при переключении вкладки. Возвращает объект текущей активной вкладки (DuckDevTabItem)",
383
- features: "Особенности:",
384
- feature1: "Анимированные переходы между вкладками (слайд влево/вправо)",
385
- feature2: "Анимированный индикатор активной вкладки",
386
- feature3: "Signal-based архитектура (input/output функции вместо декораторов)",
387
- feature4: "Автоматическое определение направления анимации",
388
- feature5: "Поддержка ng-content для размещения контента",
389
- feature6: "Современный синтаксис Angular (новые директивы)",
390
- feature7: "Адаптивный дизайн",
391
- api: "TypeScript интерфейс DuckDevTabItem:",
392
410
  apiId: "уникальный идентификатор вкладки",
393
411
  apiLabel: "текст на кнопке вкладки",
394
412
  apiContent: "опциональные дополнительные данные",
395
- implementation: "Пример интеграции:",
396
- implementation1: "Импортируйте DuckDevTab и DuckDevTabItem из 'duck-dev-lib'",
397
- implementation2: "Создайте массив вкладок в компоненте",
398
- implementation3: "Используйте signal для хранения активной вкладки",
399
- implementation4: "Обработайте событие tabChange для переключения контента",
400
- implementation5: "Разместите контент вкладок внутри компонента используя условные блоки"
413
+ outputTabChange: "срабатывает при переключении, возвращает DuckDevTabItem"
414
+ },
415
+ classicHighlights: {
416
+ animationEyebrow: "Анимация",
417
+ animationTitle: "Плавные переходы",
418
+ animationText: "Слайд влево/вправо с эффектом blur и автоматическим определением направления по индексу вкладки.",
419
+ signalsEyebrow: "Архитектура",
420
+ signalsTitle: "Signal-based API",
421
+ signalsText: "Использует input() / output() вместо декораторов. Активная вкладка отслеживается через signal().",
422
+ contentEyebrow: "Контент",
423
+ contentTitle: "ng-content проекция",
424
+ contentText: "Размещайте любой контент внутри компонента. Используйте @if блоки для условного рендеринга."
425
+ },
426
+ classicCode: {
427
+ templateTitle: "Шаблон (HTML)",
428
+ componentTitle: "Компонент (TypeScript)"
429
+ },
430
+ classicDemo: {
431
+ title: "Живой пример",
432
+ tab1: "Обзор",
433
+ tab2: "Возможности",
434
+ tab3: "API",
435
+ overviewTitle: "Обзор компонента вкладок",
436
+ overviewText: "Это живой пример компонента DuckDevTab. Нажимайте на вкладки выше, чтобы увидеть анимированные переходы между панелями. Направление анимации определяется автоматически.",
437
+ featuresTitle: "Ключевые возможности",
438
+ featuresText: "Анимированные переходы с эффектом blur, signal-based архитектура, автоматическое определение направления, поддержка ng-content, адаптивный дизайн и полная клавиатурная доступность.",
439
+ apiTitle: "Простой API",
440
+ apiText: "Передайте массив DuckDevTabItem через [tabs]. Слушайте (tabChange) для реакции на переключение. Используйте signal() для отслеживания активной вкладки и условного рендеринга."
441
+ },
442
+ classicTip: {
443
+ title: "Совет:",
444
+ text: "Компонент вкладок используется по всей этой документации для переключения между стилями Classic и Neobrutalism. Вы смотрите на него прямо сейчас — это тот же самый DuckDevTab."
401
445
  },
402
446
  neobrutal: {
403
447
  usage: "Neobrutalism варианты:",
@@ -793,4 +837,4 @@ var ru = {
793
837
  };
794
838
 
795
839
  export { accordionDoc, badgeDoc, buttons, cardDoc, ru as default, directivesDoc, documentationStyleTabs, inputComponent, loaders, modalDoc, notifications, progressDoc, quickStart, segmentDoc, slider, speakerBubbleDoc, svgComponent, tabs, tabsComponent };
796
- //# sourceMappingURL=duck-dev-lib-ru-BezMvMFU.mjs.map
840
+ //# sourceMappingURL=duck-dev-lib-ru-BiVnCmCN.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"duck-dev-lib-en-BXgJr6gM.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"duck-dev-lib-ru-BiVnCmCN.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}