From d61cb6e4037ca724c420ab838faacc1fdf55b91d Mon Sep 17 00:00:00 2001
From: Boris Voropaev
Date: Fri, 25 Aug 2023 17:17:11 +0300
Subject: [PATCH] first push
---
.browserslistrc | 17 +
.editorconfig | 16 +
.gitignore | 78 +-
.vscode/launch.json | 15 +
README.md | 46 +-
angular.json | 136 +
karma.conf.js | 44 +
package-lock.json | 21605 ++++++++++++++++
package.json | 51 +
src/app/_directives/particles.directive.ts | 468 +
src/app/_helpers/auth.guard.ts | 24 +
src/app/_helpers/error.interceptor.ts | 24 +
src/app/_helpers/fake-backend.ts | 77 +
src/app/_helpers/index.ts | 4 +
src/app/_helpers/jwt.interceptor.ts | 26 +
src/app/_models/asset.ts | 29 +
src/app/_models/index.ts | 3 +
src/app/_models/oauthToken.ts | 6 +
src/app/_models/user.ts | 23 +
.../administration/administration.module.ts | 35 +
.../administrate-committee.component.html | 1 +
.../administrate-committee.component.scss | 0
.../administrate-committee.component.ts | 20 +
.../administrate-company.component.html | 2 +
.../administrate-company.component.scss | 4 +
.../company/administrate-company.component.ts | 47 +
.../page/administration-page.component.html | 11 +
.../page/administration-page.component.scss | 5 +
.../page/administration-page.component.ts | 36 +
.../_modules/advisories/advisories.module.ts | 23 +
.../tree/advisories-tree.component.html | 5 +
.../tree/advisories-tree.component.scss | 158 +
.../tree/advisories-tree.component.ts | 31 +
.../advisories-tree-advisory.component.html | 30 +
.../advisories-tree-advisory.component.scss | 0
.../advisories-tree-advisory.component.ts | 112 +
.../advisories-tree-company.component.html | 21 +
.../advisories-tree-company.component.scss | 0
.../advisories-tree-company.component.ts | 99 +
.../advisories-tree-member.component.html | 16 +
.../advisories-tree-member.component.scss | 0
.../advisories-tree-member.component.ts | 52 +
.../applications/applications.module.ts | 31 +
.../list/applications-list.component.html | 5 +
.../list/applications-list.component.scss | 18 +
.../list/applications-list.component.ts | 41 +
.../applications-list-item.component.html | 38 +
.../applications-list-item.component.scss | 51 +
.../item/applications-list-item.component.ts | 74 +
.../page/applications-page.component.html | 19 +
.../page/applications-page.component.scss | 0
.../page/applications-page.component.ts | 36 +
src/app/_modules/auth/auth.module.ts | 38 +
.../auth/forget/forget.component.html | 24 +
.../auth/forget/forget.component.scss | 5 +
.../_modules/auth/forget/forget.component.ts | 59 +
.../_modules/auth/form/form.component.html | 7 +
.../_modules/auth/form/form.component.scss | 26 +
src/app/_modules/auth/form/form.component.ts | 26 +
.../_modules/auth/login/login.component.html | 31 +
.../_modules/auth/login/login.component.scss | 151 +
.../_modules/auth/login/login.component.ts | 74 +
.../auth/reset/password-reset.component.html | 24 +
.../auth/reset/password-reset.component.scss | 0
.../auth/reset/password-reset.component.ts | 65 +
.../auth/signup/signup.component.html | 43 +
.../auth/signup/signup.component.scss | 0
.../_modules/auth/signup/signup.component.ts | 87 +
.../company-advisories.component.html | 6 +
.../company-advisories.component.scss | 0
.../company-advisories.component.ts | 37 +
.../_modules/companies/companies.module.ts | 30 +
.../companies/company/company.component.html | 12 +
.../companies/company/company.component.scss | 149 +
.../companies/company/company.component.ts | 57 +
.../members/company-members.component.html | 3 +
.../members/company-members.component.scss | 3 +
.../members/company-members.component.ts | 46 +
.../member/company-member.component.html | 16 +
.../member/company-member.component.scss | 58 +
.../member/company-member.component.ts | 50 +
.../company-structure.component.html | 4 +
.../company-structure.component.scss | 0
.../structure/company-structure.component.ts | 40 +
.../company-department.component.html | 17 +
.../company-department.component.scss | 87 +
.../company-department.component.ts | 87 +
.../field/filter-field.component.html | 18 +
.../field/filter-field.component.scss | 25 +
.../field/filter-field.component.ts | 21 +
.../filter-fields/filter-fields.module.ts | 34 +
.../filter-field-boolean.component.html | 10 +
.../filter-field-boolean.component.scss | 17 +
.../boolean/filter-field-boolean.component.ts | 28 +
.../boolean/filter-field-boolean.module.ts | 18 +
.../date/filter-field-date.component.html | 13 +
.../date/filter-field-date.component.scss | 13 +
.../types/date/filter-field-date.component.ts | 56 +
.../types/date/filter-field-date.module.ts | 28 +
.../filter-field-datetime.component.html | 5 +
.../filter-field-datetime.component.scss | 8 +
.../filter-field-datetime.component.ts | 22 +
.../datetime/filter-field-datetime.module.ts | 19 +
.../float/filter-field-float.component.html | 5 +
.../float/filter-field-float.component.scss | 8 +
.../float/filter-field-float.component.ts | 43 +
.../types/float/filter-field-float.module.ts | 18 +
src/app/_modules/filter-fields/types/index.ts | 8 +
.../filter-field-integer.component.html | 5 +
.../filter-field-integer.component.scss | 8 +
.../integer/filter-field-integer.component.ts | 43 +
.../integer/filter-field-integer.module.ts | 18 +
.../checkbox/relation-checkbox.component.html | 11 +
.../checkbox/relation-checkbox.component.scss | 22 +
.../checkbox/relation-checkbox.component.ts | 61 +
.../combobox/relation-combobox.component.html | 31 +
.../combobox/relation-combobox.component.scss | 0
.../combobox/relation-combobox.component.ts | 87 +
.../filter-field-relation.component.html | 5 +
.../filter-field-relation.component.scss | 169 +
.../filter-field-relation.component.ts | 21 +
.../relation/filter-field-relation.module.ts | 26 +
.../radio/relation-radio.component.html | 12 +
.../radio/relation-radio.component.scss | 22 +
.../radio/relation-radio.component.ts | 32 +
.../string/filter-field-string.component.html | 3 +
.../string/filter-field-string.component.scss | 0
.../string/filter-field-string.component.ts | 29 +
.../string/filter-field-string.module.ts | 18 +
.../text/filter-field-text.component.html | 1 +
.../text/filter-field-text.component.scss | 13 +
.../types/text/filter-field-text.component.ts | 25 +
.../types/text/filter-field-text.module.ts | 16 +
.../field/form-field.component.html | 26 +
.../field/form-field.component.scss | 43 +
.../form-fields/field/form-field.component.ts | 64 +
.../form-fields/form-fields.module.ts | 47 +
.../boolean/form-field-boolean.component.html | 6 +
.../boolean/form-field-boolean.component.scss | 0
.../boolean/form-field-boolean.component.ts | 20 +
.../boolean/form-field-boolean.module.ts | 22 +
.../field-boolean-readonly.component.html | 1 +
.../field-boolean-readonly.component.scss | 3 +
.../field-boolean-readonly.component.ts | 25 +
.../field-boolean-single.component.html | 3 +
.../field-boolean-single.component.scss | 3 +
.../single/field-boolean-single.component.ts | 40 +
.../types/date/form-field-date.component.html | 4 +
.../types/date/form-field-date.component.scss | 0
.../types/date/form-field-date.component.ts | 21 +
.../types/date/form-field-date.module.ts | 37 +
.../field-date-readonly.component.html | 2 +
.../field-date-readonly.component.scss | 3 +
.../readonly/field-date-readonly.component.ts | 21 +
.../single/field-date-single.component.html | 4 +
.../single/field-date-single.component.scss | 6 +
.../single/field-date-single.component.ts | 50 +
.../form-field-datetime.component.html | 4 +
.../form-field-datetime.component.scss | 0
.../datetime/form-field-datetime.component.ts | 21 +
.../datetime/form-field-datetime.module.ts | 25 +
.../field-datetime-readonly.component.html | 2 +
.../field-datetime-readonly.component.scss | 3 +
.../field-datetime-readonly.component.ts | 21 +
.../field-datetime-single.component.html | 3 +
.../field-datetime-single.component.scss | 0
.../single/field-datetime-single.component.ts | 35 +
.../form-field-document.component.html | 5 +
.../form-field-document.component.scss | 82 +
.../document/form-field-document.component.ts | 18 +
.../document/form-field-document.module.ts | 24 +
.../field-document-multiple.component.html | 14 +
.../field-document-multiple.component.scss | 0
.../field-document-multiple.component.ts | 98 +
.../field-document-readonly.component.html | 6 +
.../field-document-readonly.component.scss | 3 +
.../field-document-readonly.component.ts | 23 +
.../field-document-single.component.html | 14 +
.../field-document-single.component.scss | 0
.../single/field-document-single.component.ts | 89 +
.../float/form-field-float.component.html | 4 +
.../float/form-field-float.component.scss | 0
.../types/float/form-field-float.component.ts | 20 +
.../types/float/form-field-float.module.ts | 22 +
.../field-float-readonly.component.html | 2 +
.../field-float-readonly.component.scss | 3 +
.../field-float-readonly.component.ts | 21 +
.../single/field-float-single.component.html | 3 +
.../single/field-float-single.component.scss | 0
.../single/field-float-single.component.ts | 36 +
.../hidden/form-field-hidden.component.html | 3 +
.../hidden/form-field-hidden.component.scss | 0
.../hidden/form-field-hidden.component.ts | 23 +
.../types/hidden/form-field-hidden.module.ts | 19 +
.../types/html/form-field-html.component.html | 4 +
.../types/html/form-field-html.component.scss | 4 +
.../types/html/form-field-html.component.ts | 19 +
.../types/html/form-field-html.module.ts | 28 +
.../field-html-readonly.component.html | 2 +
.../field-html-readonly.component.scss | 3 +
.../readonly/field-html-readonly.component.ts | 23 +
.../single/field-html-single.component.html | 7 +
.../single/field-html-single.component.scss | 0
.../single/field-html-single.component.ts | 63 +
.../image/form-field-image.component.html | 5 +
.../image/form-field-image.component.scss | 91 +
.../types/image/form-field-image.component.ts | 18 +
.../types/image/form-field-image.module.ts | 26 +
.../field-image-multiple.component.html | 14 +
.../field-image-multiple.component.scss | 0
.../field-image-multiple.component.ts | 98 +
.../field-image-readonly.component.html | 5 +
.../field-image-readonly.component.scss | 0
.../field-image-readonly.component.ts | 23 +
.../single/field-image-single.component.html | 14 +
.../single/field-image-single.component.scss | 0
.../single/field-image-single.component.ts | 93 +
src/app/_modules/form-fields/types/index.ts | 14 +
.../integer/form-field-integer.component.html | 5 +
.../integer/form-field-integer.component.scss | 0
.../integer/form-field-integer.component.ts | 21 +
.../integer/form-field-integer.module.ts | 24 +
.../field-integer-multiple.component.html | 9 +
.../field-integer-multiple.component.scss | 41 +
.../field-integer-multiple.component.ts | 56 +
.../field-integer-readonly.component.html | 2 +
.../field-integer-readonly.component.scss | 3 +
.../field-integer-readonly.component.ts | 21 +
.../field-integer-single.component.html | 3 +
.../field-integer-single.component.scss | 0
.../single/field-integer-single.component.ts | 36 +
.../form-field-relation.component.html | 5 +
.../form-field-relation.component.scss | 168 +
.../relation/form-field-relation.component.ts | 18 +
.../relation/form-field-relation.module.ts | 33 +
.../checkbox/relation-checkbox.component.html | 9 +
.../checkbox/relation-checkbox.component.scss | 147 +
.../checkbox/relation-checkbox.component.ts | 54 +
.../combobox/combobox-multiple.component.html | 29 +
.../combobox/combobox-multiple.component.scss | 0
.../combobox/combobox-multiple.component.ts | 86 +
.../field-relation-multiple.component.html | 4 +
.../field-relation-multiple.component.scss | 3 +
.../field-relation-multiple.component.ts | 19 +
.../field-relation-readonly.component.html | 5 +
.../field-relation-readonly.component.scss | 9 +
.../field-relation-readonly.component.ts | 20 +
.../combobox/combobox-single.component.html | 20 +
.../combobox/combobox-single.component.scss | 0
.../combobox/combobox-single.component.ts | 80 +
.../field-relation-single.component.html | 4 +
.../field-relation-single.component.scss | 0
.../single/field-relation-single.component.ts | 21 +
.../radio/relation-radio.component.html | 6 +
.../radio/relation-radio.component.scss | 155 +
.../single/radio/relation-radio.component.ts | 39 +
.../string/form-field-string.component.html | 4 +
.../string/form-field-string.component.scss | 0
.../string/form-field-string.component.ts | 21 +
.../types/string/form-field-string.module.ts | 22 +
.../field-string-readonly.component.html | 2 +
.../field-string-readonly.component.scss | 3 +
.../field-string-readonly.component.ts | 21 +
.../single/field-string-single.component.html | 3 +
.../single/field-string-single.component.scss | 0
.../single/field-string-single.component.ts | 37 +
.../types/text/form-field-text.component.html | 5 +
.../types/text/form-field-text.component.scss | 4 +
.../types/text/form-field-text.component.ts | 20 +
.../types/text/form-field-text.module.ts | 26 +
.../field-text-multiple.component.html | 11 +
.../field-text-multiple.component.scss | 20 +
.../multiple/field-text-multiple.component.ts | 52 +
.../field-text-readonly.component.html | 2 +
.../field-text-readonly.component.scss | 3 +
.../readonly/field-text-readonly.component.ts | 23 +
.../single/field-text-single.component.html | 3 +
.../single/field-text-single.component.scss | 6 +
.../single/field-text-single.component.ts | 38 +
.../types/time/form-field-time.component.html | 4 +
.../types/time/form-field-time.component.scss | 0
.../types/time/form-field-time.component.ts | 13 +
.../types/time/form-field-time.module.ts | 23 +
.../field-time-readonly.component.html | 2 +
.../field-time-readonly.component.scss | 3 +
.../readonly/field-time-readonly.component.ts | 21 +
.../single/field-time-single.component.html | 3 +
.../single/field-time-single.component.scss | 3 +
.../single/field-time-single.component.ts | 34 +
.../topics/form-field-topics.component.html | 22 +
.../topics/form-field-topics.component.scss | 72 +
.../topics/form-field-topics.component.ts | 69 +
.../types/topics/form-field-topics.module.ts | 29 +
.../layout/footer/footer.component.html | 28 +
.../layout/footer/footer.component.scss | 110 +
.../layout/footer/footer.component.ts | 15 +
.../_modules/layout/grid/grid.component.html | 12 +
.../_modules/layout/grid/grid.component.scss | 13 +
.../_modules/layout/grid/grid.component.ts | 34 +
.../layout/header/header.component.html | 36 +
.../layout/header/header.component.scss | 231 +
.../layout/header/header.component.ts | 61 +
.../user-bar/header-user-bar.component.html | 32 +
.../user-bar/header-user-bar.component.scss | 95 +
.../user-bar/header-user-bar.component.ts | 47 +
src/app/_modules/layout/layout.module.ts | 34 +
.../setting-site/setting-site.component.html | 45 +
.../setting-site/setting-site.component.scss | 90 +
.../setting-site/setting-site.component.ts | 92 +
.../layout/sidebar/sidebar.component.html | 4 +
.../layout/sidebar/sidebar.component.scss | 0
.../layout/sidebar/sidebar.component.ts | 17 +
.../notifications-list-item.component.html | 13 +
.../notifications-list-item.component.scss | 65 +
.../item/notifications-list-item.component.ts | 52 +
.../list/notifications-list.component.html | 15 +
.../list/notifications-list.component.scss | 18 +
.../list/notifications-list.component.ts | 31 +
.../notifications/notifications.module.ts | 31 +
.../group/object-filters-group.component.html | 6 +
.../group/object-filters-group.component.scss | 18 +
.../group/object-filters-group.component.ts | 23 +
.../filters/object-filters.component.html | 1 +
.../filters/object-filters.component.scss | 0
.../filters/object-filters.component.ts | 56 +
.../slider/slider-filters.component.html | 19 +
.../slider/slider-filters.component.scss | 0
.../slider/slider-filters.component.ts | 62 +
.../form/frame/form-frame.component.html | 1 +
.../form/frame/form-frame.component.scss | 0
.../form/frame/form-frame.component.ts | 87 +
.../group/object-form-group.component.html | 6 +
.../group/object-form-group.component.scss | 5 +
.../form/group/object-form-group.component.ts | 22 +
.../objects/form/object-form.component.html | 2 +
.../objects/form/object-form.component.scss | 0
.../objects/form/object-form.component.ts | 41 +
.../form/slider/slider-form.component.html | 29 +
.../form/slider/slider-form.component.scss | 0
.../form/slider/slider-form.component.ts | 148 +
src/app/_modules/objects/objects.module.ts | 45 +
.../home/cards/homepage-cards.component.html | 7 +
.../home/cards/homepage-cards.component.scss | 39 +
.../home/cards/homepage-cards.component.ts | 15 +
.../pages/home/homepage.component.html | 5 +
.../pages/home/homepage.component.scss | 4 +
.../_modules/pages/home/homepage.component.ts | 44 +
.../_modules/pages/home/homepage.module.ts | 34 +
.../home/intro/homepage-intro.component.html | 9 +
.../home/intro/homepage-intro.component.scss | 71 +
.../home/intro/homepage-intro.component.ts | 15 +
.../intro/promo/homepage-promo.component.html | 1444 ++
.../intro/promo/homepage-promo.component.scss | 64 +
.../intro/promo/homepage-promo.component.ts | 15 +
.../home/news/homepage-news.component.html | 23 +
.../home/news/homepage-news.component.scss | 106 +
.../home/news/homepage-news.component.ts | 47 +
.../partners/homepage-partners.component.html | 22 +
.../partners/homepage-partners.component.scss | 15 +
.../partners/homepage-partners.component.ts | 15 +
.../homepage-portfolio.component.html | 22 +
.../homepage-portfolio.component.scss | 102 +
.../portfolio/homepage-portfolio.component.ts | 35 +
.../list/item/pages-list-item.component.html | 1 +
.../list/item/pages-list-item.component.scss | 0
.../list/item/pages-list-item.component.ts | 17 +
.../pages/list/pages-list.component.html | 6 +
.../pages/list/pages-list.component.scss | 0
.../pages/list/pages-list.component.ts | 46 +
.../menu/item/pages-menu-item.component.html | 7 +
.../menu/item/pages-menu-item.component.scss | 1 +
.../menu/item/pages-menu-item.component.ts | 36 +
.../pages/menu/pages-menu.component.html | 2 +
.../pages/menu/pages-menu.component.scss | 0
.../pages/menu/pages-menu.component.ts | 33 +
.../not-found/page-not-found.component.html | 1 +
.../not-found/page-not-found.component.scss | 0
.../not-found/page-not-found.component.ts | 16 +
.../page-breadcrumbs.component.html | 5 +
.../page-breadcrumbs.component.scss | 38 +
.../breadcrumbs/page-breadcrumbs.component.ts | 22 +
.../_modules/pages/page/page.component.html | 21 +
.../_modules/pages/page/page.component.scss | 77 +
src/app/_modules/pages/page/page.component.ts | 73 +
.../types/content/content-page.component.html | 8 +
.../types/content/content-page.component.scss | 0
.../types/content/content-page.component.ts | 28 +
.../publications-page.component.html | 1 +
.../publications-page.component.scss | 54 +
.../publications-page.component.ts | 17 +
.../registry/registry-page.component.html | 2 +
.../registry/registry-page.component.scss | 0
.../types/registry/registry-page.component.ts | 38 +
.../tk-structure-page.component.html | 27 +
.../tk-structure-page.component.scss | 150 +
.../tk-structure-page.component.ts | 60 +
.../_modules/pages/pages-routing.module.ts | 46 +
src/app/_modules/pages/pages.module.ts | 42 +
.../sections/add/add-section.component.html | 19 +
.../sections/add/add-section.component.scss | 92 +
.../sections/add/add-section.component.ts | 60 +
.../sections/item/page-section.component.html | 26 +
.../sections/item/page-section.component.scss | 13 +
.../sections/item/page-section.component.ts | 63 +
.../list/page-sections.component.html | 2 +
.../list/page-sections.component.scss | 0
.../sections/list/page-sections.component.ts | 24 +
.../pages/sections/page-sections.module.ts | 54 +
.../item/search-sections-item.component.html | 2 +
.../item/search-sections-item.component.scss | 3 +
.../item/search-sections-item.component.ts | 25 +
.../search/search-sections.component.html | 5 +
.../search/search-sections.component.scss | 8 +
.../search/search-sections.component.ts | 47 +
.../button/button-section.component.html | 1 +
.../button/button-section.component.scss | 8 +
.../basic/button/button-section.component.ts | 30 +
.../contact/contact-section.component.html | 8 +
.../contact/contact-section.component.scss | 36 +
.../contact/contact-section.component.ts | 39 +
.../documents-section.component.html | 5 +
.../documents-section.component.scss | 6 +
.../documents/documents-section.component.ts | 23 +
.../feedback/feedback-section.component.html | 16 +
.../feedback/feedback-section.component.scss | 27 +
.../feedback/feedback-section.component.ts | 39 +
.../header/header-section.component.html | 5 +
.../header/header-section.component.scss | 21 +
.../basic/header/header-section.component.ts | 24 +
.../basic/html/html-section.component.html | 1 +
.../basic/html/html-section.component.scss | 1 +
.../basic/html/html-section.component.ts | 25 +
.../iframe/iframe-section.component.html | 1 +
.../iframe/iframe-section.component.scss | 5 +
.../basic/iframe/iframe-section.component.ts | 26 +
.../images/images-section.component.html | 39 +
.../images/images-section.component.scss | 112 +
.../basic/images/images-section.component.ts | 111 +
.../basic/list/list-section.component.html | 6 +
.../basic/list/list-section.component.scss | 3 +
.../basic/list/list-section.component.ts | 25 +
.../basic/maps/maps-section.component.html | 1 +
.../basic/maps/maps-section.component.scss | 5 +
.../basic/maps/maps-section.component.ts | 35 +
.../basic/text/text-section.component.html | 1 +
.../basic/text/text-section.component.scss | 3 +
.../basic/text/text-section.component.ts | 22 +
.../basic/video/video-section.component.html | 5 +
.../basic/video/video-section.component.scss | 7 +
.../basic/video/video-section.component.ts | 43 +
.../sidebars/add/add-sidebar.component.html | 11 +
.../sidebars/add/add-sidebar.component.scss | 21 +
.../sidebars/add/add-sidebar.component.ts | 39 +
.../sidebars/item/page-sidebar.component.html | 18 +
.../sidebars/item/page-sidebar.component.scss | 74 +
.../sidebars/item/page-sidebar.component.ts | 64 +
.../list/page-sidebars.component.html | 2 +
.../list/page-sidebars.component.scss | 0
.../sidebars/list/page-sidebars.component.ts | 23 +
.../pages/sidebars/page-sidebars.module.ts | 21 +
.../pagination/pagination.component.html | 9 +
.../pagination/pagination.component.scss | 59 +
.../pagination/pagination.component.ts | 75 +
.../_modules/pagination/pagination.module.ts | 17 +
.../item/phonebook-list-item.component.html | 7 +
.../item/phonebook-list-item.component.scss | 0
.../item/phonebook-list-item.component.ts | 24 +
.../list/phonebook-list.component.html | 5 +
.../list/phonebook-list.component.scss | 11 +
.../list/phonebook-list.component.ts | 47 +
.../page/phonebook-page.component.html | 12 +
.../page/phonebook-page.component.scss | 0
.../page/phonebook-page.component.ts | 31 +
.../_modules/phonebook/phonebook.module.ts | 33 +
.../list/item/item.component.html | 8 +
.../list/item/item.component.scss | 0
.../publications/list/item/item.component.ts | 18 +
.../list/item/menu/menu.component.html | 7 +
.../list/item/menu/menu.component.scss | 32 +
.../list/item/menu/menu.component.ts | 54 +
.../list/item/news/news.component.html | 13 +
.../list/item/news/news.component.scss | 80 +
.../list/item/news/news.component.ts | 17 +
.../list/item/photos/photos.component.html | 31 +
.../list/item/photos/photos.component.scss | 145 +
.../list/item/photos/photos.component.ts | 112 +
.../item/portfolio/portfolio.component.html | 15 +
.../item/portfolio/portfolio.component.scss | 65 +
.../item/portfolio/portfolio.component.ts | 17 +
.../list/item/smi/smi.component.html | 14 +
.../list/item/smi/smi.component.scss | 58 +
.../list/item/smi/smi.component.ts | 17 +
.../list/item/video/video.component.html | 13 +
.../list/item/video/video.component.scss | 71 +
.../list/item/video/video.component.ts | 23 +
.../publications/list/list.component.html | 8 +
.../publications/list/list.component.scss | 25 +
.../publications/list/list.component.ts | 62 +
.../publication/publication.component.html | 5 +
.../publication/publication.component.scss | 14 +
.../publication/publication.component.ts | 18 +
.../publications/publications.module.ts | 39 +
.../_modules/registries/registries.module.ts | 42 +
.../category/registry-category.component.html | 15 +
.../category/registry-category.component.scss | 3 +
.../category/registry-category.component.ts | 61 +
.../registry-categories.component.html | 3 +
.../registry-categories.component.scss | 0
.../registry-categories.component.ts | 61 +
.../entry-properties.component.html | 13 +
.../entry-properties.component.scss | 0
.../properties/entry-properties.component.ts | 41 +
.../entry/registry-entry.component.html | 34 +
.../entry/registry-entry.component.scss | 45 +
.../entries/entry/registry-entry.component.ts | 82 +
.../entries/registry-entries.component.html | 9 +
.../entries/registry-entries.component.scss | 29 +
.../entries/registry-entries.component.ts | 67 +
.../filters/registry-filters.component.html | 11 +
.../filters/registry-filters.component.scss | 5 +
.../filters/registry-filters.component.ts | 27 +
.../entry-operations.component.html | 1 +
.../entry-operations.component.scss | 7 +
.../operations/entry-operations.component.ts | 46 +
.../operation/entry-operation.component.html | 22 +
.../operation/entry-operation.component.scss | 11 +
.../operation/entry-operation.component.ts | 66 +
.../registry/registry.component.html | 14 +
.../registry/registry.component.scss | 37 +
.../registries/registry/registry.component.ts | 77 +
.../search/page/search-page.component.html | 22 +
.../search/page/search-page.component.scss | 14 +
.../search/page/search-page.component.ts | 107 +
src/app/_modules/search/search.module.ts | 30 +
.../_modules/sorting/sorting.component.html | 9 +
.../_modules/sorting/sorting.component.scss | 12 +
src/app/_modules/sorting/sorting.component.ts | 41 +
src/app/_modules/sorting/sorting.module.ts | 16 +
.../users/profile/user-profile.component.html | 22 +
.../users/profile/user-profile.component.scss | 85 +
.../users/profile/user-profile.component.ts | 46 +
src/app/_modules/users/users.module.ts | 23 +
src/app/_services/advisories.service.ts | 25 +
.../_services/advisory-companies.service.ts | 23 +
src/app/_services/advisory-members.service.ts | 23 +
src/app/_services/applications.service.ts | 23 +
src/app/_services/assets.service.ts | 21 +
src/app/_services/authentication.service.ts | 80 +
src/app/_services/companies.service.ts | 20 +
src/app/_services/company-members.service.ts | 23 +
src/app/_services/departments.service.ts | 19 +
src/app/_services/filters.service.ts | 18 +
src/app/_services/form-fields.service.ts | 35 +
src/app/_services/forms.service.ts | 60 +
src/app/_services/index.ts | 10 +
src/app/_services/lists.service.ts | 71 +
src/app/_services/notification.service.ts | 39 +
src/app/_services/objects.service.ts | 118 +
src/app/_services/pages.service.ts | 33 +
src/app/_services/publications.service.ts | 32 +
src/app/_services/registries.service.ts | 23 +
.../_services/registry-categories.service.ts | 27 +
src/app/_services/registry-entries.service.ts | 27 +
src/app/_services/user.service.ts | 16 +
src/app/_services/utility.service.ts | 78 +
src/app/_services/window-scrolling.service.ts | 23 +
src/app/app.component.html | 1 +
src/app/app.component.scss | 0
src/app/app.component.ts | 12 +
src/app/app.module.ts | 46 +
src/app/config/particles.ts | 55 +
src/assets/.gitkeep | 0
src/assets/css/basics.scss | 140 +
src/assets/css/buttons.scss | 115 +
src/assets/css/documents-lists.scss | 60 +
src/assets/css/dropdown.scss | 62 +
src/assets/css/fonts.scss | 119 +
src/assets/css/forms.scss | 51 +
src/assets/css/list-items.scss | 86 +
src/assets/css/main-menu.scss | 261 +
src/assets/css/page-top-panel.scss | 68 +
src/assets/css/registry.scss | 56 +
src/assets/css/slider.scss | 176 +
src/assets/css/tables.scss | 60 +
src/assets/css/tabs.scss | 47 +
src/assets/fonts/lato/Lato-Black.ttf | Bin 0 -> 584008 bytes
src/assets/fonts/lato/Lato-BlackItalic.ttf | Bin 0 -> 616316 bytes
src/assets/fonts/lato/Lato-Bold.ttf | Bin 0 -> 600856 bytes
src/assets/fonts/lato/Lato-BoldItalic.ttf | Bin 0 -> 622572 bytes
src/assets/fonts/lato/Lato-Hairline.ttf | Bin 0 -> 565624 bytes
src/assets/fonts/lato/Lato-HairlineItalic.ttf | Bin 0 -> 588144 bytes
src/assets/fonts/lato/Lato-Heavy.ttf | Bin 0 -> 603056 bytes
src/assets/fonts/lato/Lato-HeavyItalic.ttf | Bin 0 -> 620528 bytes
src/assets/fonts/lato/Lato-Italic.ttf | Bin 0 -> 639388 bytes
src/assets/fonts/lato/Lato-Light.ttf | Bin 0 -> 617492 bytes
src/assets/fonts/lato/Lato-LightItalic.ttf | Bin 0 -> 628640 bytes
src/assets/fonts/lato/Lato-Medium.ttf | Bin 0 -> 600476 bytes
src/assets/fonts/lato/Lato-MediumItalic.ttf | Bin 0 -> 627928 bytes
src/assets/fonts/lato/Lato-Regular.ttf | Bin 0 -> 607720 bytes
src/assets/fonts/lato/Lato-Semibold.ttf | Bin 0 -> 614256 bytes
src/assets/fonts/lato/Lato-SemiboldItalic.ttf | Bin 0 -> 630852 bytes
src/assets/fonts/lato/Lato-Thin.ttf | Bin 0 -> 610876 bytes
src/assets/fonts/lato/Lato-ThinItalic.ttf | Bin 0 -> 628352 bytes
src/assets/fonts/ptrootui/PT-Root-UI_Bold.ttf | Bin 0 -> 386992 bytes
.../fonts/ptrootui/PT-Root-UI_Light.ttf | Bin 0 -> 389548 bytes
.../fonts/ptrootui/PT-Root-UI_Medium.ttf | Bin 0 -> 387136 bytes
.../fonts/ptrootui/PT-Root-UI_Regular.ttf | Bin 0 -> 386988 bytes
src/assets/fonts/ptrootui/PT-Root-UI_VF.ttf | Bin 0 -> 259644 bytes
src/assets/fonts/ptsans/PT_Sans-Web-Bold.ttf | Bin 0 -> 470240 bytes
.../fonts/ptsans/PT_Sans-Web-BoldItalic.ttf | Bin 0 -> 375204 bytes
.../fonts/ptsans/PT_Sans-Web-Italic.ttf | Bin 0 -> 436452 bytes
.../fonts/ptsans/PT_Sans-Web-Regular.ttf | Bin 0 -> 442960 bytes
src/assets/fonts/sans/OpenSans-Bold.eot | Bin 0 -> 121946 bytes
src/assets/fonts/sans/OpenSans-Bold.ttf | Bin 0 -> 121768 bytes
src/assets/fonts/sans/OpenSans-Bold.woff | Bin 0 -> 70120 bytes
src/assets/fonts/sans/OpenSans-Bold.woff2 | Bin 0 -> 52016 bytes
src/assets/fonts/sans/OpenSans-BoldItalic.eot | Bin 0 -> 110642 bytes
src/assets/fonts/sans/OpenSans-BoldItalic.ttf | Bin 0 -> 110436 bytes
.../fonts/sans/OpenSans-BoldItalic.woff | Bin 0 -> 65028 bytes
.../fonts/sans/OpenSans-BoldItalic.woff2 | Bin 0 -> 47860 bytes
src/assets/fonts/sans/OpenSans-ExtraBold.eot | Bin 0 -> 120018 bytes
src/assets/fonts/sans/OpenSans-ExtraBold.ttf | Bin 0 -> 119804 bytes
src/assets/fonts/sans/OpenSans-ExtraBold.woff | Bin 0 -> 69876 bytes
.../fonts/sans/OpenSans-ExtraBold.woff2 | Bin 0 -> 51776 bytes
.../fonts/sans/OpenSans-ExtraBoldItalic.eot | Bin 0 -> 110854 bytes
.../fonts/sans/OpenSans-ExtraBoldItalic.ttf | Bin 0 -> 110628 bytes
.../fonts/sans/OpenSans-ExtraBoldItalic.woff | Bin 0 -> 65384 bytes
.../fonts/sans/OpenSans-ExtraBoldItalic.woff2 | Bin 0 -> 47912 bytes
src/assets/fonts/sans/OpenSans-Italic.eot | Bin 0 -> 110130 bytes
src/assets/fonts/sans/OpenSans-Italic.ttf | Bin 0 -> 109944 bytes
src/assets/fonts/sans/OpenSans-Italic.woff | Bin 0 -> 65132 bytes
src/assets/fonts/sans/OpenSans-Italic.woff2 | Bin 0 -> 48144 bytes
src/assets/fonts/sans/OpenSans-Light.eot | Bin 0 -> 119826 bytes
src/assets/fonts/sans/OpenSans-Light.ttf | Bin 0 -> 119628 bytes
src/assets/fonts/sans/OpenSans-Light.woff | Bin 0 -> 69336 bytes
src/assets/fonts/sans/OpenSans-Light.woff2 | Bin 0 -> 51436 bytes
.../fonts/sans/OpenSans-LightItalic.eot | Bin 0 -> 110566 bytes
.../fonts/sans/OpenSans-LightItalic.ttf | Bin 0 -> 110356 bytes
.../fonts/sans/OpenSans-LightItalic.woff | Bin 0 -> 65056 bytes
.../fonts/sans/OpenSans-LightItalic.woff2 | Bin 0 -> 47676 bytes
src/assets/fonts/sans/OpenSans-Regular.eot | Bin 0 -> 114746 bytes
src/assets/fonts/sans/OpenSans-Regular.ttf | Bin 0 -> 114556 bytes
src/assets/fonts/sans/OpenSans-Regular.woff | Bin 0 -> 67488 bytes
src/assets/fonts/sans/OpenSans-Regular.woff2 | Bin 0 -> 50180 bytes
src/assets/fonts/sans/OpenSans-SemiBold.eot | Bin 0 -> 118730 bytes
src/assets/fonts/sans/OpenSans-SemiBold.ttf | Bin 0 -> 118520 bytes
src/assets/fonts/sans/OpenSans-SemiBold.woff | Bin 0 -> 69844 bytes
src/assets/fonts/sans/OpenSans-SemiBold.woff2 | Bin 0 -> 52188 bytes
.../fonts/sans/OpenSans-SemiBoldItalic.eot | Bin 0 -> 110282 bytes
.../fonts/sans/OpenSans-SemiBoldItalic.ttf | Bin 0 -> 110060 bytes
.../fonts/sans/OpenSans-SemiBoldItalic.woff | Bin 0 -> 65840 bytes
.../fonts/sans/OpenSans-SemiBoldItalic.woff2 | Bin 0 -> 49256 bytes
src/assets/images/_remove/news_1.jpg | Bin 0 -> 97191 bytes
src/assets/images/_remove/news_2.jpg | Bin 0 -> 165229 bytes
src/assets/images/_remove/p1.png | Bin 0 -> 474585 bytes
src/assets/images/build.png | Bin 0 -> 135766 bytes
src/assets/images/favicon.png | Bin 0 -> 10290 bytes
src/assets/images/icons/add_24dp.svg | 5 +
src/assets/images/icons/add_folder_24.svg | 5 +
src/assets/images/icons/add_library_24.svg | 5 +
.../images/icons/add_library_dark_24.svg | 5 +
src/assets/images/icons/add_notes_24.svg | 5 +
src/assets/images/icons/add_notes_dark_24.svg | 5 +
src/assets/images/icons/add_person_24.svg | 5 +
src/assets/images/icons/architecture_24.svg | 5 +
.../images/icons/arrow_downward_24dp.svg | 3 +
.../images/icons/arrow_drop_down_24dp.svg | 10 +
src/assets/images/icons/arrow_upward_24.svg | 5 +
src/assets/images/icons/arrow_upward_24dp.svg | 3 +
.../images/icons/arrow_upward_dark_24.svg | 5 +
src/assets/images/icons/ban_20dp.svg | 3 +
src/assets/images/icons/burger_white_24dp.svg | 5 +
src/assets/images/icons/chevron_left_48.svg | 3 +
src/assets/images/icons/chevron_left_48dp.svg | 3 +
.../images/icons/chevron_left_white_48dp.svg | 3 +
.../images/icons/chevron_right_20dp.svg | 3 +
.../images/icons/chevron_right_24dp.svg | 3 +
.../images/icons/chevron_right_48dp.svg | 3 +
.../icons/chevron_right_orange_20dp.svg | 3 +
.../images/icons/chevron_right_white_48dp.svg | 3 +
.../images/icons/circle_half_stroke_21dp.svg | 3 +
src/assets/images/icons/circle_minus_24.svg | 5 +
src/assets/images/icons/circle_plus_24.svg | 5 +
src/assets/images/icons/close_16dp.svg | 4 +
src/assets/images/icons/close_20dp.svg | 3 +
src/assets/images/icons/close_24.svg | 3 +
src/assets/images/icons/close_24dp.svg | 3 +
src/assets/images/icons/close_white_24dp.svg | 3 +
src/assets/images/icons/delete_24dp.svg | 4 +
src/assets/images/icons/dialpad_24dp.svg | 3 +
src/assets/images/icons/document_20.svg | 3 +
src/assets/images/icons/document_20dp.svg | 10 +
src/assets/images/icons/drag-n-drop_24.svg | 3 +
src/assets/images/icons/drag-n-drop_24w.svg | 3 +
src/assets/images/icons/edit_20.svg | 5 +
src/assets/images/icons/edit_24.svg | 5 +
src/assets/images/icons/edit_24dp.svg | 5 +
src/assets/images/icons/edit_dark_24.svg | 5 +
src/assets/images/icons/email_20.svg | 3 +
src/assets/images/icons/email_orange_24dp.svg | 10 +
src/assets/images/icons/email_white_24dp.svg | 10 +
src/assets/images/icons/expand_less_20.svg | 10 +
src/assets/images/icons/expand_less_24.svg | 3 +
.../images/icons/expand_less_dark_24.svg | 3 +
src/assets/images/icons/expand_more_20.svg | 10 +
src/assets/images/icons/filter_empty_24.svg | 5 +
src/assets/images/icons/filter_filled_24.svg | 5 +
src/assets/images/icons/glasses_24dp.svg | 3 +
src/assets/images/icons/image_grey_20dp.svg | 3 +
.../images/icons/location_orange_24dp.svg | 10 +
.../images/icons/location_white_24dp.svg | 10 +
src/assets/images/icons/login.svg | 3 +
src/assets/images/icons/login_24dp.svg | 3 +
src/assets/images/icons/login_white_24dp.svg | 3 +
src/assets/images/icons/mail_orange_24dp.svg | 10 +
src/assets/images/icons/minus_grey_20dp.svg | 3 +
src/assets/images/icons/more_horiz_20dp.svg | 3 +
src/assets/images/icons/note_add_20.svg | 5 +
src/assets/images/icons/ok_black_24dp.svg | 4 +
src/assets/images/icons/ok_grey_24dp.svg | 4 +
src/assets/images/icons/phone_20.svg | 3 +
src/assets/images/icons/phone_orange_24dp.svg | 13 +
src/assets/images/icons/phone_white_24dp.svg | 13 +
src/assets/images/icons/plus_grey_20dp.svg | 3 +
src/assets/images/icons/registration.svg | 5 +
src/assets/images/icons/return_19dp.svg | 3 +
src/assets/images/icons/search_24.svg | 3 +
src/assets/images/icons/search_24dp.svg | 3 +
src/assets/images/icons/step_active.svg | 3 +
src/assets/images/icons/step_finished.svg | 3 +
src/assets/images/icons/step_upcoming.svg | 3 +
src/assets/images/icons/sun_22dp.svg | 3 +
src/assets/images/icons/telegram_24dp.svg | 4 +
.../images/icons/telegram_black_24dp.svg | 4 +
.../images/icons/telegram_grey_24dp.svg | 4 +
src/assets/images/icons/trash_20.svg | 5 +
src/assets/images/icons/trash_24dp.svg | 5 +
.../images/icons/visibility_off_24dp.svg | 3 +
.../images/icons/visibility_on_24dp.svg | 10 +
src/assets/images/icons/vk_black_24dp.svg | 4 +
src/assets/images/icons/vk_grey_24dp.svg | 4 +
src/assets/images/icons/x.svg | 3 +
src/assets/images/icons/youtube_24dp.svg | 4 +
src/assets/images/ksi.svg | 44 +
src/assets/images/logo_fcs_48x48.svg | 9 +
src/assets/images/logo_fcs_black.svg | 55 +
src/assets/images/logo_fcs_white.svg | 55 +
src/assets/images/logo_fcs_white_218x60.svg | 55 +
src/assets/images/logo_minstroy_black.svg | 813 +
src/assets/images/logo_minstroy_white.svg | 813 +
.../images/logo_minstroy_white_179x72.svg | 813 +
src/assets/images/normativ.svg | 6 +
src/assets/images/partners/eaes_logo.png | Bin 0 -> 6340 bytes
.../partners/glavgosekspertiza_logo.png | Bin 0 -> 29979 bytes
src/assets/images/partners/iso_logo.png | Bin 0 -> 9378 bytes
src/assets/images/partners/minstroy_logo.png | Bin 0 -> 33782 bytes
.../images/partners/rosstandart_logo.png | Bin 0 -> 33750 bytes
src/assets/images/portfolio-sample.png | Bin 0 -> 232758 bytes
src/assets/images/portfolio_bg.png | Bin 0 -> 224381 bytes
src/assets/images/tehnicheskie.svg | 6 +
src/assets/images/tk465.svg | 4 +
src/assets/images/triangle.png | Bin 0 -> 613 bytes
src/assets/images/tu.svg | 4 +
src/assets/lang/ru.js | 1 +
src/environments/environment.prod.ts | 6 +
src/environments/environment.ts | 19 +
src/index.html | 12 +
src/main.ts | 12 +
src/polyfills.ts | 65 +
src/styles.scss | 112 +
src/test.ts | 27 +
tsconfig.app.json | 15 +
tsconfig.json | 24 +
tsconfig.spec.json | 18 +
774 files changed, 44069 insertions(+), 73 deletions(-)
create mode 100644 .browserslistrc
create mode 100644 .editorconfig
create mode 100644 .vscode/launch.json
create mode 100644 angular.json
create mode 100644 karma.conf.js
create mode 100644 package-lock.json
create mode 100644 package.json
create mode 100644 src/app/_directives/particles.directive.ts
create mode 100644 src/app/_helpers/auth.guard.ts
create mode 100644 src/app/_helpers/error.interceptor.ts
create mode 100644 src/app/_helpers/fake-backend.ts
create mode 100644 src/app/_helpers/index.ts
create mode 100644 src/app/_helpers/jwt.interceptor.ts
create mode 100644 src/app/_models/asset.ts
create mode 100644 src/app/_models/index.ts
create mode 100644 src/app/_models/oauthToken.ts
create mode 100644 src/app/_models/user.ts
create mode 100644 src/app/_modules/administration/administration.module.ts
create mode 100644 src/app/_modules/administration/committee/administrate-committee.component.html
create mode 100644 src/app/_modules/administration/committee/administrate-committee.component.scss
create mode 100644 src/app/_modules/administration/committee/administrate-committee.component.ts
create mode 100644 src/app/_modules/administration/company/administrate-company.component.html
create mode 100644 src/app/_modules/administration/company/administrate-company.component.scss
create mode 100644 src/app/_modules/administration/company/administrate-company.component.ts
create mode 100644 src/app/_modules/administration/page/administration-page.component.html
create mode 100644 src/app/_modules/administration/page/administration-page.component.scss
create mode 100644 src/app/_modules/administration/page/administration-page.component.ts
create mode 100644 src/app/_modules/advisories/advisories.module.ts
create mode 100644 src/app/_modules/advisories/tree/advisories-tree.component.html
create mode 100644 src/app/_modules/advisories/tree/advisories-tree.component.scss
create mode 100644 src/app/_modules/advisories/tree/advisories-tree.component.ts
create mode 100644 src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.html
create mode 100644 src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.scss
create mode 100644 src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.ts
create mode 100644 src/app/_modules/advisories/tree/company/advisories-tree-company.component.html
create mode 100644 src/app/_modules/advisories/tree/company/advisories-tree-company.component.scss
create mode 100644 src/app/_modules/advisories/tree/company/advisories-tree-company.component.ts
create mode 100644 src/app/_modules/advisories/tree/member/advisories-tree-member.component.html
create mode 100644 src/app/_modules/advisories/tree/member/advisories-tree-member.component.scss
create mode 100644 src/app/_modules/advisories/tree/member/advisories-tree-member.component.ts
create mode 100644 src/app/_modules/applications/applications.module.ts
create mode 100644 src/app/_modules/applications/list/applications-list.component.html
create mode 100644 src/app/_modules/applications/list/applications-list.component.scss
create mode 100644 src/app/_modules/applications/list/applications-list.component.ts
create mode 100644 src/app/_modules/applications/list/item/applications-list-item.component.html
create mode 100644 src/app/_modules/applications/list/item/applications-list-item.component.scss
create mode 100644 src/app/_modules/applications/list/item/applications-list-item.component.ts
create mode 100644 src/app/_modules/applications/page/applications-page.component.html
create mode 100644 src/app/_modules/applications/page/applications-page.component.scss
create mode 100644 src/app/_modules/applications/page/applications-page.component.ts
create mode 100644 src/app/_modules/auth/auth.module.ts
create mode 100644 src/app/_modules/auth/forget/forget.component.html
create mode 100644 src/app/_modules/auth/forget/forget.component.scss
create mode 100644 src/app/_modules/auth/forget/forget.component.ts
create mode 100644 src/app/_modules/auth/form/form.component.html
create mode 100644 src/app/_modules/auth/form/form.component.scss
create mode 100644 src/app/_modules/auth/form/form.component.ts
create mode 100644 src/app/_modules/auth/login/login.component.html
create mode 100644 src/app/_modules/auth/login/login.component.scss
create mode 100644 src/app/_modules/auth/login/login.component.ts
create mode 100644 src/app/_modules/auth/reset/password-reset.component.html
create mode 100644 src/app/_modules/auth/reset/password-reset.component.scss
create mode 100644 src/app/_modules/auth/reset/password-reset.component.ts
create mode 100644 src/app/_modules/auth/signup/signup.component.html
create mode 100644 src/app/_modules/auth/signup/signup.component.scss
create mode 100644 src/app/_modules/auth/signup/signup.component.ts
create mode 100644 src/app/_modules/companies/advisories/company-advisories.component.html
create mode 100644 src/app/_modules/companies/advisories/company-advisories.component.scss
create mode 100644 src/app/_modules/companies/advisories/company-advisories.component.ts
create mode 100644 src/app/_modules/companies/companies.module.ts
create mode 100644 src/app/_modules/companies/company/company.component.html
create mode 100644 src/app/_modules/companies/company/company.component.scss
create mode 100644 src/app/_modules/companies/company/company.component.ts
create mode 100644 src/app/_modules/companies/members/company-members.component.html
create mode 100644 src/app/_modules/companies/members/company-members.component.scss
create mode 100644 src/app/_modules/companies/members/company-members.component.ts
create mode 100644 src/app/_modules/companies/members/member/company-member.component.html
create mode 100644 src/app/_modules/companies/members/member/company-member.component.scss
create mode 100644 src/app/_modules/companies/members/member/company-member.component.ts
create mode 100644 src/app/_modules/companies/structure/company-structure.component.html
create mode 100644 src/app/_modules/companies/structure/company-structure.component.scss
create mode 100644 src/app/_modules/companies/structure/company-structure.component.ts
create mode 100644 src/app/_modules/companies/structure/department/company-department.component.html
create mode 100644 src/app/_modules/companies/structure/department/company-department.component.scss
create mode 100644 src/app/_modules/companies/structure/department/company-department.component.ts
create mode 100644 src/app/_modules/filter-fields/field/filter-field.component.html
create mode 100644 src/app/_modules/filter-fields/field/filter-field.component.scss
create mode 100644 src/app/_modules/filter-fields/field/filter-field.component.ts
create mode 100644 src/app/_modules/filter-fields/filter-fields.module.ts
create mode 100644 src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.html
create mode 100644 src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.scss
create mode 100644 src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.ts
create mode 100644 src/app/_modules/filter-fields/types/boolean/filter-field-boolean.module.ts
create mode 100644 src/app/_modules/filter-fields/types/date/filter-field-date.component.html
create mode 100644 src/app/_modules/filter-fields/types/date/filter-field-date.component.scss
create mode 100644 src/app/_modules/filter-fields/types/date/filter-field-date.component.ts
create mode 100644 src/app/_modules/filter-fields/types/date/filter-field-date.module.ts
create mode 100644 src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.html
create mode 100644 src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.scss
create mode 100644 src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.ts
create mode 100644 src/app/_modules/filter-fields/types/datetime/filter-field-datetime.module.ts
create mode 100644 src/app/_modules/filter-fields/types/float/filter-field-float.component.html
create mode 100644 src/app/_modules/filter-fields/types/float/filter-field-float.component.scss
create mode 100644 src/app/_modules/filter-fields/types/float/filter-field-float.component.ts
create mode 100644 src/app/_modules/filter-fields/types/float/filter-field-float.module.ts
create mode 100644 src/app/_modules/filter-fields/types/index.ts
create mode 100644 src/app/_modules/filter-fields/types/integer/filter-field-integer.component.html
create mode 100644 src/app/_modules/filter-fields/types/integer/filter-field-integer.component.scss
create mode 100644 src/app/_modules/filter-fields/types/integer/filter-field-integer.component.ts
create mode 100644 src/app/_modules/filter-fields/types/integer/filter-field-integer.module.ts
create mode 100644 src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.html
create mode 100644 src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.scss
create mode 100644 src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.ts
create mode 100644 src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.html
create mode 100644 src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.scss
create mode 100644 src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.ts
create mode 100644 src/app/_modules/filter-fields/types/relation/filter-field-relation.component.html
create mode 100644 src/app/_modules/filter-fields/types/relation/filter-field-relation.component.scss
create mode 100644 src/app/_modules/filter-fields/types/relation/filter-field-relation.component.ts
create mode 100644 src/app/_modules/filter-fields/types/relation/filter-field-relation.module.ts
create mode 100644 src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.html
create mode 100644 src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.scss
create mode 100644 src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.ts
create mode 100644 src/app/_modules/filter-fields/types/string/filter-field-string.component.html
create mode 100644 src/app/_modules/filter-fields/types/string/filter-field-string.component.scss
create mode 100644 src/app/_modules/filter-fields/types/string/filter-field-string.component.ts
create mode 100644 src/app/_modules/filter-fields/types/string/filter-field-string.module.ts
create mode 100644 src/app/_modules/filter-fields/types/text/filter-field-text.component.html
create mode 100644 src/app/_modules/filter-fields/types/text/filter-field-text.component.scss
create mode 100644 src/app/_modules/filter-fields/types/text/filter-field-text.component.ts
create mode 100644 src/app/_modules/filter-fields/types/text/filter-field-text.module.ts
create mode 100644 src/app/_modules/form-fields/field/form-field.component.html
create mode 100644 src/app/_modules/form-fields/field/form-field.component.scss
create mode 100644 src/app/_modules/form-fields/field/form-field.component.ts
create mode 100644 src/app/_modules/form-fields/form-fields.module.ts
create mode 100644 src/app/_modules/form-fields/types/boolean/form-field-boolean.component.html
create mode 100644 src/app/_modules/form-fields/types/boolean/form-field-boolean.component.scss
create mode 100644 src/app/_modules/form-fields/types/boolean/form-field-boolean.component.ts
create mode 100644 src/app/_modules/form-fields/types/boolean/form-field-boolean.module.ts
create mode 100644 src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.html
create mode 100644 src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/date/form-field-date.component.html
create mode 100644 src/app/_modules/form-fields/types/date/form-field-date.component.scss
create mode 100644 src/app/_modules/form-fields/types/date/form-field-date.component.ts
create mode 100644 src/app/_modules/form-fields/types/date/form-field-date.module.ts
create mode 100644 src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/date/single/field-date-single.component.html
create mode 100644 src/app/_modules/form-fields/types/date/single/field-date-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/date/single/field-date-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/datetime/form-field-datetime.component.html
create mode 100644 src/app/_modules/form-fields/types/datetime/form-field-datetime.component.scss
create mode 100644 src/app/_modules/form-fields/types/datetime/form-field-datetime.component.ts
create mode 100644 src/app/_modules/form-fields/types/datetime/form-field-datetime.module.ts
create mode 100644 src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.html
create mode 100644 src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/document/form-field-document.component.html
create mode 100644 src/app/_modules/form-fields/types/document/form-field-document.component.scss
create mode 100644 src/app/_modules/form-fields/types/document/form-field-document.component.ts
create mode 100644 src/app/_modules/form-fields/types/document/form-field-document.module.ts
create mode 100644 src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.html
create mode 100644 src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.scss
create mode 100644 src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.ts
create mode 100644 src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/document/single/field-document-single.component.html
create mode 100644 src/app/_modules/form-fields/types/document/single/field-document-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/document/single/field-document-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/float/form-field-float.component.html
create mode 100644 src/app/_modules/form-fields/types/float/form-field-float.component.scss
create mode 100644 src/app/_modules/form-fields/types/float/form-field-float.component.ts
create mode 100644 src/app/_modules/form-fields/types/float/form-field-float.module.ts
create mode 100644 src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/float/single/field-float-single.component.html
create mode 100644 src/app/_modules/form-fields/types/float/single/field-float-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/float/single/field-float-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/hidden/form-field-hidden.component.html
create mode 100644 src/app/_modules/form-fields/types/hidden/form-field-hidden.component.scss
create mode 100644 src/app/_modules/form-fields/types/hidden/form-field-hidden.component.ts
create mode 100644 src/app/_modules/form-fields/types/hidden/form-field-hidden.module.ts
create mode 100644 src/app/_modules/form-fields/types/html/form-field-html.component.html
create mode 100644 src/app/_modules/form-fields/types/html/form-field-html.component.scss
create mode 100644 src/app/_modules/form-fields/types/html/form-field-html.component.ts
create mode 100644 src/app/_modules/form-fields/types/html/form-field-html.module.ts
create mode 100644 src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/html/single/field-html-single.component.html
create mode 100644 src/app/_modules/form-fields/types/html/single/field-html-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/html/single/field-html-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/image/form-field-image.component.html
create mode 100644 src/app/_modules/form-fields/types/image/form-field-image.component.scss
create mode 100644 src/app/_modules/form-fields/types/image/form-field-image.component.ts
create mode 100644 src/app/_modules/form-fields/types/image/form-field-image.module.ts
create mode 100644 src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.html
create mode 100644 src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.scss
create mode 100644 src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.ts
create mode 100644 src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/image/single/field-image-single.component.html
create mode 100644 src/app/_modules/form-fields/types/image/single/field-image-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/image/single/field-image-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/index.ts
create mode 100644 src/app/_modules/form-fields/types/integer/form-field-integer.component.html
create mode 100644 src/app/_modules/form-fields/types/integer/form-field-integer.component.scss
create mode 100644 src/app/_modules/form-fields/types/integer/form-field-integer.component.ts
create mode 100644 src/app/_modules/form-fields/types/integer/form-field-integer.module.ts
create mode 100644 src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.html
create mode 100644 src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.scss
create mode 100644 src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.ts
create mode 100644 src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/integer/single/field-integer-single.component.html
create mode 100644 src/app/_modules/form-fields/types/integer/single/field-integer-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/integer/single/field-integer-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/relation/form-field-relation.component.html
create mode 100644 src/app/_modules/form-fields/types/relation/form-field-relation.component.scss
create mode 100644 src/app/_modules/form-fields/types/relation/form-field-relation.component.ts
create mode 100644 src/app/_modules/form-fields/types/relation/form-field-relation.module.ts
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.html
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.scss
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.ts
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.html
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.scss
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.ts
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.html
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.scss
create mode 100644 src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.ts
create mode 100644 src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.html
create mode 100644 src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/relation/single/field-relation-single.component.html
create mode 100644 src/app/_modules/form-fields/types/relation/single/field-relation-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/relation/single/field-relation-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.html
create mode 100644 src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.scss
create mode 100644 src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.ts
create mode 100644 src/app/_modules/form-fields/types/string/form-field-string.component.html
create mode 100644 src/app/_modules/form-fields/types/string/form-field-string.component.scss
create mode 100644 src/app/_modules/form-fields/types/string/form-field-string.component.ts
create mode 100644 src/app/_modules/form-fields/types/string/form-field-string.module.ts
create mode 100644 src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/string/single/field-string-single.component.html
create mode 100644 src/app/_modules/form-fields/types/string/single/field-string-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/string/single/field-string-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/text/form-field-text.component.html
create mode 100644 src/app/_modules/form-fields/types/text/form-field-text.component.scss
create mode 100644 src/app/_modules/form-fields/types/text/form-field-text.component.ts
create mode 100644 src/app/_modules/form-fields/types/text/form-field-text.module.ts
create mode 100644 src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.html
create mode 100644 src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.scss
create mode 100644 src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.ts
create mode 100644 src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/text/single/field-text-single.component.html
create mode 100644 src/app/_modules/form-fields/types/text/single/field-text-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/text/single/field-text-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/time/form-field-time.component.html
create mode 100644 src/app/_modules/form-fields/types/time/form-field-time.component.scss
create mode 100644 src/app/_modules/form-fields/types/time/form-field-time.component.ts
create mode 100644 src/app/_modules/form-fields/types/time/form-field-time.module.ts
create mode 100644 src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.html
create mode 100644 src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.scss
create mode 100644 src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.ts
create mode 100644 src/app/_modules/form-fields/types/time/single/field-time-single.component.html
create mode 100644 src/app/_modules/form-fields/types/time/single/field-time-single.component.scss
create mode 100644 src/app/_modules/form-fields/types/time/single/field-time-single.component.ts
create mode 100644 src/app/_modules/form-fields/types/topics/form-field-topics.component.html
create mode 100644 src/app/_modules/form-fields/types/topics/form-field-topics.component.scss
create mode 100644 src/app/_modules/form-fields/types/topics/form-field-topics.component.ts
create mode 100644 src/app/_modules/form-fields/types/topics/form-field-topics.module.ts
create mode 100644 src/app/_modules/layout/footer/footer.component.html
create mode 100644 src/app/_modules/layout/footer/footer.component.scss
create mode 100644 src/app/_modules/layout/footer/footer.component.ts
create mode 100644 src/app/_modules/layout/grid/grid.component.html
create mode 100644 src/app/_modules/layout/grid/grid.component.scss
create mode 100644 src/app/_modules/layout/grid/grid.component.ts
create mode 100644 src/app/_modules/layout/header/header.component.html
create mode 100644 src/app/_modules/layout/header/header.component.scss
create mode 100644 src/app/_modules/layout/header/header.component.ts
create mode 100644 src/app/_modules/layout/header/user-bar/header-user-bar.component.html
create mode 100644 src/app/_modules/layout/header/user-bar/header-user-bar.component.scss
create mode 100644 src/app/_modules/layout/header/user-bar/header-user-bar.component.ts
create mode 100644 src/app/_modules/layout/layout.module.ts
create mode 100644 src/app/_modules/layout/setting-site/setting-site.component.html
create mode 100644 src/app/_modules/layout/setting-site/setting-site.component.scss
create mode 100644 src/app/_modules/layout/setting-site/setting-site.component.ts
create mode 100644 src/app/_modules/layout/sidebar/sidebar.component.html
create mode 100644 src/app/_modules/layout/sidebar/sidebar.component.scss
create mode 100644 src/app/_modules/layout/sidebar/sidebar.component.ts
create mode 100644 src/app/_modules/notifications/list/item/notifications-list-item.component.html
create mode 100644 src/app/_modules/notifications/list/item/notifications-list-item.component.scss
create mode 100644 src/app/_modules/notifications/list/item/notifications-list-item.component.ts
create mode 100644 src/app/_modules/notifications/list/notifications-list.component.html
create mode 100644 src/app/_modules/notifications/list/notifications-list.component.scss
create mode 100644 src/app/_modules/notifications/list/notifications-list.component.ts
create mode 100644 src/app/_modules/notifications/notifications.module.ts
create mode 100644 src/app/_modules/objects/filters/group/object-filters-group.component.html
create mode 100644 src/app/_modules/objects/filters/group/object-filters-group.component.scss
create mode 100644 src/app/_modules/objects/filters/group/object-filters-group.component.ts
create mode 100644 src/app/_modules/objects/filters/object-filters.component.html
create mode 100644 src/app/_modules/objects/filters/object-filters.component.scss
create mode 100644 src/app/_modules/objects/filters/object-filters.component.ts
create mode 100644 src/app/_modules/objects/filters/slider/slider-filters.component.html
create mode 100644 src/app/_modules/objects/filters/slider/slider-filters.component.scss
create mode 100644 src/app/_modules/objects/filters/slider/slider-filters.component.ts
create mode 100644 src/app/_modules/objects/form/frame/form-frame.component.html
create mode 100644 src/app/_modules/objects/form/frame/form-frame.component.scss
create mode 100644 src/app/_modules/objects/form/frame/form-frame.component.ts
create mode 100644 src/app/_modules/objects/form/group/object-form-group.component.html
create mode 100644 src/app/_modules/objects/form/group/object-form-group.component.scss
create mode 100644 src/app/_modules/objects/form/group/object-form-group.component.ts
create mode 100644 src/app/_modules/objects/form/object-form.component.html
create mode 100644 src/app/_modules/objects/form/object-form.component.scss
create mode 100644 src/app/_modules/objects/form/object-form.component.ts
create mode 100644 src/app/_modules/objects/form/slider/slider-form.component.html
create mode 100644 src/app/_modules/objects/form/slider/slider-form.component.scss
create mode 100644 src/app/_modules/objects/form/slider/slider-form.component.ts
create mode 100644 src/app/_modules/objects/objects.module.ts
create mode 100644 src/app/_modules/pages/home/cards/homepage-cards.component.html
create mode 100644 src/app/_modules/pages/home/cards/homepage-cards.component.scss
create mode 100644 src/app/_modules/pages/home/cards/homepage-cards.component.ts
create mode 100644 src/app/_modules/pages/home/homepage.component.html
create mode 100644 src/app/_modules/pages/home/homepage.component.scss
create mode 100644 src/app/_modules/pages/home/homepage.component.ts
create mode 100644 src/app/_modules/pages/home/homepage.module.ts
create mode 100644 src/app/_modules/pages/home/intro/homepage-intro.component.html
create mode 100644 src/app/_modules/pages/home/intro/homepage-intro.component.scss
create mode 100644 src/app/_modules/pages/home/intro/homepage-intro.component.ts
create mode 100644 src/app/_modules/pages/home/intro/promo/homepage-promo.component.html
create mode 100644 src/app/_modules/pages/home/intro/promo/homepage-promo.component.scss
create mode 100644 src/app/_modules/pages/home/intro/promo/homepage-promo.component.ts
create mode 100644 src/app/_modules/pages/home/news/homepage-news.component.html
create mode 100644 src/app/_modules/pages/home/news/homepage-news.component.scss
create mode 100644 src/app/_modules/pages/home/news/homepage-news.component.ts
create mode 100644 src/app/_modules/pages/home/partners/homepage-partners.component.html
create mode 100644 src/app/_modules/pages/home/partners/homepage-partners.component.scss
create mode 100644 src/app/_modules/pages/home/partners/homepage-partners.component.ts
create mode 100644 src/app/_modules/pages/home/portfolio/homepage-portfolio.component.html
create mode 100644 src/app/_modules/pages/home/portfolio/homepage-portfolio.component.scss
create mode 100644 src/app/_modules/pages/home/portfolio/homepage-portfolio.component.ts
create mode 100644 src/app/_modules/pages/list/item/pages-list-item.component.html
create mode 100644 src/app/_modules/pages/list/item/pages-list-item.component.scss
create mode 100644 src/app/_modules/pages/list/item/pages-list-item.component.ts
create mode 100644 src/app/_modules/pages/list/pages-list.component.html
create mode 100644 src/app/_modules/pages/list/pages-list.component.scss
create mode 100644 src/app/_modules/pages/list/pages-list.component.ts
create mode 100644 src/app/_modules/pages/menu/item/pages-menu-item.component.html
create mode 100644 src/app/_modules/pages/menu/item/pages-menu-item.component.scss
create mode 100644 src/app/_modules/pages/menu/item/pages-menu-item.component.ts
create mode 100644 src/app/_modules/pages/menu/pages-menu.component.html
create mode 100644 src/app/_modules/pages/menu/pages-menu.component.scss
create mode 100644 src/app/_modules/pages/menu/pages-menu.component.ts
create mode 100644 src/app/_modules/pages/not-found/page-not-found.component.html
create mode 100644 src/app/_modules/pages/not-found/page-not-found.component.scss
create mode 100644 src/app/_modules/pages/not-found/page-not-found.component.ts
create mode 100644 src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.html
create mode 100644 src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.scss
create mode 100644 src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.ts
create mode 100644 src/app/_modules/pages/page/page.component.html
create mode 100644 src/app/_modules/pages/page/page.component.scss
create mode 100644 src/app/_modules/pages/page/page.component.ts
create mode 100644 src/app/_modules/pages/page/types/content/content-page.component.html
create mode 100644 src/app/_modules/pages/page/types/content/content-page.component.scss
create mode 100644 src/app/_modules/pages/page/types/content/content-page.component.ts
create mode 100644 src/app/_modules/pages/page/types/publications/publications-page.component.html
create mode 100644 src/app/_modules/pages/page/types/publications/publications-page.component.scss
create mode 100644 src/app/_modules/pages/page/types/publications/publications-page.component.ts
create mode 100644 src/app/_modules/pages/page/types/registry/registry-page.component.html
create mode 100644 src/app/_modules/pages/page/types/registry/registry-page.component.scss
create mode 100644 src/app/_modules/pages/page/types/registry/registry-page.component.ts
create mode 100644 src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.html
create mode 100644 src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.scss
create mode 100644 src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.ts
create mode 100644 src/app/_modules/pages/pages-routing.module.ts
create mode 100644 src/app/_modules/pages/pages.module.ts
create mode 100644 src/app/_modules/pages/sections/add/add-section.component.html
create mode 100644 src/app/_modules/pages/sections/add/add-section.component.scss
create mode 100644 src/app/_modules/pages/sections/add/add-section.component.ts
create mode 100644 src/app/_modules/pages/sections/item/page-section.component.html
create mode 100644 src/app/_modules/pages/sections/item/page-section.component.scss
create mode 100644 src/app/_modules/pages/sections/item/page-section.component.ts
create mode 100644 src/app/_modules/pages/sections/list/page-sections.component.html
create mode 100644 src/app/_modules/pages/sections/list/page-sections.component.scss
create mode 100644 src/app/_modules/pages/sections/list/page-sections.component.ts
create mode 100644 src/app/_modules/pages/sections/page-sections.module.ts
create mode 100644 src/app/_modules/pages/sections/search/item/search-sections-item.component.html
create mode 100644 src/app/_modules/pages/sections/search/item/search-sections-item.component.scss
create mode 100644 src/app/_modules/pages/sections/search/item/search-sections-item.component.ts
create mode 100644 src/app/_modules/pages/sections/search/search-sections.component.html
create mode 100644 src/app/_modules/pages/sections/search/search-sections.component.scss
create mode 100644 src/app/_modules/pages/sections/search/search-sections.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/button/button-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/button/button-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/button/button-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/contact/contact-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/contact/contact-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/contact/contact-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/documents/documents-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/documents/documents-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/documents/documents-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/header/header-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/header/header-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/header/header-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/html/html-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/html/html-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/html/html-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/images/images-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/images/images-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/images/images-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/list/list-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/list/list-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/list/list-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/maps/maps-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/maps/maps-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/maps/maps-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/text/text-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/text/text-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/text/text-section.component.ts
create mode 100644 src/app/_modules/pages/sections/types/basic/video/video-section.component.html
create mode 100644 src/app/_modules/pages/sections/types/basic/video/video-section.component.scss
create mode 100644 src/app/_modules/pages/sections/types/basic/video/video-section.component.ts
create mode 100644 src/app/_modules/pages/sidebars/add/add-sidebar.component.html
create mode 100644 src/app/_modules/pages/sidebars/add/add-sidebar.component.scss
create mode 100644 src/app/_modules/pages/sidebars/add/add-sidebar.component.ts
create mode 100644 src/app/_modules/pages/sidebars/item/page-sidebar.component.html
create mode 100644 src/app/_modules/pages/sidebars/item/page-sidebar.component.scss
create mode 100644 src/app/_modules/pages/sidebars/item/page-sidebar.component.ts
create mode 100644 src/app/_modules/pages/sidebars/list/page-sidebars.component.html
create mode 100644 src/app/_modules/pages/sidebars/list/page-sidebars.component.scss
create mode 100644 src/app/_modules/pages/sidebars/list/page-sidebars.component.ts
create mode 100644 src/app/_modules/pages/sidebars/page-sidebars.module.ts
create mode 100644 src/app/_modules/pagination/pagination.component.html
create mode 100644 src/app/_modules/pagination/pagination.component.scss
create mode 100644 src/app/_modules/pagination/pagination.component.ts
create mode 100644 src/app/_modules/pagination/pagination.module.ts
create mode 100644 src/app/_modules/phonebook/list/item/phonebook-list-item.component.html
create mode 100644 src/app/_modules/phonebook/list/item/phonebook-list-item.component.scss
create mode 100644 src/app/_modules/phonebook/list/item/phonebook-list-item.component.ts
create mode 100644 src/app/_modules/phonebook/list/phonebook-list.component.html
create mode 100644 src/app/_modules/phonebook/list/phonebook-list.component.scss
create mode 100644 src/app/_modules/phonebook/list/phonebook-list.component.ts
create mode 100644 src/app/_modules/phonebook/page/phonebook-page.component.html
create mode 100644 src/app/_modules/phonebook/page/phonebook-page.component.scss
create mode 100644 src/app/_modules/phonebook/page/phonebook-page.component.ts
create mode 100644 src/app/_modules/phonebook/phonebook.module.ts
create mode 100644 src/app/_modules/publications/list/item/item.component.html
create mode 100644 src/app/_modules/publications/list/item/item.component.scss
create mode 100644 src/app/_modules/publications/list/item/item.component.ts
create mode 100644 src/app/_modules/publications/list/item/menu/menu.component.html
create mode 100644 src/app/_modules/publications/list/item/menu/menu.component.scss
create mode 100644 src/app/_modules/publications/list/item/menu/menu.component.ts
create mode 100644 src/app/_modules/publications/list/item/news/news.component.html
create mode 100644 src/app/_modules/publications/list/item/news/news.component.scss
create mode 100644 src/app/_modules/publications/list/item/news/news.component.ts
create mode 100644 src/app/_modules/publications/list/item/photos/photos.component.html
create mode 100644 src/app/_modules/publications/list/item/photos/photos.component.scss
create mode 100644 src/app/_modules/publications/list/item/photos/photos.component.ts
create mode 100644 src/app/_modules/publications/list/item/portfolio/portfolio.component.html
create mode 100644 src/app/_modules/publications/list/item/portfolio/portfolio.component.scss
create mode 100644 src/app/_modules/publications/list/item/portfolio/portfolio.component.ts
create mode 100644 src/app/_modules/publications/list/item/smi/smi.component.html
create mode 100644 src/app/_modules/publications/list/item/smi/smi.component.scss
create mode 100644 src/app/_modules/publications/list/item/smi/smi.component.ts
create mode 100644 src/app/_modules/publications/list/item/video/video.component.html
create mode 100644 src/app/_modules/publications/list/item/video/video.component.scss
create mode 100644 src/app/_modules/publications/list/item/video/video.component.ts
create mode 100644 src/app/_modules/publications/list/list.component.html
create mode 100644 src/app/_modules/publications/list/list.component.scss
create mode 100644 src/app/_modules/publications/list/list.component.ts
create mode 100644 src/app/_modules/publications/publication/publication.component.html
create mode 100644 src/app/_modules/publications/publication/publication.component.scss
create mode 100644 src/app/_modules/publications/publication/publication.component.ts
create mode 100644 src/app/_modules/publications/publications.module.ts
create mode 100644 src/app/_modules/registries/registries.module.ts
create mode 100644 src/app/_modules/registries/registry/categories/category/registry-category.component.html
create mode 100644 src/app/_modules/registries/registry/categories/category/registry-category.component.scss
create mode 100644 src/app/_modules/registries/registry/categories/category/registry-category.component.ts
create mode 100644 src/app/_modules/registries/registry/categories/registry-categories.component.html
create mode 100644 src/app/_modules/registries/registry/categories/registry-categories.component.scss
create mode 100644 src/app/_modules/registries/registry/categories/registry-categories.component.ts
create mode 100644 src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.html
create mode 100644 src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.scss
create mode 100644 src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.ts
create mode 100644 src/app/_modules/registries/registry/entries/entry/registry-entry.component.html
create mode 100644 src/app/_modules/registries/registry/entries/entry/registry-entry.component.scss
create mode 100644 src/app/_modules/registries/registry/entries/entry/registry-entry.component.ts
create mode 100644 src/app/_modules/registries/registry/entries/registry-entries.component.html
create mode 100644 src/app/_modules/registries/registry/entries/registry-entries.component.scss
create mode 100644 src/app/_modules/registries/registry/entries/registry-entries.component.ts
create mode 100644 src/app/_modules/registries/registry/filters/registry-filters.component.html
create mode 100644 src/app/_modules/registries/registry/filters/registry-filters.component.scss
create mode 100644 src/app/_modules/registries/registry/filters/registry-filters.component.ts
create mode 100644 src/app/_modules/registries/registry/operations/entry-operations.component.html
create mode 100644 src/app/_modules/registries/registry/operations/entry-operations.component.scss
create mode 100644 src/app/_modules/registries/registry/operations/entry-operations.component.ts
create mode 100644 src/app/_modules/registries/registry/operations/operation/entry-operation.component.html
create mode 100644 src/app/_modules/registries/registry/operations/operation/entry-operation.component.scss
create mode 100644 src/app/_modules/registries/registry/operations/operation/entry-operation.component.ts
create mode 100644 src/app/_modules/registries/registry/registry.component.html
create mode 100644 src/app/_modules/registries/registry/registry.component.scss
create mode 100644 src/app/_modules/registries/registry/registry.component.ts
create mode 100644 src/app/_modules/search/page/search-page.component.html
create mode 100644 src/app/_modules/search/page/search-page.component.scss
create mode 100644 src/app/_modules/search/page/search-page.component.ts
create mode 100644 src/app/_modules/search/search.module.ts
create mode 100644 src/app/_modules/sorting/sorting.component.html
create mode 100644 src/app/_modules/sorting/sorting.component.scss
create mode 100644 src/app/_modules/sorting/sorting.component.ts
create mode 100644 src/app/_modules/sorting/sorting.module.ts
create mode 100644 src/app/_modules/users/profile/user-profile.component.html
create mode 100644 src/app/_modules/users/profile/user-profile.component.scss
create mode 100644 src/app/_modules/users/profile/user-profile.component.ts
create mode 100644 src/app/_modules/users/users.module.ts
create mode 100644 src/app/_services/advisories.service.ts
create mode 100644 src/app/_services/advisory-companies.service.ts
create mode 100644 src/app/_services/advisory-members.service.ts
create mode 100644 src/app/_services/applications.service.ts
create mode 100644 src/app/_services/assets.service.ts
create mode 100644 src/app/_services/authentication.service.ts
create mode 100644 src/app/_services/companies.service.ts
create mode 100644 src/app/_services/company-members.service.ts
create mode 100644 src/app/_services/departments.service.ts
create mode 100644 src/app/_services/filters.service.ts
create mode 100644 src/app/_services/form-fields.service.ts
create mode 100644 src/app/_services/forms.service.ts
create mode 100644 src/app/_services/index.ts
create mode 100644 src/app/_services/lists.service.ts
create mode 100644 src/app/_services/notification.service.ts
create mode 100644 src/app/_services/objects.service.ts
create mode 100644 src/app/_services/pages.service.ts
create mode 100644 src/app/_services/publications.service.ts
create mode 100644 src/app/_services/registries.service.ts
create mode 100644 src/app/_services/registry-categories.service.ts
create mode 100644 src/app/_services/registry-entries.service.ts
create mode 100644 src/app/_services/user.service.ts
create mode 100644 src/app/_services/utility.service.ts
create mode 100644 src/app/_services/window-scrolling.service.ts
create mode 100644 src/app/app.component.html
create mode 100644 src/app/app.component.scss
create mode 100644 src/app/app.component.ts
create mode 100644 src/app/app.module.ts
create mode 100644 src/app/config/particles.ts
create mode 100644 src/assets/.gitkeep
create mode 100644 src/assets/css/basics.scss
create mode 100644 src/assets/css/buttons.scss
create mode 100644 src/assets/css/documents-lists.scss
create mode 100644 src/assets/css/dropdown.scss
create mode 100644 src/assets/css/fonts.scss
create mode 100644 src/assets/css/forms.scss
create mode 100644 src/assets/css/list-items.scss
create mode 100644 src/assets/css/main-menu.scss
create mode 100644 src/assets/css/page-top-panel.scss
create mode 100644 src/assets/css/registry.scss
create mode 100644 src/assets/css/slider.scss
create mode 100644 src/assets/css/tables.scss
create mode 100644 src/assets/css/tabs.scss
create mode 100644 src/assets/fonts/lato/Lato-Black.ttf
create mode 100644 src/assets/fonts/lato/Lato-BlackItalic.ttf
create mode 100644 src/assets/fonts/lato/Lato-Bold.ttf
create mode 100644 src/assets/fonts/lato/Lato-BoldItalic.ttf
create mode 100644 src/assets/fonts/lato/Lato-Hairline.ttf
create mode 100644 src/assets/fonts/lato/Lato-HairlineItalic.ttf
create mode 100644 src/assets/fonts/lato/Lato-Heavy.ttf
create mode 100644 src/assets/fonts/lato/Lato-HeavyItalic.ttf
create mode 100644 src/assets/fonts/lato/Lato-Italic.ttf
create mode 100644 src/assets/fonts/lato/Lato-Light.ttf
create mode 100644 src/assets/fonts/lato/Lato-LightItalic.ttf
create mode 100644 src/assets/fonts/lato/Lato-Medium.ttf
create mode 100644 src/assets/fonts/lato/Lato-MediumItalic.ttf
create mode 100644 src/assets/fonts/lato/Lato-Regular.ttf
create mode 100644 src/assets/fonts/lato/Lato-Semibold.ttf
create mode 100644 src/assets/fonts/lato/Lato-SemiboldItalic.ttf
create mode 100644 src/assets/fonts/lato/Lato-Thin.ttf
create mode 100644 src/assets/fonts/lato/Lato-ThinItalic.ttf
create mode 100644 src/assets/fonts/ptrootui/PT-Root-UI_Bold.ttf
create mode 100644 src/assets/fonts/ptrootui/PT-Root-UI_Light.ttf
create mode 100644 src/assets/fonts/ptrootui/PT-Root-UI_Medium.ttf
create mode 100644 src/assets/fonts/ptrootui/PT-Root-UI_Regular.ttf
create mode 100644 src/assets/fonts/ptrootui/PT-Root-UI_VF.ttf
create mode 100644 src/assets/fonts/ptsans/PT_Sans-Web-Bold.ttf
create mode 100644 src/assets/fonts/ptsans/PT_Sans-Web-BoldItalic.ttf
create mode 100644 src/assets/fonts/ptsans/PT_Sans-Web-Italic.ttf
create mode 100644 src/assets/fonts/ptsans/PT_Sans-Web-Regular.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-Bold.eot
create mode 100644 src/assets/fonts/sans/OpenSans-Bold.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-Bold.woff
create mode 100644 src/assets/fonts/sans/OpenSans-Bold.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-BoldItalic.eot
create mode 100644 src/assets/fonts/sans/OpenSans-BoldItalic.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-BoldItalic.woff
create mode 100644 src/assets/fonts/sans/OpenSans-BoldItalic.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-ExtraBold.eot
create mode 100644 src/assets/fonts/sans/OpenSans-ExtraBold.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-ExtraBold.woff
create mode 100644 src/assets/fonts/sans/OpenSans-ExtraBold.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-ExtraBoldItalic.eot
create mode 100644 src/assets/fonts/sans/OpenSans-ExtraBoldItalic.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-ExtraBoldItalic.woff
create mode 100644 src/assets/fonts/sans/OpenSans-ExtraBoldItalic.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-Italic.eot
create mode 100644 src/assets/fonts/sans/OpenSans-Italic.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-Italic.woff
create mode 100644 src/assets/fonts/sans/OpenSans-Italic.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-Light.eot
create mode 100644 src/assets/fonts/sans/OpenSans-Light.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-Light.woff
create mode 100644 src/assets/fonts/sans/OpenSans-Light.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-LightItalic.eot
create mode 100644 src/assets/fonts/sans/OpenSans-LightItalic.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-LightItalic.woff
create mode 100644 src/assets/fonts/sans/OpenSans-LightItalic.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-Regular.eot
create mode 100644 src/assets/fonts/sans/OpenSans-Regular.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-Regular.woff
create mode 100644 src/assets/fonts/sans/OpenSans-Regular.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-SemiBold.eot
create mode 100644 src/assets/fonts/sans/OpenSans-SemiBold.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-SemiBold.woff
create mode 100644 src/assets/fonts/sans/OpenSans-SemiBold.woff2
create mode 100644 src/assets/fonts/sans/OpenSans-SemiBoldItalic.eot
create mode 100644 src/assets/fonts/sans/OpenSans-SemiBoldItalic.ttf
create mode 100644 src/assets/fonts/sans/OpenSans-SemiBoldItalic.woff
create mode 100644 src/assets/fonts/sans/OpenSans-SemiBoldItalic.woff2
create mode 100644 src/assets/images/_remove/news_1.jpg
create mode 100644 src/assets/images/_remove/news_2.jpg
create mode 100644 src/assets/images/_remove/p1.png
create mode 100644 src/assets/images/build.png
create mode 100644 src/assets/images/favicon.png
create mode 100644 src/assets/images/icons/add_24dp.svg
create mode 100644 src/assets/images/icons/add_folder_24.svg
create mode 100644 src/assets/images/icons/add_library_24.svg
create mode 100644 src/assets/images/icons/add_library_dark_24.svg
create mode 100644 src/assets/images/icons/add_notes_24.svg
create mode 100644 src/assets/images/icons/add_notes_dark_24.svg
create mode 100644 src/assets/images/icons/add_person_24.svg
create mode 100644 src/assets/images/icons/architecture_24.svg
create mode 100644 src/assets/images/icons/arrow_downward_24dp.svg
create mode 100644 src/assets/images/icons/arrow_drop_down_24dp.svg
create mode 100644 src/assets/images/icons/arrow_upward_24.svg
create mode 100644 src/assets/images/icons/arrow_upward_24dp.svg
create mode 100644 src/assets/images/icons/arrow_upward_dark_24.svg
create mode 100644 src/assets/images/icons/ban_20dp.svg
create mode 100644 src/assets/images/icons/burger_white_24dp.svg
create mode 100644 src/assets/images/icons/chevron_left_48.svg
create mode 100644 src/assets/images/icons/chevron_left_48dp.svg
create mode 100644 src/assets/images/icons/chevron_left_white_48dp.svg
create mode 100644 src/assets/images/icons/chevron_right_20dp.svg
create mode 100644 src/assets/images/icons/chevron_right_24dp.svg
create mode 100644 src/assets/images/icons/chevron_right_48dp.svg
create mode 100644 src/assets/images/icons/chevron_right_orange_20dp.svg
create mode 100644 src/assets/images/icons/chevron_right_white_48dp.svg
create mode 100644 src/assets/images/icons/circle_half_stroke_21dp.svg
create mode 100644 src/assets/images/icons/circle_minus_24.svg
create mode 100644 src/assets/images/icons/circle_plus_24.svg
create mode 100644 src/assets/images/icons/close_16dp.svg
create mode 100644 src/assets/images/icons/close_20dp.svg
create mode 100644 src/assets/images/icons/close_24.svg
create mode 100644 src/assets/images/icons/close_24dp.svg
create mode 100644 src/assets/images/icons/close_white_24dp.svg
create mode 100644 src/assets/images/icons/delete_24dp.svg
create mode 100644 src/assets/images/icons/dialpad_24dp.svg
create mode 100644 src/assets/images/icons/document_20.svg
create mode 100644 src/assets/images/icons/document_20dp.svg
create mode 100644 src/assets/images/icons/drag-n-drop_24.svg
create mode 100644 src/assets/images/icons/drag-n-drop_24w.svg
create mode 100644 src/assets/images/icons/edit_20.svg
create mode 100644 src/assets/images/icons/edit_24.svg
create mode 100644 src/assets/images/icons/edit_24dp.svg
create mode 100644 src/assets/images/icons/edit_dark_24.svg
create mode 100644 src/assets/images/icons/email_20.svg
create mode 100644 src/assets/images/icons/email_orange_24dp.svg
create mode 100644 src/assets/images/icons/email_white_24dp.svg
create mode 100644 src/assets/images/icons/expand_less_20.svg
create mode 100644 src/assets/images/icons/expand_less_24.svg
create mode 100644 src/assets/images/icons/expand_less_dark_24.svg
create mode 100644 src/assets/images/icons/expand_more_20.svg
create mode 100644 src/assets/images/icons/filter_empty_24.svg
create mode 100644 src/assets/images/icons/filter_filled_24.svg
create mode 100644 src/assets/images/icons/glasses_24dp.svg
create mode 100644 src/assets/images/icons/image_grey_20dp.svg
create mode 100644 src/assets/images/icons/location_orange_24dp.svg
create mode 100644 src/assets/images/icons/location_white_24dp.svg
create mode 100644 src/assets/images/icons/login.svg
create mode 100644 src/assets/images/icons/login_24dp.svg
create mode 100644 src/assets/images/icons/login_white_24dp.svg
create mode 100644 src/assets/images/icons/mail_orange_24dp.svg
create mode 100644 src/assets/images/icons/minus_grey_20dp.svg
create mode 100644 src/assets/images/icons/more_horiz_20dp.svg
create mode 100644 src/assets/images/icons/note_add_20.svg
create mode 100644 src/assets/images/icons/ok_black_24dp.svg
create mode 100644 src/assets/images/icons/ok_grey_24dp.svg
create mode 100644 src/assets/images/icons/phone_20.svg
create mode 100644 src/assets/images/icons/phone_orange_24dp.svg
create mode 100644 src/assets/images/icons/phone_white_24dp.svg
create mode 100644 src/assets/images/icons/plus_grey_20dp.svg
create mode 100644 src/assets/images/icons/registration.svg
create mode 100644 src/assets/images/icons/return_19dp.svg
create mode 100644 src/assets/images/icons/search_24.svg
create mode 100644 src/assets/images/icons/search_24dp.svg
create mode 100644 src/assets/images/icons/step_active.svg
create mode 100644 src/assets/images/icons/step_finished.svg
create mode 100644 src/assets/images/icons/step_upcoming.svg
create mode 100644 src/assets/images/icons/sun_22dp.svg
create mode 100644 src/assets/images/icons/telegram_24dp.svg
create mode 100644 src/assets/images/icons/telegram_black_24dp.svg
create mode 100644 src/assets/images/icons/telegram_grey_24dp.svg
create mode 100644 src/assets/images/icons/trash_20.svg
create mode 100644 src/assets/images/icons/trash_24dp.svg
create mode 100644 src/assets/images/icons/visibility_off_24dp.svg
create mode 100644 src/assets/images/icons/visibility_on_24dp.svg
create mode 100644 src/assets/images/icons/vk_black_24dp.svg
create mode 100644 src/assets/images/icons/vk_grey_24dp.svg
create mode 100644 src/assets/images/icons/x.svg
create mode 100644 src/assets/images/icons/youtube_24dp.svg
create mode 100644 src/assets/images/ksi.svg
create mode 100644 src/assets/images/logo_fcs_48x48.svg
create mode 100644 src/assets/images/logo_fcs_black.svg
create mode 100644 src/assets/images/logo_fcs_white.svg
create mode 100644 src/assets/images/logo_fcs_white_218x60.svg
create mode 100644 src/assets/images/logo_minstroy_black.svg
create mode 100644 src/assets/images/logo_minstroy_white.svg
create mode 100644 src/assets/images/logo_minstroy_white_179x72.svg
create mode 100644 src/assets/images/normativ.svg
create mode 100644 src/assets/images/partners/eaes_logo.png
create mode 100644 src/assets/images/partners/glavgosekspertiza_logo.png
create mode 100644 src/assets/images/partners/iso_logo.png
create mode 100644 src/assets/images/partners/minstroy_logo.png
create mode 100644 src/assets/images/partners/rosstandart_logo.png
create mode 100644 src/assets/images/portfolio-sample.png
create mode 100644 src/assets/images/portfolio_bg.png
create mode 100644 src/assets/images/tehnicheskie.svg
create mode 100644 src/assets/images/tk465.svg
create mode 100644 src/assets/images/triangle.png
create mode 100644 src/assets/images/tu.svg
create mode 100644 src/assets/lang/ru.js
create mode 100644 src/environments/environment.prod.ts
create mode 100644 src/environments/environment.ts
create mode 100644 src/index.html
create mode 100644 src/main.ts
create mode 100644 src/polyfills.ts
create mode 100644 src/styles.scss
create mode 100644 src/test.ts
create mode 100644 tsconfig.app.json
create mode 100644 tsconfig.json
create mode 100644 tsconfig.spec.json
diff --git a/.browserslistrc b/.browserslistrc
new file mode 100644
index 0000000..427441d
--- /dev/null
+++ b/.browserslistrc
@@ -0,0 +1,17 @@
+# This file is used by the build system to adjust CSS and JS output to support the specified browsers below.
+# For additional information regarding the format and rule options, please see:
+# https://github.com/browserslist/browserslist#queries
+
+# For the full list of supported browsers by the Angular framework, please see:
+# https://angular.io/guide/browser-support
+
+# You can see what browsers were selected by your queries by running:
+# npx browserslist
+
+last 1 Chrome version
+last 1 Firefox version
+last 2 Edge major versions
+last 2 Safari major versions
+last 2 iOS major versions
+Firefox ESR
+not IE 11 # Angular supports IE 11 only as an opt-in. To opt-in, remove the 'not' prefix on this line.
diff --git a/.editorconfig b/.editorconfig
new file mode 100644
index 0000000..59d9a3a
--- /dev/null
+++ b/.editorconfig
@@ -0,0 +1,16 @@
+# Editor configuration, see https://editorconfig.org
+root = true
+
+[*]
+charset = utf-8
+indent_style = space
+indent_size = 2
+insert_final_newline = true
+trim_trailing_whitespace = true
+
+[*.ts]
+quote_type = single
+
+[*.md]
+max_line_length = off
+trim_trailing_whitespace = false
diff --git a/.gitignore b/.gitignore
index b24d71e..b646978 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,50 +1,46 @@
-# These are some examples of commonly ignored file patterns.
-# You should customize this list as applicable to your project.
-# Learn more about .gitignore:
-# https://www.atlassian.com/git/tutorials/saving-changes/gitignore
+# See http://help.github.com/ignore-files/ for more about ignoring files.
-# Node artifact files
-node_modules/
-dist/
+# compiled output
+/dist
+/tmp
+/out-tsc
+# Only exists if Bazel was run
+/bazel-out
-# Compiled Java class files
-*.class
+# dependencies
+/node_modules
-# Compiled Python bytecode
-*.py[cod]
+# profiling files
+chrome-profiler-events*.json
-# Log files
-*.log
+# IDEs and editors
+/.idea
+.project
+.classpath
+.c9/
+*.launch
+.settings/
+*.sublime-workspace
-# Package files
-*.jar
+# IDE - VSCode
+.vscode/*
+!.vscode/settings.json
+!.vscode/tasks.json
+!.vscode/launch.json
+!.vscode/extensions.json
+.history/*
-# Maven
-target/
-dist/
+# misc
+/.sass-cache
+/connect.lock
+/coverage
+/libpeerconnection.log
+npm-debug.log
+yarn-error.log
+testem.log
+/typings
+/.angular
-# JetBrains IDE
-.idea/
-
-# Unit test reports
-TEST*.xml
-
-# Generated by MacOS
+# System Files
.DS_Store
-
-# Generated by Windows
Thumbs.db
-
-# Applications
-*.app
-*.exe
-*.war
-
-# Large media files
-*.mp4
-*.tiff
-*.avi
-*.flv
-*.mov
-*.wmv
-
diff --git a/.vscode/launch.json b/.vscode/launch.json
new file mode 100644
index 0000000..2ba986f
--- /dev/null
+++ b/.vscode/launch.json
@@ -0,0 +1,15 @@
+{
+ // Use IntelliSense to learn about possible attributes.
+ // Hover to view descriptions of existing attributes.
+ // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
+ "version": "0.2.0",
+ "configurations": [
+ {
+ "type": "chrome",
+ "request": "launch",
+ "name": "Launch Chrome against localhost",
+ "url": "http://localhost:8080",
+ "webRoot": "${workspaceFolder}"
+ }
+ ]
+}
\ No newline at end of file
diff --git a/README.md b/README.md
index 16eff96..b6d12eb 100644
--- a/README.md
+++ b/README.md
@@ -1,45 +1,27 @@
-**Edit a file, create a new file, and clone from Bitbucket in under 2 minutes**
+# Front
-When you're done, you can delete the content in this README and update the file with details for others getting started with your repository.
+This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 12.2.10.
-*We recommend that you open this README in another tab as you perform the tasks below. You can [watch our video](https://youtu.be/0ocf7u76WSo) for a full demo of all the steps in this tutorial. Open the video in a new tab to avoid leaving Bitbucket.*
+## Development server
----
+Run `ng serve` for a dev server. Navigate to `http://localhost:4200/`. The app will automatically reload if you change any of the source files.
-## Edit a file
+## Code scaffolding
-You’ll start by editing this README file to learn how to edit a file in Bitbucket.
+Run `ng generate component component-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module`.
-1. Click **Source** on the left side.
-2. Click the README.md link from the list of files.
-3. Click the **Edit** button.
-4. Delete the following text: *Delete this line to make a change to the README from Bitbucket.*
-5. After making your change, click **Commit** and then **Commit** again in the dialog. The commit page will open and you’ll see the change you just made.
-6. Go back to the **Source** page.
+## Build
----
+Run `ng build` to build the project. The build artifacts will be stored in the `dist/` directory.
-## Create a file
+## Running unit tests
-Next, you’ll add a new file to this repository.
+Run `ng test` to execute the unit tests via [Karma](https://karma-runner.github.io).
-1. Click the **New file** button at the top of the **Source** page.
-2. Give the file a filename of **contributors.txt**.
-3. Enter your name in the empty file space.
-4. Click **Commit** and then **Commit** again in the dialog.
-5. Go back to the **Source** page.
+## Running end-to-end tests
-Before you move on, go ahead and explore the repository. You've already seen the **Source** page, but check out the **Commits**, **Branches**, and **Settings** pages.
+Run `ng e2e` to execute the end-to-end tests via a platform of your choice. To use this command, you need to first add a package that implements end-to-end testing capabilities.
----
+## Further help
-## Clone a repository
-
-Use these steps to clone from SourceTree, our client for using the repository command-line free. Cloning allows you to work on your files locally. If you don't yet have SourceTree, [download and install first](https://www.sourcetreeapp.com/). If you prefer to clone from the command line, see [Clone a repository](https://confluence.atlassian.com/x/4whODQ).
-
-1. You’ll see the clone button under the **Source** heading. Click that button.
-2. Now click **Check out in SourceTree**. You may need to create a SourceTree account or log in.
-3. When you see the **Clone New** dialog in SourceTree, update the destination path and name if you’d like to and then click **Clone**.
-4. Open the directory you just created to see your repository’s files.
-
-Now that you're more familiar with your Bitbucket repository, go ahead and add a new file locally. You can [push your change back to Bitbucket with SourceTree](https://confluence.atlassian.com/x/iqyBMg), or you can [add, commit,](https://confluence.atlassian.com/x/8QhODQ) and [push from the command line](https://confluence.atlassian.com/x/NQ0zDQ).
\ No newline at end of file
+To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
diff --git a/angular.json b/angular.json
new file mode 100644
index 0000000..b6e6855
--- /dev/null
+++ b/angular.json
@@ -0,0 +1,136 @@
+{
+ "$schema": "./node_modules/@angular/cli/lib/config/schema.json",
+ "cli": {
+ "analytics": false
+ },
+ "version": 1,
+ "newProjectRoot": "projects",
+ "projects": {
+ "front": {
+ "projectType": "application",
+ "schematics": {
+ "@schematics/angular:component": {
+ "style": "scss"
+ },
+ "@schematics/angular:application": {
+ "strict": true
+ }
+ },
+ "root": "",
+ "sourceRoot": "src",
+ "prefix": "app",
+ "architect": {
+ "build": {
+ "builder": "@angular-devkit/build-angular:browser",
+ "options": {
+ "outputPath": "dist/front",
+ "index": "src/index.html",
+ "main": "src/main.ts",
+ "polyfills": "src/polyfills.ts",
+ "tsConfig": "tsconfig.app.json",
+ "inlineStyleLanguage": "scss",
+ "assets": [
+ {"glob": "**/*", "input": "node_modules/tinymce", "output": "/tinymce/"},
+ "src/favicon.ico",
+ "src/assets"
+ ],
+ "styles": [
+ "src/assets/css/fonts.scss",
+ "src/assets/css/basics.scss",
+ "src/assets/css/main-menu.scss",
+ "src/assets/css/registry.scss",
+ "src/assets/css/page-top-panel.scss",
+ "src/assets/css/buttons.scss",
+ "src/assets/css/dropdown.scss",
+ "src/assets/css/forms.scss",
+ "src/assets/css/tables.scss",
+ "src/assets/css/tabs.scss",
+ "src/assets/css/list-items.scss",
+ "src/assets/css/documents-lists.scss",
+ "src/assets/css/slider.scss",
+ "src/styles.scss",
+ "node_modules/swiper/swiper-bundle.css"
+ ],
+ "stylePreprocessorOptions": {
+ "includePaths": [
+ "src/styles"
+ ]
+ },
+ "scripts": [
+ "node_modules/tinymce/tinymce.min.js"
+ ]
+ },
+ "configurations": {
+ "production": {
+ "budgets": [
+ {
+ "type": "initial",
+ "maximumWarning": "1500kb",
+ "maximumError": "10mb"
+ },
+ {
+ "type": "anyComponentStyle",
+ "maximumWarning": "32kb",
+ "maximumError": "64kb"
+ }
+ ],
+ "fileReplacements": [
+ {
+ "replace": "src/environments/environment.ts",
+ "with": "src/environments/environment.prod.ts"
+ }
+ ],
+ "outputHashing": "all"
+ },
+ "development": {
+ "buildOptimizer": false,
+ "optimization": false,
+ "vendorChunk": true,
+ "extractLicenses": false,
+ "sourceMap": true,
+ "namedChunks": true
+ }
+ },
+ "defaultConfiguration": "production"
+ },
+ "serve": {
+ "builder": "@angular-devkit/build-angular:dev-server",
+ "configurations": {
+ "production": {
+ "browserTarget": "front:build:production"
+ },
+ "development": {
+ "browserTarget": "front:build:development"
+ }
+ },
+ "defaultConfiguration": "development"
+ },
+ "extract-i18n": {
+ "builder": "@angular-devkit/build-angular:extract-i18n",
+ "options": {
+ "browserTarget": "front:build"
+ }
+ },
+ "test": {
+ "builder": "@angular-devkit/build-angular:karma",
+ "options": {
+ "main": "src/test.ts",
+ "polyfills": "src/polyfills.ts",
+ "tsConfig": "tsconfig.spec.json",
+ "karmaConfig": "karma.conf.js",
+ "inlineStyleLanguage": "scss",
+ "assets": [
+ "src/favicon.ico",
+ "src/assets"
+ ],
+ "styles": [
+ "src/styles.scss"
+ ],
+ "scripts": []
+ }
+ }
+ }
+ }
+ },
+ "defaultProject": "front"
+}
diff --git a/karma.conf.js b/karma.conf.js
new file mode 100644
index 0000000..2f0b4e3
--- /dev/null
+++ b/karma.conf.js
@@ -0,0 +1,44 @@
+// Karma configuration file, see link for more information
+// https://karma-runner.github.io/1.0/config/configuration-file.html
+
+module.exports = function (config) {
+ config.set({
+ basePath: '',
+ frameworks: ['jasmine', '@angular-devkit/build-angular'],
+ plugins: [
+ require('karma-jasmine'),
+ require('karma-chrome-launcher'),
+ require('karma-jasmine-html-reporter'),
+ require('karma-coverage'),
+ require('@angular-devkit/build-angular/plugins/karma')
+ ],
+ client: {
+ jasmine: {
+ // you can add configuration options for Jasmine here
+ // the possible options are listed at https://jasmine.github.io/api/edge/Configuration.html
+ // for example, you can disable the random execution with `random: false`
+ // or set a specific seed with `seed: 4321`
+ },
+ clearContext: false // leave Jasmine Spec Runner output visible in browser
+ },
+ jasmineHtmlReporter: {
+ suppressAll: true // removes the duplicated traces
+ },
+ coverageReporter: {
+ dir: require('path').join(__dirname, './coverage/front'),
+ subdir: '.',
+ reporters: [
+ { type: 'html' },
+ { type: 'text-summary' }
+ ]
+ },
+ reporters: ['progress', 'kjhtml'],
+ port: 9876,
+ colors: true,
+ logLevel: config.LOG_INFO,
+ autoWatch: true,
+ browsers: ['Chrome'],
+ singleRun: false,
+ restartOnFileChange: true
+ });
+};
diff --git a/package-lock.json b/package-lock.json
new file mode 100644
index 0000000..c1c8ba5
--- /dev/null
+++ b/package-lock.json
@@ -0,0 +1,21605 @@
+{
+ "name": "front",
+ "version": "0.0.0",
+ "lockfileVersion": 2,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "front",
+ "version": "0.0.0",
+ "dependencies": {
+ "@angular/animations": "~15.1.0",
+ "@angular/cdk": "^15.0.0",
+ "@angular/common": "~15.1.0",
+ "@angular/compiler": "~15.1.0",
+ "@angular/core": "~15.1.0",
+ "@angular/forms": "~15.1.0",
+ "@angular/material": "^15.0.0",
+ "@angular/platform-browser": "~15.1.0",
+ "@angular/platform-browser-dynamic": "~15.1.0",
+ "@angular/router": "~15.1.0",
+ "@tinymce/tinymce-angular": "^7.0.0",
+ "echarts": "^5.4.0",
+ "ngx-echarts": "^8.0.1",
+ "ngx-sortablejs": "^11.1.0",
+ "particles.js": "^2.0.0",
+ "rxjs": "~6.6.0",
+ "sortablejs": "^1.15.0",
+ "swiper": "^8.4.7",
+ "tinymce": "^6.4.2",
+ "tslib": "^2.3.0",
+ "zone.js": "~0.11.4"
+ },
+ "devDependencies": {
+ "@angular-devkit/build-angular": "^15.1.0",
+ "@angular/cli": "^15.2.9",
+ "@angular/compiler-cli": "~15.1.0",
+ "@types/echarts": "^4.9.12",
+ "@types/jasmine": "^4.0.0",
+ "@types/node": "^12.11.1",
+ "@types/sortablejs": "^1.15.1",
+ "jasmine-core": "^4.0.0",
+ "karma": "^6.4.1",
+ "karma-chrome-launcher": "^3.1.0",
+ "karma-coverage": "^2.0.3",
+ "karma-jasmine": "^4.0.0",
+ "karma-jasmine-html-reporter": "^1.7.0",
+ "typescript": "~4.9.3"
+ }
+ },
+ "node_modules/@ampproject/remapping": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz",
+ "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.1.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@angular-devkit/architect": {
+ "version": "0.1502.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/architect/-/architect-0.1502.9.tgz",
+ "integrity": "sha512-CFn+LbtYeLG7WqO+BBSjogl764StHpwgfJnNAXQ/3UouUktZ92z4lxhUm0PwIPb5k0lILsf81ubcS1vzwoXEEg==",
+ "dev": true,
+ "dependencies": {
+ "@angular-devkit/core": "15.2.9",
+ "rxjs": "6.6.7"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0",
+ "npm": "^6.11.0 || ^7.5.6 || >=8.0.0",
+ "yarn": ">= 1.13.0"
+ }
+ },
+ "node_modules/@angular-devkit/build-angular": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/build-angular/-/build-angular-15.2.9.tgz",
+ "integrity": "sha512-djOo2Q22zLrxPccSbINz93hD+pES/nNPoze4Ys/0IdtMlLmxO/YGsA+FG5eNeNAf2jK/JRoNydaYOh7XpGoCzA==",
+ "dev": true,
+ "dependencies": {
+ "@ampproject/remapping": "2.2.0",
+ "@angular-devkit/architect": "0.1502.9",
+ "@angular-devkit/build-webpack": "0.1502.9",
+ "@angular-devkit/core": "15.2.9",
+ "@babel/core": "7.20.12",
+ "@babel/generator": "7.20.14",
+ "@babel/helper-annotate-as-pure": "7.18.6",
+ "@babel/helper-split-export-declaration": "7.18.6",
+ "@babel/plugin-proposal-async-generator-functions": "7.20.7",
+ "@babel/plugin-transform-async-to-generator": "7.20.7",
+ "@babel/plugin-transform-runtime": "7.19.6",
+ "@babel/preset-env": "7.20.2",
+ "@babel/runtime": "7.20.13",
+ "@babel/template": "7.20.7",
+ "@discoveryjs/json-ext": "0.5.7",
+ "@ngtools/webpack": "15.2.9",
+ "ansi-colors": "4.1.3",
+ "autoprefixer": "10.4.13",
+ "babel-loader": "9.1.2",
+ "babel-plugin-istanbul": "6.1.1",
+ "browserslist": "4.21.5",
+ "cacache": "17.0.4",
+ "chokidar": "3.5.3",
+ "copy-webpack-plugin": "11.0.0",
+ "critters": "0.0.16",
+ "css-loader": "6.7.3",
+ "esbuild-wasm": "0.17.8",
+ "glob": "8.1.0",
+ "https-proxy-agent": "5.0.1",
+ "inquirer": "8.2.4",
+ "jsonc-parser": "3.2.0",
+ "karma-source-map-support": "1.4.0",
+ "less": "4.1.3",
+ "less-loader": "11.1.0",
+ "license-webpack-plugin": "4.0.2",
+ "loader-utils": "3.2.1",
+ "magic-string": "0.29.0",
+ "mini-css-extract-plugin": "2.7.2",
+ "open": "8.4.1",
+ "ora": "5.4.1",
+ "parse5-html-rewriting-stream": "7.0.0",
+ "piscina": "3.2.0",
+ "postcss": "8.4.21",
+ "postcss-loader": "7.0.2",
+ "resolve-url-loader": "5.0.0",
+ "rxjs": "6.6.7",
+ "sass": "1.58.1",
+ "sass-loader": "13.2.0",
+ "semver": "7.5.3",
+ "source-map-loader": "4.0.1",
+ "source-map-support": "0.5.21",
+ "terser": "5.16.3",
+ "text-table": "0.2.0",
+ "tree-kill": "1.2.2",
+ "tslib": "2.5.0",
+ "webpack": "5.76.1",
+ "webpack-dev-middleware": "6.0.1",
+ "webpack-dev-server": "4.11.1",
+ "webpack-merge": "5.8.0",
+ "webpack-subresource-integrity": "5.1.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0",
+ "npm": "^6.11.0 || ^7.5.6 || >=8.0.0",
+ "yarn": ">= 1.13.0"
+ },
+ "optionalDependencies": {
+ "esbuild": "0.17.8"
+ },
+ "peerDependencies": {
+ "@angular/compiler-cli": "^15.0.0",
+ "@angular/localize": "^15.0.0",
+ "@angular/platform-server": "^15.0.0",
+ "@angular/service-worker": "^15.0.0",
+ "karma": "^6.3.0",
+ "ng-packagr": "^15.0.0",
+ "protractor": "^7.0.0",
+ "tailwindcss": "^2.0.0 || ^3.0.0",
+ "typescript": ">=4.8.2 <5.0"
+ },
+ "peerDependenciesMeta": {
+ "@angular/localize": {
+ "optional": true
+ },
+ "@angular/platform-server": {
+ "optional": true
+ },
+ "@angular/service-worker": {
+ "optional": true
+ },
+ "karma": {
+ "optional": true
+ },
+ "ng-packagr": {
+ "optional": true
+ },
+ "protractor": {
+ "optional": true
+ },
+ "tailwindcss": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@angular-devkit/build-angular/node_modules/magic-string": {
+ "version": "0.29.0",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.29.0.tgz",
+ "integrity": "sha512-WcfidHrDjMY+eLjlU+8OvwREqHwpgCeKVBUpQ3OhYYuvfaYCUgcbuBzappNzZvg/v8onU3oQj+BYpkOJe9Iw4Q==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.4.13"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@angular-devkit/build-webpack": {
+ "version": "0.1502.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/build-webpack/-/build-webpack-0.1502.9.tgz",
+ "integrity": "sha512-VzMXoZjrbL1XlcSegqpZCBDbVvKFGPs3cKp4bXDD5ht95jcCyJPk5FA/wrh0pGGwbOF8ae/XOWFcPRzctC35iA==",
+ "dev": true,
+ "dependencies": {
+ "@angular-devkit/architect": "0.1502.9",
+ "rxjs": "6.6.7"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0",
+ "npm": "^6.11.0 || ^7.5.6 || >=8.0.0",
+ "yarn": ">= 1.13.0"
+ },
+ "peerDependencies": {
+ "webpack": "^5.30.0",
+ "webpack-dev-server": "^4.0.0"
+ }
+ },
+ "node_modules/@angular-devkit/core": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/core/-/core-15.2.9.tgz",
+ "integrity": "sha512-6u44YJ9tEG2hiWITL1rwA9yP6ot4a3cyN/UOMRkYSa/XO2Gz5/dM3U74E2kwg+P1NcxLXffBWl0rz8/Y/lSZyQ==",
+ "dev": true,
+ "dependencies": {
+ "ajv": "8.12.0",
+ "ajv-formats": "2.1.1",
+ "jsonc-parser": "3.2.0",
+ "rxjs": "6.6.7",
+ "source-map": "0.7.4"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0",
+ "npm": "^6.11.0 || ^7.5.6 || >=8.0.0",
+ "yarn": ">= 1.13.0"
+ },
+ "peerDependencies": {
+ "chokidar": "^3.5.2"
+ },
+ "peerDependenciesMeta": {
+ "chokidar": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@angular-devkit/schematics": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/schematics/-/schematics-15.2.9.tgz",
+ "integrity": "sha512-o08nE8sTpfq/Fknrr1rzBsM8vY36BDox+8dOo9Zc/KqcVPwDy94YKRzHb+xxVaU9jy1VYeCjy63mkyELy7Z3zQ==",
+ "dev": true,
+ "dependencies": {
+ "@angular-devkit/core": "15.2.9",
+ "jsonc-parser": "3.2.0",
+ "magic-string": "0.29.0",
+ "ora": "5.4.1",
+ "rxjs": "6.6.7"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0",
+ "npm": "^6.11.0 || ^7.5.6 || >=8.0.0",
+ "yarn": ">= 1.13.0"
+ }
+ },
+ "node_modules/@angular-devkit/schematics/node_modules/magic-string": {
+ "version": "0.29.0",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.29.0.tgz",
+ "integrity": "sha512-WcfidHrDjMY+eLjlU+8OvwREqHwpgCeKVBUpQ3OhYYuvfaYCUgcbuBzappNzZvg/v8onU3oQj+BYpkOJe9Iw4Q==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.4.13"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@angular/animations": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/animations/-/animations-15.1.0.tgz",
+ "integrity": "sha512-uBw1iQVJ3QS5e/gypsD7M50O//9GvpphgGqt9ZClknyD8dxO/YryEB+Kt4GNvNQxRKhRTksD8r4KaodukdQ15w==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "@angular/core": "15.1.0"
+ }
+ },
+ "node_modules/@angular/cdk": {
+ "version": "15.0.4",
+ "resolved": "https://registry.npmjs.org/@angular/cdk/-/cdk-15.0.4.tgz",
+ "integrity": "sha512-I+OedGqv9cBsHMVGl/VfjGItAi8pK7UuYiPnxSB25+m8v3jh7dMzfVGqdqpTSGxd1Zv02ypLZvEbiI30abRykQ==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "optionalDependencies": {
+ "parse5": "^7.1.2"
+ },
+ "peerDependencies": {
+ "@angular/common": "^15.0.0 || ^16.0.0",
+ "@angular/core": "^15.0.0 || ^16.0.0",
+ "rxjs": "^6.5.3 || ^7.4.0"
+ }
+ },
+ "node_modules/@angular/cli": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-15.2.9.tgz",
+ "integrity": "sha512-mI6hkGyIJDKd8MRiBl3p5chsUhgnluwmpsq3g1FFPw+wv+eXsPYgCiHqXS/OsK+shFxii9XMxoZQO28bJ4NAOQ==",
+ "dev": true,
+ "dependencies": {
+ "@angular-devkit/architect": "0.1502.9",
+ "@angular-devkit/core": "15.2.9",
+ "@angular-devkit/schematics": "15.2.9",
+ "@schematics/angular": "15.2.9",
+ "@yarnpkg/lockfile": "1.1.0",
+ "ansi-colors": "4.1.3",
+ "ini": "3.0.1",
+ "inquirer": "8.2.4",
+ "jsonc-parser": "3.2.0",
+ "npm-package-arg": "10.1.0",
+ "npm-pick-manifest": "8.0.1",
+ "open": "8.4.1",
+ "ora": "5.4.1",
+ "pacote": "15.1.0",
+ "resolve": "1.22.1",
+ "semver": "7.5.3",
+ "symbol-observable": "4.0.0",
+ "yargs": "17.6.2"
+ },
+ "bin": {
+ "ng": "bin/ng.js"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0",
+ "npm": "^6.11.0 || ^7.5.6 || >=8.0.0",
+ "yarn": ">= 1.13.0"
+ }
+ },
+ "node_modules/@angular/common": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/common/-/common-15.1.0.tgz",
+ "integrity": "sha512-O0JKOeJ7dFcd/mnnfm4xQOYTAc+yL+OrRpGte7z84lKPU2fupLpGW/30tHUy1TXixsANyTLC3cTVXTY5szPdqg==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "@angular/core": "15.1.0",
+ "rxjs": "^6.5.3 || ^7.4.0"
+ }
+ },
+ "node_modules/@angular/compiler": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/compiler/-/compiler-15.1.0.tgz",
+ "integrity": "sha512-+ky5Cvgps725Q/KdgsYzi/fe9LbT5ujhZoT9N5k+tYTJsepMUrpExFwMFkWrdMUYTK7DaxC9ufjZ4WZmHVhFoA==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "@angular/core": "15.1.0"
+ },
+ "peerDependenciesMeta": {
+ "@angular/core": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@angular/compiler-cli": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/compiler-cli/-/compiler-cli-15.1.0.tgz",
+ "integrity": "sha512-mKeXolM/plP9ebkHy3YGxHx0Yg63d09S0QCpdIcmvrbJpaPeM2D1SAkbDpO46T4BsfgfWHtSYByb5JcesrYrpQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "7.19.3",
+ "@jridgewell/sourcemap-codec": "^1.4.14",
+ "chokidar": "^3.0.0",
+ "convert-source-map": "^1.5.1",
+ "dependency-graph": "^0.11.0",
+ "magic-string": "^0.27.0",
+ "reflect-metadata": "^0.1.2",
+ "semver": "^7.0.0",
+ "tslib": "^2.3.0",
+ "yargs": "^17.2.1"
+ },
+ "bin": {
+ "ng-xi18n": "bundles/src/bin/ng_xi18n.js",
+ "ngc": "bundles/src/bin/ngc.js",
+ "ngcc": "bundles/ngcc/main-ngcc.js"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "@angular/compiler": "15.1.0",
+ "typescript": ">=4.8.2 <5.0"
+ }
+ },
+ "node_modules/@angular/compiler-cli/node_modules/@babel/core": {
+ "version": "7.19.3",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.19.3.tgz",
+ "integrity": "sha512-WneDJxdsjEvyKtXKsaBGbDeiyOjR5vYq4HcShxnIbG0qixpoHjI3MqeZM9NDvsojNCEBItQE4juOo/bU6e72gQ==",
+ "dev": true,
+ "dependencies": {
+ "@ampproject/remapping": "^2.1.0",
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.19.3",
+ "@babel/helper-compilation-targets": "^7.19.3",
+ "@babel/helper-module-transforms": "^7.19.0",
+ "@babel/helpers": "^7.19.0",
+ "@babel/parser": "^7.19.3",
+ "@babel/template": "^7.18.10",
+ "@babel/traverse": "^7.19.3",
+ "@babel/types": "^7.19.3",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/babel"
+ }
+ },
+ "node_modules/@angular/compiler-cli/node_modules/@babel/core/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@angular/core": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/core/-/core-15.1.0.tgz",
+ "integrity": "sha512-HiwctuR73MuLoLeP35j9xF8/SIg7ELx+iHZtp/TBfoH+LOmjWbdrAdVAPTbqnxvK0aJG+527dhgC6tBOXgBTcg==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "rxjs": "^6.5.3 || ^7.4.0",
+ "zone.js": "~0.11.4 || ~0.12.0"
+ }
+ },
+ "node_modules/@angular/forms": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/forms/-/forms-15.1.0.tgz",
+ "integrity": "sha512-MUAbruJng0iG/cHhCkDNrh31Y54upgBUjjkE4DnoHv138Wa7vba+GMYv2tTrs4rPWnB9vPziZgI0xIi/oSGxzg==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "@angular/common": "15.1.0",
+ "@angular/core": "15.1.0",
+ "@angular/platform-browser": "15.1.0",
+ "rxjs": "^6.5.3 || ^7.4.0"
+ }
+ },
+ "node_modules/@angular/material": {
+ "version": "15.0.4",
+ "resolved": "https://registry.npmjs.org/@angular/material/-/material-15.0.4.tgz",
+ "integrity": "sha512-hvGQYzfttb78WZdNrYjA3dwKNtCiJ3NXLzTUbEGppDG5/9awCphDyN/5Lj3tNLsU8lus8l/UAIn6CCXCw2p3Vw==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/auto-init": "15.0.0-canary.7971d6ad5.0",
+ "@material/banner": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/card": "15.0.0-canary.7971d6ad5.0",
+ "@material/checkbox": "15.0.0-canary.7971d6ad5.0",
+ "@material/chips": "15.0.0-canary.7971d6ad5.0",
+ "@material/circular-progress": "15.0.0-canary.7971d6ad5.0",
+ "@material/data-table": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dialog": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/drawer": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/fab": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/floating-label": "15.0.0-canary.7971d6ad5.0",
+ "@material/form-field": "15.0.0-canary.7971d6ad5.0",
+ "@material/icon-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/image-list": "15.0.0-canary.7971d6ad5.0",
+ "@material/layout-grid": "15.0.0-canary.7971d6ad5.0",
+ "@material/line-ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/linear-progress": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu-surface": "15.0.0-canary.7971d6ad5.0",
+ "@material/notched-outline": "15.0.0-canary.7971d6ad5.0",
+ "@material/radio": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/segmented-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/select": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/slider": "15.0.0-canary.7971d6ad5.0",
+ "@material/snackbar": "15.0.0-canary.7971d6ad5.0",
+ "@material/switch": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-bar": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-scroller": "15.0.0-canary.7971d6ad5.0",
+ "@material/textfield": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tooltip": "15.0.0-canary.7971d6ad5.0",
+ "@material/top-app-bar": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.3.0"
+ },
+ "peerDependencies": {
+ "@angular/animations": "^15.0.0 || ^16.0.0",
+ "@angular/cdk": "15.0.4",
+ "@angular/common": "^15.0.0 || ^16.0.0",
+ "@angular/core": "^15.0.0 || ^16.0.0",
+ "@angular/forms": "^15.0.0 || ^16.0.0",
+ "@angular/platform-browser": "^15.0.0 || ^16.0.0",
+ "rxjs": "^6.5.3 || ^7.4.0"
+ }
+ },
+ "node_modules/@angular/platform-browser": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/platform-browser/-/platform-browser-15.1.0.tgz",
+ "integrity": "sha512-yuJweAR+rJhWWHM4Im3Iy6S4+W3OtcVHijcqrxfVxiA9ZHbDw/jpYDi06ZZIgfnNyGWi5/BzJbHvxH3b0lAo5Q==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "@angular/animations": "15.1.0",
+ "@angular/common": "15.1.0",
+ "@angular/core": "15.1.0"
+ },
+ "peerDependenciesMeta": {
+ "@angular/animations": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@angular/platform-browser-dynamic": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/platform-browser-dynamic/-/platform-browser-dynamic-15.1.0.tgz",
+ "integrity": "sha512-ukyycXkuu4Ah/35cbN4pEB91D2PK5eZVbJ+liCD6uRb4UI3X+QVg6Qz6MoIctVAlTV6tWK20T81zoux9SzWKsg==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "@angular/common": "15.1.0",
+ "@angular/compiler": "15.1.0",
+ "@angular/core": "15.1.0",
+ "@angular/platform-browser": "15.1.0"
+ }
+ },
+ "node_modules/@angular/router": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/router/-/router-15.1.0.tgz",
+ "integrity": "sha512-78ItVVXOYdu/RRxruHwSmtNxEP2clx+afHKrkwc4e7/6uxVr4rl0VQhO6qHYme/bBtbLIcBZGJoSyoUg/xUSvQ==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0"
+ },
+ "peerDependencies": {
+ "@angular/common": "15.1.0",
+ "@angular/core": "15.1.0",
+ "@angular/platform-browser": "15.1.0",
+ "rxjs": "^6.5.3 || ^7.4.0"
+ }
+ },
+ "node_modules/@assemblyscript/loader": {
+ "version": "0.10.1",
+ "resolved": "https://registry.npmjs.org/@assemblyscript/loader/-/loader-0.10.1.tgz",
+ "integrity": "sha512-H71nDOOL8Y7kWRLqf6Sums+01Q5msqBW2KhDUTemh1tvY04eSkSXrK0uj/4mmY0Xr16/3zyZmsrxN7CKuRbNRg==",
+ "dev": true
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz",
+ "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/highlight": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/compat-data": {
+ "version": "7.20.10",
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.20.10.tgz",
+ "integrity": "sha512-sEnuDPpOJR/fcafHMjpcpGN5M2jbUGUHwmuWKM/YdPzeEDJg8bgmbcWQFUfE32MQjti1koACvoPVsDe8Uq+idg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/core": {
+ "version": "7.20.12",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.20.12.tgz",
+ "integrity": "sha512-XsMfHovsUYHFMdrIHkZphTN/2Hzzi78R08NuHfDBehym2VsPDL6Zn/JAD/JQdnRvbSsbQc4mVaU1m6JgtTEElg==",
+ "dev": true,
+ "dependencies": {
+ "@ampproject/remapping": "^2.1.0",
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.20.7",
+ "@babel/helper-compilation-targets": "^7.20.7",
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helpers": "^7.20.7",
+ "@babel/parser": "^7.20.7",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.12",
+ "@babel/types": "^7.20.7",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.2",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/babel"
+ }
+ },
+ "node_modules/@babel/core/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/generator": {
+ "version": "7.20.14",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.20.14.tgz",
+ "integrity": "sha512-AEmuXHdcD3A52HHXxaTmYlb8q/xMEhoRP67B3T4Oq7lbmSoqroMZzjnGj3+i1io3pdnF8iBYVu4Ilj+c4hBxYg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.20.7",
+ "@jridgewell/gen-mapping": "^0.3.2",
+ "jsesc": "^2.5.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/generator/node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz",
+ "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/helper-annotate-as-pure": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz",
+ "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz",
+ "integrity": "sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-explode-assignable-expression": "^7.18.6",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.7.tgz",
+ "integrity": "sha512-4tGORmfQcrc+bvrjb5y3dG9Mx1IOZjsHqQVUz7XCNHO+iTmqxWnVg3KRygjGmpRLJGdQSKuvFinbIb0CnZwHAQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.20.5",
+ "@babel/helper-validator-option": "^7.18.6",
+ "browserslist": "^4.21.3",
+ "lru-cache": "^5.1.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/helper-create-class-features-plugin": {
+ "version": "7.20.12",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.20.12.tgz",
+ "integrity": "sha512-9OunRkbT0JQcednL0UFvbfXpAsUXiGjUk0a7sN8fUXX7Mue79cUSMjHGDRRi/Vz9vYlpIhLV5fMD5dKoMhhsNQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/helper-member-expression-to-functions": "^7.20.7",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.20.7",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0",
+ "@babel/helper-split-export-declaration": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-create-regexp-features-plugin": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.20.5.tgz",
+ "integrity": "sha512-m68B1lkg3XDGX5yCvGO0kPx3v9WIYLnzjKfPcQiwntEQa5ZeRkPmo2X/ISJc8qxWGfwUr+kvZAeEzAwLec2r2w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "regexpu-core": "^5.2.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-define-polyfill-provider": {
+ "version": "0.3.3",
+ "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.3.tgz",
+ "integrity": "sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-compilation-targets": "^7.17.7",
+ "@babel/helper-plugin-utils": "^7.16.7",
+ "debug": "^4.1.1",
+ "lodash.debounce": "^4.0.8",
+ "resolve": "^1.14.2",
+ "semver": "^6.1.2"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.4.0-0"
+ }
+ },
+ "node_modules/@babel/helper-define-polyfill-provider/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/helper-environment-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz",
+ "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-explode-assignable-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz",
+ "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-function-name": {
+ "version": "7.19.0",
+ "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz",
+ "integrity": "sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/template": "^7.18.10",
+ "@babel/types": "^7.19.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-hoist-variables": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz",
+ "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-member-expression-to-functions": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.20.7.tgz",
+ "integrity": "sha512-9J0CxJLq315fEdi4s7xK5TQaNYjZw+nDVpVqr1axNGKzdrdwYBD5b4uKv3n75aABG0rCCTK8Im8Ww7eYfMrZgw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz",
+ "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-transforms": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.20.11.tgz",
+ "integrity": "sha512-uRy78kN4psmji1s2QtbtcCSaj/LILFDp0f/ymhpQH5QY3nljUZCaNWz9X1dEj/8MBdBEFECs7yRhKn8i7NjZgg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-simple-access": "^7.20.2",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/helper-validator-identifier": "^7.19.1",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.10",
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-optimise-call-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz",
+ "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-plugin-utils": {
+ "version": "7.20.2",
+ "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.20.2.tgz",
+ "integrity": "sha512-8RvlJG2mj4huQ4pZ+rU9lqKi9ZKiRmuvGuM2HlWmkmgOhbs6zEAw6IEiJ5cQqGbDzGZOhwuOQNtZMi/ENLjZoQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-remap-async-to-generator": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz",
+ "integrity": "sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-wrap-function": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-replace-supers": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.20.7.tgz",
+ "integrity": "sha512-vujDMtB6LVfNW13jhlCrp48QNslK6JXi7lQG736HVbHz/mbf4Dc7tIRh1Xf5C0rF7BP8iiSxGMCmY6Ci1ven3A==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-member-expression-to-functions": "^7.20.7",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.7",
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-simple-access": {
+ "version": "7.20.2",
+ "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz",
+ "integrity": "sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-skip-transparent-expression-wrappers": {
+ "version": "7.20.0",
+ "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz",
+ "integrity": "sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.20.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-split-export-declaration": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz",
+ "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/types": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.19.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.19.4.tgz",
+ "integrity": "sha512-nHtDoQcuqFmwYNYPz3Rah5ph2p8PFeFCsZk9A/48dPc/rGocJ5J3hAAZ7pb76VWX3fZKu+uEr/FhH5jLx7umrw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.19.1",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz",
+ "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-option": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz",
+ "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-wrap-function": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.20.5.tgz",
+ "integrity": "sha512-bYMxIWK5mh+TgXGVqAtnu5Yn1un+v8DDZtqyzKRLUzrh70Eal2O3aZ7aPYiMADO4uKlkzOiRiZ6GX5q3qxvW9Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/template": "^7.18.10",
+ "@babel/traverse": "^7.20.5",
+ "@babel/types": "^7.20.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helpers": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.20.7.tgz",
+ "integrity": "sha512-PBPjs5BppzsGaxHQCDKnZ6Gd9s6xl8bBCluz3vEInLGRJmnZan4F6BYCeqtyXqkk4W5IlPmjK4JlOuZkpJ3xZA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.7",
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/highlight": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz",
+ "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "chalk": "^2.0.0",
+ "js-tokens": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.20.7.tgz",
+ "integrity": "sha512-T3Z9oHybU+0vZlY9CiDSJQTD5ZapcW18ZctFMi0MOAl/4BjFF4ul7NVSARLdbGO5vDqy9eQiGTV0LtKfvCYvcg==",
+ "dev": true,
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz",
+ "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.20.7.tgz",
+ "integrity": "sha512-sbr9+wNE5aXMBBFBICk01tt7sBf2Oc9ikRFEcem/ZORup9IMUdNhW7/wVLEbbtlWOsEubJet46mHAL2C8+2jKQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0",
+ "@babel/plugin-proposal-optional-chaining": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.13.0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-async-generator-functions": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.20.7.tgz",
+ "integrity": "sha512-xMbiLsn/8RK7Wq7VeVytytS2L6qE69bXPB10YCmMdDZbKF4okCqY74pI/jJQ/8U0b/F6NrT2+14b8/P9/3AMGA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-remap-async-to-generator": "^7.18.9",
+ "@babel/plugin-syntax-async-generators": "^7.8.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-class-properties": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz",
+ "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-class-static-block": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.20.7.tgz",
+ "integrity": "sha512-AveGOoi9DAjUYYuUAG//Ig69GlazLnoyzMw68VCDux+c1tsnnH/OkYcpz/5xzMkEFC6UxjR5Gw1c+iY2wOGVeQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.20.7",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.12.0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-dynamic-import": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz",
+ "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-export-namespace-from": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz",
+ "integrity": "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-json-strings": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz",
+ "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-json-strings": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-logical-assignment-operators": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.20.7.tgz",
+ "integrity": "sha512-y7C7cZgpMIjWlKE5T7eJwp+tnRYM89HmRvWM5EQuB5BoHEONjmQ8lSNmBUwOyy/GFRsohJED51YBF79hE1djug==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-nullish-coalescing-operator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz",
+ "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-numeric-separator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz",
+ "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-object-rest-spread": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.20.7.tgz",
+ "integrity": "sha512-d2S98yCiLxDVmBmE8UjGcfPvNEUbA1U5q5WxaWFUGRzJSVAZqm5W6MbPct0jxnegUZ0niLeNX+IOzEs7wYg9Dg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.20.5",
+ "@babel/helper-compilation-targets": "^7.20.7",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-transform-parameters": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-optional-catch-binding": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz",
+ "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-optional-chaining": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.20.7.tgz",
+ "integrity": "sha512-T+A7b1kfjtRM51ssoOfS1+wbyCVqorfyZhT99TvxxLMirPShD8CzKMRepMlCBGM5RpHMbn8s+5MMHnPstJH6mQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-private-methods": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz",
+ "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-private-property-in-object": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.20.5.tgz",
+ "integrity": "sha512-Vq7b9dUA12ByzB4EjQTPo25sFhY+08pQDBSZRtUAkj7lb7jahaHR5igera16QZ+3my1nYR4dKsNdYj5IjPHilQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-create-class-features-plugin": "^7.20.5",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-proposal-unicode-property-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz",
+ "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-async-generators": {
+ "version": "7.8.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz",
+ "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-class-properties": {
+ "version": "7.12.13",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz",
+ "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.12.13"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-class-static-block": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz",
+ "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-dynamic-import": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz",
+ "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-export-namespace-from": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz",
+ "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.3"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-import-assertions": {
+ "version": "7.20.0",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz",
+ "integrity": "sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.19.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-json-strings": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz",
+ "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-logical-assignment-operators": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz",
+ "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz",
+ "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-numeric-separator": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz",
+ "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-object-rest-spread": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz",
+ "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-optional-catch-binding": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz",
+ "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-optional-chaining": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz",
+ "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-private-property-in-object": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz",
+ "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-syntax-top-level-await": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz",
+ "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-arrow-functions": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.20.7.tgz",
+ "integrity": "sha512-3poA5E7dzDomxj9WXWwuD6A5F3kc7VXwIJO+E+J8qtDtS+pXPAhrgEyh+9GBwBgPq1Z+bB+/JD60lp5jsN7JPQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-async-to-generator": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.20.7.tgz",
+ "integrity": "sha512-Uo5gwHPT9vgnSXQxqGtpdufUiWp96gk7yiP4Mp5bm1QMkEmLXBO7PAGYbKoJ6DhAwiNkcHFBol/x5zZZkL/t0Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-remap-async-to-generator": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-block-scoped-functions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz",
+ "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-block-scoping": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.20.11.tgz",
+ "integrity": "sha512-tA4N427a7fjf1P0/2I4ScsHGc5jcHPbb30xMbaTke2gxDuWpUfXDuX1FEymJwKk4tuGUvGcejAR6HdZVqmmPyw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-classes": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.20.7.tgz",
+ "integrity": "sha512-LWYbsiXTPKl+oBlXUGlwNlJZetXD5Am+CyBdqhPsDVjM9Jc8jwBJFrKhHf900Kfk2eZG1y9MAG3UNajol7A4VQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-compilation-targets": "^7.20.7",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-replace-supers": "^7.20.7",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-computed-properties": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.20.7.tgz",
+ "integrity": "sha512-Lz7MvBK6DTjElHAmfu6bfANzKcxpyNPeYBGEafyA6E5HtRpjpZwU+u7Qrgz/2OR0z+5TvKYbPdphfSaAcZBrYQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/template": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-destructuring": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.20.7.tgz",
+ "integrity": "sha512-Xwg403sRrZb81IVB79ZPqNQME23yhugYVqgTxAhT99h485F4f+GMELFhhOsscDUB7HCswepKeCKLn/GZvUKoBA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-dotall-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz",
+ "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-duplicate-keys": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz",
+ "integrity": "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-exponentiation-operator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz",
+ "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-for-of": {
+ "version": "7.18.8",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz",
+ "integrity": "sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-function-name": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz",
+ "integrity": "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-literals": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz",
+ "integrity": "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-member-expression-literals": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz",
+ "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-amd": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.20.11.tgz",
+ "integrity": "sha512-NuzCt5IIYOW0O30UvqktzHYR2ud5bOWbY0yaxWZ6G+aFzOMJvrs5YHNikrbdaT15+KNO31nPOy5Fim3ku6Zb5g==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helper-plugin-utils": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-commonjs": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.20.11.tgz",
+ "integrity": "sha512-S8e1f7WQ7cimJQ51JkAaDrEtohVEitXjgCGAS2N8S31Y42E+kWwfSz83LYz57QdBm7q9diARVqanIaH2oVgQnw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-simple-access": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-systemjs": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.20.11.tgz",
+ "integrity": "sha512-vVu5g9BPQKSFEmvt2TA4Da5N+QVS66EX21d8uoOihC+OCpUoGvzVsXeqFdtAEfVa5BILAeFt+U7yVmLbQnAJmw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-validator-identifier": "^7.19.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-modules-umd": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz",
+ "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-transforms": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-named-capturing-groups-regex": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.20.5.tgz",
+ "integrity": "sha512-mOW4tTzi5iTLnw+78iEq3gr8Aoq4WNRGpmSlrogqaiCBoR1HFhpU4JkpQFOHfeYx3ReVIFWOQJS4aZBRvuZ6mA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.20.5",
+ "@babel/helper-plugin-utils": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-new-target": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz",
+ "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-object-super": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz",
+ "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-parameters": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.20.7.tgz",
+ "integrity": "sha512-WiWBIkeHKVOSYPO0pWkxGPfKeWrCJyD3NJ53+Lrp/QMSZbsVPovrVl2aWZ19D/LTVnaDv5Ap7GJ/B2CTOZdrfA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-property-literals": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz",
+ "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-regenerator": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.20.5.tgz",
+ "integrity": "sha512-kW/oO7HPBtntbsahzQ0qSE3tFvkFwnbozz3NWFhLGqH75vLEg+sCGngLlhVkePlCs3Jv0dBBHDzCHxNiFAQKCQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "regenerator-transform": "^0.15.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-reserved-words": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz",
+ "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-runtime": {
+ "version": "7.19.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.19.6.tgz",
+ "integrity": "sha512-PRH37lz4JU156lYFW1p8OxE5i7d6Sl/zV58ooyr+q1J1lnQPyg5tIiXlIwNVhJaY4W3TmOtdc8jqdXQcB1v5Yw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.19.0",
+ "babel-plugin-polyfill-corejs2": "^0.3.3",
+ "babel-plugin-polyfill-corejs3": "^0.6.0",
+ "babel-plugin-polyfill-regenerator": "^0.4.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-runtime/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/plugin-transform-shorthand-properties": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz",
+ "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-spread": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.20.7.tgz",
+ "integrity": "sha512-ewBbHQ+1U/VnH1fxltbJqDeWBU1oNLG8Dj11uIv3xVf7nrQu0bPGe5Rf716r7K5Qz+SqtAOVswoVunoiBtGhxw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-sticky-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz",
+ "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-template-literals": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz",
+ "integrity": "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-typeof-symbol": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz",
+ "integrity": "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-unicode-escapes": {
+ "version": "7.18.10",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.10.tgz",
+ "integrity": "sha512-kKAdAI+YzPgGY/ftStBFXTI1LZFju38rYThnfMykS+IXy8BVx+res7s2fxf1l8I35DV2T97ezo6+SGrXz6B3iQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/plugin-transform-unicode-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz",
+ "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/preset-env": {
+ "version": "7.20.2",
+ "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.20.2.tgz",
+ "integrity": "sha512-1G0efQEWR1EHkKvKHqbG+IN/QdgwfByUpM5V5QroDzGV2t3S/WXNQd693cHiHTlCFMpr9B6FkPFXDA2lQcKoDg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.20.1",
+ "@babel/helper-compilation-targets": "^7.20.0",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-validator-option": "^7.18.6",
+ "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6",
+ "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.9",
+ "@babel/plugin-proposal-async-generator-functions": "^7.20.1",
+ "@babel/plugin-proposal-class-properties": "^7.18.6",
+ "@babel/plugin-proposal-class-static-block": "^7.18.6",
+ "@babel/plugin-proposal-dynamic-import": "^7.18.6",
+ "@babel/plugin-proposal-export-namespace-from": "^7.18.9",
+ "@babel/plugin-proposal-json-strings": "^7.18.6",
+ "@babel/plugin-proposal-logical-assignment-operators": "^7.18.9",
+ "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
+ "@babel/plugin-proposal-numeric-separator": "^7.18.6",
+ "@babel/plugin-proposal-object-rest-spread": "^7.20.2",
+ "@babel/plugin-proposal-optional-catch-binding": "^7.18.6",
+ "@babel/plugin-proposal-optional-chaining": "^7.18.9",
+ "@babel/plugin-proposal-private-methods": "^7.18.6",
+ "@babel/plugin-proposal-private-property-in-object": "^7.18.6",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.18.6",
+ "@babel/plugin-syntax-async-generators": "^7.8.4",
+ "@babel/plugin-syntax-class-properties": "^7.12.13",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3",
+ "@babel/plugin-syntax-import-assertions": "^7.20.0",
+ "@babel/plugin-syntax-json-strings": "^7.8.3",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5",
+ "@babel/plugin-syntax-top-level-await": "^7.14.5",
+ "@babel/plugin-transform-arrow-functions": "^7.18.6",
+ "@babel/plugin-transform-async-to-generator": "^7.18.6",
+ "@babel/plugin-transform-block-scoped-functions": "^7.18.6",
+ "@babel/plugin-transform-block-scoping": "^7.20.2",
+ "@babel/plugin-transform-classes": "^7.20.2",
+ "@babel/plugin-transform-computed-properties": "^7.18.9",
+ "@babel/plugin-transform-destructuring": "^7.20.2",
+ "@babel/plugin-transform-dotall-regex": "^7.18.6",
+ "@babel/plugin-transform-duplicate-keys": "^7.18.9",
+ "@babel/plugin-transform-exponentiation-operator": "^7.18.6",
+ "@babel/plugin-transform-for-of": "^7.18.8",
+ "@babel/plugin-transform-function-name": "^7.18.9",
+ "@babel/plugin-transform-literals": "^7.18.9",
+ "@babel/plugin-transform-member-expression-literals": "^7.18.6",
+ "@babel/plugin-transform-modules-amd": "^7.19.6",
+ "@babel/plugin-transform-modules-commonjs": "^7.19.6",
+ "@babel/plugin-transform-modules-systemjs": "^7.19.6",
+ "@babel/plugin-transform-modules-umd": "^7.18.6",
+ "@babel/plugin-transform-named-capturing-groups-regex": "^7.19.1",
+ "@babel/plugin-transform-new-target": "^7.18.6",
+ "@babel/plugin-transform-object-super": "^7.18.6",
+ "@babel/plugin-transform-parameters": "^7.20.1",
+ "@babel/plugin-transform-property-literals": "^7.18.6",
+ "@babel/plugin-transform-regenerator": "^7.18.6",
+ "@babel/plugin-transform-reserved-words": "^7.18.6",
+ "@babel/plugin-transform-shorthand-properties": "^7.18.6",
+ "@babel/plugin-transform-spread": "^7.19.0",
+ "@babel/plugin-transform-sticky-regex": "^7.18.6",
+ "@babel/plugin-transform-template-literals": "^7.18.9",
+ "@babel/plugin-transform-typeof-symbol": "^7.18.9",
+ "@babel/plugin-transform-unicode-escapes": "^7.18.10",
+ "@babel/plugin-transform-unicode-regex": "^7.18.6",
+ "@babel/preset-modules": "^0.1.5",
+ "@babel/types": "^7.20.2",
+ "babel-plugin-polyfill-corejs2": "^0.3.3",
+ "babel-plugin-polyfill-corejs3": "^0.6.0",
+ "babel-plugin-polyfill-regenerator": "^0.4.1",
+ "core-js-compat": "^3.25.1",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/preset-env/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/@babel/preset-modules": {
+ "version": "0.1.5",
+ "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz",
+ "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.4.4",
+ "@babel/plugin-transform-dotall-regex": "^7.4.4",
+ "@babel/types": "^7.4.4",
+ "esutils": "^2.0.2"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@babel/runtime": {
+ "version": "7.20.13",
+ "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.20.13.tgz",
+ "integrity": "sha512-gt3PKXs0DBoL9xCvOIIZ2NEqAGZqHjAnmVbfQtB620V0uReIQutpel14KcneZuer7UioY8ALKZ7iocavvzTNFA==",
+ "dev": true,
+ "dependencies": {
+ "regenerator-runtime": "^0.13.11"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.20.7.tgz",
+ "integrity": "sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/parser": "^7.20.7",
+ "@babel/types": "^7.20.7"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.20.12",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.20.12.tgz",
+ "integrity": "sha512-MsIbFN0u+raeja38qboyF8TIT7K0BFzz/Yd/77ta4MsUsmP2RAnidIlwq7d5HFQrH/OZJecGV6B71C4zAgpoSQ==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.20.7",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/parser": "^7.20.7",
+ "@babel/types": "^7.20.7",
+ "debug": "^4.1.0",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.20.7.tgz",
+ "integrity": "sha512-69OnhBxSSgK0OzTJai4kyPDiKTIe3j+ctaHdIGVbRahTLAT7L3R9oeXHC2aVSuGYt3cVnoAMDmOCgJ2yaiLMvg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.19.4",
+ "@babel/helper-validator-identifier": "^7.19.1",
+ "to-fast-properties": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@colors/colors": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/@colors/colors/-/colors-1.5.0.tgz",
+ "integrity": "sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.1.90"
+ }
+ },
+ "node_modules/@discoveryjs/json-ext": {
+ "version": "0.5.7",
+ "resolved": "https://registry.npmjs.org/@discoveryjs/json-ext/-/json-ext-0.5.7.tgz",
+ "integrity": "sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/@esbuild/android-arm": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.8.tgz",
+ "integrity": "sha512-0/rb91GYKhrtbeglJXOhAv9RuYimgI8h623TplY2X+vA4EXnk3Zj1fXZreJ0J3OJJu1bwmb0W7g+2cT/d8/l/w==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.8.tgz",
+ "integrity": "sha512-oa/N5j6v1svZQs7EIRPqR8f+Bf8g6HBDjD/xHC02radE/NjKHK7oQmtmLxPs1iVwYyvE+Kolo6lbpfEQ9xnhxQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/android-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.8.tgz",
+ "integrity": "sha512-bTliMLqD7pTOoPg4zZkXqCDuzIUguEWLpeqkNfC41ODBHwoUgZ2w5JBeYimv4oP6TDVocoYmEhZrCLQTrH89bg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.8.tgz",
+ "integrity": "sha512-ghAbV3ia2zybEefXRRm7+lx8J/rnupZT0gp9CaGy/3iolEXkJ6LYRq4IpQVI9zR97ID80KJVoUlo3LSeA/sMAg==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/darwin-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.8.tgz",
+ "integrity": "sha512-n5WOpyvZ9TIdv2V1K3/iIkkJeKmUpKaCTdun9buhGRWfH//osmUjlv4Z5mmWdPWind/VGcVxTHtLfLCOohsOXw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.8.tgz",
+ "integrity": "sha512-a/SATTaOhPIPFWvHZDoZYgxaZRVHn0/LX1fHLGfZ6C13JqFUZ3K6SMD6/HCtwOQ8HnsNaEeokdiDSFLuizqv5A==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/freebsd-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.8.tgz",
+ "integrity": "sha512-xpFJb08dfXr5+rZc4E+ooZmayBW6R3q59daCpKZ/cDU96/kvDM+vkYzNeTJCGd8rtO6fHWMq5Rcv/1cY6p6/0Q==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.8.tgz",
+ "integrity": "sha512-6Ij8gfuGszcEwZpi5jQIJCVIACLS8Tz2chnEBfYjlmMzVsfqBP1iGmHQPp7JSnZg5xxK9tjCc+pJ2WtAmPRFVA==",
+ "cpu": [
+ "arm"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.8.tgz",
+ "integrity": "sha512-v3iwDQuDljLTxpsqQDl3fl/yihjPAyOguxuloON9kFHYwopeJEf1BkDXODzYyXEI19gisEsQlG1bM65YqKSIww==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ia32": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.8.tgz",
+ "integrity": "sha512-8svILYKhE5XetuFk/B6raFYIyIqydQi+GngEXJgdPdI7OMKUbSd7uzR02wSY4kb53xBrClLkhH4Xs8P61Q2BaA==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-loong64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.8.tgz",
+ "integrity": "sha512-B6FyMeRJeV0NpyEOYlm5qtQfxbdlgmiGdD+QsipzKfFky0K5HW5Td6dyK3L3ypu1eY4kOmo7wW0o94SBqlqBSA==",
+ "cpu": [
+ "loong64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-mips64el": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.8.tgz",
+ "integrity": "sha512-CCb67RKahNobjm/eeEqeD/oJfJlrWyw29fgiyB6vcgyq97YAf3gCOuP6qMShYSPXgnlZe/i4a8WFHBw6N8bYAA==",
+ "cpu": [
+ "mips64el"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-ppc64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.8.tgz",
+ "integrity": "sha512-bytLJOi55y55+mGSdgwZ5qBm0K9WOCh0rx+vavVPx+gqLLhxtSFU0XbeYy/dsAAD6xECGEv4IQeFILaSS2auXw==",
+ "cpu": [
+ "ppc64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-riscv64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.8.tgz",
+ "integrity": "sha512-2YpRyQJmKVBEHSBLa8kBAtbhucaclb6ex4wchfY0Tj3Kg39kpjeJ9vhRU7x4mUpq8ISLXRXH1L0dBYjAeqzZAw==",
+ "cpu": [
+ "riscv64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-s390x": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.8.tgz",
+ "integrity": "sha512-QgbNY/V3IFXvNf11SS6exkpVcX0LJcob+0RWCgV9OiDAmVElnxciHIisoSix9uzYzScPmS6dJFbZULdSAEkQVw==",
+ "cpu": [
+ "s390x"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/linux-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.8.tgz",
+ "integrity": "sha512-mM/9S0SbAFDBc4OPoyP6SEOo5324LpUxdpeIUUSrSTOfhHU9hEfqRngmKgqILqwx/0DVJBzeNW7HmLEWp9vcOA==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/netbsd-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.8.tgz",
+ "integrity": "sha512-eKUYcWaWTaYr9zbj8GertdVtlt1DTS1gNBWov+iQfWuWyuu59YN6gSEJvFzC5ESJ4kMcKR0uqWThKUn5o8We6Q==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "netbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/openbsd-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.8.tgz",
+ "integrity": "sha512-Vc9J4dXOboDyMXKD0eCeW0SIeEzr8K9oTHJU+Ci1mZc5njPfhKAqkRt3B/fUNU7dP+mRyralPu8QUkiaQn7iIg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "openbsd"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/sunos-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.8.tgz",
+ "integrity": "sha512-0xvOTNuPXI7ft1LYUgiaXtpCEjp90RuBBYovdd2lqAFxje4sEucurg30M1WIm03+3jxByd3mfo+VUmPtRSVuOw==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "sunos"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.8.tgz",
+ "integrity": "sha512-G0JQwUI5WdEFEnYNKzklxtBheCPkuDdu1YrtRrjuQv30WsYbkkoixKxLLv8qhJmNI+ATEWquZe/N0d0rpr55Mg==",
+ "cpu": [
+ "arm64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-ia32": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.8.tgz",
+ "integrity": "sha512-Fqy63515xl20OHGFykjJsMnoIWS+38fqfg88ClvPXyDbLtgXal2DTlhb1TfTX34qWi3u4I7Cq563QcHpqgLx8w==",
+ "cpu": [
+ "ia32"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@esbuild/win32-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.8.tgz",
+ "integrity": "sha512-1iuezdyDNngPnz8rLRDO2C/ZZ/emJLb72OsZeqQ6gL6Avko/XCXZw+NuxBSNhBAP13Hie418V7VMt9et1FMvpg==",
+ "cpu": [
+ "x64"
+ ],
+ "dev": true,
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@isaacs/cliui": {
+ "version": "8.0.2",
+ "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz",
+ "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==",
+ "dev": true,
+ "dependencies": {
+ "string-width": "^5.1.2",
+ "string-width-cjs": "npm:string-width@^4.2.0",
+ "strip-ansi": "^7.0.1",
+ "strip-ansi-cjs": "npm:strip-ansi@^6.0.1",
+ "wrap-ansi": "^8.1.0",
+ "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@isaacs/cliui/node_modules/ansi-regex": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz",
+ "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-regex?sponsor=1"
+ }
+ },
+ "node_modules/@isaacs/cliui/node_modules/ansi-styles": {
+ "version": "6.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
+ "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/@isaacs/cliui/node_modules/emoji-regex": {
+ "version": "9.2.2",
+ "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz",
+ "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==",
+ "dev": true
+ },
+ "node_modules/@isaacs/cliui/node_modules/string-width": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz",
+ "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==",
+ "dev": true,
+ "dependencies": {
+ "eastasianwidth": "^0.2.0",
+ "emoji-regex": "^9.2.2",
+ "strip-ansi": "^7.0.1"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@isaacs/cliui/node_modules/strip-ansi": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
+ "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
+ "dev": true,
+ "dependencies": {
+ "ansi-regex": "^6.0.1"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/strip-ansi?sponsor=1"
+ }
+ },
+ "node_modules/@isaacs/cliui/node_modules/wrap-ansi": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz",
+ "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^6.1.0",
+ "string-width": "^5.0.1",
+ "strip-ansi": "^7.0.1"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
+ }
+ },
+ "node_modules/@istanbuljs/load-nyc-config": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz",
+ "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==",
+ "dev": true,
+ "dependencies": {
+ "camelcase": "^5.3.1",
+ "find-up": "^4.1.0",
+ "get-package-type": "^0.1.0",
+ "js-yaml": "^3.13.1",
+ "resolve-from": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@istanbuljs/schema": {
+ "version": "0.1.3",
+ "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz",
+ "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/@jridgewell/gen-mapping": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz",
+ "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.0",
+ "@jridgewell/sourcemap-codec": "^1.4.10"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/resolve-uri": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz",
+ "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/set-array": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz",
+ "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/source-map": {
+ "version": "0.3.5",
+ "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.5.tgz",
+ "integrity": "sha512-UTYAUj/wviwdsMfzoSJspJxbkH5o1snzwX0//0ENX1u/55kkZZkcTZP6u9bwKGkv+dkk9at4m1Cpt0uY80kcpQ==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.3.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ },
+ "node_modules/@jridgewell/source-map/node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.3",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz",
+ "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.4.14",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz",
+ "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==",
+ "dev": true
+ },
+ "node_modules/@jridgewell/trace-mapping": {
+ "version": "0.3.17",
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz",
+ "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/resolve-uri": "3.1.0",
+ "@jridgewell/sourcemap-codec": "1.4.14"
+ }
+ },
+ "node_modules/@leichtgewicht/ip-codec": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/@leichtgewicht/ip-codec/-/ip-codec-2.0.4.tgz",
+ "integrity": "sha512-Hcv+nVC0kZnQ3tD9GVu5xSMR4VVYOteQIr/hwFPVEvPdlXqgGEuRjiheChHgdM+JyqdgNcmzZOX/tnl0JOiI7A==",
+ "dev": true
+ },
+ "node_modules/@material/animation": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/animation/-/animation-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-nOCOgzp/Vdgloyw/SjFCEtpcxXWtXUjvX+JCVg7o+EEtaGLBQdgjJUj5lt+RQ6e9r0eiMYKJ6l1+1TGGebsIfA==",
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/auto-init": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/auto-init/-/auto-init-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-JmST/NkQpdJ1+nyAU8qbV1eRXbOwvpaTRy096Y5mOK1CeUsagUyrKkCeLsO56pmvayxnOIkJCOhH/8gzIsmiJA==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/banner": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/banner/-/banner-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-OA23YGt9qTz5i+FdGgk4QpRkmby/w+k12YMlL7u+TmwWIiGom2AaOy/DbBCr2/uNJEJ6o0h+wcNBEmGe7bJutw==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/base": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/base/-/base-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-wXgoWl8NG4BZ2U8MCg4BLQLNla3IdyxBJIMSsJ1qvP2YswmG9HXTkS8y9mHTAhzzQEFQtlwDOyp4Ntq2Ep4WZA==",
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/button": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/button/-/button-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-lyV4unJUG/onzNSLL5TjTGJxscBReG6+lNBvGSfgCafW2bfHW278BbqPDbPr52ONe6vg5INptZJ6bZx4FStGIQ==",
+ "dependencies": {
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/card": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/card/-/card-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-0YNba4Keg+a0U4JK+siLDbTyO13s40hm88kX7uQ46SmsQlY3fbMsdOpX9+y/PaOkOXIJIgX6g+c7ASM7c/6Zyw==",
+ "dependencies": {
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/checkbox": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/checkbox/-/checkbox-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-RSFJhMtU28BhXWyQHMrThqkGMtYb16JOuKkZ54bc1AzIndQnniQoGpkb5tHx1hOCGhOUyAGVh/w8BHczWRsLbw==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/chips": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/chips/-/chips-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-W8e90cxnERoP/OvsYSSkjP/HEeogYH1YJVBemKfTOQyAAMh3DmetBGdO6Gdf65/Jt7iYrvab5IPn0D7DWoMZlQ==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/checkbox": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "safevalues": "^0.3.4",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/circular-progress": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/circular-progress/-/circular-progress-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-dE66rFNI9T2khLejoTyONQZqnHjUXsmdzDx1lI3qO918gtdkwdBVWvFm0U7+1VdHAB9sjP4o+mVL/3rNss2Jtg==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/progress-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/data-table": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/data-table/-/data-table-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-JIg3GqnWGoiP5OXRkM7xjpoYIcal3a2vcvx8qUBK8rJZUXXShMcrFD8bpoEK+VIo7NXp5oR3baR3g063sTmv7g==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/checkbox": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/icon-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/linear-progress": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/select": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/density": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/density/-/density-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-JfRRdyewKuVGDLTxm0Bn/5MFgkPHo5fZ0JU6kCqI+SdOER/ceRti6xJtNfgV/lBPqstftARcKv116nQRy2085Q==",
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/dialog": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/dialog/-/dialog-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-P7+nNN1YdPISSOIECyECiYNcmAJn4ezogpkcGkGBKc0KZAzG47Y1prgLNFaHat5mE20GjLL50M7T4SU7F64dqA==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/icon-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/dom": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/dom/-/dom-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-h+KV0egRy7zniZElzDW5duh/VDZUTO9SmMeC8FFiqJMvPe3V8xcH0zB+jL67hueLqFixSSJebbdXMbVce4nwOA==",
+ "dependencies": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/drawer": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/drawer/-/drawer-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-LYuriNp3lecXXIj3lK22z0ym5bGHHIturofEV60BK9uHi4baBWS/ovTPAw5T8YvpADv5kyidg4mkgkPY9Ydexg==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/elevation": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/elevation/-/elevation-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-M9SZKJI5wjbOwq0o8eknDrI27YE63wLg8qJHLvJWrWXdlm6yN0INilihExzmGHXpVHQ6sUdI4oyoAx1qr+vorQ==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/fab": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/fab/-/fab-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-G58ZFK7M9r9xkLFP0Gufh1VKdcvRcTvYwEjBuG3+XOMDMjFzCDEMY4c54RG+tbwIiHmB8lw1Yl/dN3kFVc3kTA==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/feature-targeting": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/feature-targeting/-/feature-targeting-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-xH8pdvB5oKO6OTY61vEs44eQJQY3GTobpzaxp+CIBH0UMobSl5KFee+j7MxpEbTkRGtMqWkzAA+vviT8hvmH+A==",
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/floating-label": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/floating-label/-/floating-label-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-Tjv2xnYr+VvsojRbRBVVmjxmut/y4hJrRCBMjU1982cTUYQlfqMaM7BUObt49jwRBKDLr2NjM+fwNIo0//YItA==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/focus-ring": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/focus-ring/-/focus-ring-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-xutZrHnrfnKftU3HUS9em8wO5Nb4zbnRrwDCGi3xnFR7bFP4u2J2ZUnVpO+RZfjr3A9l8chDavlFCL5HMfzt4A==",
+ "dependencies": {
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0"
+ }
+ },
+ "node_modules/@material/form-field": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/form-field/-/form-field-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-N0UnlZ7j3GT4DGmMgJYMl9etOh7rsQjCjRRATWSnuAel+ir4a5HvLj9xQUyp0tlYuu9ZizB8ZOwbAz/XCiU94Q==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/icon-button": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/icon-button/-/icon-button-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-BT+tHdRviY1o/yBgtX5NxfS7LfQtQSf7DiZfgP9eExSU5fDA6AfqJfZHyJdLmJCtFZbzlxJ0PBmt44NSlI2/DA==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/image-list": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/image-list/-/image-list-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-FrBosWy9VnqWYDR8XkQPt8cE6MPNq5g7oEvULImmqjRxhktTJCPfDZSWHpjLpAvU0quYZZprPDRrwM3qw69z/A==",
+ "dependencies": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/layout-grid": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/layout-grid/-/layout-grid-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-H4KEhaGaIuGHd3jKJqaoZkynJjqfyti4QhG6wiTt774Lv4Uri1+ZBxQ8FAFShEvETM2pfBy4mEECi/+M4V2ZTA==",
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/line-ripple": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/line-ripple/-/line-ripple-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-f4tcd82xu1OT0wAVT/kHiWDmJy9fRt9QA5b+v81fTSVFK41mYpxy8jIQ5gdoIvY/0BWLh4HzUejG6j98AkyLEQ==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/linear-progress": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/linear-progress/-/linear-progress-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-3HlEEPv+RrtGPxq06QzCOAZoNJ8q6UtOOkRxh+buQy1F+Uv0n4BdmvUYsHZaSTn+kSlFMzIKDtRjUG2i7b4/hg==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/progress-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/list": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/list/-/list-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-rYg3cM41MJTSNoFOj8IzF1CpPFK9DDlTFMbERFakRHB1QsfnebxkuoAyI8j5G/pDdvkeAmDbz4tbKK8yJdifRw==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/menu": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/menu/-/menu-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-Xa+tXk8kMFMhdOYrIre1ye4L23i4LzEn48FN398742m1K/VY/IxAuslyQ5CmX77CxkOqbQFqwUarUTod0rEwjw==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu-surface": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/menu-surface": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/menu-surface/-/menu-surface-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-7sRmwY7+a3gB5GM6Vl0sZzVVW3iu6QNW79vRias6nZKJMXbE/JDWnhcgkl9QkxvUolBIJ0y1ChgZyntO8Val/g==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/notched-outline": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/notched-outline/-/notched-outline-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-kMUDUqZ7ztvnwqCENZukztyA0oGZhY/mqd/WIaqRhIU58Q2mnDM6Vfd9fifeM61rIMnXHER2fvjjFzim50mw4g==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/floating-label": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/progress-indicator": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/progress-indicator/-/progress-indicator-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-CRQAM2C1weVKVr8rQeQTrOISmTupXw+l9sfpdIx8tQ14fOebZFcEbW9LRRvDAMmUNZF6W6pwL74+zk46DYIKBg==",
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/radio": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/radio/-/radio-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-wpiLuHQtpMb846SSYvG2NQJl/wUi1NbVlCV+uGHSv5LFnbe10e537KFpjtjaDi/Y6e42bUxj8njN5cEZ3NfBUg==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/ripple": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/ripple/-/ripple-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-S9S8260lwHreEgvOqg3EM0DF0y8ThuN9fFPVb+cCOAPzCn4Z2tO1pcvPfAmY8yZA7QIx9c5pt6Ci+q44LzPEYA==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/rtl": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/rtl/-/rtl-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-G02MQTQxHPhNlAIoOToCalxSba48VZ+CdrqkWr53eBb/P1I6Do0drMElqNmO5CYS5G/8AEScXmfJ0xSq92ABew==",
+ "dependencies": {
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/segmented-button": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/segmented-button/-/segmented-button-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-qu9nfKkPAxv6YFFObZAXHgaC0qq8i4Cr2lUbOQdL0E9HmKG+IE9ILualGJrAl2LOpCSJdwA0CjOuv2IsrscpHA==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/select": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/select/-/select-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-MgbztOBl0Y7UHVPUTuXoAAYfBh+bwbRW9lkK/EJQ4YQrmZB/0L14S7feqh52JhFXVhjFzeYPFMQg+uP2hhHSpg==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/floating-label": "15.0.0-canary.7971d6ad5.0",
+ "@material/line-ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu-surface": "15.0.0-canary.7971d6ad5.0",
+ "@material/notched-outline": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/shape": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/shape/-/shape-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-mlsNFWKOK38ECoB1onCFpi8HKRGgrElk0YioF3V0Joszp1HVV2Fn+SWoKg2LwWHaJet4iBYtNoCbQC6dH2YBeA==",
+ "dependencies": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/slider": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/slider/-/slider-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-OjbxB3vwZvhbTGP8EGLWoXyodbTMuwkvoFdblEiZtWrrPL0Us5hg/20n8VfUQ0N+c00mElsEv79Jsx+B0iTV+Q==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/snackbar": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/snackbar/-/snackbar-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-svNOI1Kwu9Mg259SNTaGgyJqETRIPwQPkxYhHvWT4vYiHQkJJJe9kFBcIKi+sdTxqqoMZxyjC2SwS/1mkU4/xg==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/icon-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/switch": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/switch/-/switch-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-WBsTIq0NwccMAbt9YFcU1vhcmFOVpNDeZ9gNMJypk19ZiqDcZBZNDx0JmceRqTYrCxndqVwfD25qK0jFVplK9g==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "safevalues": "^0.3.4",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/tab": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tab/-/tab-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-hmqRl9s7g1/8KpZ5rqANxUXrHi4PYO3GsGhASrYrB99/5ZX1ghdCGwEN1Lp9ntKIgZjd1s6qtzccBtmnW+boXA==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/tab-bar": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tab-bar/-/tab-bar-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-hEMnb2C1yOQPbqdFCTCuyMmjcqO4QIvPKAsbquAwOZc0tz/U88tzmfuhv1k77FB2hbESwN9sPpImU0g4Lrvfhw==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-scroller": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/tab-indicator": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tab-indicator/-/tab-indicator-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-0X2tJf0E+CwL5Bx3Fqxi5Uuj1BgncKqd4yFpWE7cv8IZHphNReSOrCcSgUwUfirmee6MqkQ4Drk51Pf4ANj2OA==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/tab-scroller": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tab-scroller/-/tab-scroller-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-//Ih8ZPx92PLQwXhFzv6YCQc5xW2IH84GdIeJrdBNcQN6wgbQNsbU7h9m6jymtpWQgvvLY8E0+2qkNcnWejnag==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/textfield": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/textfield/-/textfield-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-n9aWMZGyE2GBTr2Tx6n4hLp08uyIo1/xNqcZ0Kx2tKK1spPgTgp+g2fEKImGnnbfiCTJPNrcJ8bQ+Vy7Dp0n3Q==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/floating-label": "15.0.0-canary.7971d6ad5.0",
+ "@material/line-ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/notched-outline": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/theme": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/theme/-/theme-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-4YUyQo4SOatHHH15/h2LBIyxmVxtefo+QC8bRopF13f/qq5lHpX/stK6chf1OR/z9BUxnNHZWXd2LG5SvJGs9Q==",
+ "dependencies": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/tokens": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tokens/-/tokens-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-tRa/Uki/moIP6f/QJPrad2jHbSZ5NB5TRSfAS1NZof0KNFjW8n2lJVpgcgD+f1NENin3dWM4NpfJwxulGlWE7g==",
+ "dependencies": {
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0"
+ }
+ },
+ "node_modules/@material/tooltip": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tooltip/-/tooltip-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-gidVGZOGmJUNDxm3ZorNZMAFmbeFmJ+6DH2F45hi1iU/GflfyvMfvbG2VvPFGYj84YAKHs799yAjidvk1nSZZg==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "safevalues": "^0.3.4",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/top-app-bar": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/top-app-bar/-/top-app-bar-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-ztvglUBK0y4LDHD8xhvNGCpbsHYoAVtI06cJHu5G241WD5wAmseEnLMY+ty86FHMzs796PzhUqUmahEHeBNlEg==",
+ "dependencies": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/touch-target": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/touch-target/-/touch-target-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-aT8GyRfH0TJuF53HWKga+vuwJbJ/euN6T8CS/+RP5F/rjzWwxSd8RtyBmVUzBjVzOxr6Os+El0c3TFfEDxRdAg==",
+ "dependencies": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@material/typography": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/typography/-/typography-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-4J5qPXbCS3wMtGl0AJIj/M9rUxHR7fRX3IKtfOyvra10lZbr4qma+4g0+t+O9cPzcCBS1NwPkJ/E4t+ijEa6gA==",
+ "dependencies": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/@ngtools/webpack": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-15.2.9.tgz",
+ "integrity": "sha512-nOXUGqKkAEMlCcrhkDwWDzcVdKNH7MNRUXfNzsFc9zdeR/5p3qt6SVMN7OOE3NREyI7P6nzARc3S+6QDBjf3Jg==",
+ "dev": true,
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0",
+ "npm": "^6.11.0 || ^7.5.6 || >=8.0.0",
+ "yarn": ">= 1.13.0"
+ },
+ "peerDependencies": {
+ "@angular/compiler-cli": "^15.0.0",
+ "typescript": ">=4.8.2 <5.0",
+ "webpack": "^5.54.0"
+ }
+ },
+ "node_modules/@nodelib/fs.scandir": {
+ "version": "2.1.5",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
+ "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
+ "dev": true,
+ "dependencies": {
+ "@nodelib/fs.stat": "2.0.5",
+ "run-parallel": "^1.1.9"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@nodelib/fs.stat": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
+ "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
+ "dev": true,
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@nodelib/fs.walk": {
+ "version": "1.2.8",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
+ "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
+ "dev": true,
+ "dependencies": {
+ "@nodelib/fs.scandir": "2.1.5",
+ "fastq": "^1.6.0"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/@npmcli/fs": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@npmcli/fs/-/fs-3.1.0.tgz",
+ "integrity": "sha512-7kZUAaLscfgbwBQRbvdMYaZOWyMEcPTH/tJjnyAWJ/dvvs9Ef+CERx/qJb9GExJpl1qipaDGn7KqHnFGGixd0w==",
+ "dev": true,
+ "dependencies": {
+ "semver": "^7.3.5"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@npmcli/git": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/@npmcli/git/-/git-4.1.0.tgz",
+ "integrity": "sha512-9hwoB3gStVfa0N31ymBmrX+GuDGdVA/QWShZVqE0HK2Af+7QGGrCTbZia/SW0ImUTjTne7SP91qxDmtXvDHRPQ==",
+ "dev": true,
+ "dependencies": {
+ "@npmcli/promise-spawn": "^6.0.0",
+ "lru-cache": "^7.4.4",
+ "npm-pick-manifest": "^8.0.0",
+ "proc-log": "^3.0.0",
+ "promise-inflight": "^1.0.1",
+ "promise-retry": "^2.0.1",
+ "semver": "^7.3.5",
+ "which": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@npmcli/git/node_modules/lru-cache": {
+ "version": "7.18.3",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz",
+ "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/@npmcli/git/node_modules/which": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-3.0.1.tgz",
+ "integrity": "sha512-XA1b62dzQzLfaEOSQFTCOd5KFf/1VSzZo7/7TUjnya6u0vGGKzU96UQBZTAThCb2j4/xjBAyii1OhRLJEivHvg==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/which.js"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@npmcli/installed-package-contents": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/@npmcli/installed-package-contents/-/installed-package-contents-2.0.2.tgz",
+ "integrity": "sha512-xACzLPhnfD51GKvTOOuNX2/V4G4mz9/1I2MfDoye9kBM3RYe5g2YbscsaGoTlaWqkxeiapBWyseULVKpSVHtKQ==",
+ "dev": true,
+ "dependencies": {
+ "npm-bundled": "^3.0.0",
+ "npm-normalize-package-bin": "^3.0.0"
+ },
+ "bin": {
+ "installed-package-contents": "lib/index.js"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@npmcli/node-gyp": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/@npmcli/node-gyp/-/node-gyp-3.0.0.tgz",
+ "integrity": "sha512-gp8pRXC2oOxu0DUE1/M3bYtb1b3/DbJ5aM113+XJBgfXdussRAsX0YOrOhdd8WvnAR6auDBvJomGAkLKA5ydxA==",
+ "dev": true,
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@npmcli/promise-spawn": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/@npmcli/promise-spawn/-/promise-spawn-6.0.2.tgz",
+ "integrity": "sha512-gGq0NJkIGSwdbUt4yhdF8ZrmkGKVz9vAdVzpOfnom+V8PLSmSOVhZwbNvZZS1EYcJN5hzzKBxmmVVAInM6HQLg==",
+ "dev": true,
+ "dependencies": {
+ "which": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@npmcli/promise-spawn/node_modules/which": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-3.0.1.tgz",
+ "integrity": "sha512-XA1b62dzQzLfaEOSQFTCOd5KFf/1VSzZo7/7TUjnya6u0vGGKzU96UQBZTAThCb2j4/xjBAyii1OhRLJEivHvg==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/which.js"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@npmcli/run-script": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/@npmcli/run-script/-/run-script-6.0.2.tgz",
+ "integrity": "sha512-NCcr1uQo1k5U+SYlnIrbAh3cxy+OQT1VtqiAbxdymSlptbzBb62AjH2xXgjNCoP073hoa1CfCAcwoZ8k96C4nA==",
+ "dev": true,
+ "dependencies": {
+ "@npmcli/node-gyp": "^3.0.0",
+ "@npmcli/promise-spawn": "^6.0.0",
+ "node-gyp": "^9.0.0",
+ "read-package-json-fast": "^3.0.0",
+ "which": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@npmcli/run-script/node_modules/which": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-3.0.1.tgz",
+ "integrity": "sha512-XA1b62dzQzLfaEOSQFTCOd5KFf/1VSzZo7/7TUjnya6u0vGGKzU96UQBZTAThCb2j4/xjBAyii1OhRLJEivHvg==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/which.js"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@pkgjs/parseargs": {
+ "version": "0.11.0",
+ "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz",
+ "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==",
+ "dev": true,
+ "optional": true,
+ "engines": {
+ "node": ">=14"
+ }
+ },
+ "node_modules/@schematics/angular": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-15.2.9.tgz",
+ "integrity": "sha512-0Lit6TLNUwcAYiEkXgZp3vY9xAO1cnZCBXuUcp+6v+Ddnrt2w/YOiGe74p21cYe0StkTpTljsqsKBTiX7TMjQg==",
+ "dev": true,
+ "dependencies": {
+ "@angular-devkit/core": "15.2.9",
+ "@angular-devkit/schematics": "15.2.9",
+ "jsonc-parser": "3.2.0"
+ },
+ "engines": {
+ "node": "^14.20.0 || ^16.13.0 || >=18.10.0",
+ "npm": "^6.11.0 || ^7.5.6 || >=8.0.0",
+ "yarn": ">= 1.13.0"
+ }
+ },
+ "node_modules/@sigstore/bundle": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/@sigstore/bundle/-/bundle-1.0.0.tgz",
+ "integrity": "sha512-yLvrWDOh6uMOUlFCTJIZEnwOT9Xte7NPXUqVexEKGSF5XtBAuSg5du0kn3dRR0p47a4ah10Y0mNt8+uyeQXrBQ==",
+ "dev": true,
+ "dependencies": {
+ "@sigstore/protobuf-specs": "^0.2.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@sigstore/protobuf-specs": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/@sigstore/protobuf-specs/-/protobuf-specs-0.2.0.tgz",
+ "integrity": "sha512-8ZhZKAVfXjIspDWwm3D3Kvj0ddbJ0HqDZ/pOs5cx88HpT8mVsotFrg7H1UMnXOuDHz6Zykwxn4mxG3QLuN+RUg==",
+ "dev": true,
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@sigstore/tuf": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/@sigstore/tuf/-/tuf-1.0.3.tgz",
+ "integrity": "sha512-2bRovzs0nJZFlCN3rXirE4gwxCn97JNjMmwpecqlbgV9WcxX7WRuIrgzx/X7Ib7MYRbyUTpBYE0s2x6AmZXnlg==",
+ "dev": true,
+ "dependencies": {
+ "@sigstore/protobuf-specs": "^0.2.0",
+ "tuf-js": "^1.1.7"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@socket.io/component-emitter": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.1.0.tgz",
+ "integrity": "sha512-+9jVqKhRSpsc591z5vX+X5Yyw+he/HCB4iQ/RYxw35CEPaY1gnsNE43nf9n9AaYjAQrTiI/mOwKUKdUs9vf7Xg==",
+ "dev": true
+ },
+ "node_modules/@tinymce/tinymce-angular": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/@tinymce/tinymce-angular/-/tinymce-angular-7.0.0.tgz",
+ "integrity": "sha512-IKNaG/ihlxE1XCfq6lzULbnsqZO9KNJtlpu5jo6JDJDL9zcFzj/N2A16Kk7rTj1yfmDoB1IXAk/BpMOvgDY8cg==",
+ "dependencies": {
+ "tinymce": "^6.0.0 || ^5.5.0",
+ "tslib": "^2.3.0"
+ },
+ "peerDependencies": {
+ "@angular/common": ">=14.0.0",
+ "@angular/core": ">=14.0.0",
+ "@angular/forms": ">=14.0.0"
+ }
+ },
+ "node_modules/@tootallnate/once": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-2.0.0.tgz",
+ "integrity": "sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A==",
+ "dev": true,
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@tufjs/canonical-json": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/@tufjs/canonical-json/-/canonical-json-1.0.0.tgz",
+ "integrity": "sha512-QTnf++uxunWvG2z3UFNzAoQPHxnSXOwtaI3iJ+AohhV+5vONuArPjJE7aPXPVXfXJsqrVbZBu9b81AJoSd09IQ==",
+ "dev": true,
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@tufjs/models": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/@tufjs/models/-/models-1.0.4.tgz",
+ "integrity": "sha512-qaGV9ltJP0EO25YfFUPhxRVK0evXFIAGicsVXuRim4Ed9cjPxYhNnNJ49SFmbeLgtxpslIkX317IgpfcHPVj/A==",
+ "dev": true,
+ "dependencies": {
+ "@tufjs/canonical-json": "1.0.0",
+ "minimatch": "^9.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/@tufjs/models/node_modules/minimatch": {
+ "version": "9.0.3",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz",
+ "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/@types/body-parser": {
+ "version": "1.19.2",
+ "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz",
+ "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==",
+ "dev": true,
+ "dependencies": {
+ "@types/connect": "*",
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/bonjour": {
+ "version": "3.5.10",
+ "resolved": "https://registry.npmjs.org/@types/bonjour/-/bonjour-3.5.10.tgz",
+ "integrity": "sha512-p7ienRMiS41Nu2/igbJxxLDWrSZ0WxM8UQgCeO9KhoVF7cOVFkrKsiDr1EsJIla8vV3oEEjGcz11jc5yimhzZw==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/connect": {
+ "version": "3.4.35",
+ "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz",
+ "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/connect-history-api-fallback": {
+ "version": "1.3.5",
+ "resolved": "https://registry.npmjs.org/@types/connect-history-api-fallback/-/connect-history-api-fallback-1.3.5.tgz",
+ "integrity": "sha512-h8QJa8xSb1WD4fpKBDcATDNGXghFj6/3GRWG6dhmRcu0RX1Ubasur2Uvx5aeEwlf0MwblEC2bMzzMQntxnw/Cw==",
+ "dev": true,
+ "dependencies": {
+ "@types/express-serve-static-core": "*",
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/cookie": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.4.1.tgz",
+ "integrity": "sha512-XW/Aa8APYr6jSVVA1y/DEIZX0/GMKLEVekNG727R8cs56ahETkRAy/3DR7+fJyh7oUgGwNQaRfXCun0+KbWY7Q==",
+ "dev": true
+ },
+ "node_modules/@types/cors": {
+ "version": "2.8.13",
+ "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.13.tgz",
+ "integrity": "sha512-RG8AStHlUiV5ysZQKq97copd2UmVYw3/pRMLefISZ3S1hK104Cwm7iLQ3fTKx+lsUH2CE8FlLaYeEA2LSeqYUA==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/echarts": {
+ "version": "4.9.16",
+ "resolved": "https://registry.npmjs.org/@types/echarts/-/echarts-4.9.16.tgz",
+ "integrity": "sha512-bfiagfPw3dWauAIJ9fgoJQoL4hLWlGcltqwbE6LGye0NIY5xnbZau+mDmadCzGojic3MWuFDCUiO25kl4sRGeA==",
+ "dev": true,
+ "dependencies": {
+ "@types/zrender": "*"
+ }
+ },
+ "node_modules/@types/eslint": {
+ "version": "8.44.1",
+ "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.44.1.tgz",
+ "integrity": "sha512-XpNDc4Z5Tb4x+SW1MriMVeIsMoONHCkWFMkR/aPJbzEsxqHy+4Glu/BqTdPrApfDeMaXbtNh6bseNgl5KaWrSg==",
+ "dev": true,
+ "dependencies": {
+ "@types/estree": "*",
+ "@types/json-schema": "*"
+ }
+ },
+ "node_modules/@types/eslint-scope": {
+ "version": "3.7.4",
+ "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.4.tgz",
+ "integrity": "sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA==",
+ "dev": true,
+ "dependencies": {
+ "@types/eslint": "*",
+ "@types/estree": "*"
+ }
+ },
+ "node_modules/@types/estree": {
+ "version": "0.0.51",
+ "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.51.tgz",
+ "integrity": "sha512-CuPgU6f3eT/XgKKPqKd/gLZV1Xmvf1a2R5POBOGQa6uv82xpls89HU5zKeVoyR8XzHd1RGNOlQlvUe3CFkjWNQ==",
+ "dev": true
+ },
+ "node_modules/@types/express": {
+ "version": "4.17.15",
+ "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.15.tgz",
+ "integrity": "sha512-Yv0k4bXGOH+8a+7bELd2PqHQsuiANB+A8a4gnQrkRWzrkKlb6KHaVvyXhqs04sVW/OWlbPyYxRgYlIXLfrufMQ==",
+ "dev": true,
+ "dependencies": {
+ "@types/body-parser": "*",
+ "@types/express-serve-static-core": "^4.17.31",
+ "@types/qs": "*",
+ "@types/serve-static": "*"
+ }
+ },
+ "node_modules/@types/express-serve-static-core": {
+ "version": "4.17.32",
+ "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.32.tgz",
+ "integrity": "sha512-aI5h/VOkxOF2Z1saPy0Zsxs5avets/iaiAJYznQFm5By/pamU31xWKL//epiF4OfUA2qTOc9PV6tCUjhO8wlZA==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*",
+ "@types/qs": "*",
+ "@types/range-parser": "*"
+ }
+ },
+ "node_modules/@types/http-proxy": {
+ "version": "1.17.9",
+ "resolved": "https://registry.npmjs.org/@types/http-proxy/-/http-proxy-1.17.9.tgz",
+ "integrity": "sha512-QsbSjA/fSk7xB+UXlCT3wHBy5ai9wOcNDWwZAtud+jXhwOM3l+EYZh8Lng4+/6n8uar0J7xILzqftJdJ/Wdfkw==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/jasmine": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/@types/jasmine/-/jasmine-4.3.1.tgz",
+ "integrity": "sha512-Vu8l+UGcshYmV1VWwULgnV/2RDbBaO6i2Ptx7nd//oJPIZGhoI1YLST4VKagD2Pq/Bc2/7zvtvhM7F3p4SN7kQ==",
+ "dev": true
+ },
+ "node_modules/@types/json-schema": {
+ "version": "7.0.11",
+ "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz",
+ "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==",
+ "dev": true
+ },
+ "node_modules/@types/mime": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.1.tgz",
+ "integrity": "sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==",
+ "dev": true
+ },
+ "node_modules/@types/node": {
+ "version": "12.20.55",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-12.20.55.tgz",
+ "integrity": "sha512-J8xLz7q2OFulZ2cyGTLE1TbbZcjpno7FaN6zdJNrgAdrJ+DZzh/uFR6YrTb4C+nXakvud8Q4+rbhoIWlYQbUFQ==",
+ "dev": true
+ },
+ "node_modules/@types/parse-json": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz",
+ "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==",
+ "dev": true
+ },
+ "node_modules/@types/qs": {
+ "version": "6.9.7",
+ "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz",
+ "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==",
+ "dev": true
+ },
+ "node_modules/@types/range-parser": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz",
+ "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==",
+ "dev": true
+ },
+ "node_modules/@types/retry": {
+ "version": "0.12.0",
+ "resolved": "https://registry.npmjs.org/@types/retry/-/retry-0.12.0.tgz",
+ "integrity": "sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA==",
+ "dev": true
+ },
+ "node_modules/@types/serve-index": {
+ "version": "1.9.1",
+ "resolved": "https://registry.npmjs.org/@types/serve-index/-/serve-index-1.9.1.tgz",
+ "integrity": "sha512-d/Hs3nWDxNL2xAczmOVZNj92YZCS6RGxfBPjKzuu/XirCgXdpKEb88dYNbrYGint6IVWLNP+yonwVAuRC0T2Dg==",
+ "dev": true,
+ "dependencies": {
+ "@types/express": "*"
+ }
+ },
+ "node_modules/@types/serve-static": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.0.tgz",
+ "integrity": "sha512-z5xyF6uh8CbjAu9760KDKsH2FcDxZ2tFCsA4HIMWE6IkiYMXfVoa+4f9KX+FN0ZLsaMw1WNG2ETLA6N+/YA+cg==",
+ "dev": true,
+ "dependencies": {
+ "@types/mime": "*",
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/sockjs": {
+ "version": "0.3.33",
+ "resolved": "https://registry.npmjs.org/@types/sockjs/-/sockjs-0.3.33.tgz",
+ "integrity": "sha512-f0KEEe05NvUnat+boPTZ0dgaLZ4SfSouXUgv5noUiefG2ajgKjmETo9ZJyuqsl7dfl2aHlLJUiki6B4ZYldiiw==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/sortablejs": {
+ "version": "1.15.1",
+ "resolved": "https://registry.npmjs.org/@types/sortablejs/-/sortablejs-1.15.1.tgz",
+ "integrity": "sha512-g/JwBNToh6oCTAwNS8UGVmjO7NLDKsejVhvE4x1eWiPTC3uCuNsa/TD4ssvX3du+MLiM+SHPNDuijp8y76JzLQ==",
+ "dev": true
+ },
+ "node_modules/@types/ws": {
+ "version": "8.5.4",
+ "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.4.tgz",
+ "integrity": "sha512-zdQDHKUgcX/zBc4GrwsE/7dVdAD8JR4EuiAXiiUhhfyIJXXb2+PrGshFyeXWQPMmmZ2XxgaqclgpIC7eTXc1mg==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*"
+ }
+ },
+ "node_modules/@types/zrender": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/@types/zrender/-/zrender-4.0.3.tgz",
+ "integrity": "sha512-EPI269lkHNsObwILJ1k1z7znLjKyePuWRy/XKK0shSGpBb9cIX307arcwJV4+2NeZj5wEjN06r4D8yFv7sI06g==",
+ "dev": true
+ },
+ "node_modules/@webassemblyjs/ast": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.1.tgz",
+ "integrity": "sha512-ukBh14qFLjxTQNTXocdyksN5QdM28S1CxHt2rdskFyL+xFV7VremuBLVbmCePj+URalXBENx/9Lm7lnhihtCSw==",
+ "dev": true,
+ "dependencies": {
+ "@webassemblyjs/helper-numbers": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1"
+ }
+ },
+ "node_modules/@webassemblyjs/floating-point-hex-parser": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.1.tgz",
+ "integrity": "sha512-iGRfyc5Bq+NnNuX8b5hwBrRjzf0ocrJPI6GWFodBFzmFnyvrQ83SHKhmilCU/8Jv67i4GJZBMhEzltxzcNagtQ==",
+ "dev": true
+ },
+ "node_modules/@webassemblyjs/helper-api-error": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.1.tgz",
+ "integrity": "sha512-RlhS8CBCXfRUR/cwo2ho9bkheSXG0+NwooXcc3PAILALf2QLdFyj7KGsKRbVc95hZnhnERon4kW/D3SZpp6Tcg==",
+ "dev": true
+ },
+ "node_modules/@webassemblyjs/helper-buffer": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.1.tgz",
+ "integrity": "sha512-gwikF65aDNeeXa8JxXa2BAk+REjSyhrNC9ZwdT0f8jc4dQQeDQ7G4m0f2QCLPJiMTTO6wfDmRmj/pW0PsUvIcA==",
+ "dev": true
+ },
+ "node_modules/@webassemblyjs/helper-numbers": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.1.tgz",
+ "integrity": "sha512-vDkbxiB8zfnPdNK9Rajcey5C0w+QJugEglN0of+kmO8l7lDb77AnlKYQF7aarZuCrv+l0UvqL+68gSDr3k9LPQ==",
+ "dev": true,
+ "dependencies": {
+ "@webassemblyjs/floating-point-hex-parser": "1.11.1",
+ "@webassemblyjs/helper-api-error": "1.11.1",
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "node_modules/@webassemblyjs/helper-wasm-bytecode": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.1.tgz",
+ "integrity": "sha512-PvpoOGiJwXeTrSf/qfudJhwlvDQxFgelbMqtq52WWiXC6Xgg1IREdngmPN3bs4RoO83PnL/nFrxucXj1+BX62Q==",
+ "dev": true
+ },
+ "node_modules/@webassemblyjs/helper-wasm-section": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.1.tgz",
+ "integrity": "sha512-10P9No29rYX1j7F3EVPX3JvGPQPae+AomuSTPiF9eBQeChHI6iqjMIwR9JmOJXwpnn/oVGDk7I5IlskuMwU/pg==",
+ "dev": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-buffer": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1",
+ "@webassemblyjs/wasm-gen": "1.11.1"
+ }
+ },
+ "node_modules/@webassemblyjs/ieee754": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.1.tgz",
+ "integrity": "sha512-hJ87QIPtAMKbFq6CGTkZYJivEwZDbQUgYd3qKSadTNOhVY7p+gfP6Sr0lLRVTaG1JjFj+r3YchoqRYxNH3M0GQ==",
+ "dev": true,
+ "dependencies": {
+ "@xtuc/ieee754": "^1.2.0"
+ }
+ },
+ "node_modules/@webassemblyjs/leb128": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.1.tgz",
+ "integrity": "sha512-BJ2P0hNZ0u+Th1YZXJpzW6miwqQUGcIHT1G/sf72gLVD9DZ5AdYTqPNbHZh6K1M5VmKvFXwGSWZADz+qBWxeRw==",
+ "dev": true,
+ "dependencies": {
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "node_modules/@webassemblyjs/utf8": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.1.tgz",
+ "integrity": "sha512-9kqcxAEdMhiwQkHpkNiorZzqpGrodQQ2IGrHHxCy+Ozng0ofyMA0lTqiLkVs1uzTRejX+/O0EOT7KxqVPuXosQ==",
+ "dev": true
+ },
+ "node_modules/@webassemblyjs/wasm-edit": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.1.tgz",
+ "integrity": "sha512-g+RsupUC1aTHfR8CDgnsVRVZFJqdkFHpsHMfJuWQzWU3tvnLC07UqHICfP+4XyL2tnr1amvl1Sdp06TnYCmVkA==",
+ "dev": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-buffer": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1",
+ "@webassemblyjs/helper-wasm-section": "1.11.1",
+ "@webassemblyjs/wasm-gen": "1.11.1",
+ "@webassemblyjs/wasm-opt": "1.11.1",
+ "@webassemblyjs/wasm-parser": "1.11.1",
+ "@webassemblyjs/wast-printer": "1.11.1"
+ }
+ },
+ "node_modules/@webassemblyjs/wasm-gen": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.1.tgz",
+ "integrity": "sha512-F7QqKXwwNlMmsulj6+O7r4mmtAlCWfO/0HdgOxSklZfQcDu0TpLiD1mRt/zF25Bk59FIjEuGAIyn5ei4yMfLhA==",
+ "dev": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1",
+ "@webassemblyjs/ieee754": "1.11.1",
+ "@webassemblyjs/leb128": "1.11.1",
+ "@webassemblyjs/utf8": "1.11.1"
+ }
+ },
+ "node_modules/@webassemblyjs/wasm-opt": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.1.tgz",
+ "integrity": "sha512-VqnkNqnZlU5EB64pp1l7hdm3hmQw7Vgqa0KF/KCNO9sIpI6Fk6brDEiX+iCOYrvMuBWDws0NkTOxYEb85XQHHw==",
+ "dev": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-buffer": "1.11.1",
+ "@webassemblyjs/wasm-gen": "1.11.1",
+ "@webassemblyjs/wasm-parser": "1.11.1"
+ }
+ },
+ "node_modules/@webassemblyjs/wasm-parser": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.1.tgz",
+ "integrity": "sha512-rrBujw+dJu32gYB7/Lup6UhdkPx9S9SnobZzRVL7VcBH9Bt9bCBLEuX/YXOOtBsOZ4NQrRykKhffRWHvigQvOA==",
+ "dev": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-api-error": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1",
+ "@webassemblyjs/ieee754": "1.11.1",
+ "@webassemblyjs/leb128": "1.11.1",
+ "@webassemblyjs/utf8": "1.11.1"
+ }
+ },
+ "node_modules/@webassemblyjs/wast-printer": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.1.tgz",
+ "integrity": "sha512-IQboUWM4eKzWW+N/jij2sRatKMh99QEelo3Eb2q0qXkvPRISAj8Qxtmw5itwqK+TTkBuUIE45AxYPToqPtL5gg==",
+ "dev": true,
+ "dependencies": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "node_modules/@xtuc/ieee754": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz",
+ "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==",
+ "dev": true
+ },
+ "node_modules/@xtuc/long": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz",
+ "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==",
+ "dev": true
+ },
+ "node_modules/@yarnpkg/lockfile": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz",
+ "integrity": "sha512-GpSwvyXOcOOlV70vbnzjj4fW5xW/FdUF6nQEt1ENy7m4ZCczi1+/buVUPAqmGfqznsORNFzUMjctTIp8a9tuCQ==",
+ "dev": true
+ },
+ "node_modules/abab": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz",
+ "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==",
+ "dev": true
+ },
+ "node_modules/abbrev": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
+ "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==",
+ "dev": true
+ },
+ "node_modules/accepts": {
+ "version": "1.3.8",
+ "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz",
+ "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==",
+ "dev": true,
+ "dependencies": {
+ "mime-types": "~2.1.34",
+ "negotiator": "0.6.3"
+ },
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/acorn": {
+ "version": "8.10.0",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz",
+ "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==",
+ "dev": true,
+ "bin": {
+ "acorn": "bin/acorn"
+ },
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/acorn-import-assertions": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.9.0.tgz",
+ "integrity": "sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==",
+ "dev": true,
+ "peerDependencies": {
+ "acorn": "^8"
+ }
+ },
+ "node_modules/adjust-sourcemap-loader": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/adjust-sourcemap-loader/-/adjust-sourcemap-loader-4.0.0.tgz",
+ "integrity": "sha512-OXwN5b9pCUXNQHJpwwD2qP40byEmSgzj8B4ydSN0uMNYWiFmJ6x6KwUllMmfk8Rwu/HJDFR7U8ubsWBoN0Xp0A==",
+ "dev": true,
+ "dependencies": {
+ "loader-utils": "^2.0.0",
+ "regex-parser": "^2.2.11"
+ },
+ "engines": {
+ "node": ">=8.9"
+ }
+ },
+ "node_modules/adjust-sourcemap-loader/node_modules/loader-utils": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz",
+ "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==",
+ "dev": true,
+ "dependencies": {
+ "big.js": "^5.2.2",
+ "emojis-list": "^3.0.0",
+ "json5": "^2.1.2"
+ },
+ "engines": {
+ "node": ">=8.9.0"
+ }
+ },
+ "node_modules/agent-base": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz",
+ "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==",
+ "dev": true,
+ "dependencies": {
+ "debug": "4"
+ },
+ "engines": {
+ "node": ">= 6.0.0"
+ }
+ },
+ "node_modules/agentkeepalive": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/agentkeepalive/-/agentkeepalive-4.3.0.tgz",
+ "integrity": "sha512-7Epl1Blf4Sy37j4v9f9FjICCh4+KAQOyXgHEwlyBiAQLbhKdq/i2QQU3amQalS/wPhdPzDXPL5DMR5bkn+YeWg==",
+ "dev": true,
+ "dependencies": {
+ "debug": "^4.1.0",
+ "depd": "^2.0.0",
+ "humanize-ms": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 8.0.0"
+ }
+ },
+ "node_modules/aggregate-error": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz",
+ "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==",
+ "dev": true,
+ "dependencies": {
+ "clean-stack": "^2.0.0",
+ "indent-string": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/ajv": {
+ "version": "8.12.0",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz",
+ "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==",
+ "dev": true,
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "json-schema-traverse": "^1.0.0",
+ "require-from-string": "^2.0.2",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/ajv-formats": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/ajv-formats/-/ajv-formats-2.1.1.tgz",
+ "integrity": "sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==",
+ "dev": true,
+ "dependencies": {
+ "ajv": "^8.0.0"
+ },
+ "peerDependencies": {
+ "ajv": "^8.0.0"
+ },
+ "peerDependenciesMeta": {
+ "ajv": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/ajv-keywords": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-5.1.0.tgz",
+ "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==",
+ "dev": true,
+ "dependencies": {
+ "fast-deep-equal": "^3.1.3"
+ },
+ "peerDependencies": {
+ "ajv": "^8.8.2"
+ }
+ },
+ "node_modules/ansi-colors": {
+ "version": "4.1.3",
+ "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz",
+ "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/ansi-escapes": {
+ "version": "4.3.2",
+ "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz",
+ "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==",
+ "dev": true,
+ "dependencies": {
+ "type-fest": "^0.21.3"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/ansi-html-community": {
+ "version": "0.0.8",
+ "resolved": "https://registry.npmjs.org/ansi-html-community/-/ansi-html-community-0.0.8.tgz",
+ "integrity": "sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw==",
+ "dev": true,
+ "engines": [
+ "node >= 0.8.0"
+ ],
+ "bin": {
+ "ansi-html": "bin/ansi-html"
+ }
+ },
+ "node_modules/ansi-regex": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
+ "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/ansi-styles": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
+ "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^1.9.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/anymatch": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz",
+ "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==",
+ "dev": true,
+ "dependencies": {
+ "normalize-path": "^3.0.0",
+ "picomatch": "^2.0.4"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/aproba": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz",
+ "integrity": "sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==",
+ "dev": true
+ },
+ "node_modules/are-we-there-yet": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-3.0.1.tgz",
+ "integrity": "sha512-QZW4EDmGwlYur0Yyf/b2uGucHQMa8aFUP7eu9ddR73vvhFyt4V0Vl3QHPcTNJ8l6qYOBdxgXdnBXQrHilfRQBg==",
+ "dev": true,
+ "dependencies": {
+ "delegates": "^1.0.0",
+ "readable-stream": "^3.6.0"
+ },
+ "engines": {
+ "node": "^12.13.0 || ^14.15.0 || >=16.0.0"
+ }
+ },
+ "node_modules/argparse": {
+ "version": "1.0.10",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz",
+ "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==",
+ "dev": true,
+ "dependencies": {
+ "sprintf-js": "~1.0.2"
+ }
+ },
+ "node_modules/array-flatten": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-2.1.2.tgz",
+ "integrity": "sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ==",
+ "dev": true
+ },
+ "node_modules/autoprefixer": {
+ "version": "10.4.13",
+ "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.13.tgz",
+ "integrity": "sha512-49vKpMqcZYsJjwotvt4+h/BCjJVnhGwcLpDt5xkcaOG3eLrG/HUYLagrihYsQ+qrIBgIzX1Rw7a6L8I/ZA1Atg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/autoprefixer"
+ }
+ ],
+ "dependencies": {
+ "browserslist": "^4.21.4",
+ "caniuse-lite": "^1.0.30001426",
+ "fraction.js": "^4.2.0",
+ "normalize-range": "^0.1.2",
+ "picocolors": "^1.0.0",
+ "postcss-value-parser": "^4.2.0"
+ },
+ "bin": {
+ "autoprefixer": "bin/autoprefixer"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/babel-loader": {
+ "version": "9.1.2",
+ "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-9.1.2.tgz",
+ "integrity": "sha512-mN14niXW43tddohGl8HPu5yfQq70iUThvFL/4QzESA7GcZoC0eVOhvWdQ8+3UlSjaDE9MVtsW9mxDY07W7VpVA==",
+ "dev": true,
+ "dependencies": {
+ "find-cache-dir": "^3.3.2",
+ "schema-utils": "^4.0.0"
+ },
+ "engines": {
+ "node": ">= 14.15.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.12.0",
+ "webpack": ">=5"
+ }
+ },
+ "node_modules/babel-plugin-istanbul": {
+ "version": "6.1.1",
+ "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz",
+ "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@istanbuljs/load-nyc-config": "^1.0.0",
+ "@istanbuljs/schema": "^0.1.2",
+ "istanbul-lib-instrument": "^5.0.4",
+ "test-exclude": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-corejs2": {
+ "version": "0.3.3",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.3.tgz",
+ "integrity": "sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q==",
+ "dev": true,
+ "dependencies": {
+ "@babel/compat-data": "^7.17.7",
+ "@babel/helper-define-polyfill-provider": "^0.3.3",
+ "semver": "^6.1.1"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-corejs2/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-corejs3": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.6.0.tgz",
+ "integrity": "sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-define-polyfill-provider": "^0.3.3",
+ "core-js-compat": "^3.25.1"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/babel-plugin-polyfill-regenerator": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.4.1.tgz",
+ "integrity": "sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw==",
+ "dev": true,
+ "dependencies": {
+ "@babel/helper-define-polyfill-provider": "^0.3.3"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/balanced-match": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
+ "dev": true
+ },
+ "node_modules/base64-js": {
+ "version": "1.5.1",
+ "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
+ "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ]
+ },
+ "node_modules/base64id": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz",
+ "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==",
+ "dev": true,
+ "engines": {
+ "node": "^4.5.0 || >= 5.9"
+ }
+ },
+ "node_modules/batch": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz",
+ "integrity": "sha512-x+VAiMRL6UPkx+kudNvxTl6hB2XNNCG2r+7wixVfIYwu/2HKRXimwQyaumLjMveWvT2Hkd/cAJw+QBMfJ/EKVw==",
+ "dev": true
+ },
+ "node_modules/big.js": {
+ "version": "5.2.2",
+ "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz",
+ "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==",
+ "dev": true,
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/binary-extensions": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
+ "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/bl": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz",
+ "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==",
+ "dev": true,
+ "dependencies": {
+ "buffer": "^5.5.0",
+ "inherits": "^2.0.4",
+ "readable-stream": "^3.4.0"
+ }
+ },
+ "node_modules/body-parser": {
+ "version": "1.20.1",
+ "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz",
+ "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==",
+ "dev": true,
+ "dependencies": {
+ "bytes": "3.1.2",
+ "content-type": "~1.0.4",
+ "debug": "2.6.9",
+ "depd": "2.0.0",
+ "destroy": "1.2.0",
+ "http-errors": "2.0.0",
+ "iconv-lite": "0.4.24",
+ "on-finished": "2.4.1",
+ "qs": "6.11.0",
+ "raw-body": "2.5.1",
+ "type-is": "~1.6.18",
+ "unpipe": "1.0.0"
+ },
+ "engines": {
+ "node": ">= 0.8",
+ "npm": "1.2.8000 || >= 1.4.16"
+ }
+ },
+ "node_modules/body-parser/node_modules/debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.0.0"
+ }
+ },
+ "node_modules/body-parser/node_modules/ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "node_modules/bonjour-service": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/bonjour-service/-/bonjour-service-1.1.0.tgz",
+ "integrity": "sha512-LVRinRB3k1/K0XzZ2p58COnWvkQknIY6sf0zF2rpErvcJXpMBttEPQSxK+HEXSS9VmpZlDoDnQWv8ftJT20B0Q==",
+ "dev": true,
+ "dependencies": {
+ "array-flatten": "^2.1.2",
+ "dns-equal": "^1.0.0",
+ "fast-deep-equal": "^3.1.3",
+ "multicast-dns": "^7.2.5"
+ }
+ },
+ "node_modules/boolbase": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz",
+ "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==",
+ "dev": true
+ },
+ "node_modules/brace-expansion": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz",
+ "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0"
+ }
+ },
+ "node_modules/braces": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
+ "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
+ "dev": true,
+ "dependencies": {
+ "fill-range": "^7.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/browserslist": {
+ "version": "4.21.5",
+ "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.5.tgz",
+ "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ }
+ ],
+ "dependencies": {
+ "caniuse-lite": "^1.0.30001449",
+ "electron-to-chromium": "^1.4.284",
+ "node-releases": "^2.0.8",
+ "update-browserslist-db": "^1.0.10"
+ },
+ "bin": {
+ "browserslist": "cli.js"
+ },
+ "engines": {
+ "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
+ }
+ },
+ "node_modules/buffer": {
+ "version": "5.7.1",
+ "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz",
+ "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ],
+ "dependencies": {
+ "base64-js": "^1.3.1",
+ "ieee754": "^1.1.13"
+ }
+ },
+ "node_modules/buffer-from": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
+ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==",
+ "dev": true
+ },
+ "node_modules/builtins": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.0.1.tgz",
+ "integrity": "sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==",
+ "dev": true,
+ "dependencies": {
+ "semver": "^7.0.0"
+ }
+ },
+ "node_modules/bytes": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
+ "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/cacache": {
+ "version": "17.0.4",
+ "resolved": "https://registry.npmjs.org/cacache/-/cacache-17.0.4.tgz",
+ "integrity": "sha512-Z/nL3gU+zTUjz5pCA5vVjYM8pmaw2kxM7JEiE0fv3w77Wj+sFbi70CrBruUWH0uNcEdvLDixFpgA2JM4F4DBjA==",
+ "dev": true,
+ "dependencies": {
+ "@npmcli/fs": "^3.1.0",
+ "fs-minipass": "^3.0.0",
+ "glob": "^8.0.1",
+ "lru-cache": "^7.7.1",
+ "minipass": "^4.0.0",
+ "minipass-collect": "^1.0.2",
+ "minipass-flush": "^1.0.5",
+ "minipass-pipeline": "^1.2.4",
+ "p-map": "^4.0.0",
+ "promise-inflight": "^1.0.1",
+ "ssri": "^10.0.0",
+ "tar": "^6.1.11",
+ "unique-filename": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/cacache/node_modules/lru-cache": {
+ "version": "7.14.1",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.14.1.tgz",
+ "integrity": "sha512-ysxwsnTKdAx96aTRdhDOCQfDgbHnt8SK0KY8SEjO0wHinhWOFTESbjVCMPbU1uGXg/ch4lifqx0wfjOawU2+WA==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/call-bind": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz",
+ "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
+ "dev": true,
+ "dependencies": {
+ "function-bind": "^1.1.1",
+ "get-intrinsic": "^1.0.2"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/camelcase": {
+ "version": "5.3.1",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz",
+ "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001519",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001519.tgz",
+ "integrity": "sha512-0QHgqR+Jv4bxHMp8kZ1Kn8CH55OikjKJ6JmKkZYP1F3D7w+lnFXF70nG5eNfsZS89jadi5Ywy5UCSKLAglIRkg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ]
+ },
+ "node_modules/chalk": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
+ "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^3.2.1",
+ "escape-string-regexp": "^1.0.5",
+ "supports-color": "^5.3.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/chardet": {
+ "version": "0.7.0",
+ "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz",
+ "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==",
+ "dev": true
+ },
+ "node_modules/chokidar": {
+ "version": "3.5.3",
+ "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
+ "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://paulmillr.com/funding/"
+ }
+ ],
+ "dependencies": {
+ "anymatch": "~3.1.2",
+ "braces": "~3.0.2",
+ "glob-parent": "~5.1.2",
+ "is-binary-path": "~2.1.0",
+ "is-glob": "~4.0.1",
+ "normalize-path": "~3.0.0",
+ "readdirp": "~3.6.0"
+ },
+ "engines": {
+ "node": ">= 8.10.0"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.2"
+ }
+ },
+ "node_modules/chownr": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz",
+ "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/chrome-trace-event": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz",
+ "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.0"
+ }
+ },
+ "node_modules/clean-stack": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz",
+ "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/cli-cursor": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz",
+ "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==",
+ "dev": true,
+ "dependencies": {
+ "restore-cursor": "^3.1.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/cli-spinners": {
+ "version": "2.7.0",
+ "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.7.0.tgz",
+ "integrity": "sha512-qu3pN8Y3qHNgE2AFweciB1IfMnmZ/fsNTEE+NOFjmGB2F/7rLhnhzppvpCnN4FovtP26k8lHyy9ptEbNwWFLzw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/cli-width": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz",
+ "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/cliui": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz",
+ "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==",
+ "dev": true,
+ "dependencies": {
+ "string-width": "^4.2.0",
+ "strip-ansi": "^6.0.1",
+ "wrap-ansi": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/clone": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz",
+ "integrity": "sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8"
+ }
+ },
+ "node_modules/clone-deep": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz",
+ "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==",
+ "dev": true,
+ "dependencies": {
+ "is-plain-object": "^2.0.4",
+ "kind-of": "^6.0.2",
+ "shallow-clone": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/color-convert": {
+ "version": "1.9.3",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
+ "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "1.1.3"
+ }
+ },
+ "node_modules/color-name": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
+ "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==",
+ "dev": true
+ },
+ "node_modules/color-support": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz",
+ "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==",
+ "dev": true,
+ "bin": {
+ "color-support": "bin.js"
+ }
+ },
+ "node_modules/colorette": {
+ "version": "2.0.19",
+ "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.19.tgz",
+ "integrity": "sha512-3tlv/dIP7FWvj3BsbHrGLJ6l/oKh1O3TcgBqMn+yyCagOxc23fyzDS6HypQbgxWbkpDnf52p1LuR4eWDQ/K9WQ==",
+ "dev": true
+ },
+ "node_modules/commander": {
+ "version": "2.20.3",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz",
+ "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==",
+ "dev": true
+ },
+ "node_modules/commondir": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz",
+ "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==",
+ "dev": true
+ },
+ "node_modules/compressible": {
+ "version": "2.0.18",
+ "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz",
+ "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==",
+ "dev": true,
+ "dependencies": {
+ "mime-db": ">= 1.43.0 < 2"
+ },
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/compression": {
+ "version": "1.7.4",
+ "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz",
+ "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==",
+ "dev": true,
+ "dependencies": {
+ "accepts": "~1.3.5",
+ "bytes": "3.0.0",
+ "compressible": "~2.0.16",
+ "debug": "2.6.9",
+ "on-headers": "~1.0.2",
+ "safe-buffer": "5.1.2",
+ "vary": "~1.1.2"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/compression/node_modules/bytes": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz",
+ "integrity": "sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/compression/node_modules/debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.0.0"
+ }
+ },
+ "node_modules/compression/node_modules/ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "node_modules/compression/node_modules/safe-buffer": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
+ "dev": true
+ },
+ "node_modules/concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
+ "dev": true
+ },
+ "node_modules/connect": {
+ "version": "3.7.0",
+ "resolved": "https://registry.npmjs.org/connect/-/connect-3.7.0.tgz",
+ "integrity": "sha512-ZqRXc+tZukToSNmh5C2iWMSoV3X1YUcPbqEM4DkEG5tNQXrQUZCNVGGv3IuicnkMtPfGf3Xtp8WCXs295iQ1pQ==",
+ "dev": true,
+ "dependencies": {
+ "debug": "2.6.9",
+ "finalhandler": "1.1.2",
+ "parseurl": "~1.3.3",
+ "utils-merge": "1.0.1"
+ },
+ "engines": {
+ "node": ">= 0.10.0"
+ }
+ },
+ "node_modules/connect-history-api-fallback": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-2.0.0.tgz",
+ "integrity": "sha512-U73+6lQFmfiNPrYbXqr6kZ1i1wiRqXnp2nhMsINseWXO8lDau0LGEffJ8kQi4EjLZympVgRdvqjAgiZ1tgzDDA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8"
+ }
+ },
+ "node_modules/connect/node_modules/debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.0.0"
+ }
+ },
+ "node_modules/connect/node_modules/ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "node_modules/console-control-strings": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz",
+ "integrity": "sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==",
+ "dev": true
+ },
+ "node_modules/content-disposition": {
+ "version": "0.5.4",
+ "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
+ "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
+ "dev": true,
+ "dependencies": {
+ "safe-buffer": "5.2.1"
+ },
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/content-type": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
+ "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/convert-source-map": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz",
+ "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==",
+ "dev": true
+ },
+ "node_modules/cookie": {
+ "version": "0.4.2",
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz",
+ "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/cookie-signature": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
+ "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==",
+ "dev": true
+ },
+ "node_modules/copy-anything": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/copy-anything/-/copy-anything-2.0.6.tgz",
+ "integrity": "sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==",
+ "dev": true,
+ "dependencies": {
+ "is-what": "^3.14.1"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/mesqueeb"
+ }
+ },
+ "node_modules/copy-webpack-plugin": {
+ "version": "11.0.0",
+ "resolved": "https://registry.npmjs.org/copy-webpack-plugin/-/copy-webpack-plugin-11.0.0.tgz",
+ "integrity": "sha512-fX2MWpamkW0hZxMEg0+mYnA40LTosOSa5TqZ9GYIBzyJa9C3QUaMPSE2xAi/buNr8u89SfD9wHSQVBzrRa/SOQ==",
+ "dev": true,
+ "dependencies": {
+ "fast-glob": "^3.2.11",
+ "glob-parent": "^6.0.1",
+ "globby": "^13.1.1",
+ "normalize-path": "^3.0.0",
+ "schema-utils": "^4.0.0",
+ "serialize-javascript": "^6.0.0"
+ },
+ "engines": {
+ "node": ">= 14.15.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^5.1.0"
+ }
+ },
+ "node_modules/copy-webpack-plugin/node_modules/glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "dependencies": {
+ "is-glob": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/core-js-compat": {
+ "version": "3.27.1",
+ "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.27.1.tgz",
+ "integrity": "sha512-Dg91JFeCDA17FKnneN7oCMz4BkQ4TcffkgHP4OWwp9yx3pi7ubqMDXXSacfNak1PQqjc95skyt+YBLHQJnkJwA==",
+ "dev": true,
+ "dependencies": {
+ "browserslist": "^4.21.4"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/core-js"
+ }
+ },
+ "node_modules/core-util-is": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz",
+ "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==",
+ "dev": true
+ },
+ "node_modules/cors": {
+ "version": "2.8.5",
+ "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz",
+ "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==",
+ "dev": true,
+ "dependencies": {
+ "object-assign": "^4",
+ "vary": "^1"
+ },
+ "engines": {
+ "node": ">= 0.10"
+ }
+ },
+ "node_modules/cosmiconfig": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.1.0.tgz",
+ "integrity": "sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==",
+ "dev": true,
+ "dependencies": {
+ "@types/parse-json": "^4.0.0",
+ "import-fresh": "^3.2.1",
+ "parse-json": "^5.0.0",
+ "path-type": "^4.0.0",
+ "yaml": "^1.10.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/critters": {
+ "version": "0.0.16",
+ "resolved": "https://registry.npmjs.org/critters/-/critters-0.0.16.tgz",
+ "integrity": "sha512-JwjgmO6i3y6RWtLYmXwO5jMd+maZt8Tnfu7VVISmEWyQqfLpB8soBswf8/2bu6SBXxtKA68Al3c+qIG1ApT68A==",
+ "dev": true,
+ "dependencies": {
+ "chalk": "^4.1.0",
+ "css-select": "^4.2.0",
+ "parse5": "^6.0.1",
+ "parse5-htmlparser2-tree-adapter": "^6.0.1",
+ "postcss": "^8.3.7",
+ "pretty-bytes": "^5.3.0"
+ }
+ },
+ "node_modules/critters/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/critters/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/critters/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/critters/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/critters/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/critters/node_modules/parse5": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz",
+ "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==",
+ "dev": true
+ },
+ "node_modules/critters/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/cross-spawn": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
+ "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
+ "dev": true,
+ "dependencies": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/cross-spawn/node_modules/which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/node-which"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/css-loader": {
+ "version": "6.7.3",
+ "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-6.7.3.tgz",
+ "integrity": "sha512-qhOH1KlBMnZP8FzRO6YCH9UHXQhVMcEGLyNdb7Hv2cpcmJbW0YrddO+tG1ab5nT41KpHIYGsbeHqxB9xPu1pKQ==",
+ "dev": true,
+ "dependencies": {
+ "icss-utils": "^5.1.0",
+ "postcss": "^8.4.19",
+ "postcss-modules-extract-imports": "^3.0.0",
+ "postcss-modules-local-by-default": "^4.0.0",
+ "postcss-modules-scope": "^3.0.0",
+ "postcss-modules-values": "^4.0.0",
+ "postcss-value-parser": "^4.2.0",
+ "semver": "^7.3.8"
+ },
+ "engines": {
+ "node": ">= 12.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^5.0.0"
+ }
+ },
+ "node_modules/css-select": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.3.0.tgz",
+ "integrity": "sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==",
+ "dev": true,
+ "dependencies": {
+ "boolbase": "^1.0.0",
+ "css-what": "^6.0.1",
+ "domhandler": "^4.3.1",
+ "domutils": "^2.8.0",
+ "nth-check": "^2.0.1"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/fb55"
+ }
+ },
+ "node_modules/css-what": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz",
+ "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/fb55"
+ }
+ },
+ "node_modules/cssesc": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz",
+ "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==",
+ "dev": true,
+ "bin": {
+ "cssesc": "bin/cssesc"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/custom-event": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/custom-event/-/custom-event-1.0.1.tgz",
+ "integrity": "sha512-GAj5FOq0Hd+RsCGVJxZuKaIDXDf3h6GQoNEjFgbLLI/trgtavwUbSnZ5pVfg27DVCaWjIohryS0JFwIJyT2cMg==",
+ "dev": true
+ },
+ "node_modules/date-format": {
+ "version": "4.0.14",
+ "resolved": "https://registry.npmjs.org/date-format/-/date-format-4.0.14.tgz",
+ "integrity": "sha512-39BOQLs9ZjKh0/patS9nrT8wc3ioX3/eA/zgbKNopnF2wCqJEoxywwwElATYvRsXdnOxA/OQeQoFZ3rFjVajhg==",
+ "dev": true,
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/debug": {
+ "version": "4.3.4",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
+ "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.1.2"
+ },
+ "engines": {
+ "node": ">=6.0"
+ },
+ "peerDependenciesMeta": {
+ "supports-color": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/default-gateway": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-6.0.3.tgz",
+ "integrity": "sha512-fwSOJsbbNzZ/CUFpqFBqYfYNLj1NbMPm8MMCIzHjC83iSJRBEGmDUxU+WP661BaBQImeC2yHwXtz+P/O9o+XEg==",
+ "dev": true,
+ "dependencies": {
+ "execa": "^5.0.0"
+ },
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/defaults": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.4.tgz",
+ "integrity": "sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A==",
+ "dev": true,
+ "dependencies": {
+ "clone": "^1.0.2"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/define-lazy-prop": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz",
+ "integrity": "sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/delegates": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz",
+ "integrity": "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==",
+ "dev": true
+ },
+ "node_modules/depd": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz",
+ "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/dependency-graph": {
+ "version": "0.11.0",
+ "resolved": "https://registry.npmjs.org/dependency-graph/-/dependency-graph-0.11.0.tgz",
+ "integrity": "sha512-JeMq7fEshyepOWDfcfHK06N3MhyPhz++vtqWhMT5O9A3K42rdsEDpfdVqjaqaAhsw6a+ZqeDvQVtD0hFHQWrzg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6.0"
+ }
+ },
+ "node_modules/destroy": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz",
+ "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8",
+ "npm": "1.2.8000 || >= 1.4.16"
+ }
+ },
+ "node_modules/detect-node": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.1.0.tgz",
+ "integrity": "sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==",
+ "dev": true
+ },
+ "node_modules/di": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/di/-/di-0.0.1.tgz",
+ "integrity": "sha512-uJaamHkagcZtHPqCIHZxnFrXlunQXgBOsZSUOWwFw31QJCAbyTBoHMW75YOTur5ZNx8pIeAKgf6GWIgaqqiLhA==",
+ "dev": true
+ },
+ "node_modules/dir-glob": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz",
+ "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==",
+ "dev": true,
+ "dependencies": {
+ "path-type": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/dns-equal": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/dns-equal/-/dns-equal-1.0.0.tgz",
+ "integrity": "sha512-z+paD6YUQsk+AbGCEM4PrOXSss5gd66QfcVBFTKR/HpFL9jCqikS94HYwKww6fQyO7IxrIIyUu+g0Ka9tUS2Cg==",
+ "dev": true
+ },
+ "node_modules/dns-packet": {
+ "version": "5.4.0",
+ "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-5.4.0.tgz",
+ "integrity": "sha512-EgqGeaBB8hLiHLZtp/IbaDQTL8pZ0+IvwzSHA6d7VyMDM+B9hgddEMa9xjK5oYnw0ci0JQ6g2XCD7/f6cafU6g==",
+ "dev": true,
+ "dependencies": {
+ "@leichtgewicht/ip-codec": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/dom-serialize": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/dom-serialize/-/dom-serialize-2.2.1.tgz",
+ "integrity": "sha512-Yra4DbvoW7/Z6LBN560ZwXMjoNOSAN2wRsKFGc4iBeso+mpIA6qj1vfdf9HpMaKAqG6wXTy+1SYEzmNpKXOSsQ==",
+ "dev": true,
+ "dependencies": {
+ "custom-event": "~1.0.0",
+ "ent": "~2.2.0",
+ "extend": "^3.0.0",
+ "void-elements": "^2.0.0"
+ }
+ },
+ "node_modules/dom-serializer": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.4.1.tgz",
+ "integrity": "sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==",
+ "dev": true,
+ "dependencies": {
+ "domelementtype": "^2.0.1",
+ "domhandler": "^4.2.0",
+ "entities": "^2.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1"
+ }
+ },
+ "node_modules/dom7": {
+ "version": "4.0.6",
+ "resolved": "https://registry.npmjs.org/dom7/-/dom7-4.0.6.tgz",
+ "integrity": "sha512-emjdpPLhpNubapLFdjNL9tP06Sr+GZkrIHEXLWvOGsytACUrkbeIdjO5g77m00BrHTznnlcNqgmn7pCN192TBA==",
+ "dependencies": {
+ "ssr-window": "^4.0.0"
+ }
+ },
+ "node_modules/domelementtype": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz",
+ "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/fb55"
+ }
+ ]
+ },
+ "node_modules/domhandler": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz",
+ "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==",
+ "dev": true,
+ "dependencies": {
+ "domelementtype": "^2.2.0"
+ },
+ "engines": {
+ "node": ">= 4"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/domhandler?sponsor=1"
+ }
+ },
+ "node_modules/domutils": {
+ "version": "2.8.0",
+ "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz",
+ "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==",
+ "dev": true,
+ "dependencies": {
+ "dom-serializer": "^1.0.1",
+ "domelementtype": "^2.2.0",
+ "domhandler": "^4.2.0"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/domutils?sponsor=1"
+ }
+ },
+ "node_modules/eastasianwidth": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz",
+ "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==",
+ "dev": true
+ },
+ "node_modules/echarts": {
+ "version": "5.4.1",
+ "resolved": "https://registry.npmjs.org/echarts/-/echarts-5.4.1.tgz",
+ "integrity": "sha512-9ltS3M2JB0w2EhcYjCdmtrJ+6haZcW6acBolMGIuf01Hql1yrIV01L1aRj7jsaaIULJslEP9Z3vKlEmnJaWJVQ==",
+ "dependencies": {
+ "tslib": "2.3.0",
+ "zrender": "5.4.1"
+ }
+ },
+ "node_modules/echarts/node_modules/tslib": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.0.tgz",
+ "integrity": "sha512-N82ooyxVNm6h1riLCoyS9e3fuJ3AMG2zIZs2Gd1ATcSFjSA23Q0fzjjZeh0jbJvWVDZ0cJT8yaNNaaXHzueNjg=="
+ },
+ "node_modules/ee-first": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
+ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==",
+ "dev": true
+ },
+ "node_modules/electron-to-chromium": {
+ "version": "1.4.284",
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz",
+ "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==",
+ "dev": true
+ },
+ "node_modules/emoji-regex": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
+ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
+ "dev": true
+ },
+ "node_modules/emojis-list": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz",
+ "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/encodeurl": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
+ "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/encoding": {
+ "version": "0.1.13",
+ "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz",
+ "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "iconv-lite": "^0.6.2"
+ }
+ },
+ "node_modules/encoding/node_modules/iconv-lite": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz",
+ "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "safer-buffer": ">= 2.1.2 < 3.0.0"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/engine.io": {
+ "version": "6.4.2",
+ "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-6.4.2.tgz",
+ "integrity": "sha512-FKn/3oMiJjrOEOeUub2WCox6JhxBXq/Zn3fZOMCBxKnNYtsdKjxhl7yR3fZhM9PV+rdE75SU5SYMc+2PGzo+Tg==",
+ "dev": true,
+ "dependencies": {
+ "@types/cookie": "^0.4.1",
+ "@types/cors": "^2.8.12",
+ "@types/node": ">=10.0.0",
+ "accepts": "~1.3.4",
+ "base64id": "2.0.0",
+ "cookie": "~0.4.1",
+ "cors": "~2.8.5",
+ "debug": "~4.3.1",
+ "engine.io-parser": "~5.0.3",
+ "ws": "~8.11.0"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/engine.io-parser": {
+ "version": "5.0.7",
+ "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.0.7.tgz",
+ "integrity": "sha512-P+jDFbvK6lE3n1OL+q9KuzdOFWkkZ/cMV9gol/SbVfpyqfvrfrFTOFJ6fQm2VC3PZHlU3QPhVwmbsCnauHF2MQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/enhanced-resolve": {
+ "version": "5.15.0",
+ "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.15.0.tgz",
+ "integrity": "sha512-LXYT42KJ7lpIKECr2mAXIaMldcNCh/7E0KBKOu4KSfkHmP+mZmSs+8V5gBAqisWBy0OO4W5Oyys0GO1Y8KtdKg==",
+ "dev": true,
+ "dependencies": {
+ "graceful-fs": "^4.2.4",
+ "tapable": "^2.2.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/ent": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/ent/-/ent-2.2.0.tgz",
+ "integrity": "sha512-GHrMyVZQWvTIdDtpiEXdHZnFQKzeO09apj8Cbl4pKWy4i0Oprcq17usfDt5aO63swf0JOeMWjWQE/LzgSRuWpA==",
+ "dev": true
+ },
+ "node_modules/entities": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz",
+ "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==",
+ "dev": true,
+ "funding": {
+ "url": "https://github.com/fb55/entities?sponsor=1"
+ }
+ },
+ "node_modules/env-paths": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz",
+ "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/err-code": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/err-code/-/err-code-2.0.3.tgz",
+ "integrity": "sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA==",
+ "dev": true
+ },
+ "node_modules/errno": {
+ "version": "0.1.8",
+ "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.8.tgz",
+ "integrity": "sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "prr": "~1.0.1"
+ },
+ "bin": {
+ "errno": "cli.js"
+ }
+ },
+ "node_modules/error-ex": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
+ "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
+ "dev": true,
+ "dependencies": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "node_modules/es-module-lexer": {
+ "version": "0.9.3",
+ "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-0.9.3.tgz",
+ "integrity": "sha512-1HQ2M2sPtxwnvOvT1ZClHyQDiggdNjURWpY2we6aMKCQiUVxTmVs2UYPLIrD84sS+kMdUwfBSylbJPwNnBrnHQ==",
+ "dev": true
+ },
+ "node_modules/esbuild": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.8.tgz",
+ "integrity": "sha512-g24ybC3fWhZddZK6R3uD2iF/RIPnRpwJAqLov6ouX3hMbY4+tKolP0VMF3zuIYCaXun+yHwS5IPQ91N2BT191g==",
+ "dev": true,
+ "hasInstallScript": true,
+ "optional": true,
+ "bin": {
+ "esbuild": "bin/esbuild"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "optionalDependencies": {
+ "@esbuild/android-arm": "0.17.8",
+ "@esbuild/android-arm64": "0.17.8",
+ "@esbuild/android-x64": "0.17.8",
+ "@esbuild/darwin-arm64": "0.17.8",
+ "@esbuild/darwin-x64": "0.17.8",
+ "@esbuild/freebsd-arm64": "0.17.8",
+ "@esbuild/freebsd-x64": "0.17.8",
+ "@esbuild/linux-arm": "0.17.8",
+ "@esbuild/linux-arm64": "0.17.8",
+ "@esbuild/linux-ia32": "0.17.8",
+ "@esbuild/linux-loong64": "0.17.8",
+ "@esbuild/linux-mips64el": "0.17.8",
+ "@esbuild/linux-ppc64": "0.17.8",
+ "@esbuild/linux-riscv64": "0.17.8",
+ "@esbuild/linux-s390x": "0.17.8",
+ "@esbuild/linux-x64": "0.17.8",
+ "@esbuild/netbsd-x64": "0.17.8",
+ "@esbuild/openbsd-x64": "0.17.8",
+ "@esbuild/sunos-x64": "0.17.8",
+ "@esbuild/win32-arm64": "0.17.8",
+ "@esbuild/win32-ia32": "0.17.8",
+ "@esbuild/win32-x64": "0.17.8"
+ }
+ },
+ "node_modules/esbuild-wasm": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/esbuild-wasm/-/esbuild-wasm-0.17.8.tgz",
+ "integrity": "sha512-zCmpxv95E0FuCmvdw1K836UHnj4EdiQnFfjTby35y3LAjRPtXMj3sbHDRHjbD8Mqg5lTwq3knacr/1qIFU51CQ==",
+ "dev": true,
+ "bin": {
+ "esbuild": "bin/esbuild"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/escalade": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
+ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/escape-html": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
+ "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==",
+ "dev": true
+ },
+ "node_modules/escape-string-regexp": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
+ "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/eslint-scope": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz",
+ "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==",
+ "dev": true,
+ "dependencies": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^4.1.1"
+ },
+ "engines": {
+ "node": ">=8.0.0"
+ }
+ },
+ "node_modules/esprima": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz",
+ "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==",
+ "dev": true,
+ "bin": {
+ "esparse": "bin/esparse.js",
+ "esvalidate": "bin/esvalidate.js"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "dependencies": {
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/esrecurse/node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estraverse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz",
+ "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==",
+ "dev": true,
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/etag": {
+ "version": "1.8.1",
+ "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
+ "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/eventemitter-asyncresource": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/eventemitter-asyncresource/-/eventemitter-asyncresource-1.0.0.tgz",
+ "integrity": "sha512-39F7TBIV0G7gTelxwbEqnwhp90eqCPON1k0NwNfwhgKn4Co4ybUbj2pECcXT0B3ztRKZ7Pw1JujUUgmQJHcVAQ==",
+ "dev": true
+ },
+ "node_modules/eventemitter3": {
+ "version": "4.0.7",
+ "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz",
+ "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==",
+ "dev": true
+ },
+ "node_modules/events": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz",
+ "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.x"
+ }
+ },
+ "node_modules/execa": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz",
+ "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==",
+ "dev": true,
+ "dependencies": {
+ "cross-spawn": "^7.0.3",
+ "get-stream": "^6.0.0",
+ "human-signals": "^2.1.0",
+ "is-stream": "^2.0.0",
+ "merge-stream": "^2.0.0",
+ "npm-run-path": "^4.0.1",
+ "onetime": "^5.1.2",
+ "signal-exit": "^3.0.3",
+ "strip-final-newline": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sindresorhus/execa?sponsor=1"
+ }
+ },
+ "node_modules/exponential-backoff": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/exponential-backoff/-/exponential-backoff-3.1.1.tgz",
+ "integrity": "sha512-dX7e/LHVJ6W3DE1MHWi9S1EYzDESENfLrYohG2G++ovZrYOkm4Knwa0mc1cn84xJOR4KEU0WSchhLbd0UklbHw==",
+ "dev": true
+ },
+ "node_modules/express": {
+ "version": "4.18.2",
+ "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz",
+ "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==",
+ "dev": true,
+ "dependencies": {
+ "accepts": "~1.3.8",
+ "array-flatten": "1.1.1",
+ "body-parser": "1.20.1",
+ "content-disposition": "0.5.4",
+ "content-type": "~1.0.4",
+ "cookie": "0.5.0",
+ "cookie-signature": "1.0.6",
+ "debug": "2.6.9",
+ "depd": "2.0.0",
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "etag": "~1.8.1",
+ "finalhandler": "1.2.0",
+ "fresh": "0.5.2",
+ "http-errors": "2.0.0",
+ "merge-descriptors": "1.0.1",
+ "methods": "~1.1.2",
+ "on-finished": "2.4.1",
+ "parseurl": "~1.3.3",
+ "path-to-regexp": "0.1.7",
+ "proxy-addr": "~2.0.7",
+ "qs": "6.11.0",
+ "range-parser": "~1.2.1",
+ "safe-buffer": "5.2.1",
+ "send": "0.18.0",
+ "serve-static": "1.15.0",
+ "setprototypeof": "1.2.0",
+ "statuses": "2.0.1",
+ "type-is": "~1.6.18",
+ "utils-merge": "1.0.1",
+ "vary": "~1.1.2"
+ },
+ "engines": {
+ "node": ">= 0.10.0"
+ }
+ },
+ "node_modules/express/node_modules/array-flatten": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
+ "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==",
+ "dev": true
+ },
+ "node_modules/express/node_modules/cookie": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz",
+ "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/express/node_modules/debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.0.0"
+ }
+ },
+ "node_modules/express/node_modules/finalhandler": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz",
+ "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==",
+ "dev": true,
+ "dependencies": {
+ "debug": "2.6.9",
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "on-finished": "2.4.1",
+ "parseurl": "~1.3.3",
+ "statuses": "2.0.1",
+ "unpipe": "~1.0.0"
+ },
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/express/node_modules/ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "node_modules/express/node_modules/statuses": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
+ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/extend": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz",
+ "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==",
+ "dev": true
+ },
+ "node_modules/external-editor": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz",
+ "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==",
+ "dev": true,
+ "dependencies": {
+ "chardet": "^0.7.0",
+ "iconv-lite": "^0.4.24",
+ "tmp": "^0.0.33"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true
+ },
+ "node_modules/fast-glob": {
+ "version": "3.2.12",
+ "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz",
+ "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==",
+ "dev": true,
+ "dependencies": {
+ "@nodelib/fs.stat": "^2.0.2",
+ "@nodelib/fs.walk": "^1.2.3",
+ "glob-parent": "^5.1.2",
+ "merge2": "^1.3.0",
+ "micromatch": "^4.0.4"
+ },
+ "engines": {
+ "node": ">=8.6.0"
+ }
+ },
+ "node_modules/fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true
+ },
+ "node_modules/fastq": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz",
+ "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==",
+ "dev": true,
+ "dependencies": {
+ "reusify": "^1.0.4"
+ }
+ },
+ "node_modules/faye-websocket": {
+ "version": "0.11.4",
+ "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz",
+ "integrity": "sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==",
+ "dev": true,
+ "dependencies": {
+ "websocket-driver": ">=0.5.1"
+ },
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/figures": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz",
+ "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==",
+ "dev": true,
+ "dependencies": {
+ "escape-string-regexp": "^1.0.5"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/fill-range": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
+ "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
+ "dev": true,
+ "dependencies": {
+ "to-regex-range": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/finalhandler": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz",
+ "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==",
+ "dev": true,
+ "dependencies": {
+ "debug": "2.6.9",
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "on-finished": "~2.3.0",
+ "parseurl": "~1.3.3",
+ "statuses": "~1.5.0",
+ "unpipe": "~1.0.0"
+ },
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/finalhandler/node_modules/debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.0.0"
+ }
+ },
+ "node_modules/finalhandler/node_modules/ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "node_modules/finalhandler/node_modules/on-finished": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
+ "integrity": "sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==",
+ "dev": true,
+ "dependencies": {
+ "ee-first": "1.1.1"
+ },
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/find-cache-dir": {
+ "version": "3.3.2",
+ "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz",
+ "integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==",
+ "dev": true,
+ "dependencies": {
+ "commondir": "^1.0.1",
+ "make-dir": "^3.0.2",
+ "pkg-dir": "^4.1.0"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/avajs/find-cache-dir?sponsor=1"
+ }
+ },
+ "node_modules/find-up": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
+ "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
+ "dev": true,
+ "dependencies": {
+ "locate-path": "^5.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/flatted": {
+ "version": "3.2.7",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz",
+ "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==",
+ "dev": true
+ },
+ "node_modules/follow-redirects": {
+ "version": "1.15.2",
+ "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.2.tgz",
+ "integrity": "sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "individual",
+ "url": "https://github.com/sponsors/RubenVerborgh"
+ }
+ ],
+ "engines": {
+ "node": ">=4.0"
+ },
+ "peerDependenciesMeta": {
+ "debug": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/foreground-child": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.1.1.tgz",
+ "integrity": "sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg==",
+ "dev": true,
+ "dependencies": {
+ "cross-spawn": "^7.0.0",
+ "signal-exit": "^4.0.1"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/foreground-child/node_modules/signal-exit": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz",
+ "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==",
+ "dev": true,
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/forwarded": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
+ "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/fraction.js": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz",
+ "integrity": "sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA==",
+ "dev": true,
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "type": "patreon",
+ "url": "https://www.patreon.com/infusion"
+ }
+ },
+ "node_modules/fresh": {
+ "version": "0.5.2",
+ "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
+ "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/fs-extra": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz",
+ "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==",
+ "dev": true,
+ "dependencies": {
+ "graceful-fs": "^4.2.0",
+ "jsonfile": "^4.0.0",
+ "universalify": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=6 <7 || >=8"
+ }
+ },
+ "node_modules/fs-minipass": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-3.0.0.tgz",
+ "integrity": "sha512-EUojgQaSPy6sxcqcZgQv6TVF6jiKvurji3AxhAivs/Ep4O1UpS8TusaxpybfFHZ2skRhLqzk6WR8nqNYIMMDeA==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^4.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/fs-monkey": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/fs-monkey/-/fs-monkey-1.0.3.tgz",
+ "integrity": "sha512-cybjIfiiE+pTWicSCLFHSrXZ6EilF30oh91FDP9S2B051prEa7QWfrVTQm10/dDpswBDXZugPa1Ogu8Yh+HV0Q==",
+ "dev": true
+ },
+ "node_modules/fs.realpath": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
+ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==",
+ "dev": true
+ },
+ "node_modules/fsevents": {
+ "version": "2.3.2",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
+ "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
+ "dev": true,
+ "hasInstallScript": true,
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
+ }
+ },
+ "node_modules/function-bind": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
+ "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==",
+ "dev": true
+ },
+ "node_modules/gauge": {
+ "version": "4.0.4",
+ "resolved": "https://registry.npmjs.org/gauge/-/gauge-4.0.4.tgz",
+ "integrity": "sha512-f9m+BEN5jkg6a0fZjleidjN51VE1X+mPFQ2DJ0uv1V39oCLCbsGe6yjbBnp7eK7z/+GAon99a3nHuqbuuthyPg==",
+ "dev": true,
+ "dependencies": {
+ "aproba": "^1.0.3 || ^2.0.0",
+ "color-support": "^1.1.3",
+ "console-control-strings": "^1.1.0",
+ "has-unicode": "^2.0.1",
+ "signal-exit": "^3.0.7",
+ "string-width": "^4.2.3",
+ "strip-ansi": "^6.0.1",
+ "wide-align": "^1.1.5"
+ },
+ "engines": {
+ "node": "^12.13.0 || ^14.15.0 || >=16.0.0"
+ }
+ },
+ "node_modules/gensync": {
+ "version": "1.0.0-beta.2",
+ "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
+ "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/get-caller-file": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
+ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
+ "dev": true,
+ "engines": {
+ "node": "6.* || 8.* || >= 10.*"
+ }
+ },
+ "node_modules/get-intrinsic": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz",
+ "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==",
+ "dev": true,
+ "dependencies": {
+ "function-bind": "^1.1.1",
+ "has": "^1.0.3",
+ "has-symbols": "^1.0.3"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/get-package-type": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz",
+ "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8.0.0"
+ }
+ },
+ "node_modules/get-stream": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz",
+ "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/glob": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz",
+ "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==",
+ "dev": true,
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^5.0.1",
+ "once": "^1.3.0"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/glob-parent": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
+ "dev": true,
+ "dependencies": {
+ "is-glob": "^4.0.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/glob-to-regexp": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz",
+ "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==",
+ "dev": true
+ },
+ "node_modules/globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/globby": {
+ "version": "13.1.3",
+ "resolved": "https://registry.npmjs.org/globby/-/globby-13.1.3.tgz",
+ "integrity": "sha512-8krCNHXvlCgHDpegPzleMq07yMYTO2sXKASmZmquEYWEmCx6J5UTRbp5RwMJkTJGtcQ44YpiUYUiN0b9mzy8Bw==",
+ "dev": true,
+ "dependencies": {
+ "dir-glob": "^3.0.1",
+ "fast-glob": "^3.2.11",
+ "ignore": "^5.2.0",
+ "merge2": "^1.4.1",
+ "slash": "^4.0.0"
+ },
+ "engines": {
+ "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/graceful-fs": {
+ "version": "4.2.10",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz",
+ "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==",
+ "dev": true
+ },
+ "node_modules/handle-thing": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/handle-thing/-/handle-thing-2.0.1.tgz",
+ "integrity": "sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==",
+ "dev": true
+ },
+ "node_modules/has": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
+ "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
+ "dev": true,
+ "dependencies": {
+ "function-bind": "^1.1.1"
+ },
+ "engines": {
+ "node": ">= 0.4.0"
+ }
+ },
+ "node_modules/has-flag": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
+ "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/has-symbols": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
+ "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/has-unicode": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz",
+ "integrity": "sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==",
+ "dev": true
+ },
+ "node_modules/hdr-histogram-js": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/hdr-histogram-js/-/hdr-histogram-js-2.0.3.tgz",
+ "integrity": "sha512-Hkn78wwzWHNCp2uarhzQ2SGFLU3JY8SBDDd3TAABK4fc30wm+MuPOrg5QVFVfkKOQd6Bfz3ukJEI+q9sXEkK1g==",
+ "dev": true,
+ "dependencies": {
+ "@assemblyscript/loader": "^0.10.1",
+ "base64-js": "^1.2.0",
+ "pako": "^1.0.3"
+ }
+ },
+ "node_modules/hdr-histogram-percentiles-obj": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/hdr-histogram-percentiles-obj/-/hdr-histogram-percentiles-obj-3.0.0.tgz",
+ "integrity": "sha512-7kIufnBqdsBGcSZLPJwqHT3yhk1QTsSlFsVD3kx5ixH/AlgBs9yM1q6DPhXZ8f8gtdqgh7N7/5btRLpQsS2gHw==",
+ "dev": true
+ },
+ "node_modules/hosted-git-info": {
+ "version": "6.1.1",
+ "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-6.1.1.tgz",
+ "integrity": "sha512-r0EI+HBMcXadMrugk0GCQ+6BQV39PiWAZVfq7oIckeGiN7sjRGyQxPdft3nQekFTCQbYxLBH+/axZMeH8UX6+w==",
+ "dev": true,
+ "dependencies": {
+ "lru-cache": "^7.5.1"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/hosted-git-info/node_modules/lru-cache": {
+ "version": "7.18.3",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz",
+ "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/hpack.js": {
+ "version": "2.1.6",
+ "resolved": "https://registry.npmjs.org/hpack.js/-/hpack.js-2.1.6.tgz",
+ "integrity": "sha512-zJxVehUdMGIKsRaNt7apO2Gqp0BdqW5yaiGHXXmbpvxgBYVZnAql+BJb4RO5ad2MgpbZKn5G6nMnegrH1FcNYQ==",
+ "dev": true,
+ "dependencies": {
+ "inherits": "^2.0.1",
+ "obuf": "^1.0.0",
+ "readable-stream": "^2.0.1",
+ "wbuf": "^1.1.0"
+ }
+ },
+ "node_modules/hpack.js/node_modules/readable-stream": {
+ "version": "2.3.7",
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz",
+ "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==",
+ "dev": true,
+ "dependencies": {
+ "core-util-is": "~1.0.0",
+ "inherits": "~2.0.3",
+ "isarray": "~1.0.0",
+ "process-nextick-args": "~2.0.0",
+ "safe-buffer": "~5.1.1",
+ "string_decoder": "~1.1.1",
+ "util-deprecate": "~1.0.1"
+ }
+ },
+ "node_modules/hpack.js/node_modules/safe-buffer": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
+ "dev": true
+ },
+ "node_modules/hpack.js/node_modules/string_decoder": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
+ "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
+ "dev": true,
+ "dependencies": {
+ "safe-buffer": "~5.1.0"
+ }
+ },
+ "node_modules/html-entities": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-2.3.3.tgz",
+ "integrity": "sha512-DV5Ln36z34NNTDgnz0EWGBLZENelNAtkiFA4kyNOG2tDI6Mz1uSWiq1wAKdyjnJwyDiDO7Fa2SO1CTxPXL8VxA==",
+ "dev": true
+ },
+ "node_modules/html-escaper": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz",
+ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==",
+ "dev": true
+ },
+ "node_modules/http-cache-semantics": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz",
+ "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==",
+ "dev": true
+ },
+ "node_modules/http-deceiver": {
+ "version": "1.2.7",
+ "resolved": "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz",
+ "integrity": "sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw==",
+ "dev": true
+ },
+ "node_modules/http-errors": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz",
+ "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==",
+ "dev": true,
+ "dependencies": {
+ "depd": "2.0.0",
+ "inherits": "2.0.4",
+ "setprototypeof": "1.2.0",
+ "statuses": "2.0.1",
+ "toidentifier": "1.0.1"
+ },
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/http-errors/node_modules/statuses": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
+ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/http-parser-js": {
+ "version": "0.5.8",
+ "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.8.tgz",
+ "integrity": "sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q==",
+ "dev": true
+ },
+ "node_modules/http-proxy": {
+ "version": "1.18.1",
+ "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.18.1.tgz",
+ "integrity": "sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ==",
+ "dev": true,
+ "dependencies": {
+ "eventemitter3": "^4.0.0",
+ "follow-redirects": "^1.0.0",
+ "requires-port": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=8.0.0"
+ }
+ },
+ "node_modules/http-proxy-agent": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz",
+ "integrity": "sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w==",
+ "dev": true,
+ "dependencies": {
+ "@tootallnate/once": "2",
+ "agent-base": "6",
+ "debug": "4"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/http-proxy-middleware": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-2.0.6.tgz",
+ "integrity": "sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw==",
+ "dev": true,
+ "dependencies": {
+ "@types/http-proxy": "^1.17.8",
+ "http-proxy": "^1.18.1",
+ "is-glob": "^4.0.1",
+ "is-plain-obj": "^3.0.0",
+ "micromatch": "^4.0.2"
+ },
+ "engines": {
+ "node": ">=12.0.0"
+ },
+ "peerDependencies": {
+ "@types/express": "^4.17.13"
+ },
+ "peerDependenciesMeta": {
+ "@types/express": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/https-proxy-agent": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz",
+ "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==",
+ "dev": true,
+ "dependencies": {
+ "agent-base": "6",
+ "debug": "4"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/human-signals": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz",
+ "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.17.0"
+ }
+ },
+ "node_modules/humanize-ms": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/humanize-ms/-/humanize-ms-1.2.1.tgz",
+ "integrity": "sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ==",
+ "dev": true,
+ "dependencies": {
+ "ms": "^2.0.0"
+ }
+ },
+ "node_modules/iconv-lite": {
+ "version": "0.4.24",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
+ "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
+ "dev": true,
+ "dependencies": {
+ "safer-buffer": ">= 2.1.2 < 3"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/icss-utils": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-5.1.0.tgz",
+ "integrity": "sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA==",
+ "dev": true,
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/ieee754": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
+ "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ]
+ },
+ "node_modules/ignore": {
+ "version": "5.2.4",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz",
+ "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/ignore-walk": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-6.0.3.tgz",
+ "integrity": "sha512-C7FfFoTA+bI10qfeydT8aZbvr91vAEU+2W5BZUlzPec47oNb07SsOfwYrtxuvOYdUApPP/Qlh4DtAO51Ekk2QA==",
+ "dev": true,
+ "dependencies": {
+ "minimatch": "^9.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/ignore-walk/node_modules/minimatch": {
+ "version": "9.0.3",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz",
+ "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/image-size": {
+ "version": "0.5.5",
+ "resolved": "https://registry.npmjs.org/image-size/-/image-size-0.5.5.tgz",
+ "integrity": "sha512-6TDAlDPZxUFCv+fuOkIoXT/V/f3Qbq8e37p+YOiYrUv3v9cc3/6x78VdfPgFVaB9dZYeLUfKgHRebpkm/oP2VQ==",
+ "dev": true,
+ "optional": true,
+ "bin": {
+ "image-size": "bin/image-size.js"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/immutable": {
+ "version": "4.3.2",
+ "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.3.2.tgz",
+ "integrity": "sha512-oGXzbEDem9OOpDWZu88jGiYCvIsLHMvGw+8OXlpsvTFvIQplQbjg1B1cvKg8f7Hoch6+NGjpPsH1Fr+Mc2D1aA==",
+ "dev": true
+ },
+ "node_modules/import-fresh": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
+ "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
+ "dev": true,
+ "dependencies": {
+ "parent-module": "^1.0.0",
+ "resolve-from": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/import-fresh/node_modules/resolve-from": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
+ "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.19"
+ }
+ },
+ "node_modules/indent-string": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz",
+ "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/inflight": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
+ "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==",
+ "dev": true,
+ "dependencies": {
+ "once": "^1.3.0",
+ "wrappy": "1"
+ }
+ },
+ "node_modules/inherits": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==",
+ "dev": true
+ },
+ "node_modules/ini": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/ini/-/ini-3.0.1.tgz",
+ "integrity": "sha512-it4HyVAUTKBc6m8e1iXWvXSTdndF7HbdN713+kvLrymxTaU4AUBWrJ4vEooP+V7fexnVD3LKcBshjGGPefSMUQ==",
+ "dev": true,
+ "engines": {
+ "node": "^12.13.0 || ^14.15.0 || >=16.0.0"
+ }
+ },
+ "node_modules/inquirer": {
+ "version": "8.2.4",
+ "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-8.2.4.tgz",
+ "integrity": "sha512-nn4F01dxU8VeKfq192IjLsxu0/OmMZ4Lg3xKAns148rCaXP6ntAoEkVYZThWjwON8AlzdZZi6oqnhNbxUG9hVg==",
+ "dev": true,
+ "dependencies": {
+ "ansi-escapes": "^4.2.1",
+ "chalk": "^4.1.1",
+ "cli-cursor": "^3.1.0",
+ "cli-width": "^3.0.0",
+ "external-editor": "^3.0.3",
+ "figures": "^3.0.0",
+ "lodash": "^4.17.21",
+ "mute-stream": "0.0.8",
+ "ora": "^5.4.1",
+ "run-async": "^2.4.0",
+ "rxjs": "^7.5.5",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0",
+ "through": "^2.3.6",
+ "wrap-ansi": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=12.0.0"
+ }
+ },
+ "node_modules/inquirer/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/inquirer/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/inquirer/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/inquirer/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/inquirer/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/inquirer/node_modules/rxjs": {
+ "version": "7.8.0",
+ "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.0.tgz",
+ "integrity": "sha512-F2+gxDshqmIub1KdvZkaEfGDwLNpPvk9Fs6LD/MyQxNgMds/WH9OdDDXOmxUZpME+iSK3rQCctkL0DYyytUqMg==",
+ "dev": true,
+ "dependencies": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "node_modules/inquirer/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/ip": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz",
+ "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==",
+ "dev": true
+ },
+ "node_modules/ipaddr.js": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-2.0.1.tgz",
+ "integrity": "sha512-1qTgH9NG+IIJ4yfKs2e6Pp1bZg8wbDbKHT21HrLIeYBTRLgMYKnMTPAuI3Lcs61nfx5h1xlXnbJtH1kX5/d/ng==",
+ "dev": true,
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
+ "dev": true
+ },
+ "node_modules/is-binary-path": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
+ "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
+ "dev": true,
+ "dependencies": {
+ "binary-extensions": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-core-module": {
+ "version": "2.11.0",
+ "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz",
+ "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==",
+ "dev": true,
+ "dependencies": {
+ "has": "^1.0.3"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/is-docker": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz",
+ "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==",
+ "dev": true,
+ "bin": {
+ "is-docker": "cli.js"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-fullwidth-code-point": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
+ "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "dev": true,
+ "dependencies": {
+ "is-extglob": "^2.1.1"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-interactive": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-interactive/-/is-interactive-1.0.0.tgz",
+ "integrity": "sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/is-lambda": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/is-lambda/-/is-lambda-1.0.1.tgz",
+ "integrity": "sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ==",
+ "dev": true
+ },
+ "node_modules/is-number": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.12.0"
+ }
+ },
+ "node_modules/is-plain-obj": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-3.0.0.tgz",
+ "integrity": "sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/is-plain-object": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz",
+ "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==",
+ "dev": true,
+ "dependencies": {
+ "isobject": "^3.0.1"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-stream": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz",
+ "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/is-unicode-supported": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz",
+ "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/is-what": {
+ "version": "3.14.1",
+ "resolved": "https://registry.npmjs.org/is-what/-/is-what-3.14.1.tgz",
+ "integrity": "sha512-sNxgpk9793nzSs7bA6JQJGeIuRBQhAaNGG77kzYQgMkrID+lS6SlK07K5LaptscDlSaIgH+GPFzf+d75FVxozA==",
+ "dev": true
+ },
+ "node_modules/is-wsl": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz",
+ "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==",
+ "dev": true,
+ "dependencies": {
+ "is-docker": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/isarray": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
+ "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==",
+ "dev": true
+ },
+ "node_modules/isbinaryfile": {
+ "version": "4.0.10",
+ "resolved": "https://registry.npmjs.org/isbinaryfile/-/isbinaryfile-4.0.10.tgz",
+ "integrity": "sha512-iHrqe5shvBUcFbmZq9zOQHBoeOhZJu6RQGrDpBgenUm/Am+F3JM2MgQj+rK3Z601fzrL5gLZWtAPH2OBaSVcyw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 8.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/gjtorikian/"
+ }
+ },
+ "node_modules/isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
+ "dev": true
+ },
+ "node_modules/isobject": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz",
+ "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/istanbul-lib-coverage": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz",
+ "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-instrument": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz",
+ "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/core": "^7.12.3",
+ "@babel/parser": "^7.14.7",
+ "@istanbuljs/schema": "^0.1.2",
+ "istanbul-lib-coverage": "^3.2.0",
+ "semver": "^6.3.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-instrument/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/istanbul-lib-report": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz",
+ "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==",
+ "dev": true,
+ "dependencies": {
+ "istanbul-lib-coverage": "^3.0.0",
+ "make-dir": "^3.0.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-report/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-report/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/istanbul-lib-source-maps": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz",
+ "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==",
+ "dev": true,
+ "dependencies": {
+ "debug": "^4.1.1",
+ "istanbul-lib-coverage": "^3.0.0",
+ "source-map": "^0.6.1"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/istanbul-lib-source-maps/node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/istanbul-reports": {
+ "version": "3.1.5",
+ "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz",
+ "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==",
+ "dev": true,
+ "dependencies": {
+ "html-escaper": "^2.0.0",
+ "istanbul-lib-report": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jackspeak": {
+ "version": "2.2.2",
+ "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.2.2.tgz",
+ "integrity": "sha512-mgNtVv4vUuaKA97yxUHoA3+FkuhtxkjdXEWOyB/N76fjy0FjezEt34oy3epBtvCvS+7DyKwqCFWx/oJLV5+kCg==",
+ "dev": true,
+ "dependencies": {
+ "@isaacs/cliui": "^8.0.2"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ },
+ "optionalDependencies": {
+ "@pkgjs/parseargs": "^0.11.0"
+ }
+ },
+ "node_modules/jasmine-core": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-4.5.0.tgz",
+ "integrity": "sha512-9PMzyvhtocxb3aXJVOPqBDswdgyAeSB81QnLop4npOpbqnheaTEwPc9ZloQeVswugPManznQBjD8kWDTjlnHuw==",
+ "dev": true
+ },
+ "node_modules/jest-worker": {
+ "version": "27.5.1",
+ "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz",
+ "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==",
+ "dev": true,
+ "dependencies": {
+ "@types/node": "*",
+ "merge-stream": "^2.0.0",
+ "supports-color": "^8.0.0"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ }
+ },
+ "node_modules/jest-worker/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/jest-worker/node_modules/supports-color": {
+ "version": "8.1.1",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz",
+ "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/supports-color?sponsor=1"
+ }
+ },
+ "node_modules/js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
+ "dev": true
+ },
+ "node_modules/js-yaml": {
+ "version": "3.14.1",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz",
+ "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==",
+ "dev": true,
+ "dependencies": {
+ "argparse": "^1.0.7",
+ "esprima": "^4.0.0"
+ },
+ "bin": {
+ "js-yaml": "bin/js-yaml.js"
+ }
+ },
+ "node_modules/jsesc": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
+ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
+ "dev": true,
+ "bin": {
+ "jsesc": "bin/jsesc"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/json-parse-even-better-errors": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
+ "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
+ "dev": true
+ },
+ "node_modules/json-schema-traverse": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz",
+ "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==",
+ "dev": true
+ },
+ "node_modules/json5": {
+ "version": "2.2.3",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
+ "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
+ "dev": true,
+ "bin": {
+ "json5": "lib/cli.js"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/jsonc-parser": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.2.0.tgz",
+ "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==",
+ "dev": true
+ },
+ "node_modules/jsonfile": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz",
+ "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==",
+ "dev": true,
+ "optionalDependencies": {
+ "graceful-fs": "^4.1.6"
+ }
+ },
+ "node_modules/jsonparse": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz",
+ "integrity": "sha512-POQXvpdL69+CluYsillJ7SUhKvytYjW9vG/GKpnf+xP8UWgYEM/RaMzHHofbALDiKbbP1W8UEYmgGl39WkPZsg==",
+ "dev": true,
+ "engines": [
+ "node >= 0.2.0"
+ ]
+ },
+ "node_modules/karma": {
+ "version": "6.4.1",
+ "resolved": "https://registry.npmjs.org/karma/-/karma-6.4.1.tgz",
+ "integrity": "sha512-Cj57NKOskK7wtFWSlMvZf459iX+kpYIPXmkNUzP2WAFcA7nhr/ALn5R7sw3w+1udFDcpMx/tuB8d5amgm3ijaA==",
+ "dev": true,
+ "dependencies": {
+ "@colors/colors": "1.5.0",
+ "body-parser": "^1.19.0",
+ "braces": "^3.0.2",
+ "chokidar": "^3.5.1",
+ "connect": "^3.7.0",
+ "di": "^0.0.1",
+ "dom-serialize": "^2.2.1",
+ "glob": "^7.1.7",
+ "graceful-fs": "^4.2.6",
+ "http-proxy": "^1.18.1",
+ "isbinaryfile": "^4.0.8",
+ "lodash": "^4.17.21",
+ "log4js": "^6.4.1",
+ "mime": "^2.5.2",
+ "minimatch": "^3.0.4",
+ "mkdirp": "^0.5.5",
+ "qjobs": "^1.2.0",
+ "range-parser": "^1.2.1",
+ "rimraf": "^3.0.2",
+ "socket.io": "^4.4.1",
+ "source-map": "^0.6.1",
+ "tmp": "^0.2.1",
+ "ua-parser-js": "^0.7.30",
+ "yargs": "^16.1.1"
+ },
+ "bin": {
+ "karma": "bin/karma"
+ },
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/karma-chrome-launcher": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/karma-chrome-launcher/-/karma-chrome-launcher-3.1.1.tgz",
+ "integrity": "sha512-hsIglcq1vtboGPAN+DGCISCFOxW+ZVnIqhDQcCMqqCp+4dmJ0Qpq5QAjkbA0X2L9Mi6OBkHi2Srrbmm7pUKkzQ==",
+ "dev": true,
+ "dependencies": {
+ "which": "^1.2.1"
+ }
+ },
+ "node_modules/karma-coverage": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/karma-coverage/-/karma-coverage-2.2.0.tgz",
+ "integrity": "sha512-gPVdoZBNDZ08UCzdMHHhEImKrw1+PAOQOIiffv1YsvxFhBjqvo/SVXNk4tqn1SYqX0BJZT6S/59zgxiBe+9OuA==",
+ "dev": true,
+ "dependencies": {
+ "istanbul-lib-coverage": "^3.2.0",
+ "istanbul-lib-instrument": "^5.1.0",
+ "istanbul-lib-report": "^3.0.0",
+ "istanbul-lib-source-maps": "^4.0.1",
+ "istanbul-reports": "^3.0.5",
+ "minimatch": "^3.0.4"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/karma-coverage/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/karma-coverage/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/karma-jasmine": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/karma-jasmine/-/karma-jasmine-4.0.2.tgz",
+ "integrity": "sha512-ggi84RMNQffSDmWSyyt4zxzh2CQGwsxvYYsprgyR1j8ikzIduEdOlcLvXjZGwXG/0j41KUXOWsUCBfbEHPWP9g==",
+ "dev": true,
+ "dependencies": {
+ "jasmine-core": "^3.6.0"
+ },
+ "engines": {
+ "node": ">= 10"
+ },
+ "peerDependencies": {
+ "karma": "*"
+ }
+ },
+ "node_modules/karma-jasmine-html-reporter": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/karma-jasmine-html-reporter/-/karma-jasmine-html-reporter-1.7.0.tgz",
+ "integrity": "sha512-pzum1TL7j90DTE86eFt48/s12hqwQuiD+e5aXx2Dc9wDEn2LfGq6RoAxEZZjFiN0RDSCOnosEKRZWxbQ+iMpQQ==",
+ "dev": true,
+ "peerDependencies": {
+ "jasmine-core": ">=3.8",
+ "karma": ">=0.9",
+ "karma-jasmine": ">=1.1"
+ }
+ },
+ "node_modules/karma-jasmine/node_modules/jasmine-core": {
+ "version": "3.99.1",
+ "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-3.99.1.tgz",
+ "integrity": "sha512-Hu1dmuoGcZ7AfyynN3LsfruwMbxMALMka+YtZeGoLuDEySVmVAPaonkNoBRIw/ectu8b9tVQCJNgp4a4knp+tg==",
+ "dev": true
+ },
+ "node_modules/karma-source-map-support": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/karma-source-map-support/-/karma-source-map-support-1.4.0.tgz",
+ "integrity": "sha512-RsBECncGO17KAoJCYXjv+ckIz+Ii9NCi+9enk+rq6XC81ezYkb4/RHE6CTXdA7IOJqoF3wcaLfVG0CPmE5ca6A==",
+ "dev": true,
+ "dependencies": {
+ "source-map-support": "^0.5.5"
+ }
+ },
+ "node_modules/karma/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/karma/node_modules/cliui": {
+ "version": "7.0.4",
+ "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz",
+ "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==",
+ "dev": true,
+ "dependencies": {
+ "string-width": "^4.2.0",
+ "strip-ansi": "^6.0.0",
+ "wrap-ansi": "^7.0.0"
+ }
+ },
+ "node_modules/karma/node_modules/glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ },
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/karma/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/karma/node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/karma/node_modules/tmp": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.2.1.tgz",
+ "integrity": "sha512-76SUhtfqR2Ijn+xllcI5P1oyannHNHByD80W1q447gU3mp9G9PSpGdWmjUOHRDPiHYacIk66W7ubDTuPF3BEtQ==",
+ "dev": true,
+ "dependencies": {
+ "rimraf": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8.17.0"
+ }
+ },
+ "node_modules/karma/node_modules/yargs": {
+ "version": "16.2.0",
+ "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz",
+ "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==",
+ "dev": true,
+ "dependencies": {
+ "cliui": "^7.0.2",
+ "escalade": "^3.1.1",
+ "get-caller-file": "^2.0.5",
+ "require-directory": "^2.1.1",
+ "string-width": "^4.2.0",
+ "y18n": "^5.0.5",
+ "yargs-parser": "^20.2.2"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/karma/node_modules/yargs-parser": {
+ "version": "20.2.9",
+ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz",
+ "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/kind-of": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
+ "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/klona": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/klona/-/klona-2.0.5.tgz",
+ "integrity": "sha512-pJiBpiXMbt7dkzXe8Ghj/u4FfXOOa98fPW+bihOJ4SjnoijweJrNThJfd3ifXpXhREjpoF2mZVH1GfS9LV3kHQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/less": {
+ "version": "4.1.3",
+ "resolved": "https://registry.npmjs.org/less/-/less-4.1.3.tgz",
+ "integrity": "sha512-w16Xk/Ta9Hhyei0Gpz9m7VS8F28nieJaL/VyShID7cYvP6IL5oHeL6p4TXSDJqZE/lNv0oJ2pGVjJsRkfwm5FA==",
+ "dev": true,
+ "dependencies": {
+ "copy-anything": "^2.0.1",
+ "parse-node-version": "^1.0.1",
+ "tslib": "^2.3.0"
+ },
+ "bin": {
+ "lessc": "bin/lessc"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "optionalDependencies": {
+ "errno": "^0.1.1",
+ "graceful-fs": "^4.1.2",
+ "image-size": "~0.5.0",
+ "make-dir": "^2.1.0",
+ "mime": "^1.4.1",
+ "needle": "^3.1.0",
+ "source-map": "~0.6.0"
+ }
+ },
+ "node_modules/less-loader": {
+ "version": "11.1.0",
+ "resolved": "https://registry.npmjs.org/less-loader/-/less-loader-11.1.0.tgz",
+ "integrity": "sha512-C+uDBV7kS7W5fJlUjq5mPBeBVhYpTIm5gB09APT9o3n/ILeaXVsiSFTbZpTJCJwQ/Crczfn3DmfQFwxYusWFug==",
+ "dev": true,
+ "dependencies": {
+ "klona": "^2.0.4"
+ },
+ "engines": {
+ "node": ">= 14.15.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "less": "^3.5.0 || ^4.0.0",
+ "webpack": "^5.0.0"
+ }
+ },
+ "node_modules/less/node_modules/make-dir": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz",
+ "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "pify": "^4.0.1",
+ "semver": "^5.6.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/less/node_modules/mime": {
+ "version": "1.6.0",
+ "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
+ "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
+ "dev": true,
+ "optional": true,
+ "bin": {
+ "mime": "cli.js"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/less/node_modules/semver": {
+ "version": "5.7.2",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz",
+ "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==",
+ "dev": true,
+ "optional": true,
+ "bin": {
+ "semver": "bin/semver"
+ }
+ },
+ "node_modules/less/node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true,
+ "optional": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/license-webpack-plugin": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/license-webpack-plugin/-/license-webpack-plugin-4.0.2.tgz",
+ "integrity": "sha512-771TFWFD70G1wLTC4oU2Cw4qvtmNrIw+wRvBtn+okgHl7slJVi7zfNcdmqDL72BojM30VNJ2UHylr1o77U37Jw==",
+ "dev": true,
+ "dependencies": {
+ "webpack-sources": "^3.0.0"
+ },
+ "peerDependenciesMeta": {
+ "webpack": {
+ "optional": true
+ },
+ "webpack-sources": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/lines-and-columns": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
+ "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==",
+ "dev": true
+ },
+ "node_modules/loader-runner": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.3.0.tgz",
+ "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6.11.5"
+ }
+ },
+ "node_modules/loader-utils": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.2.1.tgz",
+ "integrity": "sha512-ZvFw1KWS3GVyYBYb7qkmRM/WwL2TQQBxgCK62rlvm4WpVQ23Nb4tYjApUlfjrEGvOs7KHEsmyUn75OHZrJMWPw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 12.13.0"
+ }
+ },
+ "node_modules/locate-path": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
+ "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
+ "dev": true,
+ "dependencies": {
+ "p-locate": "^4.1.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/lodash": {
+ "version": "4.17.21",
+ "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
+ "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==",
+ "dev": true
+ },
+ "node_modules/lodash.debounce": {
+ "version": "4.0.8",
+ "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz",
+ "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==",
+ "dev": true
+ },
+ "node_modules/log-symbols": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz",
+ "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==",
+ "dev": true,
+ "dependencies": {
+ "chalk": "^4.1.0",
+ "is-unicode-supported": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/log-symbols/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/log-symbols/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/log-symbols/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/log-symbols/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/log-symbols/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/log-symbols/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/log4js": {
+ "version": "6.7.1",
+ "resolved": "https://registry.npmjs.org/log4js/-/log4js-6.7.1.tgz",
+ "integrity": "sha512-lzbd0Eq1HRdWM2abSD7mk6YIVY0AogGJzb/z+lqzRk+8+XJP+M6L1MS5FUSc3jjGru4dbKjEMJmqlsoYYpuivQ==",
+ "dev": true,
+ "dependencies": {
+ "date-format": "^4.0.14",
+ "debug": "^4.3.4",
+ "flatted": "^3.2.7",
+ "rfdc": "^1.3.0",
+ "streamroller": "^3.1.3"
+ },
+ "engines": {
+ "node": ">=8.0"
+ }
+ },
+ "node_modules/lru-cache": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz",
+ "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^3.0.2"
+ }
+ },
+ "node_modules/magic-string": {
+ "version": "0.27.0",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.27.0.tgz",
+ "integrity": "sha512-8UnnX2PeRAPZuN12svgR9j7M1uWMovg/CEnIwIG0LFkXSJJe4PdfUGiTGl8V9bsBHFUtfVINcSyYxd7q+kx9fA==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.4.13"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/make-dir": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
+ "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
+ "dev": true,
+ "dependencies": {
+ "semver": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/make-dir/node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/make-fetch-happen": {
+ "version": "11.1.1",
+ "resolved": "https://registry.npmjs.org/make-fetch-happen/-/make-fetch-happen-11.1.1.tgz",
+ "integrity": "sha512-rLWS7GCSTcEujjVBs2YqG7Y4643u8ucvCJeSRqiLYhesrDuzeuFIk37xREzAsfQaqzl8b9rNCE4m6J8tvX4Q8w==",
+ "dev": true,
+ "dependencies": {
+ "agentkeepalive": "^4.2.1",
+ "cacache": "^17.0.0",
+ "http-cache-semantics": "^4.1.1",
+ "http-proxy-agent": "^5.0.0",
+ "https-proxy-agent": "^5.0.0",
+ "is-lambda": "^1.0.1",
+ "lru-cache": "^7.7.1",
+ "minipass": "^5.0.0",
+ "minipass-fetch": "^3.0.0",
+ "minipass-flush": "^1.0.5",
+ "minipass-pipeline": "^1.2.4",
+ "negotiator": "^0.6.3",
+ "promise-retry": "^2.0.1",
+ "socks-proxy-agent": "^7.0.0",
+ "ssri": "^10.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/make-fetch-happen/node_modules/lru-cache": {
+ "version": "7.18.3",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz",
+ "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/make-fetch-happen/node_modules/minipass": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz",
+ "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/media-typer": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
+ "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/memfs": {
+ "version": "3.4.13",
+ "resolved": "https://registry.npmjs.org/memfs/-/memfs-3.4.13.tgz",
+ "integrity": "sha512-omTM41g3Skpvx5dSYeZIbXKcXoAVc/AoMNwn9TKx++L/gaen/+4TTttmu8ZSch5vfVJ8uJvGbroTsIlslRg6lg==",
+ "dev": true,
+ "dependencies": {
+ "fs-monkey": "^1.0.3"
+ },
+ "engines": {
+ "node": ">= 4.0.0"
+ }
+ },
+ "node_modules/merge-descriptors": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
+ "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==",
+ "dev": true
+ },
+ "node_modules/merge-stream": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
+ "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
+ "dev": true
+ },
+ "node_modules/merge2": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
+ "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/methods": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
+ "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/micromatch": {
+ "version": "4.0.5",
+ "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
+ "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==",
+ "dev": true,
+ "dependencies": {
+ "braces": "^3.0.2",
+ "picomatch": "^2.3.1"
+ },
+ "engines": {
+ "node": ">=8.6"
+ }
+ },
+ "node_modules/mime": {
+ "version": "2.6.0",
+ "resolved": "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz",
+ "integrity": "sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg==",
+ "dev": true,
+ "bin": {
+ "mime": "cli.js"
+ },
+ "engines": {
+ "node": ">=4.0.0"
+ }
+ },
+ "node_modules/mime-db": {
+ "version": "1.52.0",
+ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
+ "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/mime-types": {
+ "version": "2.1.35",
+ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
+ "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
+ "dev": true,
+ "dependencies": {
+ "mime-db": "1.52.0"
+ },
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/mimic-fn": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
+ "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/mini-css-extract-plugin": {
+ "version": "2.7.2",
+ "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.7.2.tgz",
+ "integrity": "sha512-EdlUizq13o0Pd+uCp+WO/JpkLvHRVGt97RqfeGhXqAcorYo1ypJSpkV+WDT0vY/kmh/p7wRdJNJtuyK540PXDw==",
+ "dev": true,
+ "dependencies": {
+ "schema-utils": "^4.0.0"
+ },
+ "engines": {
+ "node": ">= 12.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^5.0.0"
+ }
+ },
+ "node_modules/minimalistic-assert": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz",
+ "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==",
+ "dev": true
+ },
+ "node_modules/minimatch": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.2.tgz",
+ "integrity": "sha512-bNH9mmM9qsJ2X4r2Nat1B//1dJVcn3+iBLa3IgqJ7EbGaDNepL9QSHOxN4ng33s52VMMhhIfgCYDk3C4ZmlDAg==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/minimist": {
+ "version": "1.2.7",
+ "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.7.tgz",
+ "integrity": "sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g==",
+ "dev": true,
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/minipass": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-4.0.0.tgz",
+ "integrity": "sha512-g2Uuh2jEKoht+zvO6vJqXmYpflPqzRBT+Th2h01DKh5z7wbY/AZ2gCQ78cP70YoHPyFdY30YBV5WxgLOEwOykw==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-collect": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/minipass-collect/-/minipass-collect-1.0.2.tgz",
+ "integrity": "sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^3.0.0"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/minipass-collect/node_modules/minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-collect/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/minipass-fetch": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/minipass-fetch/-/minipass-fetch-3.0.3.tgz",
+ "integrity": "sha512-n5ITsTkDqYkYJZjcRWzZt9qnZKCT7nKCosJhHoj7S7zD+BP4jVbWs+odsniw5TA3E0sLomhTKOKjF86wf11PuQ==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^5.0.0",
+ "minipass-sized": "^1.0.3",
+ "minizlib": "^2.1.2"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ },
+ "optionalDependencies": {
+ "encoding": "^0.1.13"
+ }
+ },
+ "node_modules/minipass-fetch/node_modules/minipass": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz",
+ "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-flush": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz",
+ "integrity": "sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^3.0.0"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/minipass-flush/node_modules/minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-flush/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/minipass-json-stream": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/minipass-json-stream/-/minipass-json-stream-1.0.1.tgz",
+ "integrity": "sha512-ODqY18UZt/I8k+b7rl2AENgbWE8IDYam+undIJONvigAz8KR5GWblsFTEfQs0WODsjbSXWlm+JHEv8Gr6Tfdbg==",
+ "dev": true,
+ "dependencies": {
+ "jsonparse": "^1.3.1",
+ "minipass": "^3.0.0"
+ }
+ },
+ "node_modules/minipass-json-stream/node_modules/minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-json-stream/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/minipass-pipeline": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz",
+ "integrity": "sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-pipeline/node_modules/minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-pipeline/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/minipass-sized": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/minipass-sized/-/minipass-sized-1.0.3.tgz",
+ "integrity": "sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-sized/node_modules/minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minipass-sized/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/minipass/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/minizlib": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz",
+ "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^3.0.0",
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/minizlib/node_modules/minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/minizlib/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/mkdirp": {
+ "version": "0.5.6",
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz",
+ "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==",
+ "dev": true,
+ "dependencies": {
+ "minimist": "^1.2.6"
+ },
+ "bin": {
+ "mkdirp": "bin/cmd.js"
+ }
+ },
+ "node_modules/ms": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
+ "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
+ "dev": true
+ },
+ "node_modules/multicast-dns": {
+ "version": "7.2.5",
+ "resolved": "https://registry.npmjs.org/multicast-dns/-/multicast-dns-7.2.5.tgz",
+ "integrity": "sha512-2eznPJP8z2BFLX50tf0LuODrpINqP1RVIm/CObbTcBRITQgmC/TjcREF1NeTBzIcR5XO/ukWo+YHOjBbFwIupg==",
+ "dev": true,
+ "dependencies": {
+ "dns-packet": "^5.2.2",
+ "thunky": "^1.0.2"
+ },
+ "bin": {
+ "multicast-dns": "cli.js"
+ }
+ },
+ "node_modules/mute-stream": {
+ "version": "0.0.8",
+ "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz",
+ "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==",
+ "dev": true
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.4",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz",
+ "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==",
+ "dev": true,
+ "bin": {
+ "nanoid": "bin/nanoid.cjs"
+ },
+ "engines": {
+ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
+ }
+ },
+ "node_modules/needle": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/needle/-/needle-3.2.0.tgz",
+ "integrity": "sha512-oUvzXnyLiVyVGoianLijF9O/RecZUf7TkBfimjGrLM4eQhXyeJwM6GeAWccwfQ9aa4gMCZKqhAOuLaMIcQxajQ==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "debug": "^3.2.6",
+ "iconv-lite": "^0.6.3",
+ "sax": "^1.2.4"
+ },
+ "bin": {
+ "needle": "bin/needle"
+ },
+ "engines": {
+ "node": ">= 4.4.x"
+ }
+ },
+ "node_modules/needle/node_modules/debug": {
+ "version": "3.2.7",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
+ "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "ms": "^2.1.1"
+ }
+ },
+ "node_modules/needle/node_modules/iconv-lite": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz",
+ "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
+ "dev": true,
+ "optional": true,
+ "dependencies": {
+ "safer-buffer": ">= 2.1.2 < 3.0.0"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/negotiator": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz",
+ "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/neo-async": {
+ "version": "2.6.2",
+ "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz",
+ "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==",
+ "dev": true
+ },
+ "node_modules/ngx-echarts": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmjs.org/ngx-echarts/-/ngx-echarts-8.0.1.tgz",
+ "integrity": "sha512-CP+WnCcnMCNpCL9BVmDIZmhGSVPnkJhhFbQEKt0nrwV0L6d4QTAGZ+e4y6G1zTTFKkIMPHpaO0nhtDRgSXAW/w==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ },
+ "peerDependencies": {
+ "echarts": ">=5.0.0"
+ }
+ },
+ "node_modules/ngx-sortablejs": {
+ "version": "11.1.0",
+ "resolved": "https://registry.npmjs.org/ngx-sortablejs/-/ngx-sortablejs-11.1.0.tgz",
+ "integrity": "sha512-eM4dHwWSmXDcvF5gUmyMMQ0qqcqBXWCSZ9IRpqx4UkBKfo4N7pk/QuYh5io2fXVHWVFDaxW1yhn2FNpqxV6Jqw==",
+ "dependencies": {
+ "tslib": "^2.0.0"
+ },
+ "peerDependencies": {
+ "@angular/common": "^11.0.0",
+ "@angular/core": "^11.0.0",
+ "sortablejs": ">=1.7.0"
+ }
+ },
+ "node_modules/nice-napi": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/nice-napi/-/nice-napi-1.0.2.tgz",
+ "integrity": "sha512-px/KnJAJZf5RuBGcfD+Sp2pAKq0ytz8j+1NehvgIGFkvtvFrDM3T8E4x/JJODXK9WZow8RRGrbA9QQ3hs+pDhA==",
+ "dev": true,
+ "hasInstallScript": true,
+ "optional": true,
+ "os": [
+ "!win32"
+ ],
+ "dependencies": {
+ "node-addon-api": "^3.0.0",
+ "node-gyp-build": "^4.2.2"
+ }
+ },
+ "node_modules/node-addon-api": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.2.1.tgz",
+ "integrity": "sha512-mmcei9JghVNDYydghQmeDX8KoAm0FAiYyIcUt/N4nhyAipB17pllZQDOJD2fotxABnt4Mdz+dKTO7eftLg4d0A==",
+ "dev": true,
+ "optional": true
+ },
+ "node_modules/node-forge": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz",
+ "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 6.13.0"
+ }
+ },
+ "node_modules/node-gyp": {
+ "version": "9.4.0",
+ "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-9.4.0.tgz",
+ "integrity": "sha512-dMXsYP6gc9rRbejLXmTbVRYjAHw7ppswsKyMxuxJxxOHzluIO1rGp9TOQgjFJ+2MCqcOcQTOPB/8Xwhr+7s4Eg==",
+ "dev": true,
+ "dependencies": {
+ "env-paths": "^2.2.0",
+ "exponential-backoff": "^3.1.1",
+ "glob": "^7.1.4",
+ "graceful-fs": "^4.2.6",
+ "make-fetch-happen": "^11.0.3",
+ "nopt": "^6.0.0",
+ "npmlog": "^6.0.0",
+ "rimraf": "^3.0.2",
+ "semver": "^7.3.5",
+ "tar": "^6.1.2",
+ "which": "^2.0.2"
+ },
+ "bin": {
+ "node-gyp": "bin/node-gyp.js"
+ },
+ "engines": {
+ "node": "^12.13 || ^14.13 || >=16"
+ }
+ },
+ "node_modules/node-gyp-build": {
+ "version": "4.6.0",
+ "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.6.0.tgz",
+ "integrity": "sha512-NTZVKn9IylLwUzaKjkas1e4u2DLNcV4rdYagA4PWdPwW87Bi7z+BznyKSRwS/761tV/lzCGXplWsiaMjLqP2zQ==",
+ "dev": true,
+ "optional": true,
+ "bin": {
+ "node-gyp-build": "bin.js",
+ "node-gyp-build-optional": "optional.js",
+ "node-gyp-build-test": "build-test.js"
+ }
+ },
+ "node_modules/node-gyp/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/node-gyp/node_modules/glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ },
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/node-gyp/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/node-gyp/node_modules/which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/node-which"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/node-releases": {
+ "version": "2.0.8",
+ "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.8.tgz",
+ "integrity": "sha512-dFSmB8fFHEH/s81Xi+Y/15DQY6VHW81nXRj86EMSL3lmuTmK1e+aT4wrFCkTbm+gSwkw4KpX+rT/pMM2c1mF+A==",
+ "dev": true
+ },
+ "node_modules/nopt": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/nopt/-/nopt-6.0.0.tgz",
+ "integrity": "sha512-ZwLpbTgdhuZUnZzjd7nb1ZV+4DoiC6/sfiVKok72ym/4Tlf+DFdlHYmT2JPmcNNWV6Pi3SDf1kT+A4r9RTuT9g==",
+ "dev": true,
+ "dependencies": {
+ "abbrev": "^1.0.0"
+ },
+ "bin": {
+ "nopt": "bin/nopt.js"
+ },
+ "engines": {
+ "node": "^12.13.0 || ^14.15.0 || >=16.0.0"
+ }
+ },
+ "node_modules/normalize-package-data": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-5.0.0.tgz",
+ "integrity": "sha512-h9iPVIfrVZ9wVYQnxFgtw1ugSvGEMOlyPWWtm8BMJhnwyEL/FLbYbTY3V3PpjI/BUK67n9PEWDu6eHzu1fB15Q==",
+ "dev": true,
+ "dependencies": {
+ "hosted-git-info": "^6.0.0",
+ "is-core-module": "^2.8.1",
+ "semver": "^7.3.5",
+ "validate-npm-package-license": "^3.0.4"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/normalize-path": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/normalize-range": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz",
+ "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/npm-bundled": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-3.0.0.tgz",
+ "integrity": "sha512-Vq0eyEQy+elFpzsKjMss9kxqb9tG3YHg4dsyWuUENuzvSUWe1TCnW/vV9FkhvBk/brEDoDiVd+M1Btosa6ImdQ==",
+ "dev": true,
+ "dependencies": {
+ "npm-normalize-package-bin": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/npm-install-checks": {
+ "version": "6.1.1",
+ "resolved": "https://registry.npmjs.org/npm-install-checks/-/npm-install-checks-6.1.1.tgz",
+ "integrity": "sha512-dH3GmQL4vsPtld59cOn8uY0iOqRmqKvV+DLGwNXV/Q7MDgD2QfOADWd/mFXcIE5LVhYYGjA3baz6W9JneqnuCw==",
+ "dev": true,
+ "dependencies": {
+ "semver": "^7.1.1"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/npm-normalize-package-bin": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-3.0.1.tgz",
+ "integrity": "sha512-dMxCf+zZ+3zeQZXKxmyuCKlIDPGuv8EF940xbkC4kQVDTtqoh6rJFO+JTKSA6/Rwi0getWmtuy4Itup0AMcaDQ==",
+ "dev": true,
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/npm-package-arg": {
+ "version": "10.1.0",
+ "resolved": "https://registry.npmjs.org/npm-package-arg/-/npm-package-arg-10.1.0.tgz",
+ "integrity": "sha512-uFyyCEmgBfZTtrKk/5xDfHp6+MdrqGotX/VoOyEEl3mBwiEE5FlBaePanazJSVMPT7vKepcjYBY2ztg9A3yPIA==",
+ "dev": true,
+ "dependencies": {
+ "hosted-git-info": "^6.0.0",
+ "proc-log": "^3.0.0",
+ "semver": "^7.3.5",
+ "validate-npm-package-name": "^5.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/npm-packlist": {
+ "version": "7.0.4",
+ "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-7.0.4.tgz",
+ "integrity": "sha512-d6RGEuRrNS5/N84iglPivjaJPxhDbZmlbTwTDX2IbcRHG5bZCdtysYMhwiPvcF4GisXHGn7xsxv+GQ7T/02M5Q==",
+ "dev": true,
+ "dependencies": {
+ "ignore-walk": "^6.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/npm-pick-manifest": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmjs.org/npm-pick-manifest/-/npm-pick-manifest-8.0.1.tgz",
+ "integrity": "sha512-mRtvlBjTsJvfCCdmPtiu2bdlx8d/KXtF7yNXNWe7G0Z36qWA9Ny5zXsI2PfBZEv7SXgoxTmNaTzGSbbzDZChoA==",
+ "dev": true,
+ "dependencies": {
+ "npm-install-checks": "^6.0.0",
+ "npm-normalize-package-bin": "^3.0.0",
+ "npm-package-arg": "^10.0.0",
+ "semver": "^7.3.5"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/npm-registry-fetch": {
+ "version": "14.0.5",
+ "resolved": "https://registry.npmjs.org/npm-registry-fetch/-/npm-registry-fetch-14.0.5.tgz",
+ "integrity": "sha512-kIDMIo4aBm6xg7jOttupWZamsZRkAqMqwqqbVXnUqstY5+tapvv6bkH/qMR76jdgV+YljEUCyWx3hRYMrJiAgA==",
+ "dev": true,
+ "dependencies": {
+ "make-fetch-happen": "^11.0.0",
+ "minipass": "^5.0.0",
+ "minipass-fetch": "^3.0.0",
+ "minipass-json-stream": "^1.0.1",
+ "minizlib": "^2.1.2",
+ "npm-package-arg": "^10.0.0",
+ "proc-log": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/npm-registry-fetch/node_modules/minipass": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz",
+ "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/npm-run-path": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz",
+ "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==",
+ "dev": true,
+ "dependencies": {
+ "path-key": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/npmlog": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-6.0.2.tgz",
+ "integrity": "sha512-/vBvz5Jfr9dT/aFWd0FIRf+T/Q2WBsLENygUaFUqstqsycmZAP/t5BvFJTK0viFmSUxiUKTUplWy5vt+rvKIxg==",
+ "dev": true,
+ "dependencies": {
+ "are-we-there-yet": "^3.0.0",
+ "console-control-strings": "^1.1.0",
+ "gauge": "^4.0.3",
+ "set-blocking": "^2.0.0"
+ },
+ "engines": {
+ "node": "^12.13.0 || ^14.15.0 || >=16.0.0"
+ }
+ },
+ "node_modules/nth-check": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz",
+ "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==",
+ "dev": true,
+ "dependencies": {
+ "boolbase": "^1.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/nth-check?sponsor=1"
+ }
+ },
+ "node_modules/object-assign": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
+ "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/object-inspect": {
+ "version": "1.12.2",
+ "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz",
+ "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==",
+ "dev": true,
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/obuf": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz",
+ "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==",
+ "dev": true
+ },
+ "node_modules/on-finished": {
+ "version": "2.4.1",
+ "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz",
+ "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==",
+ "dev": true,
+ "dependencies": {
+ "ee-first": "1.1.1"
+ },
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/on-headers": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz",
+ "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/once": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
+ "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
+ "dev": true,
+ "dependencies": {
+ "wrappy": "1"
+ }
+ },
+ "node_modules/onetime": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz",
+ "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==",
+ "dev": true,
+ "dependencies": {
+ "mimic-fn": "^2.1.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/open": {
+ "version": "8.4.1",
+ "resolved": "https://registry.npmjs.org/open/-/open-8.4.1.tgz",
+ "integrity": "sha512-/4b7qZNhv6Uhd7jjnREh1NjnPxlTq+XNWPG88Ydkj5AILcA5m3ajvcg57pB24EQjKv0dK62XnDqk9c/hkIG5Kg==",
+ "dev": true,
+ "dependencies": {
+ "define-lazy-prop": "^2.0.0",
+ "is-docker": "^2.1.1",
+ "is-wsl": "^2.2.0"
+ },
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/ora": {
+ "version": "5.4.1",
+ "resolved": "https://registry.npmjs.org/ora/-/ora-5.4.1.tgz",
+ "integrity": "sha512-5b6Y85tPxZZ7QytO+BQzysW31HJku27cRIlkbAXaNx+BdcVi+LlRFmVXzeF6a7JCwJpyw5c4b+YSVImQIrBpuQ==",
+ "dev": true,
+ "dependencies": {
+ "bl": "^4.1.0",
+ "chalk": "^4.1.0",
+ "cli-cursor": "^3.1.0",
+ "cli-spinners": "^2.5.0",
+ "is-interactive": "^1.0.0",
+ "is-unicode-supported": "^0.1.0",
+ "log-symbols": "^4.1.0",
+ "strip-ansi": "^6.0.0",
+ "wcwidth": "^1.0.1"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/ora/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/ora/node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/ora/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/ora/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/ora/node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/ora/node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/os-tmpdir": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
+ "integrity": "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/p-limit": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
+ "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
+ "dev": true,
+ "dependencies": {
+ "p-try": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-locate": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
+ "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
+ "dev": true,
+ "dependencies": {
+ "p-limit": "^2.2.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/p-map": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz",
+ "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==",
+ "dev": true,
+ "dependencies": {
+ "aggregate-error": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-retry": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-4.6.2.tgz",
+ "integrity": "sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ==",
+ "dev": true,
+ "dependencies": {
+ "@types/retry": "0.12.0",
+ "retry": "^0.13.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/p-retry/node_modules/retry": {
+ "version": "0.13.1",
+ "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz",
+ "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/p-try": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
+ "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/pacote": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/pacote/-/pacote-15.1.0.tgz",
+ "integrity": "sha512-FFcjtIl+BQNfeliSm7MZz5cpdohvUV1yjGnqgVM4UnVF7JslRY0ImXAygdaCDV0jjUADEWu4y5xsDV8brtrTLg==",
+ "dev": true,
+ "dependencies": {
+ "@npmcli/git": "^4.0.0",
+ "@npmcli/installed-package-contents": "^2.0.1",
+ "@npmcli/promise-spawn": "^6.0.1",
+ "@npmcli/run-script": "^6.0.0",
+ "cacache": "^17.0.0",
+ "fs-minipass": "^3.0.0",
+ "minipass": "^4.0.0",
+ "npm-package-arg": "^10.0.0",
+ "npm-packlist": "^7.0.0",
+ "npm-pick-manifest": "^8.0.0",
+ "npm-registry-fetch": "^14.0.0",
+ "proc-log": "^3.0.0",
+ "promise-retry": "^2.0.1",
+ "read-package-json": "^6.0.0",
+ "read-package-json-fast": "^3.0.0",
+ "sigstore": "^1.0.0",
+ "ssri": "^10.0.0",
+ "tar": "^6.1.11"
+ },
+ "bin": {
+ "pacote": "lib/bin.js"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/pako": {
+ "version": "1.0.11",
+ "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz",
+ "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==",
+ "dev": true
+ },
+ "node_modules/parent-module": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
+ "dev": true,
+ "dependencies": {
+ "callsites": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/parse-json": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
+ "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/code-frame": "^7.0.0",
+ "error-ex": "^1.3.1",
+ "json-parse-even-better-errors": "^2.3.0",
+ "lines-and-columns": "^1.1.6"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/parse-node-version": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parse-node-version/-/parse-node-version-1.0.1.tgz",
+ "integrity": "sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.10"
+ }
+ },
+ "node_modules/parse5": {
+ "version": "7.1.2",
+ "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.2.tgz",
+ "integrity": "sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw==",
+ "devOptional": true,
+ "dependencies": {
+ "entities": "^4.4.0"
+ },
+ "funding": {
+ "url": "https://github.com/inikulin/parse5?sponsor=1"
+ }
+ },
+ "node_modules/parse5-html-rewriting-stream": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/parse5-html-rewriting-stream/-/parse5-html-rewriting-stream-7.0.0.tgz",
+ "integrity": "sha512-mazCyGWkmCRWDI15Zp+UiCqMp/0dgEmkZRvhlsqqKYr4SsVm/TvnSpD9fCvqCA2zoWJcfRym846ejWBBHRiYEg==",
+ "dev": true,
+ "dependencies": {
+ "entities": "^4.3.0",
+ "parse5": "^7.0.0",
+ "parse5-sax-parser": "^7.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/inikulin/parse5?sponsor=1"
+ }
+ },
+ "node_modules/parse5-html-rewriting-stream/node_modules/entities": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz",
+ "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.12"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/entities?sponsor=1"
+ }
+ },
+ "node_modules/parse5-htmlparser2-tree-adapter": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-6.0.1.tgz",
+ "integrity": "sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA==",
+ "dev": true,
+ "dependencies": {
+ "parse5": "^6.0.1"
+ }
+ },
+ "node_modules/parse5-htmlparser2-tree-adapter/node_modules/parse5": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz",
+ "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==",
+ "dev": true
+ },
+ "node_modules/parse5-sax-parser": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/parse5-sax-parser/-/parse5-sax-parser-7.0.0.tgz",
+ "integrity": "sha512-5A+v2SNsq8T6/mG3ahcz8ZtQ0OUFTatxPbeidoMB7tkJSGDY3tdfl4MHovtLQHkEn5CGxijNWRQHhRQ6IRpXKg==",
+ "dev": true,
+ "dependencies": {
+ "parse5": "^7.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/inikulin/parse5?sponsor=1"
+ }
+ },
+ "node_modules/parse5/node_modules/entities": {
+ "version": "4.4.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-4.4.0.tgz",
+ "integrity": "sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA==",
+ "devOptional": true,
+ "engines": {
+ "node": ">=0.12"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/entities?sponsor=1"
+ }
+ },
+ "node_modules/parseurl": {
+ "version": "1.3.3",
+ "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
+ "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/particles.js": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/particles.js/-/particles.js-2.0.0.tgz",
+ "integrity": "sha512-8e0JIqkRbMMPlFBnF9f+92hX1s07jdkd3tqB8uHE9L+cwGGjIYjQM7QLgt0FQ5MZp6SFFYYDm/Y48pqK3ZvJOQ=="
+ },
+ "node_modules/path-exists": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
+ "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-is-absolute": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
+ "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-parse": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz",
+ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==",
+ "dev": true
+ },
+ "node_modules/path-scurry": {
+ "version": "1.10.1",
+ "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.1.tgz",
+ "integrity": "sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ==",
+ "dev": true,
+ "dependencies": {
+ "lru-cache": "^9.1.1 || ^10.0.0",
+ "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0"
+ },
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/path-scurry/node_modules/lru-cache": {
+ "version": "10.0.0",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.0.0.tgz",
+ "integrity": "sha512-svTf/fzsKHffP42sujkO/Rjs37BCIsQVRCeNYIm9WN8rgT7ffoUnRtZCqU+6BqcSBdv8gwJeTz8knJpgACeQMw==",
+ "dev": true,
+ "engines": {
+ "node": "14 || >=16.14"
+ }
+ },
+ "node_modules/path-scurry/node_modules/minipass": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.2.tgz",
+ "integrity": "sha512-eL79dXrE1q9dBbDCLg7xfn/vl7MS4F1gvJAgjJrQli/jbQWdUttuVawphqpffoIYfRdq78LHx6GP4bU/EQ2ATA==",
+ "dev": true,
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ }
+ },
+ "node_modules/path-to-regexp": {
+ "version": "0.1.7",
+ "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
+ "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==",
+ "dev": true
+ },
+ "node_modules/path-type": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
+ "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/picocolors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
+ "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
+ "dev": true
+ },
+ "node_modules/picomatch": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
+ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
+ "dev": true,
+ "engines": {
+ "node": ">=8.6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/jonschlinkert"
+ }
+ },
+ "node_modules/pify": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz",
+ "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==",
+ "dev": true,
+ "optional": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/piscina": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/piscina/-/piscina-3.2.0.tgz",
+ "integrity": "sha512-yn/jMdHRw+q2ZJhFhyqsmANcbF6V2QwmD84c6xRau+QpQOmtrBCoRGdvTfeuFDYXB5W2m6MfLkjkvQa9lUSmIA==",
+ "dev": true,
+ "dependencies": {
+ "eventemitter-asyncresource": "^1.0.0",
+ "hdr-histogram-js": "^2.0.1",
+ "hdr-histogram-percentiles-obj": "^3.0.0"
+ },
+ "optionalDependencies": {
+ "nice-napi": "^1.0.2"
+ }
+ },
+ "node_modules/pkg-dir": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz",
+ "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==",
+ "dev": true,
+ "dependencies": {
+ "find-up": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/postcss": {
+ "version": "8.4.21",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.21.tgz",
+ "integrity": "sha512-tP7u/Sn/dVxK2NnruI4H9BG+x+Wxz6oeZ1cJ8P6G/PZY0IKk4k/63TDsQf2kQq3+qoJeLm2kIBUNlZe3zgb4Zg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/postcss"
+ }
+ ],
+ "dependencies": {
+ "nanoid": "^3.3.4",
+ "picocolors": "^1.0.0",
+ "source-map-js": "^1.0.2"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ }
+ },
+ "node_modules/postcss-loader": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-7.0.2.tgz",
+ "integrity": "sha512-fUJzV/QH7NXUAqV8dWJ9Lg4aTkDCezpTS5HgJ2DvqznexTbSTxgi/dTECvTZ15BwKTtk8G/bqI/QTu2HPd3ZCg==",
+ "dev": true,
+ "dependencies": {
+ "cosmiconfig": "^7.0.0",
+ "klona": "^2.0.5",
+ "semver": "^7.3.8"
+ },
+ "engines": {
+ "node": ">= 14.15.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "postcss": "^7.0.0 || ^8.0.1",
+ "webpack": "^5.0.0"
+ }
+ },
+ "node_modules/postcss-modules-extract-imports": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz",
+ "integrity": "sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw==",
+ "dev": true,
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-modules-local-by-default": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.0.tgz",
+ "integrity": "sha512-sT7ihtmGSF9yhm6ggikHdV0hlziDTX7oFoXtuVWeDd3hHObNkcHRo9V3yg7vCAY7cONyxJC/XXCmmiHHcvX7bQ==",
+ "dev": true,
+ "dependencies": {
+ "icss-utils": "^5.0.0",
+ "postcss-selector-parser": "^6.0.2",
+ "postcss-value-parser": "^4.1.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-modules-scope": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz",
+ "integrity": "sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg==",
+ "dev": true,
+ "dependencies": {
+ "postcss-selector-parser": "^6.0.4"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-modules-values": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz",
+ "integrity": "sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ==",
+ "dev": true,
+ "dependencies": {
+ "icss-utils": "^5.0.0"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >= 14"
+ },
+ "peerDependencies": {
+ "postcss": "^8.1.0"
+ }
+ },
+ "node_modules/postcss-selector-parser": {
+ "version": "6.0.11",
+ "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.11.tgz",
+ "integrity": "sha512-zbARubNdogI9j7WY4nQJBiNqQf3sLS3wCP4WfOidu+p28LofJqDH1tcXypGrcmMHhDk2t9wGhCsYe/+szLTy1g==",
+ "dev": true,
+ "dependencies": {
+ "cssesc": "^3.0.0",
+ "util-deprecate": "^1.0.2"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/postcss-value-parser": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz",
+ "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==",
+ "dev": true
+ },
+ "node_modules/pretty-bytes": {
+ "version": "5.6.0",
+ "resolved": "https://registry.npmjs.org/pretty-bytes/-/pretty-bytes-5.6.0.tgz",
+ "integrity": "sha512-FFw039TmrBqFK8ma/7OL3sDz/VytdtJr044/QUJtH0wK9lb9jLq9tJyIxUwtQJHwar2BqtiA4iCWSwo9JLkzFg==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/proc-log": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/proc-log/-/proc-log-3.0.0.tgz",
+ "integrity": "sha512-++Vn7NS4Xf9NacaU9Xq3URUuqZETPsf8L4j5/ckhaRYsfPeRyzGw+iDjFhV/Jr3uNmTvvddEJFWh5R1gRgUH8A==",
+ "dev": true,
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/process-nextick-args": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
+ "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==",
+ "dev": true
+ },
+ "node_modules/promise-inflight": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz",
+ "integrity": "sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g==",
+ "dev": true
+ },
+ "node_modules/promise-retry": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/promise-retry/-/promise-retry-2.0.1.tgz",
+ "integrity": "sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g==",
+ "dev": true,
+ "dependencies": {
+ "err-code": "^2.0.2",
+ "retry": "^0.12.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/proxy-addr": {
+ "version": "2.0.7",
+ "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
+ "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
+ "dev": true,
+ "dependencies": {
+ "forwarded": "0.2.0",
+ "ipaddr.js": "1.9.1"
+ },
+ "engines": {
+ "node": ">= 0.10"
+ }
+ },
+ "node_modules/proxy-addr/node_modules/ipaddr.js": {
+ "version": "1.9.1",
+ "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
+ "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.10"
+ }
+ },
+ "node_modules/prr": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz",
+ "integrity": "sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==",
+ "dev": true,
+ "optional": true
+ },
+ "node_modules/punycode": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.2.0.tgz",
+ "integrity": "sha512-LN6QV1IJ9ZhxWTNdktaPClrNfp8xdSAYS0Zk2ddX7XsXZAxckMHPCBcHRo0cTcEIgYPRiGEkmji3Idkh2yFtYw==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/qjobs": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/qjobs/-/qjobs-1.2.0.tgz",
+ "integrity": "sha512-8YOJEHtxpySA3fFDyCRxA+UUV+fA+rTWnuWvylOK/NCjhY+b4ocCtmu8TtsWb+mYeU+GCHf/S66KZF/AsteKHg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.9"
+ }
+ },
+ "node_modules/qs": {
+ "version": "6.11.0",
+ "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz",
+ "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==",
+ "dev": true,
+ "dependencies": {
+ "side-channel": "^1.0.4"
+ },
+ "engines": {
+ "node": ">=0.6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/queue-microtask": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
+ "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ]
+ },
+ "node_modules/randombytes": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz",
+ "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==",
+ "dev": true,
+ "dependencies": {
+ "safe-buffer": "^5.1.0"
+ }
+ },
+ "node_modules/range-parser": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
+ "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/raw-body": {
+ "version": "2.5.1",
+ "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz",
+ "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==",
+ "dev": true,
+ "dependencies": {
+ "bytes": "3.1.2",
+ "http-errors": "2.0.0",
+ "iconv-lite": "0.4.24",
+ "unpipe": "1.0.0"
+ },
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/read-package-json": {
+ "version": "6.0.4",
+ "resolved": "https://registry.npmjs.org/read-package-json/-/read-package-json-6.0.4.tgz",
+ "integrity": "sha512-AEtWXYfopBj2z5N5PbkAOeNHRPUg5q+Nen7QLxV8M2zJq1ym6/lCz3fYNTCXe19puu2d06jfHhrP7v/S2PtMMw==",
+ "dev": true,
+ "dependencies": {
+ "glob": "^10.2.2",
+ "json-parse-even-better-errors": "^3.0.0",
+ "normalize-package-data": "^5.0.0",
+ "npm-normalize-package-bin": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/read-package-json-fast": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/read-package-json-fast/-/read-package-json-fast-3.0.2.tgz",
+ "integrity": "sha512-0J+Msgym3vrLOUB3hzQCuZHII0xkNGCtz/HJH9xZshwv9DbDwkw1KaE3gx/e2J5rpEY5rtOy6cyhKOPrkP7FZw==",
+ "dev": true,
+ "dependencies": {
+ "json-parse-even-better-errors": "^3.0.0",
+ "npm-normalize-package-bin": "^3.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/read-package-json-fast/node_modules/json-parse-even-better-errors": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-3.0.0.tgz",
+ "integrity": "sha512-iZbGHafX/59r39gPwVPRBGw0QQKnA7tte5pSMrhWOW7swGsVvVTjmfyAV9pNqk8YGT7tRCdxRu8uzcgZwoDooA==",
+ "dev": true,
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/read-package-json/node_modules/glob": {
+ "version": "10.3.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.3.tgz",
+ "integrity": "sha512-92vPiMb/iqpmEgsOoIDvTjc50wf9CCCvMzsi6W0JLPeUKE8TWP1a73PgqSrqy7iAZxaSD1YdzU7QZR5LF51MJw==",
+ "dev": true,
+ "dependencies": {
+ "foreground-child": "^3.1.0",
+ "jackspeak": "^2.0.3",
+ "minimatch": "^9.0.1",
+ "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0",
+ "path-scurry": "^1.10.1"
+ },
+ "bin": {
+ "glob": "dist/cjs/src/bin.js"
+ },
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/read-package-json/node_modules/json-parse-even-better-errors": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-3.0.0.tgz",
+ "integrity": "sha512-iZbGHafX/59r39gPwVPRBGw0QQKnA7tte5pSMrhWOW7swGsVvVTjmfyAV9pNqk8YGT7tRCdxRu8uzcgZwoDooA==",
+ "dev": true,
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/read-package-json/node_modules/minimatch": {
+ "version": "9.0.3",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz",
+ "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/read-package-json/node_modules/minipass": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.2.tgz",
+ "integrity": "sha512-eL79dXrE1q9dBbDCLg7xfn/vl7MS4F1gvJAgjJrQli/jbQWdUttuVawphqpffoIYfRdq78LHx6GP4bU/EQ2ATA==",
+ "dev": true,
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ }
+ },
+ "node_modules/readable-stream": {
+ "version": "3.6.0",
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz",
+ "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==",
+ "dev": true,
+ "dependencies": {
+ "inherits": "^2.0.3",
+ "string_decoder": "^1.1.1",
+ "util-deprecate": "^1.0.1"
+ },
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/readdirp": {
+ "version": "3.6.0",
+ "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
+ "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
+ "dev": true,
+ "dependencies": {
+ "picomatch": "^2.2.1"
+ },
+ "engines": {
+ "node": ">=8.10.0"
+ }
+ },
+ "node_modules/reflect-metadata": {
+ "version": "0.1.13",
+ "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz",
+ "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==",
+ "dev": true
+ },
+ "node_modules/regenerate": {
+ "version": "1.4.2",
+ "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz",
+ "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==",
+ "dev": true
+ },
+ "node_modules/regenerate-unicode-properties": {
+ "version": "10.1.0",
+ "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz",
+ "integrity": "sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ==",
+ "dev": true,
+ "dependencies": {
+ "regenerate": "^1.4.2"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/regenerator-runtime": {
+ "version": "0.13.11",
+ "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz",
+ "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==",
+ "dev": true
+ },
+ "node_modules/regenerator-transform": {
+ "version": "0.15.1",
+ "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.1.tgz",
+ "integrity": "sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg==",
+ "dev": true,
+ "dependencies": {
+ "@babel/runtime": "^7.8.4"
+ }
+ },
+ "node_modules/regex-parser": {
+ "version": "2.2.11",
+ "resolved": "https://registry.npmjs.org/regex-parser/-/regex-parser-2.2.11.tgz",
+ "integrity": "sha512-jbD/FT0+9MBU2XAZluI7w2OBs1RBi6p9M83nkoZayQXXU9e8Robt69FcZc7wU4eJD/YFTjn1JdCk3rbMJajz8Q==",
+ "dev": true
+ },
+ "node_modules/regexpu-core": {
+ "version": "5.2.2",
+ "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.2.2.tgz",
+ "integrity": "sha512-T0+1Zp2wjF/juXMrMxHxidqGYn8U4R+zleSJhX9tQ1PUsS8a9UtYfbsF9LdiVgNX3kiX8RNaKM42nfSgvFJjmw==",
+ "dev": true,
+ "dependencies": {
+ "regenerate": "^1.4.2",
+ "regenerate-unicode-properties": "^10.1.0",
+ "regjsgen": "^0.7.1",
+ "regjsparser": "^0.9.1",
+ "unicode-match-property-ecmascript": "^2.0.0",
+ "unicode-match-property-value-ecmascript": "^2.1.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/regjsgen": {
+ "version": "0.7.1",
+ "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.7.1.tgz",
+ "integrity": "sha512-RAt+8H2ZEzHeYWxZ3H2z6tF18zyyOnlcdaafLrm21Bguj7uZy6ULibiAFdXEtKQY4Sy7wDTwDiOazasMLc4KPA==",
+ "dev": true
+ },
+ "node_modules/regjsparser": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz",
+ "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==",
+ "dev": true,
+ "dependencies": {
+ "jsesc": "~0.5.0"
+ },
+ "bin": {
+ "regjsparser": "bin/parser"
+ }
+ },
+ "node_modules/regjsparser/node_modules/jsesc": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz",
+ "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==",
+ "dev": true,
+ "bin": {
+ "jsesc": "bin/jsesc"
+ }
+ },
+ "node_modules/require-directory": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
+ "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/require-from-string": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz",
+ "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/requires-port": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz",
+ "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==",
+ "dev": true
+ },
+ "node_modules/resolve": {
+ "version": "1.22.1",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz",
+ "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==",
+ "dev": true,
+ "dependencies": {
+ "is-core-module": "^2.9.0",
+ "path-parse": "^1.0.7",
+ "supports-preserve-symlinks-flag": "^1.0.0"
+ },
+ "bin": {
+ "resolve": "bin/resolve"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/resolve-from": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
+ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/resolve-url-loader": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-url-loader/-/resolve-url-loader-5.0.0.tgz",
+ "integrity": "sha512-uZtduh8/8srhBoMx//5bwqjQ+rfYOUq8zC9NrMUGtjBiGTtFJM42s58/36+hTqeqINcnYe08Nj3LkK9lW4N8Xg==",
+ "dev": true,
+ "dependencies": {
+ "adjust-sourcemap-loader": "^4.0.0",
+ "convert-source-map": "^1.7.0",
+ "loader-utils": "^2.0.0",
+ "postcss": "^8.2.14",
+ "source-map": "0.6.1"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/resolve-url-loader/node_modules/loader-utils": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz",
+ "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==",
+ "dev": true,
+ "dependencies": {
+ "big.js": "^5.2.2",
+ "emojis-list": "^3.0.0",
+ "json5": "^2.1.2"
+ },
+ "engines": {
+ "node": ">=8.9.0"
+ }
+ },
+ "node_modules/resolve-url-loader/node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/restore-cursor": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz",
+ "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==",
+ "dev": true,
+ "dependencies": {
+ "onetime": "^5.1.0",
+ "signal-exit": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/retry": {
+ "version": "0.12.0",
+ "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz",
+ "integrity": "sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/reusify": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz",
+ "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==",
+ "dev": true,
+ "engines": {
+ "iojs": ">=1.0.0",
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/rfdc": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz",
+ "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==",
+ "dev": true
+ },
+ "node_modules/rimraf": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
+ "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
+ "dev": true,
+ "dependencies": {
+ "glob": "^7.1.3"
+ },
+ "bin": {
+ "rimraf": "bin.js"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/rimraf/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/rimraf/node_modules/glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ },
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/rimraf/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/run-async": {
+ "version": "2.4.1",
+ "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz",
+ "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.12.0"
+ }
+ },
+ "node_modules/run-parallel": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
+ "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ],
+ "dependencies": {
+ "queue-microtask": "^1.2.2"
+ }
+ },
+ "node_modules/rxjs": {
+ "version": "6.6.7",
+ "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.7.tgz",
+ "integrity": "sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ==",
+ "dependencies": {
+ "tslib": "^1.9.0"
+ },
+ "engines": {
+ "npm": ">=2.0.0"
+ }
+ },
+ "node_modules/rxjs/node_modules/tslib": {
+ "version": "1.14.1",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz",
+ "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg=="
+ },
+ "node_modules/safe-buffer": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
+ "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/feross"
+ },
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/feross"
+ },
+ {
+ "type": "consulting",
+ "url": "https://feross.org/support"
+ }
+ ]
+ },
+ "node_modules/safer-buffer": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
+ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==",
+ "dev": true
+ },
+ "node_modules/safevalues": {
+ "version": "0.3.4",
+ "resolved": "https://registry.npmjs.org/safevalues/-/safevalues-0.3.4.tgz",
+ "integrity": "sha512-LRneZZRXNgjzwG4bDQdOTSbze3fHm1EAKN/8bePxnlEZiBmkYEDggaHbuvHI9/hoqHbGfsEA7tWS9GhYHZBBsw=="
+ },
+ "node_modules/sass": {
+ "version": "1.58.1",
+ "resolved": "https://registry.npmjs.org/sass/-/sass-1.58.1.tgz",
+ "integrity": "sha512-bnINi6nPXbP1XNRaranMFEBZWUfdW/AF16Ql5+ypRxfTvCRTTKrLsMIakyDcayUt2t/RZotmL4kgJwNH5xO+bg==",
+ "dev": true,
+ "dependencies": {
+ "chokidar": ">=3.0.0 <4.0.0",
+ "immutable": "^4.0.0",
+ "source-map-js": ">=0.6.2 <2.0.0"
+ },
+ "bin": {
+ "sass": "sass.js"
+ },
+ "engines": {
+ "node": ">=12.0.0"
+ }
+ },
+ "node_modules/sass-loader": {
+ "version": "13.2.0",
+ "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-13.2.0.tgz",
+ "integrity": "sha512-JWEp48djQA4nbZxmgC02/Wh0eroSUutulROUusYJO9P9zltRbNN80JCBHqRGzjd4cmZCa/r88xgfkjGD0TXsHg==",
+ "dev": true,
+ "dependencies": {
+ "klona": "^2.0.4",
+ "neo-async": "^2.6.2"
+ },
+ "engines": {
+ "node": ">= 14.15.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "fibers": ">= 3.1.0",
+ "node-sass": "^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0",
+ "sass": "^1.3.0",
+ "sass-embedded": "*",
+ "webpack": "^5.0.0"
+ },
+ "peerDependenciesMeta": {
+ "fibers": {
+ "optional": true
+ },
+ "node-sass": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "sass-embedded": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/sax": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz",
+ "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==",
+ "dev": true,
+ "optional": true
+ },
+ "node_modules/schema-utils": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.0.0.tgz",
+ "integrity": "sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg==",
+ "dev": true,
+ "dependencies": {
+ "@types/json-schema": "^7.0.9",
+ "ajv": "^8.8.0",
+ "ajv-formats": "^2.1.1",
+ "ajv-keywords": "^5.0.0"
+ },
+ "engines": {
+ "node": ">= 12.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ }
+ },
+ "node_modules/select-hose": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz",
+ "integrity": "sha512-mEugaLK+YfkijB4fx0e6kImuJdCIt2LxCRcbEYPqRGCs4F2ogyfZU5IAZRdjCP8JPq2AtdNoC/Dux63d9Kiryg==",
+ "dev": true
+ },
+ "node_modules/selfsigned": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz",
+ "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==",
+ "dev": true,
+ "dependencies": {
+ "node-forge": "^1"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/semver": {
+ "version": "7.5.3",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.3.tgz",
+ "integrity": "sha512-QBlUtyVk/5EeHbi7X0fw6liDZc7BBmEaSYn01fMU1OUYbf6GPsbTtd8WmnqbI20SeycoHSeiybkE/q1Q+qlThQ==",
+ "dev": true,
+ "dependencies": {
+ "lru-cache": "^6.0.0"
+ },
+ "bin": {
+ "semver": "bin/semver.js"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/semver/node_modules/lru-cache": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
+ "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/semver/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/send": {
+ "version": "0.18.0",
+ "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz",
+ "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==",
+ "dev": true,
+ "dependencies": {
+ "debug": "2.6.9",
+ "depd": "2.0.0",
+ "destroy": "1.2.0",
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "etag": "~1.8.1",
+ "fresh": "0.5.2",
+ "http-errors": "2.0.0",
+ "mime": "1.6.0",
+ "ms": "2.1.3",
+ "on-finished": "2.4.1",
+ "range-parser": "~1.2.1",
+ "statuses": "2.0.1"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/send/node_modules/debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.0.0"
+ }
+ },
+ "node_modules/send/node_modules/debug/node_modules/ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "node_modules/send/node_modules/mime": {
+ "version": "1.6.0",
+ "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
+ "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
+ "dev": true,
+ "bin": {
+ "mime": "cli.js"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/send/node_modules/ms": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
+ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
+ "dev": true
+ },
+ "node_modules/send/node_modules/statuses": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
+ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/serialize-javascript": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.1.tgz",
+ "integrity": "sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w==",
+ "dev": true,
+ "dependencies": {
+ "randombytes": "^2.1.0"
+ }
+ },
+ "node_modules/serve-index": {
+ "version": "1.9.1",
+ "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz",
+ "integrity": "sha512-pXHfKNP4qujrtteMrSBb0rc8HJ9Ms/GrXwcUtUtD5s4ewDJI8bT3Cz2zTVRMKtri49pLx2e0Ya8ziP5Ya2pZZw==",
+ "dev": true,
+ "dependencies": {
+ "accepts": "~1.3.4",
+ "batch": "0.6.1",
+ "debug": "2.6.9",
+ "escape-html": "~1.0.3",
+ "http-errors": "~1.6.2",
+ "mime-types": "~2.1.17",
+ "parseurl": "~1.3.2"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/serve-index/node_modules/debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "dependencies": {
+ "ms": "2.0.0"
+ }
+ },
+ "node_modules/serve-index/node_modules/depd": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
+ "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/serve-index/node_modules/http-errors": {
+ "version": "1.6.3",
+ "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz",
+ "integrity": "sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A==",
+ "dev": true,
+ "dependencies": {
+ "depd": "~1.1.2",
+ "inherits": "2.0.3",
+ "setprototypeof": "1.1.0",
+ "statuses": ">= 1.4.0 < 2"
+ },
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/serve-index/node_modules/inherits": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
+ "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==",
+ "dev": true
+ },
+ "node_modules/serve-index/node_modules/ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "node_modules/serve-index/node_modules/setprototypeof": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz",
+ "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==",
+ "dev": true
+ },
+ "node_modules/serve-static": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz",
+ "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==",
+ "dev": true,
+ "dependencies": {
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "parseurl": "~1.3.3",
+ "send": "0.18.0"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/set-blocking": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz",
+ "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==",
+ "dev": true
+ },
+ "node_modules/setprototypeof": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
+ "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==",
+ "dev": true
+ },
+ "node_modules/shallow-clone": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz",
+ "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==",
+ "dev": true,
+ "dependencies": {
+ "kind-of": "^6.0.2"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "dependencies": {
+ "shebang-regex": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true,
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/side-channel": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz",
+ "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==",
+ "dev": true,
+ "dependencies": {
+ "call-bind": "^1.0.0",
+ "get-intrinsic": "^1.0.2",
+ "object-inspect": "^1.9.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/signal-exit": {
+ "version": "3.0.7",
+ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz",
+ "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==",
+ "dev": true
+ },
+ "node_modules/sigstore": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmjs.org/sigstore/-/sigstore-1.8.0.tgz",
+ "integrity": "sha512-ogU8qtQ3VFBawRJ8wjsBEX/vIFeHuGs1fm4jZtjWQwjo8pfAt7T/rh+udlAN4+QUe0IzA8qRSc/YZ7dHP6kh+w==",
+ "dev": true,
+ "dependencies": {
+ "@sigstore/bundle": "^1.0.0",
+ "@sigstore/protobuf-specs": "^0.2.0",
+ "@sigstore/tuf": "^1.0.3",
+ "make-fetch-happen": "^11.0.1"
+ },
+ "bin": {
+ "sigstore": "bin/sigstore.js"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/slash": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-4.0.0.tgz",
+ "integrity": "sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/smart-buffer": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz",
+ "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 6.0.0",
+ "npm": ">= 3.0.0"
+ }
+ },
+ "node_modules/socket.io": {
+ "version": "4.6.1",
+ "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-4.6.1.tgz",
+ "integrity": "sha512-KMcaAi4l/8+xEjkRICl6ak8ySoxsYG+gG6/XfRCPJPQ/haCRIJBTL4wIl8YCsmtaBovcAXGLOShyVWQ/FG8GZA==",
+ "dev": true,
+ "dependencies": {
+ "accepts": "~1.3.4",
+ "base64id": "~2.0.0",
+ "debug": "~4.3.2",
+ "engine.io": "~6.4.1",
+ "socket.io-adapter": "~2.5.2",
+ "socket.io-parser": "~4.2.1"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/socket.io-adapter": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-2.5.2.tgz",
+ "integrity": "sha512-87C3LO/NOMc+eMcpcxUBebGjkpMDkNBS9tf7KJqcDsmL936EChtVva71Dw2q4tQcuVC+hAUy4an2NO/sYXmwRA==",
+ "dev": true,
+ "dependencies": {
+ "ws": "~8.11.0"
+ }
+ },
+ "node_modules/socket.io-parser": {
+ "version": "4.2.3",
+ "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.2.3.tgz",
+ "integrity": "sha512-JMafRntWVO2DCJimKsRTh/wnqVvO4hrfwOqtO7f+uzwsQMuxO6VwImtYxaQ+ieoyshWOTJyV0fA21lccEXRPpQ==",
+ "dev": true,
+ "dependencies": {
+ "@socket.io/component-emitter": "~3.1.0",
+ "debug": "~4.3.1"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/sockjs": {
+ "version": "0.3.24",
+ "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.24.tgz",
+ "integrity": "sha512-GJgLTZ7vYb/JtPSSZ10hsOYIvEYsjbNU+zPdIHcUaWVNUEPivzxku31865sSSud0Da0W4lEeOPlmw93zLQchuQ==",
+ "dev": true,
+ "dependencies": {
+ "faye-websocket": "^0.11.3",
+ "uuid": "^8.3.2",
+ "websocket-driver": "^0.7.4"
+ }
+ },
+ "node_modules/socks": {
+ "version": "2.7.1",
+ "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz",
+ "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==",
+ "dev": true,
+ "dependencies": {
+ "ip": "^2.0.0",
+ "smart-buffer": "^4.2.0"
+ },
+ "engines": {
+ "node": ">= 10.13.0",
+ "npm": ">= 3.0.0"
+ }
+ },
+ "node_modules/socks-proxy-agent": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-7.0.0.tgz",
+ "integrity": "sha512-Fgl0YPZ902wEsAyiQ+idGd1A7rSFx/ayC1CQVMw5P+EQx2V0SgpGtf6OKFhVjPflPUl9YMmEOnmfjCdMUsygww==",
+ "dev": true,
+ "dependencies": {
+ "agent-base": "^6.0.2",
+ "debug": "^4.3.3",
+ "socks": "^2.6.2"
+ },
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/sortablejs": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/sortablejs/-/sortablejs-1.15.0.tgz",
+ "integrity": "sha512-bv9qgVMjUMf89wAvM6AxVvS/4MX3sPeN0+agqShejLU5z5GX4C75ow1O2e5k4L6XItUyAK3gH6AxSbXrOM5e8w=="
+ },
+ "node_modules/source-map": {
+ "version": "0.7.4",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz",
+ "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
+ "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-loader": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/source-map-loader/-/source-map-loader-4.0.1.tgz",
+ "integrity": "sha512-oqXpzDIByKONVY8g1NUPOTQhe0UTU5bWUl32GSkqK2LjJj0HmwTMVKxcUip0RgAYhY1mqgOxjbQM48a0mmeNfA==",
+ "dev": true,
+ "dependencies": {
+ "abab": "^2.0.6",
+ "iconv-lite": "^0.6.3",
+ "source-map-js": "^1.0.2"
+ },
+ "engines": {
+ "node": ">= 14.15.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^5.72.1"
+ }
+ },
+ "node_modules/source-map-loader/node_modules/iconv-lite": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz",
+ "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
+ "dev": true,
+ "dependencies": {
+ "safer-buffer": ">= 2.1.2 < 3.0.0"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-support": {
+ "version": "0.5.21",
+ "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz",
+ "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==",
+ "dev": true,
+ "dependencies": {
+ "buffer-from": "^1.0.0",
+ "source-map": "^0.6.0"
+ }
+ },
+ "node_modules/source-map-support/node_modules/source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/spdx-correct": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz",
+ "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==",
+ "dev": true,
+ "dependencies": {
+ "spdx-expression-parse": "^3.0.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "node_modules/spdx-exceptions": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz",
+ "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==",
+ "dev": true
+ },
+ "node_modules/spdx-expression-parse": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz",
+ "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==",
+ "dev": true,
+ "dependencies": {
+ "spdx-exceptions": "^2.1.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "node_modules/spdx-license-ids": {
+ "version": "3.0.13",
+ "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.13.tgz",
+ "integrity": "sha512-XkD+zwiqXHikFZm4AX/7JSCXA98U5Db4AFd5XUg/+9UNtnH75+Z9KxtpYiJZx36mUDVOwH83pl7yvCer6ewM3w==",
+ "dev": true
+ },
+ "node_modules/spdy": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/spdy/-/spdy-4.0.2.tgz",
+ "integrity": "sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA==",
+ "dev": true,
+ "dependencies": {
+ "debug": "^4.1.0",
+ "handle-thing": "^2.0.0",
+ "http-deceiver": "^1.2.7",
+ "select-hose": "^2.0.0",
+ "spdy-transport": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/spdy-transport": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz",
+ "integrity": "sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw==",
+ "dev": true,
+ "dependencies": {
+ "debug": "^4.1.0",
+ "detect-node": "^2.0.4",
+ "hpack.js": "^2.1.6",
+ "obuf": "^1.1.2",
+ "readable-stream": "^3.0.6",
+ "wbuf": "^1.7.3"
+ }
+ },
+ "node_modules/sprintf-js": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz",
+ "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==",
+ "dev": true
+ },
+ "node_modules/ssr-window": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/ssr-window/-/ssr-window-4.0.2.tgz",
+ "integrity": "sha512-ISv/Ch+ig7SOtw7G2+qkwfVASzazUnvlDTwypdLoPoySv+6MqlOV10VwPSE6EWkGjhW50lUmghPmpYZXMu/+AQ=="
+ },
+ "node_modules/ssri": {
+ "version": "10.0.1",
+ "resolved": "https://registry.npmjs.org/ssri/-/ssri-10.0.1.tgz",
+ "integrity": "sha512-WVy6di9DlPOeBWEjMScpNipeSX2jIZBGEn5Uuo8Q7aIuFEuDX0pw8RxcOjlD1TWP4obi24ki7m/13+nFpcbXrw==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^4.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/statuses": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz",
+ "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/streamroller": {
+ "version": "3.1.4",
+ "resolved": "https://registry.npmjs.org/streamroller/-/streamroller-3.1.4.tgz",
+ "integrity": "sha512-Ha1Ccw2/N5C/IF8Do6zgNe8F3jQo8MPBnMBGvX0QjNv/I97BcNRzK6/mzOpZHHK7DjMLTI3c7Xw7Y1KvdChkvw==",
+ "dev": true,
+ "dependencies": {
+ "date-format": "^4.0.14",
+ "debug": "^4.3.4",
+ "fs-extra": "^8.1.0"
+ },
+ "engines": {
+ "node": ">=8.0"
+ }
+ },
+ "node_modules/string_decoder": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz",
+ "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==",
+ "dev": true,
+ "dependencies": {
+ "safe-buffer": "~5.2.0"
+ }
+ },
+ "node_modules/string-width": {
+ "version": "4.2.3",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
+ "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
+ "dev": true,
+ "dependencies": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/string-width-cjs": {
+ "name": "string-width",
+ "version": "4.2.3",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
+ "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
+ "dev": true,
+ "dependencies": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-ansi": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "dependencies": {
+ "ansi-regex": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-ansi-cjs": {
+ "name": "strip-ansi",
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "dependencies": {
+ "ansi-regex": "^5.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/strip-final-newline": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz",
+ "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/supports-color": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
+ "dev": true,
+ "dependencies": {
+ "has-flag": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/supports-preserve-symlinks-flag": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
+ "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/swiper": {
+ "version": "8.4.7",
+ "resolved": "https://registry.npmjs.org/swiper/-/swiper-8.4.7.tgz",
+ "integrity": "sha512-VwO/KU3i9IV2Sf+W2NqyzwWob4yX9Qdedq6vBtS0rFqJ6Fa5iLUJwxQkuD4I38w0WDJwmFl8ojkdcRFPHWD+2g==",
+ "funding": [
+ {
+ "type": "patreon",
+ "url": "https://www.patreon.com/swiperjs"
+ },
+ {
+ "type": "open_collective",
+ "url": "http://opencollective.com/swiper"
+ }
+ ],
+ "hasInstallScript": true,
+ "dependencies": {
+ "dom7": "^4.0.4",
+ "ssr-window": "^4.0.2"
+ },
+ "engines": {
+ "node": ">= 4.7.0"
+ }
+ },
+ "node_modules/symbol-observable": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-4.0.0.tgz",
+ "integrity": "sha512-b19dMThMV4HVFynSAM1++gBHAbk2Tc/osgLIBZMKsyqh34jb2e8Os7T6ZW/Bt3pJFdBTd2JwAnAAEQV7rSNvcQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10"
+ }
+ },
+ "node_modules/tapable": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz",
+ "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/tar": {
+ "version": "6.1.13",
+ "resolved": "https://registry.npmjs.org/tar/-/tar-6.1.13.tgz",
+ "integrity": "sha512-jdIBIN6LTIe2jqzay/2vtYLlBHa3JF42ot3h1dW8Q0PaAG4v8rm0cvpVePtau5C6OKXGGcgO9q2AMNSWxiLqKw==",
+ "dev": true,
+ "dependencies": {
+ "chownr": "^2.0.0",
+ "fs-minipass": "^2.0.0",
+ "minipass": "^4.0.0",
+ "minizlib": "^2.1.1",
+ "mkdirp": "^1.0.3",
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/tar/node_modules/fs-minipass": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz",
+ "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==",
+ "dev": true,
+ "dependencies": {
+ "minipass": "^3.0.0"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/tar/node_modules/fs-minipass/node_modules/minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "dependencies": {
+ "yallist": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/tar/node_modules/mkdirp": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz",
+ "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==",
+ "dev": true,
+ "bin": {
+ "mkdirp": "bin/cmd.js"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/tar/node_modules/yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ },
+ "node_modules/terser": {
+ "version": "5.16.3",
+ "resolved": "https://registry.npmjs.org/terser/-/terser-5.16.3.tgz",
+ "integrity": "sha512-v8wWLaS/xt3nE9dgKEWhNUFP6q4kngO5B8eYFUuebsu7Dw/UNAnpUod6UHo04jSSkv8TzKHjZDSd7EXdDQAl8Q==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/source-map": "^0.3.2",
+ "acorn": "^8.5.0",
+ "commander": "^2.20.0",
+ "source-map-support": "~0.5.20"
+ },
+ "bin": {
+ "terser": "bin/terser"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/terser-webpack-plugin": {
+ "version": "5.3.9",
+ "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.9.tgz",
+ "integrity": "sha512-ZuXsqE07EcggTWQjXUj+Aot/OMcD0bMKGgF63f7UxYcu5/AJF53aIpK1YoP5xR9l6s/Hy2b+t1AM0bLNPRuhwA==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/trace-mapping": "^0.3.17",
+ "jest-worker": "^27.4.5",
+ "schema-utils": "^3.1.1",
+ "serialize-javascript": "^6.0.1",
+ "terser": "^5.16.8"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^5.1.0"
+ },
+ "peerDependenciesMeta": {
+ "@swc/core": {
+ "optional": true
+ },
+ "esbuild": {
+ "optional": true
+ },
+ "uglify-js": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/terser-webpack-plugin/node_modules/ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/terser-webpack-plugin/node_modules/ajv-keywords": {
+ "version": "3.5.2",
+ "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz",
+ "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==",
+ "dev": true,
+ "peerDependencies": {
+ "ajv": "^6.9.1"
+ }
+ },
+ "node_modules/terser-webpack-plugin/node_modules/json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "node_modules/terser-webpack-plugin/node_modules/schema-utils": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz",
+ "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==",
+ "dev": true,
+ "dependencies": {
+ "@types/json-schema": "^7.0.8",
+ "ajv": "^6.12.5",
+ "ajv-keywords": "^3.5.2"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ }
+ },
+ "node_modules/terser-webpack-plugin/node_modules/terser": {
+ "version": "5.19.2",
+ "resolved": "https://registry.npmjs.org/terser/-/terser-5.19.2.tgz",
+ "integrity": "sha512-qC5+dmecKJA4cpYxRa5aVkKehYsQKc+AHeKl0Oe62aYjBL8ZA33tTljktDHJSaxxMnbI5ZYw+o/S2DxxLu8OfA==",
+ "dev": true,
+ "dependencies": {
+ "@jridgewell/source-map": "^0.3.3",
+ "acorn": "^8.8.2",
+ "commander": "^2.20.0",
+ "source-map-support": "~0.5.20"
+ },
+ "bin": {
+ "terser": "bin/terser"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/test-exclude": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz",
+ "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==",
+ "dev": true,
+ "dependencies": {
+ "@istanbuljs/schema": "^0.1.2",
+ "glob": "^7.1.4",
+ "minimatch": "^3.0.4"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/test-exclude/node_modules/brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/test-exclude/node_modules/glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "dependencies": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ },
+ "engines": {
+ "node": "*"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/test-exclude/node_modules/minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/text-table": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
+ "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
+ "dev": true
+ },
+ "node_modules/through": {
+ "version": "2.3.8",
+ "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz",
+ "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==",
+ "dev": true
+ },
+ "node_modules/thunky": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz",
+ "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==",
+ "dev": true
+ },
+ "node_modules/tinymce": {
+ "version": "6.4.2",
+ "resolved": "https://registry.npmjs.org/tinymce/-/tinymce-6.4.2.tgz",
+ "integrity": "sha512-te+4c8PoAwTKPMBQtMQehnSZlOO9Ay5tDgaRFJKBehYb6SlX2PYZ0v3oe/cmiv5EfqdwZLkEMXk2MNOeApZZLg=="
+ },
+ "node_modules/tmp": {
+ "version": "0.0.33",
+ "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz",
+ "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==",
+ "dev": true,
+ "dependencies": {
+ "os-tmpdir": "~1.0.2"
+ },
+ "engines": {
+ "node": ">=0.6.0"
+ }
+ },
+ "node_modules/to-fast-properties": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
+ "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/to-regex-range": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
+ "dev": true,
+ "dependencies": {
+ "is-number": "^7.0.0"
+ },
+ "engines": {
+ "node": ">=8.0"
+ }
+ },
+ "node_modules/toidentifier": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
+ "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.6"
+ }
+ },
+ "node_modules/tree-kill": {
+ "version": "1.2.2",
+ "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz",
+ "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==",
+ "dev": true,
+ "bin": {
+ "tree-kill": "cli.js"
+ }
+ },
+ "node_modules/tslib": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz",
+ "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg=="
+ },
+ "node_modules/tuf-js": {
+ "version": "1.1.7",
+ "resolved": "https://registry.npmjs.org/tuf-js/-/tuf-js-1.1.7.tgz",
+ "integrity": "sha512-i3P9Kgw3ytjELUfpuKVDNBJvk4u5bXL6gskv572mcevPbSKCV3zt3djhmlEQ65yERjIbOSncy7U4cQJaB1CBCg==",
+ "dev": true,
+ "dependencies": {
+ "@tufjs/models": "1.0.4",
+ "debug": "^4.3.4",
+ "make-fetch-happen": "^11.1.1"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/type-fest": {
+ "version": "0.21.3",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz",
+ "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/type-is": {
+ "version": "1.6.18",
+ "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
+ "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
+ "dev": true,
+ "dependencies": {
+ "media-typer": "0.3.0",
+ "mime-types": "~2.1.24"
+ },
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
+ "node_modules/typed-assert": {
+ "version": "1.0.9",
+ "resolved": "https://registry.npmjs.org/typed-assert/-/typed-assert-1.0.9.tgz",
+ "integrity": "sha512-KNNZtayBCtmnNmbo5mG47p1XsCyrx6iVqomjcZnec/1Y5GGARaxPs6r49RnSPeUP3YjNYiU9sQHAtY4BBvnZwg==",
+ "dev": true
+ },
+ "node_modules/typescript": {
+ "version": "4.9.4",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.4.tgz",
+ "integrity": "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==",
+ "dev": true,
+ "bin": {
+ "tsc": "bin/tsc",
+ "tsserver": "bin/tsserver"
+ },
+ "engines": {
+ "node": ">=4.2.0"
+ }
+ },
+ "node_modules/ua-parser-js": {
+ "version": "0.7.35",
+ "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.35.tgz",
+ "integrity": "sha512-veRf7dawaj9xaWEu9HoTVn5Pggtc/qj+kqTOFvNiN1l0YdxwC1kvel57UCjThjGa3BHBihE8/UJAHI+uQHmd/g==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/ua-parser-js"
+ },
+ {
+ "type": "paypal",
+ "url": "https://paypal.me/faisalman"
+ }
+ ],
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/unicode-canonical-property-names-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-match-property-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==",
+ "dev": true,
+ "dependencies": {
+ "unicode-canonical-property-names-ecmascript": "^2.0.0",
+ "unicode-property-aliases-ecmascript": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-match-property-value-ecmascript": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz",
+ "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unicode-property-aliases-ecmascript": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz",
+ "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==",
+ "dev": true,
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/unique-filename": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-3.0.0.tgz",
+ "integrity": "sha512-afXhuC55wkAmZ0P18QsVE6kp8JaxrEokN2HGIoIVv2ijHQd419H0+6EigAFcIzXeMIkcIkNBpB3L/DXB3cTS/g==",
+ "dev": true,
+ "dependencies": {
+ "unique-slug": "^4.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/unique-slug": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-4.0.0.tgz",
+ "integrity": "sha512-WrcA6AyEfqDX5bWige/4NQfPZMtASNVxdmWR76WESYQVAACSgWcR6e9i0mofqqBxYFtL4oAxPIptY73/0YE1DQ==",
+ "dev": true,
+ "dependencies": {
+ "imurmurhash": "^0.1.4"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/universalify": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz",
+ "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 4.0.0"
+ }
+ },
+ "node_modules/unpipe": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
+ "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/update-browserslist-db": {
+ "version": "1.0.10",
+ "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz",
+ "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ }
+ ],
+ "dependencies": {
+ "escalade": "^3.1.1",
+ "picocolors": "^1.0.0"
+ },
+ "bin": {
+ "browserslist-lint": "cli.js"
+ },
+ "peerDependencies": {
+ "browserslist": ">= 4.21.0"
+ }
+ },
+ "node_modules/uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "dependencies": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "node_modules/util-deprecate": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
+ "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==",
+ "dev": true
+ },
+ "node_modules/utils-merge": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
+ "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.4.0"
+ }
+ },
+ "node_modules/uuid": {
+ "version": "8.3.2",
+ "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
+ "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==",
+ "dev": true,
+ "bin": {
+ "uuid": "dist/bin/uuid"
+ }
+ },
+ "node_modules/validate-npm-package-license": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
+ "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
+ "dev": true,
+ "dependencies": {
+ "spdx-correct": "^3.0.0",
+ "spdx-expression-parse": "^3.0.0"
+ }
+ },
+ "node_modules/validate-npm-package-name": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/validate-npm-package-name/-/validate-npm-package-name-5.0.0.tgz",
+ "integrity": "sha512-YuKoXDAhBYxY7SfOKxHBDoSyENFeW5VvIIQp2TGQuit8gpK6MnWaQelBKxso72DoxTZfZdcP3W90LqpSkgPzLQ==",
+ "dev": true,
+ "dependencies": {
+ "builtins": "^5.0.0"
+ },
+ "engines": {
+ "node": "^14.17.0 || ^16.13.0 || >=18.0.0"
+ }
+ },
+ "node_modules/vary": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
+ "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.8"
+ }
+ },
+ "node_modules/void-elements": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/void-elements/-/void-elements-2.0.1.tgz",
+ "integrity": "sha512-qZKX4RnBzH2ugr8Lxa7x+0V6XD9Sb/ouARtiasEQCHB1EVU4NXtmHsDDrx1dO4ne5fc3J6EW05BP1Dl0z0iung==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/watchpack": {
+ "version": "2.4.0",
+ "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.4.0.tgz",
+ "integrity": "sha512-Lcvm7MGST/4fup+ifyKi2hjyIAwcdI4HRgtvTpIUxBRhB+RFtUh8XtDOxUfctVCnhVi+QQj49i91OyvzkJl6cg==",
+ "dev": true,
+ "dependencies": {
+ "glob-to-regexp": "^0.4.1",
+ "graceful-fs": "^4.1.2"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/wbuf": {
+ "version": "1.7.3",
+ "resolved": "https://registry.npmjs.org/wbuf/-/wbuf-1.7.3.tgz",
+ "integrity": "sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA==",
+ "dev": true,
+ "dependencies": {
+ "minimalistic-assert": "^1.0.0"
+ }
+ },
+ "node_modules/wcwidth": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz",
+ "integrity": "sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg==",
+ "dev": true,
+ "dependencies": {
+ "defaults": "^1.0.3"
+ }
+ },
+ "node_modules/webpack": {
+ "version": "5.76.1",
+ "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.76.1.tgz",
+ "integrity": "sha512-4+YIK4Abzv8172/SGqObnUjaIHjLEuUasz9EwQj/9xmPPkYJy2Mh03Q/lJfSD3YLzbxy5FeTq5Uw0323Oh6SJQ==",
+ "dev": true,
+ "dependencies": {
+ "@types/eslint-scope": "^3.7.3",
+ "@types/estree": "^0.0.51",
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/wasm-edit": "1.11.1",
+ "@webassemblyjs/wasm-parser": "1.11.1",
+ "acorn": "^8.7.1",
+ "acorn-import-assertions": "^1.7.6",
+ "browserslist": "^4.14.5",
+ "chrome-trace-event": "^1.0.2",
+ "enhanced-resolve": "^5.10.0",
+ "es-module-lexer": "^0.9.0",
+ "eslint-scope": "5.1.1",
+ "events": "^3.2.0",
+ "glob-to-regexp": "^0.4.1",
+ "graceful-fs": "^4.2.9",
+ "json-parse-even-better-errors": "^2.3.1",
+ "loader-runner": "^4.2.0",
+ "mime-types": "^2.1.27",
+ "neo-async": "^2.6.2",
+ "schema-utils": "^3.1.0",
+ "tapable": "^2.1.1",
+ "terser-webpack-plugin": "^5.1.3",
+ "watchpack": "^2.4.0",
+ "webpack-sources": "^3.2.3"
+ },
+ "bin": {
+ "webpack": "bin/webpack.js"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependenciesMeta": {
+ "webpack-cli": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/webpack-dev-middleware": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-6.0.1.tgz",
+ "integrity": "sha512-PZPZ6jFinmqVPJZbisfggDiC+2EeGZ1ZByyMP5sOFJcPPWSexalISz+cvm+j+oYPT7FIJyxT76esjnw9DhE5sw==",
+ "dev": true,
+ "dependencies": {
+ "colorette": "^2.0.10",
+ "memfs": "^3.4.12",
+ "mime-types": "^2.1.31",
+ "range-parser": "^1.2.1",
+ "schema-utils": "^4.0.0"
+ },
+ "engines": {
+ "node": ">= 14.15.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^5.0.0"
+ }
+ },
+ "node_modules/webpack-dev-server": {
+ "version": "4.11.1",
+ "resolved": "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-4.11.1.tgz",
+ "integrity": "sha512-lILVz9tAUy1zGFwieuaQtYiadImb5M3d+H+L1zDYalYoDl0cksAB1UNyuE5MMWJrG6zR1tXkCP2fitl7yoUJiw==",
+ "dev": true,
+ "dependencies": {
+ "@types/bonjour": "^3.5.9",
+ "@types/connect-history-api-fallback": "^1.3.5",
+ "@types/express": "^4.17.13",
+ "@types/serve-index": "^1.9.1",
+ "@types/serve-static": "^1.13.10",
+ "@types/sockjs": "^0.3.33",
+ "@types/ws": "^8.5.1",
+ "ansi-html-community": "^0.0.8",
+ "bonjour-service": "^1.0.11",
+ "chokidar": "^3.5.3",
+ "colorette": "^2.0.10",
+ "compression": "^1.7.4",
+ "connect-history-api-fallback": "^2.0.0",
+ "default-gateway": "^6.0.3",
+ "express": "^4.17.3",
+ "graceful-fs": "^4.2.6",
+ "html-entities": "^2.3.2",
+ "http-proxy-middleware": "^2.0.3",
+ "ipaddr.js": "^2.0.1",
+ "open": "^8.0.9",
+ "p-retry": "^4.5.0",
+ "rimraf": "^3.0.2",
+ "schema-utils": "^4.0.0",
+ "selfsigned": "^2.1.1",
+ "serve-index": "^1.9.1",
+ "sockjs": "^0.3.24",
+ "spdy": "^4.0.2",
+ "webpack-dev-middleware": "^5.3.1",
+ "ws": "^8.4.2"
+ },
+ "bin": {
+ "webpack-dev-server": "bin/webpack-dev-server.js"
+ },
+ "engines": {
+ "node": ">= 12.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^4.37.0 || ^5.0.0"
+ },
+ "peerDependenciesMeta": {
+ "webpack-cli": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/webpack-dev-server/node_modules/webpack-dev-middleware": {
+ "version": "5.3.3",
+ "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-5.3.3.tgz",
+ "integrity": "sha512-hj5CYrY0bZLB+eTO+x/j67Pkrquiy7kWepMHmUMoPsmcUaeEnQJqFzHJOyxgWlq746/wUuA64p9ta34Kyb01pA==",
+ "dev": true,
+ "dependencies": {
+ "colorette": "^2.0.10",
+ "memfs": "^3.4.3",
+ "mime-types": "^2.1.31",
+ "range-parser": "^1.2.1",
+ "schema-utils": "^4.0.0"
+ },
+ "engines": {
+ "node": ">= 12.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ },
+ "peerDependencies": {
+ "webpack": "^4.0.0 || ^5.0.0"
+ }
+ },
+ "node_modules/webpack-dev-server/node_modules/ws": {
+ "version": "8.12.0",
+ "resolved": "https://registry.npmjs.org/ws/-/ws-8.12.0.tgz",
+ "integrity": "sha512-kU62emKIdKVeEIOIKVegvqpXMSTAMLJozpHZaJNDYqBjzlSYXQGviYwN1osDLJ9av68qHd4a2oSjd7yD4pacig==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.0.0"
+ },
+ "peerDependencies": {
+ "bufferutil": "^4.0.1",
+ "utf-8-validate": ">=5.0.2"
+ },
+ "peerDependenciesMeta": {
+ "bufferutil": {
+ "optional": true
+ },
+ "utf-8-validate": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/webpack-merge": {
+ "version": "5.8.0",
+ "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-5.8.0.tgz",
+ "integrity": "sha512-/SaI7xY0831XwP6kzuwhKWVKDP9t1QY1h65lAFLbZqMPIuYcD9QAW4u9STIbU9kaJbPBB/geU/gLr1wDjOhQ+Q==",
+ "dev": true,
+ "dependencies": {
+ "clone-deep": "^4.0.1",
+ "wildcard": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10.0.0"
+ }
+ },
+ "node_modules/webpack-sources": {
+ "version": "3.2.3",
+ "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz",
+ "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/webpack-subresource-integrity": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/webpack-subresource-integrity/-/webpack-subresource-integrity-5.1.0.tgz",
+ "integrity": "sha512-sacXoX+xd8r4WKsy9MvH/q/vBtEHr86cpImXwyg74pFIpERKt6FmB8cXpeuh0ZLgclOlHI4Wcll7+R5L02xk9Q==",
+ "dev": true,
+ "dependencies": {
+ "typed-assert": "^1.0.8"
+ },
+ "engines": {
+ "node": ">= 12"
+ },
+ "peerDependencies": {
+ "html-webpack-plugin": ">= 5.0.0-beta.1 < 6",
+ "webpack": "^5.12.0"
+ },
+ "peerDependenciesMeta": {
+ "html-webpack-plugin": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/webpack/node_modules/ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/webpack/node_modules/ajv-keywords": {
+ "version": "3.5.2",
+ "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz",
+ "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==",
+ "dev": true,
+ "peerDependencies": {
+ "ajv": "^6.9.1"
+ }
+ },
+ "node_modules/webpack/node_modules/json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "node_modules/webpack/node_modules/schema-utils": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz",
+ "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==",
+ "dev": true,
+ "dependencies": {
+ "@types/json-schema": "^7.0.8",
+ "ajv": "^6.12.5",
+ "ajv-keywords": "^3.5.2"
+ },
+ "engines": {
+ "node": ">= 10.13.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ }
+ },
+ "node_modules/websocket-driver": {
+ "version": "0.7.4",
+ "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz",
+ "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==",
+ "dev": true,
+ "dependencies": {
+ "http-parser-js": ">=0.5.1",
+ "safe-buffer": ">=5.1.0",
+ "websocket-extensions": ">=0.1.1"
+ },
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/websocket-extensions": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz",
+ "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==",
+ "dev": true,
+ "engines": {
+ "node": ">=0.8.0"
+ }
+ },
+ "node_modules/which": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
+ "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
+ "dev": true,
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "which": "bin/which"
+ }
+ },
+ "node_modules/wide-align": {
+ "version": "1.1.5",
+ "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz",
+ "integrity": "sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==",
+ "dev": true,
+ "dependencies": {
+ "string-width": "^1.0.2 || 2 || 3 || 4"
+ }
+ },
+ "node_modules/wildcard": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/wildcard/-/wildcard-2.0.0.tgz",
+ "integrity": "sha512-JcKqAHLPxcdb9KM49dufGXn2x3ssnfjbcaQdLlfZsL9rH9wgDQjUtDxbo8NE0F6SFvydeu1VhZe7hZuHsB2/pw==",
+ "dev": true
+ },
+ "node_modules/wrap-ansi": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
+ "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.0.0",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi-cjs": {
+ "name": "wrap-ansi",
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
+ "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
+ "dev": true,
+ "dependencies": {
+ "ansi-styles": "^4.0.0",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi-cjs/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/wrap-ansi-cjs/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/wrap-ansi/node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/wrap-ansi/node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "node_modules/wrappy": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
+ "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==",
+ "dev": true
+ },
+ "node_modules/ws": {
+ "version": "8.11.0",
+ "resolved": "https://registry.npmjs.org/ws/-/ws-8.11.0.tgz",
+ "integrity": "sha512-HPG3wQd9sNQoT9xHyNCXoDUa+Xw/VevmY9FoHyQ+g+rrMn4j6FB4np7Z0OhdTgjx6MgQLK7jwSy1YecU1+4Asg==",
+ "dev": true,
+ "engines": {
+ "node": ">=10.0.0"
+ },
+ "peerDependencies": {
+ "bufferutil": "^4.0.1",
+ "utf-8-validate": "^5.0.2"
+ },
+ "peerDependenciesMeta": {
+ "bufferutil": {
+ "optional": true
+ },
+ "utf-8-validate": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/y18n": {
+ "version": "5.0.8",
+ "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
+ "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
+ "dev": true,
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/yallist": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
+ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
+ "dev": true
+ },
+ "node_modules/yaml": {
+ "version": "1.10.2",
+ "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz",
+ "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==",
+ "dev": true,
+ "engines": {
+ "node": ">= 6"
+ }
+ },
+ "node_modules/yargs": {
+ "version": "17.6.2",
+ "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.6.2.tgz",
+ "integrity": "sha512-1/9UrdHjDZc0eOU0HxOHoS78C69UD3JRMvzlJ7S79S2nTaWRA/whGCTV8o9e/N/1Va9YIV7Q4sOxD8VV4pCWOw==",
+ "dev": true,
+ "dependencies": {
+ "cliui": "^8.0.1",
+ "escalade": "^3.1.1",
+ "get-caller-file": "^2.0.5",
+ "require-directory": "^2.1.1",
+ "string-width": "^4.2.3",
+ "y18n": "^5.0.5",
+ "yargs-parser": "^21.1.1"
+ },
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/yargs-parser": {
+ "version": "21.1.1",
+ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz",
+ "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==",
+ "dev": true,
+ "engines": {
+ "node": ">=12"
+ }
+ },
+ "node_modules/zone.js": {
+ "version": "0.11.8",
+ "resolved": "https://registry.npmjs.org/zone.js/-/zone.js-0.11.8.tgz",
+ "integrity": "sha512-82bctBg2hKcEJ21humWIkXRlLBBmrc3nN7DFh5LGGhcyycO2S7FN8NmdvlcKaGFDNVL4/9kFLmwmInTavdJERA==",
+ "dependencies": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "node_modules/zrender": {
+ "version": "5.4.1",
+ "resolved": "https://registry.npmjs.org/zrender/-/zrender-5.4.1.tgz",
+ "integrity": "sha512-M4Z05BHWtajY2241EmMPHglDQAJ1UyHQcYsxDNzD9XLSkPDqMq4bB28v9Pb4mvHnVQ0GxyTklZ/69xCFP6RXBA==",
+ "dependencies": {
+ "tslib": "2.3.0"
+ }
+ },
+ "node_modules/zrender/node_modules/tslib": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.0.tgz",
+ "integrity": "sha512-N82ooyxVNm6h1riLCoyS9e3fuJ3AMG2zIZs2Gd1ATcSFjSA23Q0fzjjZeh0jbJvWVDZ0cJT8yaNNaaXHzueNjg=="
+ }
+ },
+ "dependencies": {
+ "@ampproject/remapping": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz",
+ "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/gen-mapping": "^0.1.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ },
+ "@angular-devkit/architect": {
+ "version": "0.1502.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/architect/-/architect-0.1502.9.tgz",
+ "integrity": "sha512-CFn+LbtYeLG7WqO+BBSjogl764StHpwgfJnNAXQ/3UouUktZ92z4lxhUm0PwIPb5k0lILsf81ubcS1vzwoXEEg==",
+ "dev": true,
+ "requires": {
+ "@angular-devkit/core": "15.2.9",
+ "rxjs": "6.6.7"
+ }
+ },
+ "@angular-devkit/build-angular": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/build-angular/-/build-angular-15.2.9.tgz",
+ "integrity": "sha512-djOo2Q22zLrxPccSbINz93hD+pES/nNPoze4Ys/0IdtMlLmxO/YGsA+FG5eNeNAf2jK/JRoNydaYOh7XpGoCzA==",
+ "dev": true,
+ "requires": {
+ "@ampproject/remapping": "2.2.0",
+ "@angular-devkit/architect": "0.1502.9",
+ "@angular-devkit/build-webpack": "0.1502.9",
+ "@angular-devkit/core": "15.2.9",
+ "@babel/core": "7.20.12",
+ "@babel/generator": "7.20.14",
+ "@babel/helper-annotate-as-pure": "7.18.6",
+ "@babel/helper-split-export-declaration": "7.18.6",
+ "@babel/plugin-proposal-async-generator-functions": "7.20.7",
+ "@babel/plugin-transform-async-to-generator": "7.20.7",
+ "@babel/plugin-transform-runtime": "7.19.6",
+ "@babel/preset-env": "7.20.2",
+ "@babel/runtime": "7.20.13",
+ "@babel/template": "7.20.7",
+ "@discoveryjs/json-ext": "0.5.7",
+ "@ngtools/webpack": "15.2.9",
+ "ansi-colors": "4.1.3",
+ "autoprefixer": "10.4.13",
+ "babel-loader": "9.1.2",
+ "babel-plugin-istanbul": "6.1.1",
+ "browserslist": "4.21.5",
+ "cacache": "17.0.4",
+ "chokidar": "3.5.3",
+ "copy-webpack-plugin": "11.0.0",
+ "critters": "0.0.16",
+ "css-loader": "6.7.3",
+ "esbuild": "0.17.8",
+ "esbuild-wasm": "0.17.8",
+ "glob": "8.1.0",
+ "https-proxy-agent": "5.0.1",
+ "inquirer": "8.2.4",
+ "jsonc-parser": "3.2.0",
+ "karma-source-map-support": "1.4.0",
+ "less": "4.1.3",
+ "less-loader": "11.1.0",
+ "license-webpack-plugin": "4.0.2",
+ "loader-utils": "3.2.1",
+ "magic-string": "0.29.0",
+ "mini-css-extract-plugin": "2.7.2",
+ "open": "8.4.1",
+ "ora": "5.4.1",
+ "parse5-html-rewriting-stream": "7.0.0",
+ "piscina": "3.2.0",
+ "postcss": "8.4.21",
+ "postcss-loader": "7.0.2",
+ "resolve-url-loader": "5.0.0",
+ "rxjs": "6.6.7",
+ "sass": "1.58.1",
+ "sass-loader": "13.2.0",
+ "semver": "7.5.3",
+ "source-map-loader": "4.0.1",
+ "source-map-support": "0.5.21",
+ "terser": "5.16.3",
+ "text-table": "0.2.0",
+ "tree-kill": "1.2.2",
+ "tslib": "2.5.0",
+ "webpack": "5.76.1",
+ "webpack-dev-middleware": "6.0.1",
+ "webpack-dev-server": "4.11.1",
+ "webpack-merge": "5.8.0",
+ "webpack-subresource-integrity": "5.1.0"
+ },
+ "dependencies": {
+ "magic-string": {
+ "version": "0.29.0",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.29.0.tgz",
+ "integrity": "sha512-WcfidHrDjMY+eLjlU+8OvwREqHwpgCeKVBUpQ3OhYYuvfaYCUgcbuBzappNzZvg/v8onU3oQj+BYpkOJe9Iw4Q==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/sourcemap-codec": "^1.4.13"
+ }
+ }
+ }
+ },
+ "@angular-devkit/build-webpack": {
+ "version": "0.1502.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/build-webpack/-/build-webpack-0.1502.9.tgz",
+ "integrity": "sha512-VzMXoZjrbL1XlcSegqpZCBDbVvKFGPs3cKp4bXDD5ht95jcCyJPk5FA/wrh0pGGwbOF8ae/XOWFcPRzctC35iA==",
+ "dev": true,
+ "requires": {
+ "@angular-devkit/architect": "0.1502.9",
+ "rxjs": "6.6.7"
+ }
+ },
+ "@angular-devkit/core": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/core/-/core-15.2.9.tgz",
+ "integrity": "sha512-6u44YJ9tEG2hiWITL1rwA9yP6ot4a3cyN/UOMRkYSa/XO2Gz5/dM3U74E2kwg+P1NcxLXffBWl0rz8/Y/lSZyQ==",
+ "dev": true,
+ "requires": {
+ "ajv": "8.12.0",
+ "ajv-formats": "2.1.1",
+ "jsonc-parser": "3.2.0",
+ "rxjs": "6.6.7",
+ "source-map": "0.7.4"
+ }
+ },
+ "@angular-devkit/schematics": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@angular-devkit/schematics/-/schematics-15.2.9.tgz",
+ "integrity": "sha512-o08nE8sTpfq/Fknrr1rzBsM8vY36BDox+8dOo9Zc/KqcVPwDy94YKRzHb+xxVaU9jy1VYeCjy63mkyELy7Z3zQ==",
+ "dev": true,
+ "requires": {
+ "@angular-devkit/core": "15.2.9",
+ "jsonc-parser": "3.2.0",
+ "magic-string": "0.29.0",
+ "ora": "5.4.1",
+ "rxjs": "6.6.7"
+ },
+ "dependencies": {
+ "magic-string": {
+ "version": "0.29.0",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.29.0.tgz",
+ "integrity": "sha512-WcfidHrDjMY+eLjlU+8OvwREqHwpgCeKVBUpQ3OhYYuvfaYCUgcbuBzappNzZvg/v8onU3oQj+BYpkOJe9Iw4Q==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/sourcemap-codec": "^1.4.13"
+ }
+ }
+ }
+ },
+ "@angular/animations": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/animations/-/animations-15.1.0.tgz",
+ "integrity": "sha512-uBw1iQVJ3QS5e/gypsD7M50O//9GvpphgGqt9ZClknyD8dxO/YryEB+Kt4GNvNQxRKhRTksD8r4KaodukdQ15w==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/cdk": {
+ "version": "15.0.4",
+ "resolved": "https://registry.npmjs.org/@angular/cdk/-/cdk-15.0.4.tgz",
+ "integrity": "sha512-I+OedGqv9cBsHMVGl/VfjGItAi8pK7UuYiPnxSB25+m8v3jh7dMzfVGqdqpTSGxd1Zv02ypLZvEbiI30abRykQ==",
+ "requires": {
+ "parse5": "^7.1.2",
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/cli": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@angular/cli/-/cli-15.2.9.tgz",
+ "integrity": "sha512-mI6hkGyIJDKd8MRiBl3p5chsUhgnluwmpsq3g1FFPw+wv+eXsPYgCiHqXS/OsK+shFxii9XMxoZQO28bJ4NAOQ==",
+ "dev": true,
+ "requires": {
+ "@angular-devkit/architect": "0.1502.9",
+ "@angular-devkit/core": "15.2.9",
+ "@angular-devkit/schematics": "15.2.9",
+ "@schematics/angular": "15.2.9",
+ "@yarnpkg/lockfile": "1.1.0",
+ "ansi-colors": "4.1.3",
+ "ini": "3.0.1",
+ "inquirer": "8.2.4",
+ "jsonc-parser": "3.2.0",
+ "npm-package-arg": "10.1.0",
+ "npm-pick-manifest": "8.0.1",
+ "open": "8.4.1",
+ "ora": "5.4.1",
+ "pacote": "15.1.0",
+ "resolve": "1.22.1",
+ "semver": "7.5.3",
+ "symbol-observable": "4.0.0",
+ "yargs": "17.6.2"
+ }
+ },
+ "@angular/common": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/common/-/common-15.1.0.tgz",
+ "integrity": "sha512-O0JKOeJ7dFcd/mnnfm4xQOYTAc+yL+OrRpGte7z84lKPU2fupLpGW/30tHUy1TXixsANyTLC3cTVXTY5szPdqg==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/compiler": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/compiler/-/compiler-15.1.0.tgz",
+ "integrity": "sha512-+ky5Cvgps725Q/KdgsYzi/fe9LbT5ujhZoT9N5k+tYTJsepMUrpExFwMFkWrdMUYTK7DaxC9ufjZ4WZmHVhFoA==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/compiler-cli": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/compiler-cli/-/compiler-cli-15.1.0.tgz",
+ "integrity": "sha512-mKeXolM/plP9ebkHy3YGxHx0Yg63d09S0QCpdIcmvrbJpaPeM2D1SAkbDpO46T4BsfgfWHtSYByb5JcesrYrpQ==",
+ "dev": true,
+ "requires": {
+ "@babel/core": "7.19.3",
+ "@jridgewell/sourcemap-codec": "^1.4.14",
+ "chokidar": "^3.0.0",
+ "convert-source-map": "^1.5.1",
+ "dependency-graph": "^0.11.0",
+ "magic-string": "^0.27.0",
+ "reflect-metadata": "^0.1.2",
+ "semver": "^7.0.0",
+ "tslib": "^2.3.0",
+ "yargs": "^17.2.1"
+ },
+ "dependencies": {
+ "@babel/core": {
+ "version": "7.19.3",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.19.3.tgz",
+ "integrity": "sha512-WneDJxdsjEvyKtXKsaBGbDeiyOjR5vYq4HcShxnIbG0qixpoHjI3MqeZM9NDvsojNCEBItQE4juOo/bU6e72gQ==",
+ "dev": true,
+ "requires": {
+ "@ampproject/remapping": "^2.1.0",
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.19.3",
+ "@babel/helper-compilation-targets": "^7.19.3",
+ "@babel/helper-module-transforms": "^7.19.0",
+ "@babel/helpers": "^7.19.0",
+ "@babel/parser": "^7.19.3",
+ "@babel/template": "^7.18.10",
+ "@babel/traverse": "^7.19.3",
+ "@babel/types": "^7.19.3",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.1",
+ "semver": "^6.3.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ }
+ }
+ },
+ "@angular/core": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/core/-/core-15.1.0.tgz",
+ "integrity": "sha512-HiwctuR73MuLoLeP35j9xF8/SIg7ELx+iHZtp/TBfoH+LOmjWbdrAdVAPTbqnxvK0aJG+527dhgC6tBOXgBTcg==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/forms": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/forms/-/forms-15.1.0.tgz",
+ "integrity": "sha512-MUAbruJng0iG/cHhCkDNrh31Y54upgBUjjkE4DnoHv138Wa7vba+GMYv2tTrs4rPWnB9vPziZgI0xIi/oSGxzg==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/material": {
+ "version": "15.0.4",
+ "resolved": "https://registry.npmjs.org/@angular/material/-/material-15.0.4.tgz",
+ "integrity": "sha512-hvGQYzfttb78WZdNrYjA3dwKNtCiJ3NXLzTUbEGppDG5/9awCphDyN/5Lj3tNLsU8lus8l/UAIn6CCXCw2p3Vw==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/auto-init": "15.0.0-canary.7971d6ad5.0",
+ "@material/banner": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/card": "15.0.0-canary.7971d6ad5.0",
+ "@material/checkbox": "15.0.0-canary.7971d6ad5.0",
+ "@material/chips": "15.0.0-canary.7971d6ad5.0",
+ "@material/circular-progress": "15.0.0-canary.7971d6ad5.0",
+ "@material/data-table": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dialog": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/drawer": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/fab": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/floating-label": "15.0.0-canary.7971d6ad5.0",
+ "@material/form-field": "15.0.0-canary.7971d6ad5.0",
+ "@material/icon-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/image-list": "15.0.0-canary.7971d6ad5.0",
+ "@material/layout-grid": "15.0.0-canary.7971d6ad5.0",
+ "@material/line-ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/linear-progress": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu-surface": "15.0.0-canary.7971d6ad5.0",
+ "@material/notched-outline": "15.0.0-canary.7971d6ad5.0",
+ "@material/radio": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/segmented-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/select": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/slider": "15.0.0-canary.7971d6ad5.0",
+ "@material/snackbar": "15.0.0-canary.7971d6ad5.0",
+ "@material/switch": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-bar": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-scroller": "15.0.0-canary.7971d6ad5.0",
+ "@material/textfield": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tooltip": "15.0.0-canary.7971d6ad5.0",
+ "@material/top-app-bar": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/platform-browser": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/platform-browser/-/platform-browser-15.1.0.tgz",
+ "integrity": "sha512-yuJweAR+rJhWWHM4Im3Iy6S4+W3OtcVHijcqrxfVxiA9ZHbDw/jpYDi06ZZIgfnNyGWi5/BzJbHvxH3b0lAo5Q==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/platform-browser-dynamic": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/platform-browser-dynamic/-/platform-browser-dynamic-15.1.0.tgz",
+ "integrity": "sha512-ukyycXkuu4Ah/35cbN4pEB91D2PK5eZVbJ+liCD6uRb4UI3X+QVg6Qz6MoIctVAlTV6tWK20T81zoux9SzWKsg==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "@angular/router": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/@angular/router/-/router-15.1.0.tgz",
+ "integrity": "sha512-78ItVVXOYdu/RRxruHwSmtNxEP2clx+afHKrkwc4e7/6uxVr4rl0VQhO6qHYme/bBtbLIcBZGJoSyoUg/xUSvQ==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "@assemblyscript/loader": {
+ "version": "0.10.1",
+ "resolved": "https://registry.npmjs.org/@assemblyscript/loader/-/loader-0.10.1.tgz",
+ "integrity": "sha512-H71nDOOL8Y7kWRLqf6Sums+01Q5msqBW2KhDUTemh1tvY04eSkSXrK0uj/4mmY0Xr16/3zyZmsrxN7CKuRbNRg==",
+ "dev": true
+ },
+ "@babel/code-frame": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz",
+ "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==",
+ "dev": true,
+ "requires": {
+ "@babel/highlight": "^7.18.6"
+ }
+ },
+ "@babel/compat-data": {
+ "version": "7.20.10",
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.20.10.tgz",
+ "integrity": "sha512-sEnuDPpOJR/fcafHMjpcpGN5M2jbUGUHwmuWKM/YdPzeEDJg8bgmbcWQFUfE32MQjti1koACvoPVsDe8Uq+idg==",
+ "dev": true
+ },
+ "@babel/core": {
+ "version": "7.20.12",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.20.12.tgz",
+ "integrity": "sha512-XsMfHovsUYHFMdrIHkZphTN/2Hzzi78R08NuHfDBehym2VsPDL6Zn/JAD/JQdnRvbSsbQc4mVaU1m6JgtTEElg==",
+ "dev": true,
+ "requires": {
+ "@ampproject/remapping": "^2.1.0",
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.20.7",
+ "@babel/helper-compilation-targets": "^7.20.7",
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helpers": "^7.20.7",
+ "@babel/parser": "^7.20.7",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.12",
+ "@babel/types": "^7.20.7",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.2",
+ "semver": "^6.3.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ },
+ "@babel/generator": {
+ "version": "7.20.14",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.20.14.tgz",
+ "integrity": "sha512-AEmuXHdcD3A52HHXxaTmYlb8q/xMEhoRP67B3T4Oq7lbmSoqroMZzjnGj3+i1io3pdnF8iBYVu4Ilj+c4hBxYg==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.20.7",
+ "@jridgewell/gen-mapping": "^0.3.2",
+ "jsesc": "^2.5.1"
+ },
+ "dependencies": {
+ "@jridgewell/gen-mapping": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz",
+ "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ }
+ }
+ },
+ "@babel/helper-annotate-as-pure": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz",
+ "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-builder-binary-assignment-operator-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz",
+ "integrity": "sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-explode-assignable-expression": "^7.18.6",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-compilation-targets": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.7.tgz",
+ "integrity": "sha512-4tGORmfQcrc+bvrjb5y3dG9Mx1IOZjsHqQVUz7XCNHO+iTmqxWnVg3KRygjGmpRLJGdQSKuvFinbIb0CnZwHAQ==",
+ "dev": true,
+ "requires": {
+ "@babel/compat-data": "^7.20.5",
+ "@babel/helper-validator-option": "^7.18.6",
+ "browserslist": "^4.21.3",
+ "lru-cache": "^5.1.1",
+ "semver": "^6.3.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ },
+ "@babel/helper-create-class-features-plugin": {
+ "version": "7.20.12",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.20.12.tgz",
+ "integrity": "sha512-9OunRkbT0JQcednL0UFvbfXpAsUXiGjUk0a7sN8fUXX7Mue79cUSMjHGDRRi/Vz9vYlpIhLV5fMD5dKoMhhsNQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/helper-member-expression-to-functions": "^7.20.7",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.20.7",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0",
+ "@babel/helper-split-export-declaration": "^7.18.6"
+ }
+ },
+ "@babel/helper-create-regexp-features-plugin": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.20.5.tgz",
+ "integrity": "sha512-m68B1lkg3XDGX5yCvGO0kPx3v9WIYLnzjKfPcQiwntEQa5ZeRkPmo2X/ISJc8qxWGfwUr+kvZAeEzAwLec2r2w==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "regexpu-core": "^5.2.1"
+ }
+ },
+ "@babel/helper-define-polyfill-provider": {
+ "version": "0.3.3",
+ "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.3.tgz",
+ "integrity": "sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-compilation-targets": "^7.17.7",
+ "@babel/helper-plugin-utils": "^7.16.7",
+ "debug": "^4.1.1",
+ "lodash.debounce": "^4.0.8",
+ "resolve": "^1.14.2",
+ "semver": "^6.1.2"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ },
+ "@babel/helper-environment-visitor": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz",
+ "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==",
+ "dev": true
+ },
+ "@babel/helper-explode-assignable-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz",
+ "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-function-name": {
+ "version": "7.19.0",
+ "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz",
+ "integrity": "sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==",
+ "dev": true,
+ "requires": {
+ "@babel/template": "^7.18.10",
+ "@babel/types": "^7.19.0"
+ }
+ },
+ "@babel/helper-hoist-variables": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz",
+ "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-member-expression-to-functions": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.20.7.tgz",
+ "integrity": "sha512-9J0CxJLq315fEdi4s7xK5TQaNYjZw+nDVpVqr1axNGKzdrdwYBD5b4uKv3n75aABG0rCCTK8Im8Ww7eYfMrZgw==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.20.7"
+ }
+ },
+ "@babel/helper-module-imports": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz",
+ "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-module-transforms": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.20.11.tgz",
+ "integrity": "sha512-uRy78kN4psmji1s2QtbtcCSaj/LILFDp0f/ymhpQH5QY3nljUZCaNWz9X1dEj/8MBdBEFECs7yRhKn8i7NjZgg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-simple-access": "^7.20.2",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/helper-validator-identifier": "^7.19.1",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.10",
+ "@babel/types": "^7.20.7"
+ }
+ },
+ "@babel/helper-optimise-call-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz",
+ "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-plugin-utils": {
+ "version": "7.20.2",
+ "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.20.2.tgz",
+ "integrity": "sha512-8RvlJG2mj4huQ4pZ+rU9lqKi9ZKiRmuvGuM2HlWmkmgOhbs6zEAw6IEiJ5cQqGbDzGZOhwuOQNtZMi/ENLjZoQ==",
+ "dev": true
+ },
+ "@babel/helper-remap-async-to-generator": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz",
+ "integrity": "sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-wrap-function": "^7.18.9",
+ "@babel/types": "^7.18.9"
+ }
+ },
+ "@babel/helper-replace-supers": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.20.7.tgz",
+ "integrity": "sha512-vujDMtB6LVfNW13jhlCrp48QNslK6JXi7lQG736HVbHz/mbf4Dc7tIRh1Xf5C0rF7BP8iiSxGMCmY6Ci1ven3A==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-member-expression-to-functions": "^7.20.7",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.7",
+ "@babel/types": "^7.20.7"
+ }
+ },
+ "@babel/helper-simple-access": {
+ "version": "7.20.2",
+ "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz",
+ "integrity": "sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.20.2"
+ }
+ },
+ "@babel/helper-skip-transparent-expression-wrappers": {
+ "version": "7.20.0",
+ "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz",
+ "integrity": "sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.20.0"
+ }
+ },
+ "@babel/helper-split-export-declaration": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz",
+ "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.18.6"
+ }
+ },
+ "@babel/helper-string-parser": {
+ "version": "7.19.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.19.4.tgz",
+ "integrity": "sha512-nHtDoQcuqFmwYNYPz3Rah5ph2p8PFeFCsZk9A/48dPc/rGocJ5J3hAAZ7pb76VWX3fZKu+uEr/FhH5jLx7umrw==",
+ "dev": true
+ },
+ "@babel/helper-validator-identifier": {
+ "version": "7.19.1",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz",
+ "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==",
+ "dev": true
+ },
+ "@babel/helper-validator-option": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz",
+ "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==",
+ "dev": true
+ },
+ "@babel/helper-wrap-function": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.20.5.tgz",
+ "integrity": "sha512-bYMxIWK5mh+TgXGVqAtnu5Yn1un+v8DDZtqyzKRLUzrh70Eal2O3aZ7aPYiMADO4uKlkzOiRiZ6GX5q3qxvW9Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/template": "^7.18.10",
+ "@babel/traverse": "^7.20.5",
+ "@babel/types": "^7.20.5"
+ }
+ },
+ "@babel/helpers": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.20.7.tgz",
+ "integrity": "sha512-PBPjs5BppzsGaxHQCDKnZ6Gd9s6xl8bBCluz3vEInLGRJmnZan4F6BYCeqtyXqkk4W5IlPmjK4JlOuZkpJ3xZA==",
+ "dev": true,
+ "requires": {
+ "@babel/template": "^7.20.7",
+ "@babel/traverse": "^7.20.7",
+ "@babel/types": "^7.20.7"
+ }
+ },
+ "@babel/highlight": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz",
+ "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-validator-identifier": "^7.18.6",
+ "chalk": "^2.0.0",
+ "js-tokens": "^4.0.0"
+ }
+ },
+ "@babel/parser": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.20.7.tgz",
+ "integrity": "sha512-T3Z9oHybU+0vZlY9CiDSJQTD5ZapcW18ZctFMi0MOAl/4BjFF4ul7NVSARLdbGO5vDqy9eQiGTV0LtKfvCYvcg==",
+ "dev": true
+ },
+ "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz",
+ "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.20.7.tgz",
+ "integrity": "sha512-sbr9+wNE5aXMBBFBICk01tt7sBf2Oc9ikRFEcem/ZORup9IMUdNhW7/wVLEbbtlWOsEubJet46mHAL2C8+2jKQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0",
+ "@babel/plugin-proposal-optional-chaining": "^7.20.7"
+ }
+ },
+ "@babel/plugin-proposal-async-generator-functions": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.20.7.tgz",
+ "integrity": "sha512-xMbiLsn/8RK7Wq7VeVytytS2L6qE69bXPB10YCmMdDZbKF4okCqY74pI/jJQ/8U0b/F6NrT2+14b8/P9/3AMGA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-remap-async-to-generator": "^7.18.9",
+ "@babel/plugin-syntax-async-generators": "^7.8.4"
+ }
+ },
+ "@babel/plugin-proposal-class-properties": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz",
+ "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-proposal-class-static-block": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.20.7.tgz",
+ "integrity": "sha512-AveGOoi9DAjUYYuUAG//Ig69GlazLnoyzMw68VCDux+c1tsnnH/OkYcpz/5xzMkEFC6UxjR5Gw1c+iY2wOGVeQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-class-features-plugin": "^7.20.7",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5"
+ }
+ },
+ "@babel/plugin-proposal-dynamic-import": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz",
+ "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-export-namespace-from": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz",
+ "integrity": "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-json-strings": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz",
+ "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-json-strings": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-logical-assignment-operators": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.20.7.tgz",
+ "integrity": "sha512-y7C7cZgpMIjWlKE5T7eJwp+tnRYM89HmRvWM5EQuB5BoHEONjmQ8lSNmBUwOyy/GFRsohJED51YBF79hE1djug==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4"
+ }
+ },
+ "@babel/plugin-proposal-nullish-coalescing-operator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz",
+ "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-numeric-separator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz",
+ "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4"
+ }
+ },
+ "@babel/plugin-proposal-object-rest-spread": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.20.7.tgz",
+ "integrity": "sha512-d2S98yCiLxDVmBmE8UjGcfPvNEUbA1U5q5WxaWFUGRzJSVAZqm5W6MbPct0jxnegUZ0niLeNX+IOzEs7wYg9Dg==",
+ "dev": true,
+ "requires": {
+ "@babel/compat-data": "^7.20.5",
+ "@babel/helper-compilation-targets": "^7.20.7",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-transform-parameters": "^7.20.7"
+ }
+ },
+ "@babel/plugin-proposal-optional-catch-binding": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz",
+ "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-optional-chaining": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.20.7.tgz",
+ "integrity": "sha512-T+A7b1kfjtRM51ssoOfS1+wbyCVqorfyZhT99TvxxLMirPShD8CzKMRepMlCBGM5RpHMbn8s+5MMHnPstJH6mQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3"
+ }
+ },
+ "@babel/plugin-proposal-private-methods": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz",
+ "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-class-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-proposal-private-property-in-object": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.20.5.tgz",
+ "integrity": "sha512-Vq7b9dUA12ByzB4EjQTPo25sFhY+08pQDBSZRtUAkj7lb7jahaHR5igera16QZ+3my1nYR4dKsNdYj5IjPHilQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-create-class-features-plugin": "^7.20.5",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5"
+ }
+ },
+ "@babel/plugin-proposal-unicode-property-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz",
+ "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-syntax-async-generators": {
+ "version": "7.8.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz",
+ "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-class-properties": {
+ "version": "7.12.13",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz",
+ "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.12.13"
+ }
+ },
+ "@babel/plugin-syntax-class-static-block": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz",
+ "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ }
+ },
+ "@babel/plugin-syntax-dynamic-import": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz",
+ "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-export-namespace-from": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz",
+ "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.3"
+ }
+ },
+ "@babel/plugin-syntax-import-assertions": {
+ "version": "7.20.0",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz",
+ "integrity": "sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.19.0"
+ }
+ },
+ "@babel/plugin-syntax-json-strings": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz",
+ "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-logical-assignment-operators": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz",
+ "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ }
+ },
+ "@babel/plugin-syntax-nullish-coalescing-operator": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz",
+ "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-numeric-separator": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz",
+ "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ }
+ },
+ "@babel/plugin-syntax-object-rest-spread": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz",
+ "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-optional-catch-binding": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz",
+ "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-optional-chaining": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz",
+ "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-private-property-in-object": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz",
+ "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ }
+ },
+ "@babel/plugin-syntax-top-level-await": {
+ "version": "7.14.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz",
+ "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.14.5"
+ }
+ },
+ "@babel/plugin-transform-arrow-functions": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.20.7.tgz",
+ "integrity": "sha512-3poA5E7dzDomxj9WXWwuD6A5F3kc7VXwIJO+E+J8qtDtS+pXPAhrgEyh+9GBwBgPq1Z+bB+/JD60lp5jsN7JPQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2"
+ }
+ },
+ "@babel/plugin-transform-async-to-generator": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.20.7.tgz",
+ "integrity": "sha512-Uo5gwHPT9vgnSXQxqGtpdufUiWp96gk7yiP4Mp5bm1QMkEmLXBO7PAGYbKoJ6DhAwiNkcHFBol/x5zZZkL/t0Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-remap-async-to-generator": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-block-scoped-functions": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz",
+ "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-block-scoping": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.20.11.tgz",
+ "integrity": "sha512-tA4N427a7fjf1P0/2I4ScsHGc5jcHPbb30xMbaTke2gxDuWpUfXDuX1FEymJwKk4tuGUvGcejAR6HdZVqmmPyw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2"
+ }
+ },
+ "@babel/plugin-transform-classes": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.20.7.tgz",
+ "integrity": "sha512-LWYbsiXTPKl+oBlXUGlwNlJZetXD5Am+CyBdqhPsDVjM9Jc8jwBJFrKhHf900Kfk2eZG1y9MAG3UNajol7A4VQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-annotate-as-pure": "^7.18.6",
+ "@babel/helper-compilation-targets": "^7.20.7",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/helper-optimise-call-expression": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-replace-supers": "^7.20.7",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "globals": "^11.1.0"
+ }
+ },
+ "@babel/plugin-transform-computed-properties": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.20.7.tgz",
+ "integrity": "sha512-Lz7MvBK6DTjElHAmfu6bfANzKcxpyNPeYBGEafyA6E5HtRpjpZwU+u7Qrgz/2OR0z+5TvKYbPdphfSaAcZBrYQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/template": "^7.20.7"
+ }
+ },
+ "@babel/plugin-transform-destructuring": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.20.7.tgz",
+ "integrity": "sha512-Xwg403sRrZb81IVB79ZPqNQME23yhugYVqgTxAhT99h485F4f+GMELFhhOsscDUB7HCswepKeCKLn/GZvUKoBA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2"
+ }
+ },
+ "@babel/plugin-transform-dotall-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz",
+ "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-duplicate-keys": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz",
+ "integrity": "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-exponentiation-operator": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz",
+ "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-for-of": {
+ "version": "7.18.8",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz",
+ "integrity": "sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-function-name": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz",
+ "integrity": "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-compilation-targets": "^7.18.9",
+ "@babel/helper-function-name": "^7.18.9",
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-literals": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz",
+ "integrity": "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-member-expression-literals": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz",
+ "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-modules-amd": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.20.11.tgz",
+ "integrity": "sha512-NuzCt5IIYOW0O30UvqktzHYR2ud5bOWbY0yaxWZ6G+aFzOMJvrs5YHNikrbdaT15+KNO31nPOy5Fim3ku6Zb5g==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helper-plugin-utils": "^7.20.2"
+ }
+ },
+ "@babel/plugin-transform-modules-commonjs": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.20.11.tgz",
+ "integrity": "sha512-S8e1f7WQ7cimJQ51JkAaDrEtohVEitXjgCGAS2N8S31Y42E+kWwfSz83LYz57QdBm7q9diARVqanIaH2oVgQnw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-simple-access": "^7.20.2"
+ }
+ },
+ "@babel/plugin-transform-modules-systemjs": {
+ "version": "7.20.11",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.20.11.tgz",
+ "integrity": "sha512-vVu5g9BPQKSFEmvt2TA4Da5N+QVS66EX21d8uoOihC+OCpUoGvzVsXeqFdtAEfVa5BILAeFt+U7yVmLbQnAJmw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-module-transforms": "^7.20.11",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-validator-identifier": "^7.19.1"
+ }
+ },
+ "@babel/plugin-transform-modules-umd": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz",
+ "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-transforms": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-named-capturing-groups-regex": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.20.5.tgz",
+ "integrity": "sha512-mOW4tTzi5iTLnw+78iEq3gr8Aoq4WNRGpmSlrogqaiCBoR1HFhpU4JkpQFOHfeYx3ReVIFWOQJS4aZBRvuZ6mA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-regexp-features-plugin": "^7.20.5",
+ "@babel/helper-plugin-utils": "^7.20.2"
+ }
+ },
+ "@babel/plugin-transform-new-target": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz",
+ "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-object-super": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz",
+ "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6",
+ "@babel/helper-replace-supers": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-parameters": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.20.7.tgz",
+ "integrity": "sha512-WiWBIkeHKVOSYPO0pWkxGPfKeWrCJyD3NJ53+Lrp/QMSZbsVPovrVl2aWZ19D/LTVnaDv5Ap7GJ/B2CTOZdrfA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2"
+ }
+ },
+ "@babel/plugin-transform-property-literals": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz",
+ "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-regenerator": {
+ "version": "7.20.5",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.20.5.tgz",
+ "integrity": "sha512-kW/oO7HPBtntbsahzQ0qSE3tFvkFwnbozz3NWFhLGqH75vLEg+sCGngLlhVkePlCs3Jv0dBBHDzCHxNiFAQKCQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "regenerator-transform": "^0.15.1"
+ }
+ },
+ "@babel/plugin-transform-reserved-words": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz",
+ "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-runtime": {
+ "version": "7.19.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.19.6.tgz",
+ "integrity": "sha512-PRH37lz4JU156lYFW1p8OxE5i7d6Sl/zV58ooyr+q1J1lnQPyg5tIiXlIwNVhJaY4W3TmOtdc8jqdXQcB1v5Yw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-imports": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.19.0",
+ "babel-plugin-polyfill-corejs2": "^0.3.3",
+ "babel-plugin-polyfill-corejs3": "^0.6.0",
+ "babel-plugin-polyfill-regenerator": "^0.4.1",
+ "semver": "^6.3.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ },
+ "@babel/plugin-transform-shorthand-properties": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz",
+ "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-spread": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.20.7.tgz",
+ "integrity": "sha512-ewBbHQ+1U/VnH1fxltbJqDeWBU1oNLG8Dj11uIv3xVf7nrQu0bPGe5Rf716r7K5Qz+SqtAOVswoVunoiBtGhxw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0"
+ }
+ },
+ "@babel/plugin-transform-sticky-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz",
+ "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/plugin-transform-template-literals": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz",
+ "integrity": "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-typeof-symbol": {
+ "version": "7.18.9",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz",
+ "integrity": "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-unicode-escapes": {
+ "version": "7.18.10",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.10.tgz",
+ "integrity": "sha512-kKAdAI+YzPgGY/ftStBFXTI1LZFju38rYThnfMykS+IXy8BVx+res7s2fxf1l8I35DV2T97ezo6+SGrXz6B3iQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.18.9"
+ }
+ },
+ "@babel/plugin-transform-unicode-regex": {
+ "version": "7.18.6",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz",
+ "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-create-regexp-features-plugin": "^7.18.6",
+ "@babel/helper-plugin-utils": "^7.18.6"
+ }
+ },
+ "@babel/preset-env": {
+ "version": "7.20.2",
+ "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.20.2.tgz",
+ "integrity": "sha512-1G0efQEWR1EHkKvKHqbG+IN/QdgwfByUpM5V5QroDzGV2t3S/WXNQd693cHiHTlCFMpr9B6FkPFXDA2lQcKoDg==",
+ "dev": true,
+ "requires": {
+ "@babel/compat-data": "^7.20.1",
+ "@babel/helper-compilation-targets": "^7.20.0",
+ "@babel/helper-plugin-utils": "^7.20.2",
+ "@babel/helper-validator-option": "^7.18.6",
+ "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6",
+ "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.9",
+ "@babel/plugin-proposal-async-generator-functions": "^7.20.1",
+ "@babel/plugin-proposal-class-properties": "^7.18.6",
+ "@babel/plugin-proposal-class-static-block": "^7.18.6",
+ "@babel/plugin-proposal-dynamic-import": "^7.18.6",
+ "@babel/plugin-proposal-export-namespace-from": "^7.18.9",
+ "@babel/plugin-proposal-json-strings": "^7.18.6",
+ "@babel/plugin-proposal-logical-assignment-operators": "^7.18.9",
+ "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6",
+ "@babel/plugin-proposal-numeric-separator": "^7.18.6",
+ "@babel/plugin-proposal-object-rest-spread": "^7.20.2",
+ "@babel/plugin-proposal-optional-catch-binding": "^7.18.6",
+ "@babel/plugin-proposal-optional-chaining": "^7.18.9",
+ "@babel/plugin-proposal-private-methods": "^7.18.6",
+ "@babel/plugin-proposal-private-property-in-object": "^7.18.6",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.18.6",
+ "@babel/plugin-syntax-async-generators": "^7.8.4",
+ "@babel/plugin-syntax-class-properties": "^7.12.13",
+ "@babel/plugin-syntax-class-static-block": "^7.14.5",
+ "@babel/plugin-syntax-dynamic-import": "^7.8.3",
+ "@babel/plugin-syntax-export-namespace-from": "^7.8.3",
+ "@babel/plugin-syntax-import-assertions": "^7.20.0",
+ "@babel/plugin-syntax-json-strings": "^7.8.3",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3",
+ "@babel/plugin-syntax-numeric-separator": "^7.10.4",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3",
+ "@babel/plugin-syntax-private-property-in-object": "^7.14.5",
+ "@babel/plugin-syntax-top-level-await": "^7.14.5",
+ "@babel/plugin-transform-arrow-functions": "^7.18.6",
+ "@babel/plugin-transform-async-to-generator": "^7.18.6",
+ "@babel/plugin-transform-block-scoped-functions": "^7.18.6",
+ "@babel/plugin-transform-block-scoping": "^7.20.2",
+ "@babel/plugin-transform-classes": "^7.20.2",
+ "@babel/plugin-transform-computed-properties": "^7.18.9",
+ "@babel/plugin-transform-destructuring": "^7.20.2",
+ "@babel/plugin-transform-dotall-regex": "^7.18.6",
+ "@babel/plugin-transform-duplicate-keys": "^7.18.9",
+ "@babel/plugin-transform-exponentiation-operator": "^7.18.6",
+ "@babel/plugin-transform-for-of": "^7.18.8",
+ "@babel/plugin-transform-function-name": "^7.18.9",
+ "@babel/plugin-transform-literals": "^7.18.9",
+ "@babel/plugin-transform-member-expression-literals": "^7.18.6",
+ "@babel/plugin-transform-modules-amd": "^7.19.6",
+ "@babel/plugin-transform-modules-commonjs": "^7.19.6",
+ "@babel/plugin-transform-modules-systemjs": "^7.19.6",
+ "@babel/plugin-transform-modules-umd": "^7.18.6",
+ "@babel/plugin-transform-named-capturing-groups-regex": "^7.19.1",
+ "@babel/plugin-transform-new-target": "^7.18.6",
+ "@babel/plugin-transform-object-super": "^7.18.6",
+ "@babel/plugin-transform-parameters": "^7.20.1",
+ "@babel/plugin-transform-property-literals": "^7.18.6",
+ "@babel/plugin-transform-regenerator": "^7.18.6",
+ "@babel/plugin-transform-reserved-words": "^7.18.6",
+ "@babel/plugin-transform-shorthand-properties": "^7.18.6",
+ "@babel/plugin-transform-spread": "^7.19.0",
+ "@babel/plugin-transform-sticky-regex": "^7.18.6",
+ "@babel/plugin-transform-template-literals": "^7.18.9",
+ "@babel/plugin-transform-typeof-symbol": "^7.18.9",
+ "@babel/plugin-transform-unicode-escapes": "^7.18.10",
+ "@babel/plugin-transform-unicode-regex": "^7.18.6",
+ "@babel/preset-modules": "^0.1.5",
+ "@babel/types": "^7.20.2",
+ "babel-plugin-polyfill-corejs2": "^0.3.3",
+ "babel-plugin-polyfill-corejs3": "^0.6.0",
+ "babel-plugin-polyfill-regenerator": "^0.4.1",
+ "core-js-compat": "^3.25.1",
+ "semver": "^6.3.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ },
+ "@babel/preset-modules": {
+ "version": "0.1.5",
+ "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz",
+ "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@babel/plugin-proposal-unicode-property-regex": "^7.4.4",
+ "@babel/plugin-transform-dotall-regex": "^7.4.4",
+ "@babel/types": "^7.4.4",
+ "esutils": "^2.0.2"
+ }
+ },
+ "@babel/runtime": {
+ "version": "7.20.13",
+ "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.20.13.tgz",
+ "integrity": "sha512-gt3PKXs0DBoL9xCvOIIZ2NEqAGZqHjAnmVbfQtB620V0uReIQutpel14KcneZuer7UioY8ALKZ7iocavvzTNFA==",
+ "dev": true,
+ "requires": {
+ "regenerator-runtime": "^0.13.11"
+ }
+ },
+ "@babel/template": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.20.7.tgz",
+ "integrity": "sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==",
+ "dev": true,
+ "requires": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/parser": "^7.20.7",
+ "@babel/types": "^7.20.7"
+ }
+ },
+ "@babel/traverse": {
+ "version": "7.20.12",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.20.12.tgz",
+ "integrity": "sha512-MsIbFN0u+raeja38qboyF8TIT7K0BFzz/Yd/77ta4MsUsmP2RAnidIlwq7d5HFQrH/OZJecGV6B71C4zAgpoSQ==",
+ "dev": true,
+ "requires": {
+ "@babel/code-frame": "^7.18.6",
+ "@babel/generator": "^7.20.7",
+ "@babel/helper-environment-visitor": "^7.18.9",
+ "@babel/helper-function-name": "^7.19.0",
+ "@babel/helper-hoist-variables": "^7.18.6",
+ "@babel/helper-split-export-declaration": "^7.18.6",
+ "@babel/parser": "^7.20.7",
+ "@babel/types": "^7.20.7",
+ "debug": "^4.1.0",
+ "globals": "^11.1.0"
+ }
+ },
+ "@babel/types": {
+ "version": "7.20.7",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.20.7.tgz",
+ "integrity": "sha512-69OnhBxSSgK0OzTJai4kyPDiKTIe3j+ctaHdIGVbRahTLAT7L3R9oeXHC2aVSuGYt3cVnoAMDmOCgJ2yaiLMvg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-string-parser": "^7.19.4",
+ "@babel/helper-validator-identifier": "^7.19.1",
+ "to-fast-properties": "^2.0.0"
+ }
+ },
+ "@colors/colors": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/@colors/colors/-/colors-1.5.0.tgz",
+ "integrity": "sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==",
+ "dev": true
+ },
+ "@discoveryjs/json-ext": {
+ "version": "0.5.7",
+ "resolved": "https://registry.npmjs.org/@discoveryjs/json-ext/-/json-ext-0.5.7.tgz",
+ "integrity": "sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==",
+ "dev": true
+ },
+ "@esbuild/android-arm": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.8.tgz",
+ "integrity": "sha512-0/rb91GYKhrtbeglJXOhAv9RuYimgI8h623TplY2X+vA4EXnk3Zj1fXZreJ0J3OJJu1bwmb0W7g+2cT/d8/l/w==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/android-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.8.tgz",
+ "integrity": "sha512-oa/N5j6v1svZQs7EIRPqR8f+Bf8g6HBDjD/xHC02radE/NjKHK7oQmtmLxPs1iVwYyvE+Kolo6lbpfEQ9xnhxQ==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/android-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.8.tgz",
+ "integrity": "sha512-bTliMLqD7pTOoPg4zZkXqCDuzIUguEWLpeqkNfC41ODBHwoUgZ2w5JBeYimv4oP6TDVocoYmEhZrCLQTrH89bg==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/darwin-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.8.tgz",
+ "integrity": "sha512-ghAbV3ia2zybEefXRRm7+lx8J/rnupZT0gp9CaGy/3iolEXkJ6LYRq4IpQVI9zR97ID80KJVoUlo3LSeA/sMAg==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/darwin-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.8.tgz",
+ "integrity": "sha512-n5WOpyvZ9TIdv2V1K3/iIkkJeKmUpKaCTdun9buhGRWfH//osmUjlv4Z5mmWdPWind/VGcVxTHtLfLCOohsOXw==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/freebsd-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.8.tgz",
+ "integrity": "sha512-a/SATTaOhPIPFWvHZDoZYgxaZRVHn0/LX1fHLGfZ6C13JqFUZ3K6SMD6/HCtwOQ8HnsNaEeokdiDSFLuizqv5A==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/freebsd-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.8.tgz",
+ "integrity": "sha512-xpFJb08dfXr5+rZc4E+ooZmayBW6R3q59daCpKZ/cDU96/kvDM+vkYzNeTJCGd8rtO6fHWMq5Rcv/1cY6p6/0Q==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-arm": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.8.tgz",
+ "integrity": "sha512-6Ij8gfuGszcEwZpi5jQIJCVIACLS8Tz2chnEBfYjlmMzVsfqBP1iGmHQPp7JSnZg5xxK9tjCc+pJ2WtAmPRFVA==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.8.tgz",
+ "integrity": "sha512-v3iwDQuDljLTxpsqQDl3fl/yihjPAyOguxuloON9kFHYwopeJEf1BkDXODzYyXEI19gisEsQlG1bM65YqKSIww==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-ia32": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.8.tgz",
+ "integrity": "sha512-8svILYKhE5XetuFk/B6raFYIyIqydQi+GngEXJgdPdI7OMKUbSd7uzR02wSY4kb53xBrClLkhH4Xs8P61Q2BaA==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-loong64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.8.tgz",
+ "integrity": "sha512-B6FyMeRJeV0NpyEOYlm5qtQfxbdlgmiGdD+QsipzKfFky0K5HW5Td6dyK3L3ypu1eY4kOmo7wW0o94SBqlqBSA==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-mips64el": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.8.tgz",
+ "integrity": "sha512-CCb67RKahNobjm/eeEqeD/oJfJlrWyw29fgiyB6vcgyq97YAf3gCOuP6qMShYSPXgnlZe/i4a8WFHBw6N8bYAA==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-ppc64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.8.tgz",
+ "integrity": "sha512-bytLJOi55y55+mGSdgwZ5qBm0K9WOCh0rx+vavVPx+gqLLhxtSFU0XbeYy/dsAAD6xECGEv4IQeFILaSS2auXw==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-riscv64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.8.tgz",
+ "integrity": "sha512-2YpRyQJmKVBEHSBLa8kBAtbhucaclb6ex4wchfY0Tj3Kg39kpjeJ9vhRU7x4mUpq8ISLXRXH1L0dBYjAeqzZAw==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-s390x": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.8.tgz",
+ "integrity": "sha512-QgbNY/V3IFXvNf11SS6exkpVcX0LJcob+0RWCgV9OiDAmVElnxciHIisoSix9uzYzScPmS6dJFbZULdSAEkQVw==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/linux-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.8.tgz",
+ "integrity": "sha512-mM/9S0SbAFDBc4OPoyP6SEOo5324LpUxdpeIUUSrSTOfhHU9hEfqRngmKgqILqwx/0DVJBzeNW7HmLEWp9vcOA==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/netbsd-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.8.tgz",
+ "integrity": "sha512-eKUYcWaWTaYr9zbj8GertdVtlt1DTS1gNBWov+iQfWuWyuu59YN6gSEJvFzC5ESJ4kMcKR0uqWThKUn5o8We6Q==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/openbsd-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.8.tgz",
+ "integrity": "sha512-Vc9J4dXOboDyMXKD0eCeW0SIeEzr8K9oTHJU+Ci1mZc5njPfhKAqkRt3B/fUNU7dP+mRyralPu8QUkiaQn7iIg==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/sunos-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.8.tgz",
+ "integrity": "sha512-0xvOTNuPXI7ft1LYUgiaXtpCEjp90RuBBYovdd2lqAFxje4sEucurg30M1WIm03+3jxByd3mfo+VUmPtRSVuOw==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/win32-arm64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.8.tgz",
+ "integrity": "sha512-G0JQwUI5WdEFEnYNKzklxtBheCPkuDdu1YrtRrjuQv30WsYbkkoixKxLLv8qhJmNI+ATEWquZe/N0d0rpr55Mg==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/win32-ia32": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.8.tgz",
+ "integrity": "sha512-Fqy63515xl20OHGFykjJsMnoIWS+38fqfg88ClvPXyDbLtgXal2DTlhb1TfTX34qWi3u4I7Cq563QcHpqgLx8w==",
+ "dev": true,
+ "optional": true
+ },
+ "@esbuild/win32-x64": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.8.tgz",
+ "integrity": "sha512-1iuezdyDNngPnz8rLRDO2C/ZZ/emJLb72OsZeqQ6gL6Avko/XCXZw+NuxBSNhBAP13Hie418V7VMt9et1FMvpg==",
+ "dev": true,
+ "optional": true
+ },
+ "@isaacs/cliui": {
+ "version": "8.0.2",
+ "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz",
+ "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==",
+ "dev": true,
+ "requires": {
+ "string-width": "^5.1.2",
+ "string-width-cjs": "npm:string-width@^4.2.0",
+ "strip-ansi": "^7.0.1",
+ "strip-ansi-cjs": "npm:strip-ansi@^6.0.1",
+ "wrap-ansi": "^8.1.0",
+ "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0"
+ },
+ "dependencies": {
+ "ansi-regex": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz",
+ "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==",
+ "dev": true
+ },
+ "ansi-styles": {
+ "version": "6.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
+ "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
+ "dev": true
+ },
+ "emoji-regex": {
+ "version": "9.2.2",
+ "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz",
+ "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==",
+ "dev": true
+ },
+ "string-width": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz",
+ "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==",
+ "dev": true,
+ "requires": {
+ "eastasianwidth": "^0.2.0",
+ "emoji-regex": "^9.2.2",
+ "strip-ansi": "^7.0.1"
+ }
+ },
+ "strip-ansi": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
+ "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^6.0.1"
+ }
+ },
+ "wrap-ansi": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz",
+ "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^6.1.0",
+ "string-width": "^5.0.1",
+ "strip-ansi": "^7.0.1"
+ }
+ }
+ }
+ },
+ "@istanbuljs/load-nyc-config": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz",
+ "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==",
+ "dev": true,
+ "requires": {
+ "camelcase": "^5.3.1",
+ "find-up": "^4.1.0",
+ "get-package-type": "^0.1.0",
+ "js-yaml": "^3.13.1",
+ "resolve-from": "^5.0.0"
+ }
+ },
+ "@istanbuljs/schema": {
+ "version": "0.1.3",
+ "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz",
+ "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==",
+ "dev": true
+ },
+ "@jridgewell/gen-mapping": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz",
+ "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/set-array": "^1.0.0",
+ "@jridgewell/sourcemap-codec": "^1.4.10"
+ }
+ },
+ "@jridgewell/resolve-uri": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz",
+ "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==",
+ "dev": true
+ },
+ "@jridgewell/set-array": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz",
+ "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==",
+ "dev": true
+ },
+ "@jridgewell/source-map": {
+ "version": "0.3.5",
+ "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.5.tgz",
+ "integrity": "sha512-UTYAUj/wviwdsMfzoSJspJxbkH5o1snzwX0//0ENX1u/55kkZZkcTZP6u9bwKGkv+dkk9at4m1Cpt0uY80kcpQ==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/gen-mapping": "^0.3.0",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ },
+ "dependencies": {
+ "@jridgewell/gen-mapping": {
+ "version": "0.3.3",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz",
+ "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/set-array": "^1.0.1",
+ "@jridgewell/sourcemap-codec": "^1.4.10",
+ "@jridgewell/trace-mapping": "^0.3.9"
+ }
+ }
+ }
+ },
+ "@jridgewell/sourcemap-codec": {
+ "version": "1.4.14",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz",
+ "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==",
+ "dev": true
+ },
+ "@jridgewell/trace-mapping": {
+ "version": "0.3.17",
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz",
+ "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/resolve-uri": "3.1.0",
+ "@jridgewell/sourcemap-codec": "1.4.14"
+ }
+ },
+ "@leichtgewicht/ip-codec": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/@leichtgewicht/ip-codec/-/ip-codec-2.0.4.tgz",
+ "integrity": "sha512-Hcv+nVC0kZnQ3tD9GVu5xSMR4VVYOteQIr/hwFPVEvPdlXqgGEuRjiheChHgdM+JyqdgNcmzZOX/tnl0JOiI7A==",
+ "dev": true
+ },
+ "@material/animation": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/animation/-/animation-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-nOCOgzp/Vdgloyw/SjFCEtpcxXWtXUjvX+JCVg7o+EEtaGLBQdgjJUj5lt+RQ6e9r0eiMYKJ6l1+1TGGebsIfA==",
+ "requires": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/auto-init": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/auto-init/-/auto-init-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-JmST/NkQpdJ1+nyAU8qbV1eRXbOwvpaTRy096Y5mOK1CeUsagUyrKkCeLsO56pmvayxnOIkJCOhH/8gzIsmiJA==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/banner": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/banner/-/banner-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-OA23YGt9qTz5i+FdGgk4QpRkmby/w+k12YMlL7u+TmwWIiGom2AaOy/DbBCr2/uNJEJ6o0h+wcNBEmGe7bJutw==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/base": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/base/-/base-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-wXgoWl8NG4BZ2U8MCg4BLQLNla3IdyxBJIMSsJ1qvP2YswmG9HXTkS8y9mHTAhzzQEFQtlwDOyp4Ntq2Ep4WZA==",
+ "requires": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/button": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/button/-/button-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-lyV4unJUG/onzNSLL5TjTGJxscBReG6+lNBvGSfgCafW2bfHW278BbqPDbPr52ONe6vg5INptZJ6bZx4FStGIQ==",
+ "requires": {
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/card": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/card/-/card-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-0YNba4Keg+a0U4JK+siLDbTyO13s40hm88kX7uQ46SmsQlY3fbMsdOpX9+y/PaOkOXIJIgX6g+c7ASM7c/6Zyw==",
+ "requires": {
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/checkbox": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/checkbox/-/checkbox-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-RSFJhMtU28BhXWyQHMrThqkGMtYb16JOuKkZ54bc1AzIndQnniQoGpkb5tHx1hOCGhOUyAGVh/w8BHczWRsLbw==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/chips": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/chips/-/chips-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-W8e90cxnERoP/OvsYSSkjP/HEeogYH1YJVBemKfTOQyAAMh3DmetBGdO6Gdf65/Jt7iYrvab5IPn0D7DWoMZlQ==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/checkbox": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "safevalues": "^0.3.4",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/circular-progress": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/circular-progress/-/circular-progress-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-dE66rFNI9T2khLejoTyONQZqnHjUXsmdzDx1lI3qO918gtdkwdBVWvFm0U7+1VdHAB9sjP4o+mVL/3rNss2Jtg==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/progress-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/data-table": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/data-table/-/data-table-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-JIg3GqnWGoiP5OXRkM7xjpoYIcal3a2vcvx8qUBK8rJZUXXShMcrFD8bpoEK+VIo7NXp5oR3baR3g063sTmv7g==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/checkbox": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/icon-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/linear-progress": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/select": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/density": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/density/-/density-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-JfRRdyewKuVGDLTxm0Bn/5MFgkPHo5fZ0JU6kCqI+SdOER/ceRti6xJtNfgV/lBPqstftARcKv116nQRy2085Q==",
+ "requires": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/dialog": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/dialog/-/dialog-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-P7+nNN1YdPISSOIECyECiYNcmAJn4ezogpkcGkGBKc0KZAzG47Y1prgLNFaHat5mE20GjLL50M7T4SU7F64dqA==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/icon-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/dom": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/dom/-/dom-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-h+KV0egRy7zniZElzDW5duh/VDZUTO9SmMeC8FFiqJMvPe3V8xcH0zB+jL67hueLqFixSSJebbdXMbVce4nwOA==",
+ "requires": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/drawer": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/drawer/-/drawer-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-LYuriNp3lecXXIj3lK22z0ym5bGHHIturofEV60BK9uHi4baBWS/ovTPAw5T8YvpADv5kyidg4mkgkPY9Ydexg==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/elevation": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/elevation/-/elevation-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-M9SZKJI5wjbOwq0o8eknDrI27YE63wLg8qJHLvJWrWXdlm6yN0INilihExzmGHXpVHQ6sUdI4oyoAx1qr+vorQ==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/fab": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/fab/-/fab-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-G58ZFK7M9r9xkLFP0Gufh1VKdcvRcTvYwEjBuG3+XOMDMjFzCDEMY4c54RG+tbwIiHmB8lw1Yl/dN3kFVc3kTA==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/feature-targeting": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/feature-targeting/-/feature-targeting-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-xH8pdvB5oKO6OTY61vEs44eQJQY3GTobpzaxp+CIBH0UMobSl5KFee+j7MxpEbTkRGtMqWkzAA+vviT8hvmH+A==",
+ "requires": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/floating-label": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/floating-label/-/floating-label-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-Tjv2xnYr+VvsojRbRBVVmjxmut/y4hJrRCBMjU1982cTUYQlfqMaM7BUObt49jwRBKDLr2NjM+fwNIo0//YItA==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/focus-ring": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/focus-ring/-/focus-ring-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-xutZrHnrfnKftU3HUS9em8wO5Nb4zbnRrwDCGi3xnFR7bFP4u2J2ZUnVpO+RZfjr3A9l8chDavlFCL5HMfzt4A==",
+ "requires": {
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0"
+ }
+ },
+ "@material/form-field": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/form-field/-/form-field-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-N0UnlZ7j3GT4DGmMgJYMl9etOh7rsQjCjRRATWSnuAel+ir4a5HvLj9xQUyp0tlYuu9ZizB8ZOwbAz/XCiU94Q==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/icon-button": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/icon-button/-/icon-button-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-BT+tHdRviY1o/yBgtX5NxfS7LfQtQSf7DiZfgP9eExSU5fDA6AfqJfZHyJdLmJCtFZbzlxJ0PBmt44NSlI2/DA==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/image-list": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/image-list/-/image-list-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-FrBosWy9VnqWYDR8XkQPt8cE6MPNq5g7oEvULImmqjRxhktTJCPfDZSWHpjLpAvU0quYZZprPDRrwM3qw69z/A==",
+ "requires": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/layout-grid": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/layout-grid/-/layout-grid-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-H4KEhaGaIuGHd3jKJqaoZkynJjqfyti4QhG6wiTt774Lv4Uri1+ZBxQ8FAFShEvETM2pfBy4mEECi/+M4V2ZTA==",
+ "requires": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/line-ripple": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/line-ripple/-/line-ripple-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-f4tcd82xu1OT0wAVT/kHiWDmJy9fRt9QA5b+v81fTSVFK41mYpxy8jIQ5gdoIvY/0BWLh4HzUejG6j98AkyLEQ==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/linear-progress": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/linear-progress/-/linear-progress-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-3HlEEPv+RrtGPxq06QzCOAZoNJ8q6UtOOkRxh+buQy1F+Uv0n4BdmvUYsHZaSTn+kSlFMzIKDtRjUG2i7b4/hg==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/progress-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/list": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/list/-/list-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-rYg3cM41MJTSNoFOj8IzF1CpPFK9DDlTFMbERFakRHB1QsfnebxkuoAyI8j5G/pDdvkeAmDbz4tbKK8yJdifRw==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/menu": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/menu/-/menu-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-Xa+tXk8kMFMhdOYrIre1ye4L23i4LzEn48FN398742m1K/VY/IxAuslyQ5CmX77CxkOqbQFqwUarUTod0rEwjw==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu-surface": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/menu-surface": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/menu-surface/-/menu-surface-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-7sRmwY7+a3gB5GM6Vl0sZzVVW3iu6QNW79vRias6nZKJMXbE/JDWnhcgkl9QkxvUolBIJ0y1ChgZyntO8Val/g==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/notched-outline": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/notched-outline/-/notched-outline-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-kMUDUqZ7ztvnwqCENZukztyA0oGZhY/mqd/WIaqRhIU58Q2mnDM6Vfd9fifeM61rIMnXHER2fvjjFzim50mw4g==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/floating-label": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/progress-indicator": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/progress-indicator/-/progress-indicator-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-CRQAM2C1weVKVr8rQeQTrOISmTupXw+l9sfpdIx8tQ14fOebZFcEbW9LRRvDAMmUNZF6W6pwL74+zk46DYIKBg==",
+ "requires": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/radio": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/radio/-/radio-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-wpiLuHQtpMb846SSYvG2NQJl/wUi1NbVlCV+uGHSv5LFnbe10e537KFpjtjaDi/Y6e42bUxj8njN5cEZ3NfBUg==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/ripple": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/ripple/-/ripple-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-S9S8260lwHreEgvOqg3EM0DF0y8ThuN9fFPVb+cCOAPzCn4Z2tO1pcvPfAmY8yZA7QIx9c5pt6Ci+q44LzPEYA==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/rtl": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/rtl/-/rtl-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-G02MQTQxHPhNlAIoOToCalxSba48VZ+CdrqkWr53eBb/P1I6Do0drMElqNmO5CYS5G/8AEScXmfJ0xSq92ABew==",
+ "requires": {
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/segmented-button": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/segmented-button/-/segmented-button-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-qu9nfKkPAxv6YFFObZAXHgaC0qq8i4Cr2lUbOQdL0E9HmKG+IE9ILualGJrAl2LOpCSJdwA0CjOuv2IsrscpHA==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/touch-target": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/select": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/select/-/select-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-MgbztOBl0Y7UHVPUTuXoAAYfBh+bwbRW9lkK/EJQ4YQrmZB/0L14S7feqh52JhFXVhjFzeYPFMQg+uP2hhHSpg==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/floating-label": "15.0.0-canary.7971d6ad5.0",
+ "@material/line-ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/list": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu": "15.0.0-canary.7971d6ad5.0",
+ "@material/menu-surface": "15.0.0-canary.7971d6ad5.0",
+ "@material/notched-outline": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/shape": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/shape/-/shape-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-mlsNFWKOK38ECoB1onCFpi8HKRGgrElk0YioF3V0Joszp1HVV2Fn+SWoKg2LwWHaJet4iBYtNoCbQC6dH2YBeA==",
+ "requires": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/slider": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/slider/-/slider-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-OjbxB3vwZvhbTGP8EGLWoXyodbTMuwkvoFdblEiZtWrrPL0Us5hg/20n8VfUQ0N+c00mElsEv79Jsx+B0iTV+Q==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/snackbar": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/snackbar/-/snackbar-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-svNOI1Kwu9Mg259SNTaGgyJqETRIPwQPkxYhHvWT4vYiHQkJJJe9kFBcIKi+sdTxqqoMZxyjC2SwS/1mkU4/xg==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/icon-button": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/switch": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/switch/-/switch-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-WBsTIq0NwccMAbt9YFcU1vhcmFOVpNDeZ9gNMJypk19ZiqDcZBZNDx0JmceRqTYrCxndqVwfD25qK0jFVplK9g==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "safevalues": "^0.3.4",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/tab": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tab/-/tab-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-hmqRl9s7g1/8KpZ5rqANxUXrHi4PYO3GsGhASrYrB99/5ZX1ghdCGwEN1Lp9ntKIgZjd1s6qtzccBtmnW+boXA==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/focus-ring": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/tab-bar": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tab-bar/-/tab-bar-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-hEMnb2C1yOQPbqdFCTCuyMmjcqO4QIvPKAsbquAwOZc0tz/U88tzmfuhv1k77FB2hbESwN9sPpImU0g4Lrvfhw==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-indicator": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab-scroller": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/tab-indicator": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tab-indicator/-/tab-indicator-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-0X2tJf0E+CwL5Bx3Fqxi5Uuj1BgncKqd4yFpWE7cv8IZHphNReSOrCcSgUwUfirmee6MqkQ4Drk51Pf4ANj2OA==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/tab-scroller": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tab-scroller/-/tab-scroller-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-//Ih8ZPx92PLQwXhFzv6YCQc5xW2IH84GdIeJrdBNcQN6wgbQNsbU7h9m6jymtpWQgvvLY8E0+2qkNcnWejnag==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/tab": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/textfield": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/textfield/-/textfield-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-n9aWMZGyE2GBTr2Tx6n4hLp08uyIo1/xNqcZ0Kx2tKK1spPgTgp+g2fEKImGnnbfiCTJPNrcJ8bQ+Vy7Dp0n3Q==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/density": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/floating-label": "15.0.0-canary.7971d6ad5.0",
+ "@material/line-ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/notched-outline": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/theme": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/theme/-/theme-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-4YUyQo4SOatHHH15/h2LBIyxmVxtefo+QC8bRopF13f/qq5lHpX/stK6chf1OR/z9BUxnNHZWXd2LG5SvJGs9Q==",
+ "requires": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/tokens": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tokens/-/tokens-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-tRa/Uki/moIP6f/QJPrad2jHbSZ5NB5TRSfAS1NZof0KNFjW8n2lJVpgcgD+f1NENin3dWM4NpfJwxulGlWE7g==",
+ "requires": {
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0"
+ }
+ },
+ "@material/tooltip": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/tooltip/-/tooltip-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-gidVGZOGmJUNDxm3ZorNZMAFmbeFmJ+6DH2F45hi1iU/GflfyvMfvbG2VvPFGYj84YAKHs799yAjidvk1nSZZg==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/button": "15.0.0-canary.7971d6ad5.0",
+ "@material/dom": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/tokens": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "safevalues": "^0.3.4",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/top-app-bar": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/top-app-bar/-/top-app-bar-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-ztvglUBK0y4LDHD8xhvNGCpbsHYoAVtI06cJHu5G241WD5wAmseEnLMY+ty86FHMzs796PzhUqUmahEHeBNlEg==",
+ "requires": {
+ "@material/animation": "15.0.0-canary.7971d6ad5.0",
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/elevation": "15.0.0-canary.7971d6ad5.0",
+ "@material/ripple": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "@material/shape": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "@material/typography": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/touch-target": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/touch-target/-/touch-target-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-aT8GyRfH0TJuF53HWKga+vuwJbJ/euN6T8CS/+RP5F/rjzWwxSd8RtyBmVUzBjVzOxr6Os+El0c3TFfEDxRdAg==",
+ "requires": {
+ "@material/base": "15.0.0-canary.7971d6ad5.0",
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/rtl": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@material/typography": {
+ "version": "15.0.0-canary.7971d6ad5.0",
+ "resolved": "https://registry.npmjs.org/@material/typography/-/typography-15.0.0-canary.7971d6ad5.0.tgz",
+ "integrity": "sha512-4J5qPXbCS3wMtGl0AJIj/M9rUxHR7fRX3IKtfOyvra10lZbr4qma+4g0+t+O9cPzcCBS1NwPkJ/E4t+ijEa6gA==",
+ "requires": {
+ "@material/feature-targeting": "15.0.0-canary.7971d6ad5.0",
+ "@material/theme": "15.0.0-canary.7971d6ad5.0",
+ "tslib": "^2.1.0"
+ }
+ },
+ "@ngtools/webpack": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@ngtools/webpack/-/webpack-15.2.9.tgz",
+ "integrity": "sha512-nOXUGqKkAEMlCcrhkDwWDzcVdKNH7MNRUXfNzsFc9zdeR/5p3qt6SVMN7OOE3NREyI7P6nzARc3S+6QDBjf3Jg==",
+ "dev": true
+ },
+ "@nodelib/fs.scandir": {
+ "version": "2.1.5",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
+ "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
+ "dev": true,
+ "requires": {
+ "@nodelib/fs.stat": "2.0.5",
+ "run-parallel": "^1.1.9"
+ }
+ },
+ "@nodelib/fs.stat": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
+ "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
+ "dev": true
+ },
+ "@nodelib/fs.walk": {
+ "version": "1.2.8",
+ "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
+ "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
+ "dev": true,
+ "requires": {
+ "@nodelib/fs.scandir": "2.1.5",
+ "fastq": "^1.6.0"
+ }
+ },
+ "@npmcli/fs": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@npmcli/fs/-/fs-3.1.0.tgz",
+ "integrity": "sha512-7kZUAaLscfgbwBQRbvdMYaZOWyMEcPTH/tJjnyAWJ/dvvs9Ef+CERx/qJb9GExJpl1qipaDGn7KqHnFGGixd0w==",
+ "dev": true,
+ "requires": {
+ "semver": "^7.3.5"
+ }
+ },
+ "@npmcli/git": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/@npmcli/git/-/git-4.1.0.tgz",
+ "integrity": "sha512-9hwoB3gStVfa0N31ymBmrX+GuDGdVA/QWShZVqE0HK2Af+7QGGrCTbZia/SW0ImUTjTne7SP91qxDmtXvDHRPQ==",
+ "dev": true,
+ "requires": {
+ "@npmcli/promise-spawn": "^6.0.0",
+ "lru-cache": "^7.4.4",
+ "npm-pick-manifest": "^8.0.0",
+ "proc-log": "^3.0.0",
+ "promise-inflight": "^1.0.1",
+ "promise-retry": "^2.0.1",
+ "semver": "^7.3.5",
+ "which": "^3.0.0"
+ },
+ "dependencies": {
+ "lru-cache": {
+ "version": "7.18.3",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz",
+ "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==",
+ "dev": true
+ },
+ "which": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-3.0.1.tgz",
+ "integrity": "sha512-XA1b62dzQzLfaEOSQFTCOd5KFf/1VSzZo7/7TUjnya6u0vGGKzU96UQBZTAThCb2j4/xjBAyii1OhRLJEivHvg==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ }
+ }
+ },
+ "@npmcli/installed-package-contents": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/@npmcli/installed-package-contents/-/installed-package-contents-2.0.2.tgz",
+ "integrity": "sha512-xACzLPhnfD51GKvTOOuNX2/V4G4mz9/1I2MfDoye9kBM3RYe5g2YbscsaGoTlaWqkxeiapBWyseULVKpSVHtKQ==",
+ "dev": true,
+ "requires": {
+ "npm-bundled": "^3.0.0",
+ "npm-normalize-package-bin": "^3.0.0"
+ }
+ },
+ "@npmcli/node-gyp": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/@npmcli/node-gyp/-/node-gyp-3.0.0.tgz",
+ "integrity": "sha512-gp8pRXC2oOxu0DUE1/M3bYtb1b3/DbJ5aM113+XJBgfXdussRAsX0YOrOhdd8WvnAR6auDBvJomGAkLKA5ydxA==",
+ "dev": true
+ },
+ "@npmcli/promise-spawn": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/@npmcli/promise-spawn/-/promise-spawn-6.0.2.tgz",
+ "integrity": "sha512-gGq0NJkIGSwdbUt4yhdF8ZrmkGKVz9vAdVzpOfnom+V8PLSmSOVhZwbNvZZS1EYcJN5hzzKBxmmVVAInM6HQLg==",
+ "dev": true,
+ "requires": {
+ "which": "^3.0.0"
+ },
+ "dependencies": {
+ "which": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-3.0.1.tgz",
+ "integrity": "sha512-XA1b62dzQzLfaEOSQFTCOd5KFf/1VSzZo7/7TUjnya6u0vGGKzU96UQBZTAThCb2j4/xjBAyii1OhRLJEivHvg==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ }
+ }
+ },
+ "@npmcli/run-script": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/@npmcli/run-script/-/run-script-6.0.2.tgz",
+ "integrity": "sha512-NCcr1uQo1k5U+SYlnIrbAh3cxy+OQT1VtqiAbxdymSlptbzBb62AjH2xXgjNCoP073hoa1CfCAcwoZ8k96C4nA==",
+ "dev": true,
+ "requires": {
+ "@npmcli/node-gyp": "^3.0.0",
+ "@npmcli/promise-spawn": "^6.0.0",
+ "node-gyp": "^9.0.0",
+ "read-package-json-fast": "^3.0.0",
+ "which": "^3.0.0"
+ },
+ "dependencies": {
+ "which": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-3.0.1.tgz",
+ "integrity": "sha512-XA1b62dzQzLfaEOSQFTCOd5KFf/1VSzZo7/7TUjnya6u0vGGKzU96UQBZTAThCb2j4/xjBAyii1OhRLJEivHvg==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ }
+ }
+ },
+ "@pkgjs/parseargs": {
+ "version": "0.11.0",
+ "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz",
+ "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==",
+ "dev": true,
+ "optional": true
+ },
+ "@schematics/angular": {
+ "version": "15.2.9",
+ "resolved": "https://registry.npmjs.org/@schematics/angular/-/angular-15.2.9.tgz",
+ "integrity": "sha512-0Lit6TLNUwcAYiEkXgZp3vY9xAO1cnZCBXuUcp+6v+Ddnrt2w/YOiGe74p21cYe0StkTpTljsqsKBTiX7TMjQg==",
+ "dev": true,
+ "requires": {
+ "@angular-devkit/core": "15.2.9",
+ "@angular-devkit/schematics": "15.2.9",
+ "jsonc-parser": "3.2.0"
+ }
+ },
+ "@sigstore/bundle": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/@sigstore/bundle/-/bundle-1.0.0.tgz",
+ "integrity": "sha512-yLvrWDOh6uMOUlFCTJIZEnwOT9Xte7NPXUqVexEKGSF5XtBAuSg5du0kn3dRR0p47a4ah10Y0mNt8+uyeQXrBQ==",
+ "dev": true,
+ "requires": {
+ "@sigstore/protobuf-specs": "^0.2.0"
+ }
+ },
+ "@sigstore/protobuf-specs": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/@sigstore/protobuf-specs/-/protobuf-specs-0.2.0.tgz",
+ "integrity": "sha512-8ZhZKAVfXjIspDWwm3D3Kvj0ddbJ0HqDZ/pOs5cx88HpT8mVsotFrg7H1UMnXOuDHz6Zykwxn4mxG3QLuN+RUg==",
+ "dev": true
+ },
+ "@sigstore/tuf": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/@sigstore/tuf/-/tuf-1.0.3.tgz",
+ "integrity": "sha512-2bRovzs0nJZFlCN3rXirE4gwxCn97JNjMmwpecqlbgV9WcxX7WRuIrgzx/X7Ib7MYRbyUTpBYE0s2x6AmZXnlg==",
+ "dev": true,
+ "requires": {
+ "@sigstore/protobuf-specs": "^0.2.0",
+ "tuf-js": "^1.1.7"
+ }
+ },
+ "@socket.io/component-emitter": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/@socket.io/component-emitter/-/component-emitter-3.1.0.tgz",
+ "integrity": "sha512-+9jVqKhRSpsc591z5vX+X5Yyw+he/HCB4iQ/RYxw35CEPaY1gnsNE43nf9n9AaYjAQrTiI/mOwKUKdUs9vf7Xg==",
+ "dev": true
+ },
+ "@tinymce/tinymce-angular": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/@tinymce/tinymce-angular/-/tinymce-angular-7.0.0.tgz",
+ "integrity": "sha512-IKNaG/ihlxE1XCfq6lzULbnsqZO9KNJtlpu5jo6JDJDL9zcFzj/N2A16Kk7rTj1yfmDoB1IXAk/BpMOvgDY8cg==",
+ "requires": {
+ "tinymce": "^6.0.0 || ^5.5.0",
+ "tslib": "^2.3.0"
+ }
+ },
+ "@tootallnate/once": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-2.0.0.tgz",
+ "integrity": "sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A==",
+ "dev": true
+ },
+ "@tufjs/canonical-json": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/@tufjs/canonical-json/-/canonical-json-1.0.0.tgz",
+ "integrity": "sha512-QTnf++uxunWvG2z3UFNzAoQPHxnSXOwtaI3iJ+AohhV+5vONuArPjJE7aPXPVXfXJsqrVbZBu9b81AJoSd09IQ==",
+ "dev": true
+ },
+ "@tufjs/models": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/@tufjs/models/-/models-1.0.4.tgz",
+ "integrity": "sha512-qaGV9ltJP0EO25YfFUPhxRVK0evXFIAGicsVXuRim4Ed9cjPxYhNnNJ49SFmbeLgtxpslIkX317IgpfcHPVj/A==",
+ "dev": true,
+ "requires": {
+ "@tufjs/canonical-json": "1.0.0",
+ "minimatch": "^9.0.0"
+ },
+ "dependencies": {
+ "minimatch": {
+ "version": "9.0.3",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz",
+ "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^2.0.1"
+ }
+ }
+ }
+ },
+ "@types/body-parser": {
+ "version": "1.19.2",
+ "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz",
+ "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==",
+ "dev": true,
+ "requires": {
+ "@types/connect": "*",
+ "@types/node": "*"
+ }
+ },
+ "@types/bonjour": {
+ "version": "3.5.10",
+ "resolved": "https://registry.npmjs.org/@types/bonjour/-/bonjour-3.5.10.tgz",
+ "integrity": "sha512-p7ienRMiS41Nu2/igbJxxLDWrSZ0WxM8UQgCeO9KhoVF7cOVFkrKsiDr1EsJIla8vV3oEEjGcz11jc5yimhzZw==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/connect": {
+ "version": "3.4.35",
+ "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz",
+ "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/connect-history-api-fallback": {
+ "version": "1.3.5",
+ "resolved": "https://registry.npmjs.org/@types/connect-history-api-fallback/-/connect-history-api-fallback-1.3.5.tgz",
+ "integrity": "sha512-h8QJa8xSb1WD4fpKBDcATDNGXghFj6/3GRWG6dhmRcu0RX1Ubasur2Uvx5aeEwlf0MwblEC2bMzzMQntxnw/Cw==",
+ "dev": true,
+ "requires": {
+ "@types/express-serve-static-core": "*",
+ "@types/node": "*"
+ }
+ },
+ "@types/cookie": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.4.1.tgz",
+ "integrity": "sha512-XW/Aa8APYr6jSVVA1y/DEIZX0/GMKLEVekNG727R8cs56ahETkRAy/3DR7+fJyh7oUgGwNQaRfXCun0+KbWY7Q==",
+ "dev": true
+ },
+ "@types/cors": {
+ "version": "2.8.13",
+ "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.13.tgz",
+ "integrity": "sha512-RG8AStHlUiV5ysZQKq97copd2UmVYw3/pRMLefISZ3S1hK104Cwm7iLQ3fTKx+lsUH2CE8FlLaYeEA2LSeqYUA==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/echarts": {
+ "version": "4.9.16",
+ "resolved": "https://registry.npmjs.org/@types/echarts/-/echarts-4.9.16.tgz",
+ "integrity": "sha512-bfiagfPw3dWauAIJ9fgoJQoL4hLWlGcltqwbE6LGye0NIY5xnbZau+mDmadCzGojic3MWuFDCUiO25kl4sRGeA==",
+ "dev": true,
+ "requires": {
+ "@types/zrender": "*"
+ }
+ },
+ "@types/eslint": {
+ "version": "8.44.1",
+ "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.44.1.tgz",
+ "integrity": "sha512-XpNDc4Z5Tb4x+SW1MriMVeIsMoONHCkWFMkR/aPJbzEsxqHy+4Glu/BqTdPrApfDeMaXbtNh6bseNgl5KaWrSg==",
+ "dev": true,
+ "requires": {
+ "@types/estree": "*",
+ "@types/json-schema": "*"
+ }
+ },
+ "@types/eslint-scope": {
+ "version": "3.7.4",
+ "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.4.tgz",
+ "integrity": "sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA==",
+ "dev": true,
+ "requires": {
+ "@types/eslint": "*",
+ "@types/estree": "*"
+ }
+ },
+ "@types/estree": {
+ "version": "0.0.51",
+ "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.51.tgz",
+ "integrity": "sha512-CuPgU6f3eT/XgKKPqKd/gLZV1Xmvf1a2R5POBOGQa6uv82xpls89HU5zKeVoyR8XzHd1RGNOlQlvUe3CFkjWNQ==",
+ "dev": true
+ },
+ "@types/express": {
+ "version": "4.17.15",
+ "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.15.tgz",
+ "integrity": "sha512-Yv0k4bXGOH+8a+7bELd2PqHQsuiANB+A8a4gnQrkRWzrkKlb6KHaVvyXhqs04sVW/OWlbPyYxRgYlIXLfrufMQ==",
+ "dev": true,
+ "requires": {
+ "@types/body-parser": "*",
+ "@types/express-serve-static-core": "^4.17.31",
+ "@types/qs": "*",
+ "@types/serve-static": "*"
+ }
+ },
+ "@types/express-serve-static-core": {
+ "version": "4.17.32",
+ "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.32.tgz",
+ "integrity": "sha512-aI5h/VOkxOF2Z1saPy0Zsxs5avets/iaiAJYznQFm5By/pamU31xWKL//epiF4OfUA2qTOc9PV6tCUjhO8wlZA==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*",
+ "@types/qs": "*",
+ "@types/range-parser": "*"
+ }
+ },
+ "@types/http-proxy": {
+ "version": "1.17.9",
+ "resolved": "https://registry.npmjs.org/@types/http-proxy/-/http-proxy-1.17.9.tgz",
+ "integrity": "sha512-QsbSjA/fSk7xB+UXlCT3wHBy5ai9wOcNDWwZAtud+jXhwOM3l+EYZh8Lng4+/6n8uar0J7xILzqftJdJ/Wdfkw==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/jasmine": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/@types/jasmine/-/jasmine-4.3.1.tgz",
+ "integrity": "sha512-Vu8l+UGcshYmV1VWwULgnV/2RDbBaO6i2Ptx7nd//oJPIZGhoI1YLST4VKagD2Pq/Bc2/7zvtvhM7F3p4SN7kQ==",
+ "dev": true
+ },
+ "@types/json-schema": {
+ "version": "7.0.11",
+ "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz",
+ "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==",
+ "dev": true
+ },
+ "@types/mime": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.1.tgz",
+ "integrity": "sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==",
+ "dev": true
+ },
+ "@types/node": {
+ "version": "12.20.55",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-12.20.55.tgz",
+ "integrity": "sha512-J8xLz7q2OFulZ2cyGTLE1TbbZcjpno7FaN6zdJNrgAdrJ+DZzh/uFR6YrTb4C+nXakvud8Q4+rbhoIWlYQbUFQ==",
+ "dev": true
+ },
+ "@types/parse-json": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz",
+ "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==",
+ "dev": true
+ },
+ "@types/qs": {
+ "version": "6.9.7",
+ "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz",
+ "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==",
+ "dev": true
+ },
+ "@types/range-parser": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz",
+ "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==",
+ "dev": true
+ },
+ "@types/retry": {
+ "version": "0.12.0",
+ "resolved": "https://registry.npmjs.org/@types/retry/-/retry-0.12.0.tgz",
+ "integrity": "sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA==",
+ "dev": true
+ },
+ "@types/serve-index": {
+ "version": "1.9.1",
+ "resolved": "https://registry.npmjs.org/@types/serve-index/-/serve-index-1.9.1.tgz",
+ "integrity": "sha512-d/Hs3nWDxNL2xAczmOVZNj92YZCS6RGxfBPjKzuu/XirCgXdpKEb88dYNbrYGint6IVWLNP+yonwVAuRC0T2Dg==",
+ "dev": true,
+ "requires": {
+ "@types/express": "*"
+ }
+ },
+ "@types/serve-static": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.0.tgz",
+ "integrity": "sha512-z5xyF6uh8CbjAu9760KDKsH2FcDxZ2tFCsA4HIMWE6IkiYMXfVoa+4f9KX+FN0ZLsaMw1WNG2ETLA6N+/YA+cg==",
+ "dev": true,
+ "requires": {
+ "@types/mime": "*",
+ "@types/node": "*"
+ }
+ },
+ "@types/sockjs": {
+ "version": "0.3.33",
+ "resolved": "https://registry.npmjs.org/@types/sockjs/-/sockjs-0.3.33.tgz",
+ "integrity": "sha512-f0KEEe05NvUnat+boPTZ0dgaLZ4SfSouXUgv5noUiefG2ajgKjmETo9ZJyuqsl7dfl2aHlLJUiki6B4ZYldiiw==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/sortablejs": {
+ "version": "1.15.1",
+ "resolved": "https://registry.npmjs.org/@types/sortablejs/-/sortablejs-1.15.1.tgz",
+ "integrity": "sha512-g/JwBNToh6oCTAwNS8UGVmjO7NLDKsejVhvE4x1eWiPTC3uCuNsa/TD4ssvX3du+MLiM+SHPNDuijp8y76JzLQ==",
+ "dev": true
+ },
+ "@types/ws": {
+ "version": "8.5.4",
+ "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.4.tgz",
+ "integrity": "sha512-zdQDHKUgcX/zBc4GrwsE/7dVdAD8JR4EuiAXiiUhhfyIJXXb2+PrGshFyeXWQPMmmZ2XxgaqclgpIC7eTXc1mg==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/zrender": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/@types/zrender/-/zrender-4.0.3.tgz",
+ "integrity": "sha512-EPI269lkHNsObwILJ1k1z7znLjKyePuWRy/XKK0shSGpBb9cIX307arcwJV4+2NeZj5wEjN06r4D8yFv7sI06g==",
+ "dev": true
+ },
+ "@webassemblyjs/ast": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.1.tgz",
+ "integrity": "sha512-ukBh14qFLjxTQNTXocdyksN5QdM28S1CxHt2rdskFyL+xFV7VremuBLVbmCePj+URalXBENx/9Lm7lnhihtCSw==",
+ "dev": true,
+ "requires": {
+ "@webassemblyjs/helper-numbers": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1"
+ }
+ },
+ "@webassemblyjs/floating-point-hex-parser": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.1.tgz",
+ "integrity": "sha512-iGRfyc5Bq+NnNuX8b5hwBrRjzf0ocrJPI6GWFodBFzmFnyvrQ83SHKhmilCU/8Jv67i4GJZBMhEzltxzcNagtQ==",
+ "dev": true
+ },
+ "@webassemblyjs/helper-api-error": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.1.tgz",
+ "integrity": "sha512-RlhS8CBCXfRUR/cwo2ho9bkheSXG0+NwooXcc3PAILALf2QLdFyj7KGsKRbVc95hZnhnERon4kW/D3SZpp6Tcg==",
+ "dev": true
+ },
+ "@webassemblyjs/helper-buffer": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.1.tgz",
+ "integrity": "sha512-gwikF65aDNeeXa8JxXa2BAk+REjSyhrNC9ZwdT0f8jc4dQQeDQ7G4m0f2QCLPJiMTTO6wfDmRmj/pW0PsUvIcA==",
+ "dev": true
+ },
+ "@webassemblyjs/helper-numbers": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.1.tgz",
+ "integrity": "sha512-vDkbxiB8zfnPdNK9Rajcey5C0w+QJugEglN0of+kmO8l7lDb77AnlKYQF7aarZuCrv+l0UvqL+68gSDr3k9LPQ==",
+ "dev": true,
+ "requires": {
+ "@webassemblyjs/floating-point-hex-parser": "1.11.1",
+ "@webassemblyjs/helper-api-error": "1.11.1",
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "@webassemblyjs/helper-wasm-bytecode": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.1.tgz",
+ "integrity": "sha512-PvpoOGiJwXeTrSf/qfudJhwlvDQxFgelbMqtq52WWiXC6Xgg1IREdngmPN3bs4RoO83PnL/nFrxucXj1+BX62Q==",
+ "dev": true
+ },
+ "@webassemblyjs/helper-wasm-section": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.1.tgz",
+ "integrity": "sha512-10P9No29rYX1j7F3EVPX3JvGPQPae+AomuSTPiF9eBQeChHI6iqjMIwR9JmOJXwpnn/oVGDk7I5IlskuMwU/pg==",
+ "dev": true,
+ "requires": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-buffer": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1",
+ "@webassemblyjs/wasm-gen": "1.11.1"
+ }
+ },
+ "@webassemblyjs/ieee754": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.1.tgz",
+ "integrity": "sha512-hJ87QIPtAMKbFq6CGTkZYJivEwZDbQUgYd3qKSadTNOhVY7p+gfP6Sr0lLRVTaG1JjFj+r3YchoqRYxNH3M0GQ==",
+ "dev": true,
+ "requires": {
+ "@xtuc/ieee754": "^1.2.0"
+ }
+ },
+ "@webassemblyjs/leb128": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.1.tgz",
+ "integrity": "sha512-BJ2P0hNZ0u+Th1YZXJpzW6miwqQUGcIHT1G/sf72gLVD9DZ5AdYTqPNbHZh6K1M5VmKvFXwGSWZADz+qBWxeRw==",
+ "dev": true,
+ "requires": {
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "@webassemblyjs/utf8": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.1.tgz",
+ "integrity": "sha512-9kqcxAEdMhiwQkHpkNiorZzqpGrodQQ2IGrHHxCy+Ozng0ofyMA0lTqiLkVs1uzTRejX+/O0EOT7KxqVPuXosQ==",
+ "dev": true
+ },
+ "@webassemblyjs/wasm-edit": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.1.tgz",
+ "integrity": "sha512-g+RsupUC1aTHfR8CDgnsVRVZFJqdkFHpsHMfJuWQzWU3tvnLC07UqHICfP+4XyL2tnr1amvl1Sdp06TnYCmVkA==",
+ "dev": true,
+ "requires": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-buffer": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1",
+ "@webassemblyjs/helper-wasm-section": "1.11.1",
+ "@webassemblyjs/wasm-gen": "1.11.1",
+ "@webassemblyjs/wasm-opt": "1.11.1",
+ "@webassemblyjs/wasm-parser": "1.11.1",
+ "@webassemblyjs/wast-printer": "1.11.1"
+ }
+ },
+ "@webassemblyjs/wasm-gen": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.1.tgz",
+ "integrity": "sha512-F7QqKXwwNlMmsulj6+O7r4mmtAlCWfO/0HdgOxSklZfQcDu0TpLiD1mRt/zF25Bk59FIjEuGAIyn5ei4yMfLhA==",
+ "dev": true,
+ "requires": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1",
+ "@webassemblyjs/ieee754": "1.11.1",
+ "@webassemblyjs/leb128": "1.11.1",
+ "@webassemblyjs/utf8": "1.11.1"
+ }
+ },
+ "@webassemblyjs/wasm-opt": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.1.tgz",
+ "integrity": "sha512-VqnkNqnZlU5EB64pp1l7hdm3hmQw7Vgqa0KF/KCNO9sIpI6Fk6brDEiX+iCOYrvMuBWDws0NkTOxYEb85XQHHw==",
+ "dev": true,
+ "requires": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-buffer": "1.11.1",
+ "@webassemblyjs/wasm-gen": "1.11.1",
+ "@webassemblyjs/wasm-parser": "1.11.1"
+ }
+ },
+ "@webassemblyjs/wasm-parser": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.1.tgz",
+ "integrity": "sha512-rrBujw+dJu32gYB7/Lup6UhdkPx9S9SnobZzRVL7VcBH9Bt9bCBLEuX/YXOOtBsOZ4NQrRykKhffRWHvigQvOA==",
+ "dev": true,
+ "requires": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/helper-api-error": "1.11.1",
+ "@webassemblyjs/helper-wasm-bytecode": "1.11.1",
+ "@webassemblyjs/ieee754": "1.11.1",
+ "@webassemblyjs/leb128": "1.11.1",
+ "@webassemblyjs/utf8": "1.11.1"
+ }
+ },
+ "@webassemblyjs/wast-printer": {
+ "version": "1.11.1",
+ "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.1.tgz",
+ "integrity": "sha512-IQboUWM4eKzWW+N/jij2sRatKMh99QEelo3Eb2q0qXkvPRISAj8Qxtmw5itwqK+TTkBuUIE45AxYPToqPtL5gg==",
+ "dev": true,
+ "requires": {
+ "@webassemblyjs/ast": "1.11.1",
+ "@xtuc/long": "4.2.2"
+ }
+ },
+ "@xtuc/ieee754": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz",
+ "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==",
+ "dev": true
+ },
+ "@xtuc/long": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz",
+ "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==",
+ "dev": true
+ },
+ "@yarnpkg/lockfile": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz",
+ "integrity": "sha512-GpSwvyXOcOOlV70vbnzjj4fW5xW/FdUF6nQEt1ENy7m4ZCczi1+/buVUPAqmGfqznsORNFzUMjctTIp8a9tuCQ==",
+ "dev": true
+ },
+ "abab": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz",
+ "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==",
+ "dev": true
+ },
+ "abbrev": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
+ "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==",
+ "dev": true
+ },
+ "accepts": {
+ "version": "1.3.8",
+ "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz",
+ "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==",
+ "dev": true,
+ "requires": {
+ "mime-types": "~2.1.34",
+ "negotiator": "0.6.3"
+ }
+ },
+ "acorn": {
+ "version": "8.10.0",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz",
+ "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==",
+ "dev": true
+ },
+ "acorn-import-assertions": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.9.0.tgz",
+ "integrity": "sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==",
+ "dev": true
+ },
+ "adjust-sourcemap-loader": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/adjust-sourcemap-loader/-/adjust-sourcemap-loader-4.0.0.tgz",
+ "integrity": "sha512-OXwN5b9pCUXNQHJpwwD2qP40byEmSgzj8B4ydSN0uMNYWiFmJ6x6KwUllMmfk8Rwu/HJDFR7U8ubsWBoN0Xp0A==",
+ "dev": true,
+ "requires": {
+ "loader-utils": "^2.0.0",
+ "regex-parser": "^2.2.11"
+ },
+ "dependencies": {
+ "loader-utils": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz",
+ "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==",
+ "dev": true,
+ "requires": {
+ "big.js": "^5.2.2",
+ "emojis-list": "^3.0.0",
+ "json5": "^2.1.2"
+ }
+ }
+ }
+ },
+ "agent-base": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz",
+ "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==",
+ "dev": true,
+ "requires": {
+ "debug": "4"
+ }
+ },
+ "agentkeepalive": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/agentkeepalive/-/agentkeepalive-4.3.0.tgz",
+ "integrity": "sha512-7Epl1Blf4Sy37j4v9f9FjICCh4+KAQOyXgHEwlyBiAQLbhKdq/i2QQU3amQalS/wPhdPzDXPL5DMR5bkn+YeWg==",
+ "dev": true,
+ "requires": {
+ "debug": "^4.1.0",
+ "depd": "^2.0.0",
+ "humanize-ms": "^1.2.1"
+ }
+ },
+ "aggregate-error": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz",
+ "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==",
+ "dev": true,
+ "requires": {
+ "clean-stack": "^2.0.0",
+ "indent-string": "^4.0.0"
+ }
+ },
+ "ajv": {
+ "version": "8.12.0",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.12.0.tgz",
+ "integrity": "sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==",
+ "dev": true,
+ "requires": {
+ "fast-deep-equal": "^3.1.1",
+ "json-schema-traverse": "^1.0.0",
+ "require-from-string": "^2.0.2",
+ "uri-js": "^4.2.2"
+ }
+ },
+ "ajv-formats": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/ajv-formats/-/ajv-formats-2.1.1.tgz",
+ "integrity": "sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==",
+ "dev": true,
+ "requires": {
+ "ajv": "^8.0.0"
+ }
+ },
+ "ajv-keywords": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-5.1.0.tgz",
+ "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==",
+ "dev": true,
+ "requires": {
+ "fast-deep-equal": "^3.1.3"
+ }
+ },
+ "ansi-colors": {
+ "version": "4.1.3",
+ "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz",
+ "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==",
+ "dev": true
+ },
+ "ansi-escapes": {
+ "version": "4.3.2",
+ "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz",
+ "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==",
+ "dev": true,
+ "requires": {
+ "type-fest": "^0.21.3"
+ }
+ },
+ "ansi-html-community": {
+ "version": "0.0.8",
+ "resolved": "https://registry.npmjs.org/ansi-html-community/-/ansi-html-community-0.0.8.tgz",
+ "integrity": "sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw==",
+ "dev": true
+ },
+ "ansi-regex": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
+ "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
+ "dev": true
+ },
+ "ansi-styles": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
+ "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^1.9.0"
+ }
+ },
+ "anymatch": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz",
+ "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==",
+ "dev": true,
+ "requires": {
+ "normalize-path": "^3.0.0",
+ "picomatch": "^2.0.4"
+ }
+ },
+ "aproba": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz",
+ "integrity": "sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==",
+ "dev": true
+ },
+ "are-we-there-yet": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-3.0.1.tgz",
+ "integrity": "sha512-QZW4EDmGwlYur0Yyf/b2uGucHQMa8aFUP7eu9ddR73vvhFyt4V0Vl3QHPcTNJ8l6qYOBdxgXdnBXQrHilfRQBg==",
+ "dev": true,
+ "requires": {
+ "delegates": "^1.0.0",
+ "readable-stream": "^3.6.0"
+ }
+ },
+ "argparse": {
+ "version": "1.0.10",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz",
+ "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==",
+ "dev": true,
+ "requires": {
+ "sprintf-js": "~1.0.2"
+ }
+ },
+ "array-flatten": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-2.1.2.tgz",
+ "integrity": "sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ==",
+ "dev": true
+ },
+ "autoprefixer": {
+ "version": "10.4.13",
+ "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.13.tgz",
+ "integrity": "sha512-49vKpMqcZYsJjwotvt4+h/BCjJVnhGwcLpDt5xkcaOG3eLrG/HUYLagrihYsQ+qrIBgIzX1Rw7a6L8I/ZA1Atg==",
+ "dev": true,
+ "requires": {
+ "browserslist": "^4.21.4",
+ "caniuse-lite": "^1.0.30001426",
+ "fraction.js": "^4.2.0",
+ "normalize-range": "^0.1.2",
+ "picocolors": "^1.0.0",
+ "postcss-value-parser": "^4.2.0"
+ }
+ },
+ "babel-loader": {
+ "version": "9.1.2",
+ "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-9.1.2.tgz",
+ "integrity": "sha512-mN14niXW43tddohGl8HPu5yfQq70iUThvFL/4QzESA7GcZoC0eVOhvWdQ8+3UlSjaDE9MVtsW9mxDY07W7VpVA==",
+ "dev": true,
+ "requires": {
+ "find-cache-dir": "^3.3.2",
+ "schema-utils": "^4.0.0"
+ }
+ },
+ "babel-plugin-istanbul": {
+ "version": "6.1.1",
+ "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz",
+ "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@istanbuljs/load-nyc-config": "^1.0.0",
+ "@istanbuljs/schema": "^0.1.2",
+ "istanbul-lib-instrument": "^5.0.4",
+ "test-exclude": "^6.0.0"
+ }
+ },
+ "babel-plugin-polyfill-corejs2": {
+ "version": "0.3.3",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.3.tgz",
+ "integrity": "sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q==",
+ "dev": true,
+ "requires": {
+ "@babel/compat-data": "^7.17.7",
+ "@babel/helper-define-polyfill-provider": "^0.3.3",
+ "semver": "^6.1.1"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ },
+ "babel-plugin-polyfill-corejs3": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.6.0.tgz",
+ "integrity": "sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-define-polyfill-provider": "^0.3.3",
+ "core-js-compat": "^3.25.1"
+ }
+ },
+ "babel-plugin-polyfill-regenerator": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.4.1.tgz",
+ "integrity": "sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-define-polyfill-provider": "^0.3.3"
+ }
+ },
+ "balanced-match": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
+ "dev": true
+ },
+ "base64-js": {
+ "version": "1.5.1",
+ "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
+ "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==",
+ "dev": true
+ },
+ "base64id": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz",
+ "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==",
+ "dev": true
+ },
+ "batch": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz",
+ "integrity": "sha512-x+VAiMRL6UPkx+kudNvxTl6hB2XNNCG2r+7wixVfIYwu/2HKRXimwQyaumLjMveWvT2Hkd/cAJw+QBMfJ/EKVw==",
+ "dev": true
+ },
+ "big.js": {
+ "version": "5.2.2",
+ "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz",
+ "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==",
+ "dev": true
+ },
+ "binary-extensions": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz",
+ "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==",
+ "dev": true
+ },
+ "bl": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz",
+ "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==",
+ "dev": true,
+ "requires": {
+ "buffer": "^5.5.0",
+ "inherits": "^2.0.4",
+ "readable-stream": "^3.4.0"
+ }
+ },
+ "body-parser": {
+ "version": "1.20.1",
+ "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz",
+ "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==",
+ "dev": true,
+ "requires": {
+ "bytes": "3.1.2",
+ "content-type": "~1.0.4",
+ "debug": "2.6.9",
+ "depd": "2.0.0",
+ "destroy": "1.2.0",
+ "http-errors": "2.0.0",
+ "iconv-lite": "0.4.24",
+ "on-finished": "2.4.1",
+ "qs": "6.11.0",
+ "raw-body": "2.5.1",
+ "type-is": "~1.6.18",
+ "unpipe": "1.0.0"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ }
+ }
+ },
+ "bonjour-service": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/bonjour-service/-/bonjour-service-1.1.0.tgz",
+ "integrity": "sha512-LVRinRB3k1/K0XzZ2p58COnWvkQknIY6sf0zF2rpErvcJXpMBttEPQSxK+HEXSS9VmpZlDoDnQWv8ftJT20B0Q==",
+ "dev": true,
+ "requires": {
+ "array-flatten": "^2.1.2",
+ "dns-equal": "^1.0.0",
+ "fast-deep-equal": "^3.1.3",
+ "multicast-dns": "^7.2.5"
+ }
+ },
+ "boolbase": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz",
+ "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==",
+ "dev": true
+ },
+ "brace-expansion": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz",
+ "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==",
+ "dev": true,
+ "requires": {
+ "balanced-match": "^1.0.0"
+ }
+ },
+ "braces": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
+ "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
+ "dev": true,
+ "requires": {
+ "fill-range": "^7.0.1"
+ }
+ },
+ "browserslist": {
+ "version": "4.21.5",
+ "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.5.tgz",
+ "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==",
+ "dev": true,
+ "requires": {
+ "caniuse-lite": "^1.0.30001449",
+ "electron-to-chromium": "^1.4.284",
+ "node-releases": "^2.0.8",
+ "update-browserslist-db": "^1.0.10"
+ }
+ },
+ "buffer": {
+ "version": "5.7.1",
+ "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz",
+ "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==",
+ "dev": true,
+ "requires": {
+ "base64-js": "^1.3.1",
+ "ieee754": "^1.1.13"
+ }
+ },
+ "buffer-from": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz",
+ "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==",
+ "dev": true
+ },
+ "builtins": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/builtins/-/builtins-5.0.1.tgz",
+ "integrity": "sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==",
+ "dev": true,
+ "requires": {
+ "semver": "^7.0.0"
+ }
+ },
+ "bytes": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
+ "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==",
+ "dev": true
+ },
+ "cacache": {
+ "version": "17.0.4",
+ "resolved": "https://registry.npmjs.org/cacache/-/cacache-17.0.4.tgz",
+ "integrity": "sha512-Z/nL3gU+zTUjz5pCA5vVjYM8pmaw2kxM7JEiE0fv3w77Wj+sFbi70CrBruUWH0uNcEdvLDixFpgA2JM4F4DBjA==",
+ "dev": true,
+ "requires": {
+ "@npmcli/fs": "^3.1.0",
+ "fs-minipass": "^3.0.0",
+ "glob": "^8.0.1",
+ "lru-cache": "^7.7.1",
+ "minipass": "^4.0.0",
+ "minipass-collect": "^1.0.2",
+ "minipass-flush": "^1.0.5",
+ "minipass-pipeline": "^1.2.4",
+ "p-map": "^4.0.0",
+ "promise-inflight": "^1.0.1",
+ "ssri": "^10.0.0",
+ "tar": "^6.1.11",
+ "unique-filename": "^3.0.0"
+ },
+ "dependencies": {
+ "lru-cache": {
+ "version": "7.14.1",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.14.1.tgz",
+ "integrity": "sha512-ysxwsnTKdAx96aTRdhDOCQfDgbHnt8SK0KY8SEjO0wHinhWOFTESbjVCMPbU1uGXg/ch4lifqx0wfjOawU2+WA==",
+ "dev": true
+ }
+ }
+ },
+ "call-bind": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz",
+ "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==",
+ "dev": true,
+ "requires": {
+ "function-bind": "^1.1.1",
+ "get-intrinsic": "^1.0.2"
+ }
+ },
+ "callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true
+ },
+ "camelcase": {
+ "version": "5.3.1",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz",
+ "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
+ "dev": true
+ },
+ "caniuse-lite": {
+ "version": "1.0.30001519",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001519.tgz",
+ "integrity": "sha512-0QHgqR+Jv4bxHMp8kZ1Kn8CH55OikjKJ6JmKkZYP1F3D7w+lnFXF70nG5eNfsZS89jadi5Ywy5UCSKLAglIRkg==",
+ "dev": true
+ },
+ "chalk": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
+ "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^3.2.1",
+ "escape-string-regexp": "^1.0.5",
+ "supports-color": "^5.3.0"
+ }
+ },
+ "chardet": {
+ "version": "0.7.0",
+ "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz",
+ "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==",
+ "dev": true
+ },
+ "chokidar": {
+ "version": "3.5.3",
+ "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz",
+ "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==",
+ "dev": true,
+ "requires": {
+ "anymatch": "~3.1.2",
+ "braces": "~3.0.2",
+ "fsevents": "~2.3.2",
+ "glob-parent": "~5.1.2",
+ "is-binary-path": "~2.1.0",
+ "is-glob": "~4.0.1",
+ "normalize-path": "~3.0.0",
+ "readdirp": "~3.6.0"
+ }
+ },
+ "chownr": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz",
+ "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==",
+ "dev": true
+ },
+ "chrome-trace-event": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz",
+ "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==",
+ "dev": true
+ },
+ "clean-stack": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz",
+ "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==",
+ "dev": true
+ },
+ "cli-cursor": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz",
+ "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==",
+ "dev": true,
+ "requires": {
+ "restore-cursor": "^3.1.0"
+ }
+ },
+ "cli-spinners": {
+ "version": "2.7.0",
+ "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.7.0.tgz",
+ "integrity": "sha512-qu3pN8Y3qHNgE2AFweciB1IfMnmZ/fsNTEE+NOFjmGB2F/7rLhnhzppvpCnN4FovtP26k8lHyy9ptEbNwWFLzw==",
+ "dev": true
+ },
+ "cli-width": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-3.0.0.tgz",
+ "integrity": "sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==",
+ "dev": true
+ },
+ "cliui": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz",
+ "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==",
+ "dev": true,
+ "requires": {
+ "string-width": "^4.2.0",
+ "strip-ansi": "^6.0.1",
+ "wrap-ansi": "^7.0.0"
+ }
+ },
+ "clone": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz",
+ "integrity": "sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg==",
+ "dev": true
+ },
+ "clone-deep": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz",
+ "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==",
+ "dev": true,
+ "requires": {
+ "is-plain-object": "^2.0.4",
+ "kind-of": "^6.0.2",
+ "shallow-clone": "^3.0.0"
+ }
+ },
+ "color-convert": {
+ "version": "1.9.3",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
+ "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
+ "dev": true,
+ "requires": {
+ "color-name": "1.1.3"
+ }
+ },
+ "color-name": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
+ "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==",
+ "dev": true
+ },
+ "color-support": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz",
+ "integrity": "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==",
+ "dev": true
+ },
+ "colorette": {
+ "version": "2.0.19",
+ "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.19.tgz",
+ "integrity": "sha512-3tlv/dIP7FWvj3BsbHrGLJ6l/oKh1O3TcgBqMn+yyCagOxc23fyzDS6HypQbgxWbkpDnf52p1LuR4eWDQ/K9WQ==",
+ "dev": true
+ },
+ "commander": {
+ "version": "2.20.3",
+ "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz",
+ "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==",
+ "dev": true
+ },
+ "commondir": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz",
+ "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==",
+ "dev": true
+ },
+ "compressible": {
+ "version": "2.0.18",
+ "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz",
+ "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==",
+ "dev": true,
+ "requires": {
+ "mime-db": ">= 1.43.0 < 2"
+ }
+ },
+ "compression": {
+ "version": "1.7.4",
+ "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz",
+ "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==",
+ "dev": true,
+ "requires": {
+ "accepts": "~1.3.5",
+ "bytes": "3.0.0",
+ "compressible": "~2.0.16",
+ "debug": "2.6.9",
+ "on-headers": "~1.0.2",
+ "safe-buffer": "5.1.2",
+ "vary": "~1.1.2"
+ },
+ "dependencies": {
+ "bytes": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz",
+ "integrity": "sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw==",
+ "dev": true
+ },
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "safe-buffer": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
+ "dev": true
+ }
+ }
+ },
+ "concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
+ "dev": true
+ },
+ "connect": {
+ "version": "3.7.0",
+ "resolved": "https://registry.npmjs.org/connect/-/connect-3.7.0.tgz",
+ "integrity": "sha512-ZqRXc+tZukToSNmh5C2iWMSoV3X1YUcPbqEM4DkEG5tNQXrQUZCNVGGv3IuicnkMtPfGf3Xtp8WCXs295iQ1pQ==",
+ "dev": true,
+ "requires": {
+ "debug": "2.6.9",
+ "finalhandler": "1.1.2",
+ "parseurl": "~1.3.3",
+ "utils-merge": "1.0.1"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ }
+ }
+ },
+ "connect-history-api-fallback": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-2.0.0.tgz",
+ "integrity": "sha512-U73+6lQFmfiNPrYbXqr6kZ1i1wiRqXnp2nhMsINseWXO8lDau0LGEffJ8kQi4EjLZympVgRdvqjAgiZ1tgzDDA==",
+ "dev": true
+ },
+ "console-control-strings": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz",
+ "integrity": "sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==",
+ "dev": true
+ },
+ "content-disposition": {
+ "version": "0.5.4",
+ "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
+ "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
+ "dev": true,
+ "requires": {
+ "safe-buffer": "5.2.1"
+ }
+ },
+ "content-type": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz",
+ "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==",
+ "dev": true
+ },
+ "convert-source-map": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz",
+ "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==",
+ "dev": true
+ },
+ "cookie": {
+ "version": "0.4.2",
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz",
+ "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==",
+ "dev": true
+ },
+ "cookie-signature": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
+ "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==",
+ "dev": true
+ },
+ "copy-anything": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/copy-anything/-/copy-anything-2.0.6.tgz",
+ "integrity": "sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==",
+ "dev": true,
+ "requires": {
+ "is-what": "^3.14.1"
+ }
+ },
+ "copy-webpack-plugin": {
+ "version": "11.0.0",
+ "resolved": "https://registry.npmjs.org/copy-webpack-plugin/-/copy-webpack-plugin-11.0.0.tgz",
+ "integrity": "sha512-fX2MWpamkW0hZxMEg0+mYnA40LTosOSa5TqZ9GYIBzyJa9C3QUaMPSE2xAi/buNr8u89SfD9wHSQVBzrRa/SOQ==",
+ "dev": true,
+ "requires": {
+ "fast-glob": "^3.2.11",
+ "glob-parent": "^6.0.1",
+ "globby": "^13.1.1",
+ "normalize-path": "^3.0.0",
+ "schema-utils": "^4.0.0",
+ "serialize-javascript": "^6.0.0"
+ },
+ "dependencies": {
+ "glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "requires": {
+ "is-glob": "^4.0.3"
+ }
+ }
+ }
+ },
+ "core-js-compat": {
+ "version": "3.27.1",
+ "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.27.1.tgz",
+ "integrity": "sha512-Dg91JFeCDA17FKnneN7oCMz4BkQ4TcffkgHP4OWwp9yx3pi7ubqMDXXSacfNak1PQqjc95skyt+YBLHQJnkJwA==",
+ "dev": true,
+ "requires": {
+ "browserslist": "^4.21.4"
+ }
+ },
+ "core-util-is": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz",
+ "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==",
+ "dev": true
+ },
+ "cors": {
+ "version": "2.8.5",
+ "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz",
+ "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==",
+ "dev": true,
+ "requires": {
+ "object-assign": "^4",
+ "vary": "^1"
+ }
+ },
+ "cosmiconfig": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.1.0.tgz",
+ "integrity": "sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==",
+ "dev": true,
+ "requires": {
+ "@types/parse-json": "^4.0.0",
+ "import-fresh": "^3.2.1",
+ "parse-json": "^5.0.0",
+ "path-type": "^4.0.0",
+ "yaml": "^1.10.0"
+ }
+ },
+ "critters": {
+ "version": "0.0.16",
+ "resolved": "https://registry.npmjs.org/critters/-/critters-0.0.16.tgz",
+ "integrity": "sha512-JwjgmO6i3y6RWtLYmXwO5jMd+maZt8Tnfu7VVISmEWyQqfLpB8soBswf8/2bu6SBXxtKA68Al3c+qIG1ApT68A==",
+ "dev": true,
+ "requires": {
+ "chalk": "^4.1.0",
+ "css-select": "^4.2.0",
+ "parse5": "^6.0.1",
+ "parse5-htmlparser2-tree-adapter": "^6.0.1",
+ "postcss": "^8.3.7",
+ "pretty-bytes": "^5.3.0"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^2.0.1"
+ }
+ },
+ "chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true
+ },
+ "parse5": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz",
+ "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "cross-spawn": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
+ "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
+ "dev": true,
+ "requires": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ },
+ "dependencies": {
+ "which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ }
+ }
+ },
+ "css-loader": {
+ "version": "6.7.3",
+ "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-6.7.3.tgz",
+ "integrity": "sha512-qhOH1KlBMnZP8FzRO6YCH9UHXQhVMcEGLyNdb7Hv2cpcmJbW0YrddO+tG1ab5nT41KpHIYGsbeHqxB9xPu1pKQ==",
+ "dev": true,
+ "requires": {
+ "icss-utils": "^5.1.0",
+ "postcss": "^8.4.19",
+ "postcss-modules-extract-imports": "^3.0.0",
+ "postcss-modules-local-by-default": "^4.0.0",
+ "postcss-modules-scope": "^3.0.0",
+ "postcss-modules-values": "^4.0.0",
+ "postcss-value-parser": "^4.2.0",
+ "semver": "^7.3.8"
+ }
+ },
+ "css-select": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.3.0.tgz",
+ "integrity": "sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==",
+ "dev": true,
+ "requires": {
+ "boolbase": "^1.0.0",
+ "css-what": "^6.0.1",
+ "domhandler": "^4.3.1",
+ "domutils": "^2.8.0",
+ "nth-check": "^2.0.1"
+ }
+ },
+ "css-what": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz",
+ "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==",
+ "dev": true
+ },
+ "cssesc": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz",
+ "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==",
+ "dev": true
+ },
+ "custom-event": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/custom-event/-/custom-event-1.0.1.tgz",
+ "integrity": "sha512-GAj5FOq0Hd+RsCGVJxZuKaIDXDf3h6GQoNEjFgbLLI/trgtavwUbSnZ5pVfg27DVCaWjIohryS0JFwIJyT2cMg==",
+ "dev": true
+ },
+ "date-format": {
+ "version": "4.0.14",
+ "resolved": "https://registry.npmjs.org/date-format/-/date-format-4.0.14.tgz",
+ "integrity": "sha512-39BOQLs9ZjKh0/patS9nrT8wc3ioX3/eA/zgbKNopnF2wCqJEoxywwwElATYvRsXdnOxA/OQeQoFZ3rFjVajhg==",
+ "dev": true
+ },
+ "debug": {
+ "version": "4.3.4",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
+ "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
+ "dev": true,
+ "requires": {
+ "ms": "2.1.2"
+ }
+ },
+ "default-gateway": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-6.0.3.tgz",
+ "integrity": "sha512-fwSOJsbbNzZ/CUFpqFBqYfYNLj1NbMPm8MMCIzHjC83iSJRBEGmDUxU+WP661BaBQImeC2yHwXtz+P/O9o+XEg==",
+ "dev": true,
+ "requires": {
+ "execa": "^5.0.0"
+ }
+ },
+ "defaults": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.4.tgz",
+ "integrity": "sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A==",
+ "dev": true,
+ "requires": {
+ "clone": "^1.0.2"
+ }
+ },
+ "define-lazy-prop": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz",
+ "integrity": "sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==",
+ "dev": true
+ },
+ "delegates": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz",
+ "integrity": "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==",
+ "dev": true
+ },
+ "depd": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz",
+ "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==",
+ "dev": true
+ },
+ "dependency-graph": {
+ "version": "0.11.0",
+ "resolved": "https://registry.npmjs.org/dependency-graph/-/dependency-graph-0.11.0.tgz",
+ "integrity": "sha512-JeMq7fEshyepOWDfcfHK06N3MhyPhz++vtqWhMT5O9A3K42rdsEDpfdVqjaqaAhsw6a+ZqeDvQVtD0hFHQWrzg==",
+ "dev": true
+ },
+ "destroy": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz",
+ "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==",
+ "dev": true
+ },
+ "detect-node": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.1.0.tgz",
+ "integrity": "sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==",
+ "dev": true
+ },
+ "di": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/di/-/di-0.0.1.tgz",
+ "integrity": "sha512-uJaamHkagcZtHPqCIHZxnFrXlunQXgBOsZSUOWwFw31QJCAbyTBoHMW75YOTur5ZNx8pIeAKgf6GWIgaqqiLhA==",
+ "dev": true
+ },
+ "dir-glob": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz",
+ "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==",
+ "dev": true,
+ "requires": {
+ "path-type": "^4.0.0"
+ }
+ },
+ "dns-equal": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/dns-equal/-/dns-equal-1.0.0.tgz",
+ "integrity": "sha512-z+paD6YUQsk+AbGCEM4PrOXSss5gd66QfcVBFTKR/HpFL9jCqikS94HYwKww6fQyO7IxrIIyUu+g0Ka9tUS2Cg==",
+ "dev": true
+ },
+ "dns-packet": {
+ "version": "5.4.0",
+ "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-5.4.0.tgz",
+ "integrity": "sha512-EgqGeaBB8hLiHLZtp/IbaDQTL8pZ0+IvwzSHA6d7VyMDM+B9hgddEMa9xjK5oYnw0ci0JQ6g2XCD7/f6cafU6g==",
+ "dev": true,
+ "requires": {
+ "@leichtgewicht/ip-codec": "^2.0.1"
+ }
+ },
+ "dom-serialize": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/dom-serialize/-/dom-serialize-2.2.1.tgz",
+ "integrity": "sha512-Yra4DbvoW7/Z6LBN560ZwXMjoNOSAN2wRsKFGc4iBeso+mpIA6qj1vfdf9HpMaKAqG6wXTy+1SYEzmNpKXOSsQ==",
+ "dev": true,
+ "requires": {
+ "custom-event": "~1.0.0",
+ "ent": "~2.2.0",
+ "extend": "^3.0.0",
+ "void-elements": "^2.0.0"
+ }
+ },
+ "dom-serializer": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.4.1.tgz",
+ "integrity": "sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==",
+ "dev": true,
+ "requires": {
+ "domelementtype": "^2.0.1",
+ "domhandler": "^4.2.0",
+ "entities": "^2.0.0"
+ }
+ },
+ "dom7": {
+ "version": "4.0.6",
+ "resolved": "https://registry.npmjs.org/dom7/-/dom7-4.0.6.tgz",
+ "integrity": "sha512-emjdpPLhpNubapLFdjNL9tP06Sr+GZkrIHEXLWvOGsytACUrkbeIdjO5g77m00BrHTznnlcNqgmn7pCN192TBA==",
+ "requires": {
+ "ssr-window": "^4.0.0"
+ }
+ },
+ "domelementtype": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz",
+ "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==",
+ "dev": true
+ },
+ "domhandler": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz",
+ "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==",
+ "dev": true,
+ "requires": {
+ "domelementtype": "^2.2.0"
+ }
+ },
+ "domutils": {
+ "version": "2.8.0",
+ "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz",
+ "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==",
+ "dev": true,
+ "requires": {
+ "dom-serializer": "^1.0.1",
+ "domelementtype": "^2.2.0",
+ "domhandler": "^4.2.0"
+ }
+ },
+ "eastasianwidth": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz",
+ "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==",
+ "dev": true
+ },
+ "echarts": {
+ "version": "5.4.1",
+ "resolved": "https://registry.npmjs.org/echarts/-/echarts-5.4.1.tgz",
+ "integrity": "sha512-9ltS3M2JB0w2EhcYjCdmtrJ+6haZcW6acBolMGIuf01Hql1yrIV01L1aRj7jsaaIULJslEP9Z3vKlEmnJaWJVQ==",
+ "requires": {
+ "tslib": "2.3.0",
+ "zrender": "5.4.1"
+ },
+ "dependencies": {
+ "tslib": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.0.tgz",
+ "integrity": "sha512-N82ooyxVNm6h1riLCoyS9e3fuJ3AMG2zIZs2Gd1ATcSFjSA23Q0fzjjZeh0jbJvWVDZ0cJT8yaNNaaXHzueNjg=="
+ }
+ }
+ },
+ "ee-first": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
+ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==",
+ "dev": true
+ },
+ "electron-to-chromium": {
+ "version": "1.4.284",
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz",
+ "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==",
+ "dev": true
+ },
+ "emoji-regex": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
+ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
+ "dev": true
+ },
+ "emojis-list": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz",
+ "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==",
+ "dev": true
+ },
+ "encodeurl": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
+ "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==",
+ "dev": true
+ },
+ "encoding": {
+ "version": "0.1.13",
+ "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz",
+ "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "iconv-lite": "^0.6.2"
+ },
+ "dependencies": {
+ "iconv-lite": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz",
+ "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "safer-buffer": ">= 2.1.2 < 3.0.0"
+ }
+ }
+ }
+ },
+ "engine.io": {
+ "version": "6.4.2",
+ "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-6.4.2.tgz",
+ "integrity": "sha512-FKn/3oMiJjrOEOeUub2WCox6JhxBXq/Zn3fZOMCBxKnNYtsdKjxhl7yR3fZhM9PV+rdE75SU5SYMc+2PGzo+Tg==",
+ "dev": true,
+ "requires": {
+ "@types/cookie": "^0.4.1",
+ "@types/cors": "^2.8.12",
+ "@types/node": ">=10.0.0",
+ "accepts": "~1.3.4",
+ "base64id": "2.0.0",
+ "cookie": "~0.4.1",
+ "cors": "~2.8.5",
+ "debug": "~4.3.1",
+ "engine.io-parser": "~5.0.3",
+ "ws": "~8.11.0"
+ }
+ },
+ "engine.io-parser": {
+ "version": "5.0.7",
+ "resolved": "https://registry.npmjs.org/engine.io-parser/-/engine.io-parser-5.0.7.tgz",
+ "integrity": "sha512-P+jDFbvK6lE3n1OL+q9KuzdOFWkkZ/cMV9gol/SbVfpyqfvrfrFTOFJ6fQm2VC3PZHlU3QPhVwmbsCnauHF2MQ==",
+ "dev": true
+ },
+ "enhanced-resolve": {
+ "version": "5.15.0",
+ "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.15.0.tgz",
+ "integrity": "sha512-LXYT42KJ7lpIKECr2mAXIaMldcNCh/7E0KBKOu4KSfkHmP+mZmSs+8V5gBAqisWBy0OO4W5Oyys0GO1Y8KtdKg==",
+ "dev": true,
+ "requires": {
+ "graceful-fs": "^4.2.4",
+ "tapable": "^2.2.0"
+ }
+ },
+ "ent": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/ent/-/ent-2.2.0.tgz",
+ "integrity": "sha512-GHrMyVZQWvTIdDtpiEXdHZnFQKzeO09apj8Cbl4pKWy4i0Oprcq17usfDt5aO63swf0JOeMWjWQE/LzgSRuWpA==",
+ "dev": true
+ },
+ "entities": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz",
+ "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==",
+ "dev": true
+ },
+ "env-paths": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz",
+ "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==",
+ "dev": true
+ },
+ "err-code": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/err-code/-/err-code-2.0.3.tgz",
+ "integrity": "sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA==",
+ "dev": true
+ },
+ "errno": {
+ "version": "0.1.8",
+ "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.8.tgz",
+ "integrity": "sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "prr": "~1.0.1"
+ }
+ },
+ "error-ex": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
+ "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
+ "dev": true,
+ "requires": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "es-module-lexer": {
+ "version": "0.9.3",
+ "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-0.9.3.tgz",
+ "integrity": "sha512-1HQ2M2sPtxwnvOvT1ZClHyQDiggdNjURWpY2we6aMKCQiUVxTmVs2UYPLIrD84sS+kMdUwfBSylbJPwNnBrnHQ==",
+ "dev": true
+ },
+ "esbuild": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.8.tgz",
+ "integrity": "sha512-g24ybC3fWhZddZK6R3uD2iF/RIPnRpwJAqLov6ouX3hMbY4+tKolP0VMF3zuIYCaXun+yHwS5IPQ91N2BT191g==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "@esbuild/android-arm": "0.17.8",
+ "@esbuild/android-arm64": "0.17.8",
+ "@esbuild/android-x64": "0.17.8",
+ "@esbuild/darwin-arm64": "0.17.8",
+ "@esbuild/darwin-x64": "0.17.8",
+ "@esbuild/freebsd-arm64": "0.17.8",
+ "@esbuild/freebsd-x64": "0.17.8",
+ "@esbuild/linux-arm": "0.17.8",
+ "@esbuild/linux-arm64": "0.17.8",
+ "@esbuild/linux-ia32": "0.17.8",
+ "@esbuild/linux-loong64": "0.17.8",
+ "@esbuild/linux-mips64el": "0.17.8",
+ "@esbuild/linux-ppc64": "0.17.8",
+ "@esbuild/linux-riscv64": "0.17.8",
+ "@esbuild/linux-s390x": "0.17.8",
+ "@esbuild/linux-x64": "0.17.8",
+ "@esbuild/netbsd-x64": "0.17.8",
+ "@esbuild/openbsd-x64": "0.17.8",
+ "@esbuild/sunos-x64": "0.17.8",
+ "@esbuild/win32-arm64": "0.17.8",
+ "@esbuild/win32-ia32": "0.17.8",
+ "@esbuild/win32-x64": "0.17.8"
+ }
+ },
+ "esbuild-wasm": {
+ "version": "0.17.8",
+ "resolved": "https://registry.npmjs.org/esbuild-wasm/-/esbuild-wasm-0.17.8.tgz",
+ "integrity": "sha512-zCmpxv95E0FuCmvdw1K836UHnj4EdiQnFfjTby35y3LAjRPtXMj3sbHDRHjbD8Mqg5lTwq3knacr/1qIFU51CQ==",
+ "dev": true
+ },
+ "escalade": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
+ "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
+ "dev": true
+ },
+ "escape-html": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
+ "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==",
+ "dev": true
+ },
+ "escape-string-regexp": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
+ "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
+ "dev": true
+ },
+ "eslint-scope": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz",
+ "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==",
+ "dev": true,
+ "requires": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^4.1.1"
+ }
+ },
+ "esprima": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz",
+ "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==",
+ "dev": true
+ },
+ "esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "requires": {
+ "estraverse": "^5.2.0"
+ },
+ "dependencies": {
+ "estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true
+ }
+ }
+ },
+ "estraverse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz",
+ "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==",
+ "dev": true
+ },
+ "esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true
+ },
+ "etag": {
+ "version": "1.8.1",
+ "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
+ "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==",
+ "dev": true
+ },
+ "eventemitter-asyncresource": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/eventemitter-asyncresource/-/eventemitter-asyncresource-1.0.0.tgz",
+ "integrity": "sha512-39F7TBIV0G7gTelxwbEqnwhp90eqCPON1k0NwNfwhgKn4Co4ybUbj2pECcXT0B3ztRKZ7Pw1JujUUgmQJHcVAQ==",
+ "dev": true
+ },
+ "eventemitter3": {
+ "version": "4.0.7",
+ "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz",
+ "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==",
+ "dev": true
+ },
+ "events": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz",
+ "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==",
+ "dev": true
+ },
+ "execa": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz",
+ "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==",
+ "dev": true,
+ "requires": {
+ "cross-spawn": "^7.0.3",
+ "get-stream": "^6.0.0",
+ "human-signals": "^2.1.0",
+ "is-stream": "^2.0.0",
+ "merge-stream": "^2.0.0",
+ "npm-run-path": "^4.0.1",
+ "onetime": "^5.1.2",
+ "signal-exit": "^3.0.3",
+ "strip-final-newline": "^2.0.0"
+ }
+ },
+ "exponential-backoff": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/exponential-backoff/-/exponential-backoff-3.1.1.tgz",
+ "integrity": "sha512-dX7e/LHVJ6W3DE1MHWi9S1EYzDESENfLrYohG2G++ovZrYOkm4Knwa0mc1cn84xJOR4KEU0WSchhLbd0UklbHw==",
+ "dev": true
+ },
+ "express": {
+ "version": "4.18.2",
+ "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz",
+ "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==",
+ "dev": true,
+ "requires": {
+ "accepts": "~1.3.8",
+ "array-flatten": "1.1.1",
+ "body-parser": "1.20.1",
+ "content-disposition": "0.5.4",
+ "content-type": "~1.0.4",
+ "cookie": "0.5.0",
+ "cookie-signature": "1.0.6",
+ "debug": "2.6.9",
+ "depd": "2.0.0",
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "etag": "~1.8.1",
+ "finalhandler": "1.2.0",
+ "fresh": "0.5.2",
+ "http-errors": "2.0.0",
+ "merge-descriptors": "1.0.1",
+ "methods": "~1.1.2",
+ "on-finished": "2.4.1",
+ "parseurl": "~1.3.3",
+ "path-to-regexp": "0.1.7",
+ "proxy-addr": "~2.0.7",
+ "qs": "6.11.0",
+ "range-parser": "~1.2.1",
+ "safe-buffer": "5.2.1",
+ "send": "0.18.0",
+ "serve-static": "1.15.0",
+ "setprototypeof": "1.2.0",
+ "statuses": "2.0.1",
+ "type-is": "~1.6.18",
+ "utils-merge": "1.0.1",
+ "vary": "~1.1.2"
+ },
+ "dependencies": {
+ "array-flatten": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
+ "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==",
+ "dev": true
+ },
+ "cookie": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz",
+ "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==",
+ "dev": true
+ },
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "finalhandler": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz",
+ "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==",
+ "dev": true,
+ "requires": {
+ "debug": "2.6.9",
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "on-finished": "2.4.1",
+ "parseurl": "~1.3.3",
+ "statuses": "2.0.1",
+ "unpipe": "~1.0.0"
+ }
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "statuses": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
+ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
+ "dev": true
+ }
+ }
+ },
+ "extend": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz",
+ "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==",
+ "dev": true
+ },
+ "external-editor": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz",
+ "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==",
+ "dev": true,
+ "requires": {
+ "chardet": "^0.7.0",
+ "iconv-lite": "^0.4.24",
+ "tmp": "^0.0.33"
+ }
+ },
+ "fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true
+ },
+ "fast-glob": {
+ "version": "3.2.12",
+ "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz",
+ "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==",
+ "dev": true,
+ "requires": {
+ "@nodelib/fs.stat": "^2.0.2",
+ "@nodelib/fs.walk": "^1.2.3",
+ "glob-parent": "^5.1.2",
+ "merge2": "^1.3.0",
+ "micromatch": "^4.0.4"
+ }
+ },
+ "fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true
+ },
+ "fastq": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz",
+ "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==",
+ "dev": true,
+ "requires": {
+ "reusify": "^1.0.4"
+ }
+ },
+ "faye-websocket": {
+ "version": "0.11.4",
+ "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz",
+ "integrity": "sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==",
+ "dev": true,
+ "requires": {
+ "websocket-driver": ">=0.5.1"
+ }
+ },
+ "figures": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz",
+ "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==",
+ "dev": true,
+ "requires": {
+ "escape-string-regexp": "^1.0.5"
+ }
+ },
+ "fill-range": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
+ "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
+ "dev": true,
+ "requires": {
+ "to-regex-range": "^5.0.1"
+ }
+ },
+ "finalhandler": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz",
+ "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==",
+ "dev": true,
+ "requires": {
+ "debug": "2.6.9",
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "on-finished": "~2.3.0",
+ "parseurl": "~1.3.3",
+ "statuses": "~1.5.0",
+ "unpipe": "~1.0.0"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "on-finished": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
+ "integrity": "sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==",
+ "dev": true,
+ "requires": {
+ "ee-first": "1.1.1"
+ }
+ }
+ }
+ },
+ "find-cache-dir": {
+ "version": "3.3.2",
+ "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz",
+ "integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==",
+ "dev": true,
+ "requires": {
+ "commondir": "^1.0.1",
+ "make-dir": "^3.0.2",
+ "pkg-dir": "^4.1.0"
+ }
+ },
+ "find-up": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
+ "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
+ "dev": true,
+ "requires": {
+ "locate-path": "^5.0.0",
+ "path-exists": "^4.0.0"
+ }
+ },
+ "flatted": {
+ "version": "3.2.7",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz",
+ "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==",
+ "dev": true
+ },
+ "follow-redirects": {
+ "version": "1.15.2",
+ "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.2.tgz",
+ "integrity": "sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==",
+ "dev": true
+ },
+ "foreground-child": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.1.1.tgz",
+ "integrity": "sha512-TMKDUnIte6bfb5nWv7V/caI169OHgvwjb7V4WkeUvbQQdjr5rWKqHFiKWb/fcOwB+CzBT+qbWjvj+DVwRskpIg==",
+ "dev": true,
+ "requires": {
+ "cross-spawn": "^7.0.0",
+ "signal-exit": "^4.0.1"
+ },
+ "dependencies": {
+ "signal-exit": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz",
+ "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==",
+ "dev": true
+ }
+ }
+ },
+ "forwarded": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
+ "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==",
+ "dev": true
+ },
+ "fraction.js": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz",
+ "integrity": "sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA==",
+ "dev": true
+ },
+ "fresh": {
+ "version": "0.5.2",
+ "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
+ "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==",
+ "dev": true
+ },
+ "fs-extra": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz",
+ "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==",
+ "dev": true,
+ "requires": {
+ "graceful-fs": "^4.2.0",
+ "jsonfile": "^4.0.0",
+ "universalify": "^0.1.0"
+ }
+ },
+ "fs-minipass": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-3.0.0.tgz",
+ "integrity": "sha512-EUojgQaSPy6sxcqcZgQv6TVF6jiKvurji3AxhAivs/Ep4O1UpS8TusaxpybfFHZ2skRhLqzk6WR8nqNYIMMDeA==",
+ "dev": true,
+ "requires": {
+ "minipass": "^4.0.0"
+ }
+ },
+ "fs-monkey": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/fs-monkey/-/fs-monkey-1.0.3.tgz",
+ "integrity": "sha512-cybjIfiiE+pTWicSCLFHSrXZ6EilF30oh91FDP9S2B051prEa7QWfrVTQm10/dDpswBDXZugPa1Ogu8Yh+HV0Q==",
+ "dev": true
+ },
+ "fs.realpath": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
+ "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==",
+ "dev": true
+ },
+ "fsevents": {
+ "version": "2.3.2",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
+ "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
+ "dev": true,
+ "optional": true
+ },
+ "function-bind": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
+ "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==",
+ "dev": true
+ },
+ "gauge": {
+ "version": "4.0.4",
+ "resolved": "https://registry.npmjs.org/gauge/-/gauge-4.0.4.tgz",
+ "integrity": "sha512-f9m+BEN5jkg6a0fZjleidjN51VE1X+mPFQ2DJ0uv1V39oCLCbsGe6yjbBnp7eK7z/+GAon99a3nHuqbuuthyPg==",
+ "dev": true,
+ "requires": {
+ "aproba": "^1.0.3 || ^2.0.0",
+ "color-support": "^1.1.3",
+ "console-control-strings": "^1.1.0",
+ "has-unicode": "^2.0.1",
+ "signal-exit": "^3.0.7",
+ "string-width": "^4.2.3",
+ "strip-ansi": "^6.0.1",
+ "wide-align": "^1.1.5"
+ }
+ },
+ "gensync": {
+ "version": "1.0.0-beta.2",
+ "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
+ "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
+ "dev": true
+ },
+ "get-caller-file": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
+ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
+ "dev": true
+ },
+ "get-intrinsic": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz",
+ "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==",
+ "dev": true,
+ "requires": {
+ "function-bind": "^1.1.1",
+ "has": "^1.0.3",
+ "has-symbols": "^1.0.3"
+ }
+ },
+ "get-package-type": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz",
+ "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==",
+ "dev": true
+ },
+ "get-stream": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz",
+ "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==",
+ "dev": true
+ },
+ "glob": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz",
+ "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==",
+ "dev": true,
+ "requires": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^5.0.1",
+ "once": "^1.3.0"
+ }
+ },
+ "glob-parent": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
+ "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
+ "dev": true,
+ "requires": {
+ "is-glob": "^4.0.1"
+ }
+ },
+ "glob-to-regexp": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz",
+ "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==",
+ "dev": true
+ },
+ "globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "dev": true
+ },
+ "globby": {
+ "version": "13.1.3",
+ "resolved": "https://registry.npmjs.org/globby/-/globby-13.1.3.tgz",
+ "integrity": "sha512-8krCNHXvlCgHDpegPzleMq07yMYTO2sXKASmZmquEYWEmCx6J5UTRbp5RwMJkTJGtcQ44YpiUYUiN0b9mzy8Bw==",
+ "dev": true,
+ "requires": {
+ "dir-glob": "^3.0.1",
+ "fast-glob": "^3.2.11",
+ "ignore": "^5.2.0",
+ "merge2": "^1.4.1",
+ "slash": "^4.0.0"
+ }
+ },
+ "graceful-fs": {
+ "version": "4.2.10",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz",
+ "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==",
+ "dev": true
+ },
+ "handle-thing": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/handle-thing/-/handle-thing-2.0.1.tgz",
+ "integrity": "sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==",
+ "dev": true
+ },
+ "has": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
+ "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
+ "dev": true,
+ "requires": {
+ "function-bind": "^1.1.1"
+ }
+ },
+ "has-flag": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
+ "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
+ "dev": true
+ },
+ "has-symbols": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
+ "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
+ "dev": true
+ },
+ "has-unicode": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz",
+ "integrity": "sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==",
+ "dev": true
+ },
+ "hdr-histogram-js": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/hdr-histogram-js/-/hdr-histogram-js-2.0.3.tgz",
+ "integrity": "sha512-Hkn78wwzWHNCp2uarhzQ2SGFLU3JY8SBDDd3TAABK4fc30wm+MuPOrg5QVFVfkKOQd6Bfz3ukJEI+q9sXEkK1g==",
+ "dev": true,
+ "requires": {
+ "@assemblyscript/loader": "^0.10.1",
+ "base64-js": "^1.2.0",
+ "pako": "^1.0.3"
+ }
+ },
+ "hdr-histogram-percentiles-obj": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/hdr-histogram-percentiles-obj/-/hdr-histogram-percentiles-obj-3.0.0.tgz",
+ "integrity": "sha512-7kIufnBqdsBGcSZLPJwqHT3yhk1QTsSlFsVD3kx5ixH/AlgBs9yM1q6DPhXZ8f8gtdqgh7N7/5btRLpQsS2gHw==",
+ "dev": true
+ },
+ "hosted-git-info": {
+ "version": "6.1.1",
+ "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-6.1.1.tgz",
+ "integrity": "sha512-r0EI+HBMcXadMrugk0GCQ+6BQV39PiWAZVfq7oIckeGiN7sjRGyQxPdft3nQekFTCQbYxLBH+/axZMeH8UX6+w==",
+ "dev": true,
+ "requires": {
+ "lru-cache": "^7.5.1"
+ },
+ "dependencies": {
+ "lru-cache": {
+ "version": "7.18.3",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz",
+ "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==",
+ "dev": true
+ }
+ }
+ },
+ "hpack.js": {
+ "version": "2.1.6",
+ "resolved": "https://registry.npmjs.org/hpack.js/-/hpack.js-2.1.6.tgz",
+ "integrity": "sha512-zJxVehUdMGIKsRaNt7apO2Gqp0BdqW5yaiGHXXmbpvxgBYVZnAql+BJb4RO5ad2MgpbZKn5G6nMnegrH1FcNYQ==",
+ "dev": true,
+ "requires": {
+ "inherits": "^2.0.1",
+ "obuf": "^1.0.0",
+ "readable-stream": "^2.0.1",
+ "wbuf": "^1.1.0"
+ },
+ "dependencies": {
+ "readable-stream": {
+ "version": "2.3.7",
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz",
+ "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==",
+ "dev": true,
+ "requires": {
+ "core-util-is": "~1.0.0",
+ "inherits": "~2.0.3",
+ "isarray": "~1.0.0",
+ "process-nextick-args": "~2.0.0",
+ "safe-buffer": "~5.1.1",
+ "string_decoder": "~1.1.1",
+ "util-deprecate": "~1.0.1"
+ }
+ },
+ "safe-buffer": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
+ "dev": true
+ },
+ "string_decoder": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
+ "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
+ "dev": true,
+ "requires": {
+ "safe-buffer": "~5.1.0"
+ }
+ }
+ }
+ },
+ "html-entities": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-2.3.3.tgz",
+ "integrity": "sha512-DV5Ln36z34NNTDgnz0EWGBLZENelNAtkiFA4kyNOG2tDI6Mz1uSWiq1wAKdyjnJwyDiDO7Fa2SO1CTxPXL8VxA==",
+ "dev": true
+ },
+ "html-escaper": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz",
+ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==",
+ "dev": true
+ },
+ "http-cache-semantics": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz",
+ "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==",
+ "dev": true
+ },
+ "http-deceiver": {
+ "version": "1.2.7",
+ "resolved": "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz",
+ "integrity": "sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw==",
+ "dev": true
+ },
+ "http-errors": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz",
+ "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==",
+ "dev": true,
+ "requires": {
+ "depd": "2.0.0",
+ "inherits": "2.0.4",
+ "setprototypeof": "1.2.0",
+ "statuses": "2.0.1",
+ "toidentifier": "1.0.1"
+ },
+ "dependencies": {
+ "statuses": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
+ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
+ "dev": true
+ }
+ }
+ },
+ "http-parser-js": {
+ "version": "0.5.8",
+ "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.8.tgz",
+ "integrity": "sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q==",
+ "dev": true
+ },
+ "http-proxy": {
+ "version": "1.18.1",
+ "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.18.1.tgz",
+ "integrity": "sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ==",
+ "dev": true,
+ "requires": {
+ "eventemitter3": "^4.0.0",
+ "follow-redirects": "^1.0.0",
+ "requires-port": "^1.0.0"
+ }
+ },
+ "http-proxy-agent": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz",
+ "integrity": "sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w==",
+ "dev": true,
+ "requires": {
+ "@tootallnate/once": "2",
+ "agent-base": "6",
+ "debug": "4"
+ }
+ },
+ "http-proxy-middleware": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-2.0.6.tgz",
+ "integrity": "sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw==",
+ "dev": true,
+ "requires": {
+ "@types/http-proxy": "^1.17.8",
+ "http-proxy": "^1.18.1",
+ "is-glob": "^4.0.1",
+ "is-plain-obj": "^3.0.0",
+ "micromatch": "^4.0.2"
+ }
+ },
+ "https-proxy-agent": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz",
+ "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==",
+ "dev": true,
+ "requires": {
+ "agent-base": "6",
+ "debug": "4"
+ }
+ },
+ "human-signals": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz",
+ "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==",
+ "dev": true
+ },
+ "humanize-ms": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/humanize-ms/-/humanize-ms-1.2.1.tgz",
+ "integrity": "sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ==",
+ "dev": true,
+ "requires": {
+ "ms": "^2.0.0"
+ }
+ },
+ "iconv-lite": {
+ "version": "0.4.24",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
+ "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
+ "dev": true,
+ "requires": {
+ "safer-buffer": ">= 2.1.2 < 3"
+ }
+ },
+ "icss-utils": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-5.1.0.tgz",
+ "integrity": "sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA==",
+ "dev": true
+ },
+ "ieee754": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
+ "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==",
+ "dev": true
+ },
+ "ignore": {
+ "version": "5.2.4",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz",
+ "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==",
+ "dev": true
+ },
+ "ignore-walk": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-6.0.3.tgz",
+ "integrity": "sha512-C7FfFoTA+bI10qfeydT8aZbvr91vAEU+2W5BZUlzPec47oNb07SsOfwYrtxuvOYdUApPP/Qlh4DtAO51Ekk2QA==",
+ "dev": true,
+ "requires": {
+ "minimatch": "^9.0.0"
+ },
+ "dependencies": {
+ "minimatch": {
+ "version": "9.0.3",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz",
+ "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^2.0.1"
+ }
+ }
+ }
+ },
+ "image-size": {
+ "version": "0.5.5",
+ "resolved": "https://registry.npmjs.org/image-size/-/image-size-0.5.5.tgz",
+ "integrity": "sha512-6TDAlDPZxUFCv+fuOkIoXT/V/f3Qbq8e37p+YOiYrUv3v9cc3/6x78VdfPgFVaB9dZYeLUfKgHRebpkm/oP2VQ==",
+ "dev": true,
+ "optional": true
+ },
+ "immutable": {
+ "version": "4.3.2",
+ "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.3.2.tgz",
+ "integrity": "sha512-oGXzbEDem9OOpDWZu88jGiYCvIsLHMvGw+8OXlpsvTFvIQplQbjg1B1cvKg8f7Hoch6+NGjpPsH1Fr+Mc2D1aA==",
+ "dev": true
+ },
+ "import-fresh": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
+ "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
+ "dev": true,
+ "requires": {
+ "parent-module": "^1.0.0",
+ "resolve-from": "^4.0.0"
+ },
+ "dependencies": {
+ "resolve-from": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
+ "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
+ "dev": true
+ }
+ }
+ },
+ "imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
+ "dev": true
+ },
+ "indent-string": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz",
+ "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==",
+ "dev": true
+ },
+ "inflight": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
+ "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==",
+ "dev": true,
+ "requires": {
+ "once": "^1.3.0",
+ "wrappy": "1"
+ }
+ },
+ "inherits": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==",
+ "dev": true
+ },
+ "ini": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/ini/-/ini-3.0.1.tgz",
+ "integrity": "sha512-it4HyVAUTKBc6m8e1iXWvXSTdndF7HbdN713+kvLrymxTaU4AUBWrJ4vEooP+V7fexnVD3LKcBshjGGPefSMUQ==",
+ "dev": true
+ },
+ "inquirer": {
+ "version": "8.2.4",
+ "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-8.2.4.tgz",
+ "integrity": "sha512-nn4F01dxU8VeKfq192IjLsxu0/OmMZ4Lg3xKAns148rCaXP6ntAoEkVYZThWjwON8AlzdZZi6oqnhNbxUG9hVg==",
+ "dev": true,
+ "requires": {
+ "ansi-escapes": "^4.2.1",
+ "chalk": "^4.1.1",
+ "cli-cursor": "^3.1.0",
+ "cli-width": "^3.0.0",
+ "external-editor": "^3.0.3",
+ "figures": "^3.0.0",
+ "lodash": "^4.17.21",
+ "mute-stream": "0.0.8",
+ "ora": "^5.4.1",
+ "run-async": "^2.4.0",
+ "rxjs": "^7.5.5",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0",
+ "through": "^2.3.6",
+ "wrap-ansi": "^7.0.0"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^2.0.1"
+ }
+ },
+ "chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true
+ },
+ "rxjs": {
+ "version": "7.8.0",
+ "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.0.tgz",
+ "integrity": "sha512-F2+gxDshqmIub1KdvZkaEfGDwLNpPvk9Fs6LD/MyQxNgMds/WH9OdDDXOmxUZpME+iSK3rQCctkL0DYyytUqMg==",
+ "dev": true,
+ "requires": {
+ "tslib": "^2.1.0"
+ }
+ },
+ "supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "ip": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ip/-/ip-2.0.0.tgz",
+ "integrity": "sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==",
+ "dev": true
+ },
+ "ipaddr.js": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-2.0.1.tgz",
+ "integrity": "sha512-1qTgH9NG+IIJ4yfKs2e6Pp1bZg8wbDbKHT21HrLIeYBTRLgMYKnMTPAuI3Lcs61nfx5h1xlXnbJtH1kX5/d/ng==",
+ "dev": true
+ },
+ "is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
+ "dev": true
+ },
+ "is-binary-path": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz",
+ "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==",
+ "dev": true,
+ "requires": {
+ "binary-extensions": "^2.0.0"
+ }
+ },
+ "is-core-module": {
+ "version": "2.11.0",
+ "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz",
+ "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==",
+ "dev": true,
+ "requires": {
+ "has": "^1.0.3"
+ }
+ },
+ "is-docker": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz",
+ "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==",
+ "dev": true
+ },
+ "is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
+ "dev": true
+ },
+ "is-fullwidth-code-point": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
+ "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
+ "dev": true
+ },
+ "is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "dev": true,
+ "requires": {
+ "is-extglob": "^2.1.1"
+ }
+ },
+ "is-interactive": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-interactive/-/is-interactive-1.0.0.tgz",
+ "integrity": "sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w==",
+ "dev": true
+ },
+ "is-lambda": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/is-lambda/-/is-lambda-1.0.1.tgz",
+ "integrity": "sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ==",
+ "dev": true
+ },
+ "is-number": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
+ "dev": true
+ },
+ "is-plain-obj": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-3.0.0.tgz",
+ "integrity": "sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA==",
+ "dev": true
+ },
+ "is-plain-object": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz",
+ "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==",
+ "dev": true,
+ "requires": {
+ "isobject": "^3.0.1"
+ }
+ },
+ "is-stream": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz",
+ "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==",
+ "dev": true
+ },
+ "is-unicode-supported": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz",
+ "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==",
+ "dev": true
+ },
+ "is-what": {
+ "version": "3.14.1",
+ "resolved": "https://registry.npmjs.org/is-what/-/is-what-3.14.1.tgz",
+ "integrity": "sha512-sNxgpk9793nzSs7bA6JQJGeIuRBQhAaNGG77kzYQgMkrID+lS6SlK07K5LaptscDlSaIgH+GPFzf+d75FVxozA==",
+ "dev": true
+ },
+ "is-wsl": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz",
+ "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==",
+ "dev": true,
+ "requires": {
+ "is-docker": "^2.0.0"
+ }
+ },
+ "isarray": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
+ "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==",
+ "dev": true
+ },
+ "isbinaryfile": {
+ "version": "4.0.10",
+ "resolved": "https://registry.npmjs.org/isbinaryfile/-/isbinaryfile-4.0.10.tgz",
+ "integrity": "sha512-iHrqe5shvBUcFbmZq9zOQHBoeOhZJu6RQGrDpBgenUm/Am+F3JM2MgQj+rK3Z601fzrL5gLZWtAPH2OBaSVcyw==",
+ "dev": true
+ },
+ "isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
+ "dev": true
+ },
+ "isobject": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz",
+ "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==",
+ "dev": true
+ },
+ "istanbul-lib-coverage": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz",
+ "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==",
+ "dev": true
+ },
+ "istanbul-lib-instrument": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz",
+ "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==",
+ "dev": true,
+ "requires": {
+ "@babel/core": "^7.12.3",
+ "@babel/parser": "^7.14.7",
+ "@istanbuljs/schema": "^0.1.2",
+ "istanbul-lib-coverage": "^3.2.0",
+ "semver": "^6.3.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ },
+ "istanbul-lib-report": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz",
+ "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==",
+ "dev": true,
+ "requires": {
+ "istanbul-lib-coverage": "^3.0.0",
+ "make-dir": "^3.0.0",
+ "supports-color": "^7.1.0"
+ },
+ "dependencies": {
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "istanbul-lib-source-maps": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz",
+ "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==",
+ "dev": true,
+ "requires": {
+ "debug": "^4.1.1",
+ "istanbul-lib-coverage": "^3.0.0",
+ "source-map": "^0.6.1"
+ },
+ "dependencies": {
+ "source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true
+ }
+ }
+ },
+ "istanbul-reports": {
+ "version": "3.1.5",
+ "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz",
+ "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==",
+ "dev": true,
+ "requires": {
+ "html-escaper": "^2.0.0",
+ "istanbul-lib-report": "^3.0.0"
+ }
+ },
+ "jackspeak": {
+ "version": "2.2.2",
+ "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.2.2.tgz",
+ "integrity": "sha512-mgNtVv4vUuaKA97yxUHoA3+FkuhtxkjdXEWOyB/N76fjy0FjezEt34oy3epBtvCvS+7DyKwqCFWx/oJLV5+kCg==",
+ "dev": true,
+ "requires": {
+ "@isaacs/cliui": "^8.0.2",
+ "@pkgjs/parseargs": "^0.11.0"
+ }
+ },
+ "jasmine-core": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-4.5.0.tgz",
+ "integrity": "sha512-9PMzyvhtocxb3aXJVOPqBDswdgyAeSB81QnLop4npOpbqnheaTEwPc9ZloQeVswugPManznQBjD8kWDTjlnHuw==",
+ "dev": true
+ },
+ "jest-worker": {
+ "version": "27.5.1",
+ "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz",
+ "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*",
+ "merge-stream": "^2.0.0",
+ "supports-color": "^8.0.0"
+ },
+ "dependencies": {
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "8.1.1",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz",
+ "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
+ "dev": true
+ },
+ "js-yaml": {
+ "version": "3.14.1",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz",
+ "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==",
+ "dev": true,
+ "requires": {
+ "argparse": "^1.0.7",
+ "esprima": "^4.0.0"
+ }
+ },
+ "jsesc": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
+ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
+ "dev": true
+ },
+ "json-parse-even-better-errors": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
+ "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
+ "dev": true
+ },
+ "json-schema-traverse": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz",
+ "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==",
+ "dev": true
+ },
+ "json5": {
+ "version": "2.2.3",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
+ "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
+ "dev": true
+ },
+ "jsonc-parser": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.2.0.tgz",
+ "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==",
+ "dev": true
+ },
+ "jsonfile": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz",
+ "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==",
+ "dev": true,
+ "requires": {
+ "graceful-fs": "^4.1.6"
+ }
+ },
+ "jsonparse": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz",
+ "integrity": "sha512-POQXvpdL69+CluYsillJ7SUhKvytYjW9vG/GKpnf+xP8UWgYEM/RaMzHHofbALDiKbbP1W8UEYmgGl39WkPZsg==",
+ "dev": true
+ },
+ "karma": {
+ "version": "6.4.1",
+ "resolved": "https://registry.npmjs.org/karma/-/karma-6.4.1.tgz",
+ "integrity": "sha512-Cj57NKOskK7wtFWSlMvZf459iX+kpYIPXmkNUzP2WAFcA7nhr/ALn5R7sw3w+1udFDcpMx/tuB8d5amgm3ijaA==",
+ "dev": true,
+ "requires": {
+ "@colors/colors": "1.5.0",
+ "body-parser": "^1.19.0",
+ "braces": "^3.0.2",
+ "chokidar": "^3.5.1",
+ "connect": "^3.7.0",
+ "di": "^0.0.1",
+ "dom-serialize": "^2.2.1",
+ "glob": "^7.1.7",
+ "graceful-fs": "^4.2.6",
+ "http-proxy": "^1.18.1",
+ "isbinaryfile": "^4.0.8",
+ "lodash": "^4.17.21",
+ "log4js": "^6.4.1",
+ "mime": "^2.5.2",
+ "minimatch": "^3.0.4",
+ "mkdirp": "^0.5.5",
+ "qjobs": "^1.2.0",
+ "range-parser": "^1.2.1",
+ "rimraf": "^3.0.2",
+ "socket.io": "^4.4.1",
+ "source-map": "^0.6.1",
+ "tmp": "^0.2.1",
+ "ua-parser-js": "^0.7.30",
+ "yargs": "^16.1.1"
+ },
+ "dependencies": {
+ "brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "requires": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "cliui": {
+ "version": "7.0.4",
+ "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz",
+ "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==",
+ "dev": true,
+ "requires": {
+ "string-width": "^4.2.0",
+ "strip-ansi": "^6.0.0",
+ "wrap-ansi": "^7.0.0"
+ }
+ },
+ "glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "requires": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ }
+ },
+ "minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^1.1.7"
+ }
+ },
+ "source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true
+ },
+ "tmp": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.2.1.tgz",
+ "integrity": "sha512-76SUhtfqR2Ijn+xllcI5P1oyannHNHByD80W1q447gU3mp9G9PSpGdWmjUOHRDPiHYacIk66W7ubDTuPF3BEtQ==",
+ "dev": true,
+ "requires": {
+ "rimraf": "^3.0.0"
+ }
+ },
+ "yargs": {
+ "version": "16.2.0",
+ "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz",
+ "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==",
+ "dev": true,
+ "requires": {
+ "cliui": "^7.0.2",
+ "escalade": "^3.1.1",
+ "get-caller-file": "^2.0.5",
+ "require-directory": "^2.1.1",
+ "string-width": "^4.2.0",
+ "y18n": "^5.0.5",
+ "yargs-parser": "^20.2.2"
+ }
+ },
+ "yargs-parser": {
+ "version": "20.2.9",
+ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz",
+ "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==",
+ "dev": true
+ }
+ }
+ },
+ "karma-chrome-launcher": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/karma-chrome-launcher/-/karma-chrome-launcher-3.1.1.tgz",
+ "integrity": "sha512-hsIglcq1vtboGPAN+DGCISCFOxW+ZVnIqhDQcCMqqCp+4dmJ0Qpq5QAjkbA0X2L9Mi6OBkHi2Srrbmm7pUKkzQ==",
+ "dev": true,
+ "requires": {
+ "which": "^1.2.1"
+ }
+ },
+ "karma-coverage": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/karma-coverage/-/karma-coverage-2.2.0.tgz",
+ "integrity": "sha512-gPVdoZBNDZ08UCzdMHHhEImKrw1+PAOQOIiffv1YsvxFhBjqvo/SVXNk4tqn1SYqX0BJZT6S/59zgxiBe+9OuA==",
+ "dev": true,
+ "requires": {
+ "istanbul-lib-coverage": "^3.2.0",
+ "istanbul-lib-instrument": "^5.1.0",
+ "istanbul-lib-report": "^3.0.0",
+ "istanbul-lib-source-maps": "^4.0.1",
+ "istanbul-reports": "^3.0.5",
+ "minimatch": "^3.0.4"
+ },
+ "dependencies": {
+ "brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "requires": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^1.1.7"
+ }
+ }
+ }
+ },
+ "karma-jasmine": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/karma-jasmine/-/karma-jasmine-4.0.2.tgz",
+ "integrity": "sha512-ggi84RMNQffSDmWSyyt4zxzh2CQGwsxvYYsprgyR1j8ikzIduEdOlcLvXjZGwXG/0j41KUXOWsUCBfbEHPWP9g==",
+ "dev": true,
+ "requires": {
+ "jasmine-core": "^3.6.0"
+ },
+ "dependencies": {
+ "jasmine-core": {
+ "version": "3.99.1",
+ "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-3.99.1.tgz",
+ "integrity": "sha512-Hu1dmuoGcZ7AfyynN3LsfruwMbxMALMka+YtZeGoLuDEySVmVAPaonkNoBRIw/ectu8b9tVQCJNgp4a4knp+tg==",
+ "dev": true
+ }
+ }
+ },
+ "karma-jasmine-html-reporter": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/karma-jasmine-html-reporter/-/karma-jasmine-html-reporter-1.7.0.tgz",
+ "integrity": "sha512-pzum1TL7j90DTE86eFt48/s12hqwQuiD+e5aXx2Dc9wDEn2LfGq6RoAxEZZjFiN0RDSCOnosEKRZWxbQ+iMpQQ==",
+ "dev": true
+ },
+ "karma-source-map-support": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/karma-source-map-support/-/karma-source-map-support-1.4.0.tgz",
+ "integrity": "sha512-RsBECncGO17KAoJCYXjv+ckIz+Ii9NCi+9enk+rq6XC81ezYkb4/RHE6CTXdA7IOJqoF3wcaLfVG0CPmE5ca6A==",
+ "dev": true,
+ "requires": {
+ "source-map-support": "^0.5.5"
+ }
+ },
+ "kind-of": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
+ "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
+ "dev": true
+ },
+ "klona": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/klona/-/klona-2.0.5.tgz",
+ "integrity": "sha512-pJiBpiXMbt7dkzXe8Ghj/u4FfXOOa98fPW+bihOJ4SjnoijweJrNThJfd3ifXpXhREjpoF2mZVH1GfS9LV3kHQ==",
+ "dev": true
+ },
+ "less": {
+ "version": "4.1.3",
+ "resolved": "https://registry.npmjs.org/less/-/less-4.1.3.tgz",
+ "integrity": "sha512-w16Xk/Ta9Hhyei0Gpz9m7VS8F28nieJaL/VyShID7cYvP6IL5oHeL6p4TXSDJqZE/lNv0oJ2pGVjJsRkfwm5FA==",
+ "dev": true,
+ "requires": {
+ "copy-anything": "^2.0.1",
+ "errno": "^0.1.1",
+ "graceful-fs": "^4.1.2",
+ "image-size": "~0.5.0",
+ "make-dir": "^2.1.0",
+ "mime": "^1.4.1",
+ "needle": "^3.1.0",
+ "parse-node-version": "^1.0.1",
+ "source-map": "~0.6.0",
+ "tslib": "^2.3.0"
+ },
+ "dependencies": {
+ "make-dir": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz",
+ "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "pify": "^4.0.1",
+ "semver": "^5.6.0"
+ }
+ },
+ "mime": {
+ "version": "1.6.0",
+ "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
+ "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
+ "dev": true,
+ "optional": true
+ },
+ "semver": {
+ "version": "5.7.2",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz",
+ "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==",
+ "dev": true,
+ "optional": true
+ },
+ "source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true,
+ "optional": true
+ }
+ }
+ },
+ "less-loader": {
+ "version": "11.1.0",
+ "resolved": "https://registry.npmjs.org/less-loader/-/less-loader-11.1.0.tgz",
+ "integrity": "sha512-C+uDBV7kS7W5fJlUjq5mPBeBVhYpTIm5gB09APT9o3n/ILeaXVsiSFTbZpTJCJwQ/Crczfn3DmfQFwxYusWFug==",
+ "dev": true,
+ "requires": {
+ "klona": "^2.0.4"
+ }
+ },
+ "license-webpack-plugin": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/license-webpack-plugin/-/license-webpack-plugin-4.0.2.tgz",
+ "integrity": "sha512-771TFWFD70G1wLTC4oU2Cw4qvtmNrIw+wRvBtn+okgHl7slJVi7zfNcdmqDL72BojM30VNJ2UHylr1o77U37Jw==",
+ "dev": true,
+ "requires": {
+ "webpack-sources": "^3.0.0"
+ }
+ },
+ "lines-and-columns": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
+ "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==",
+ "dev": true
+ },
+ "loader-runner": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.3.0.tgz",
+ "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==",
+ "dev": true
+ },
+ "loader-utils": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.2.1.tgz",
+ "integrity": "sha512-ZvFw1KWS3GVyYBYb7qkmRM/WwL2TQQBxgCK62rlvm4WpVQ23Nb4tYjApUlfjrEGvOs7KHEsmyUn75OHZrJMWPw==",
+ "dev": true
+ },
+ "locate-path": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
+ "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
+ "dev": true,
+ "requires": {
+ "p-locate": "^4.1.0"
+ }
+ },
+ "lodash": {
+ "version": "4.17.21",
+ "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
+ "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==",
+ "dev": true
+ },
+ "lodash.debounce": {
+ "version": "4.0.8",
+ "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz",
+ "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==",
+ "dev": true
+ },
+ "log-symbols": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz",
+ "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==",
+ "dev": true,
+ "requires": {
+ "chalk": "^4.1.0",
+ "is-unicode-supported": "^0.1.0"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^2.0.1"
+ }
+ },
+ "chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "log4js": {
+ "version": "6.7.1",
+ "resolved": "https://registry.npmjs.org/log4js/-/log4js-6.7.1.tgz",
+ "integrity": "sha512-lzbd0Eq1HRdWM2abSD7mk6YIVY0AogGJzb/z+lqzRk+8+XJP+M6L1MS5FUSc3jjGru4dbKjEMJmqlsoYYpuivQ==",
+ "dev": true,
+ "requires": {
+ "date-format": "^4.0.14",
+ "debug": "^4.3.4",
+ "flatted": "^3.2.7",
+ "rfdc": "^1.3.0",
+ "streamroller": "^3.1.3"
+ }
+ },
+ "lru-cache": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz",
+ "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
+ "dev": true,
+ "requires": {
+ "yallist": "^3.0.2"
+ }
+ },
+ "magic-string": {
+ "version": "0.27.0",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.27.0.tgz",
+ "integrity": "sha512-8UnnX2PeRAPZuN12svgR9j7M1uWMovg/CEnIwIG0LFkXSJJe4PdfUGiTGl8V9bsBHFUtfVINcSyYxd7q+kx9fA==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/sourcemap-codec": "^1.4.13"
+ }
+ },
+ "make-dir": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
+ "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
+ "dev": true,
+ "requires": {
+ "semver": "^6.0.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true
+ }
+ }
+ },
+ "make-fetch-happen": {
+ "version": "11.1.1",
+ "resolved": "https://registry.npmjs.org/make-fetch-happen/-/make-fetch-happen-11.1.1.tgz",
+ "integrity": "sha512-rLWS7GCSTcEujjVBs2YqG7Y4643u8ucvCJeSRqiLYhesrDuzeuFIk37xREzAsfQaqzl8b9rNCE4m6J8tvX4Q8w==",
+ "dev": true,
+ "requires": {
+ "agentkeepalive": "^4.2.1",
+ "cacache": "^17.0.0",
+ "http-cache-semantics": "^4.1.1",
+ "http-proxy-agent": "^5.0.0",
+ "https-proxy-agent": "^5.0.0",
+ "is-lambda": "^1.0.1",
+ "lru-cache": "^7.7.1",
+ "minipass": "^5.0.0",
+ "minipass-fetch": "^3.0.0",
+ "minipass-flush": "^1.0.5",
+ "minipass-pipeline": "^1.2.4",
+ "negotiator": "^0.6.3",
+ "promise-retry": "^2.0.1",
+ "socks-proxy-agent": "^7.0.0",
+ "ssri": "^10.0.0"
+ },
+ "dependencies": {
+ "lru-cache": {
+ "version": "7.18.3",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz",
+ "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==",
+ "dev": true
+ },
+ "minipass": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz",
+ "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==",
+ "dev": true
+ }
+ }
+ },
+ "media-typer": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
+ "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==",
+ "dev": true
+ },
+ "memfs": {
+ "version": "3.4.13",
+ "resolved": "https://registry.npmjs.org/memfs/-/memfs-3.4.13.tgz",
+ "integrity": "sha512-omTM41g3Skpvx5dSYeZIbXKcXoAVc/AoMNwn9TKx++L/gaen/+4TTttmu8ZSch5vfVJ8uJvGbroTsIlslRg6lg==",
+ "dev": true,
+ "requires": {
+ "fs-monkey": "^1.0.3"
+ }
+ },
+ "merge-descriptors": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
+ "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==",
+ "dev": true
+ },
+ "merge-stream": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
+ "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
+ "dev": true
+ },
+ "merge2": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
+ "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==",
+ "dev": true
+ },
+ "methods": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
+ "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==",
+ "dev": true
+ },
+ "micromatch": {
+ "version": "4.0.5",
+ "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
+ "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==",
+ "dev": true,
+ "requires": {
+ "braces": "^3.0.2",
+ "picomatch": "^2.3.1"
+ }
+ },
+ "mime": {
+ "version": "2.6.0",
+ "resolved": "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz",
+ "integrity": "sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg==",
+ "dev": true
+ },
+ "mime-db": {
+ "version": "1.52.0",
+ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
+ "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
+ "dev": true
+ },
+ "mime-types": {
+ "version": "2.1.35",
+ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
+ "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
+ "dev": true,
+ "requires": {
+ "mime-db": "1.52.0"
+ }
+ },
+ "mimic-fn": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
+ "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
+ "dev": true
+ },
+ "mini-css-extract-plugin": {
+ "version": "2.7.2",
+ "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.7.2.tgz",
+ "integrity": "sha512-EdlUizq13o0Pd+uCp+WO/JpkLvHRVGt97RqfeGhXqAcorYo1ypJSpkV+WDT0vY/kmh/p7wRdJNJtuyK540PXDw==",
+ "dev": true,
+ "requires": {
+ "schema-utils": "^4.0.0"
+ }
+ },
+ "minimalistic-assert": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz",
+ "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==",
+ "dev": true
+ },
+ "minimatch": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.2.tgz",
+ "integrity": "sha512-bNH9mmM9qsJ2X4r2Nat1B//1dJVcn3+iBLa3IgqJ7EbGaDNepL9QSHOxN4ng33s52VMMhhIfgCYDk3C4ZmlDAg==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^2.0.1"
+ }
+ },
+ "minimist": {
+ "version": "1.2.7",
+ "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.7.tgz",
+ "integrity": "sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g==",
+ "dev": true
+ },
+ "minipass": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-4.0.0.tgz",
+ "integrity": "sha512-g2Uuh2jEKoht+zvO6vJqXmYpflPqzRBT+Th2h01DKh5z7wbY/AZ2gCQ78cP70YoHPyFdY30YBV5WxgLOEwOykw==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ },
+ "dependencies": {
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "minipass-collect": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/minipass-collect/-/minipass-collect-1.0.2.tgz",
+ "integrity": "sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA==",
+ "dev": true,
+ "requires": {
+ "minipass": "^3.0.0"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "minipass-fetch": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/minipass-fetch/-/minipass-fetch-3.0.3.tgz",
+ "integrity": "sha512-n5ITsTkDqYkYJZjcRWzZt9qnZKCT7nKCosJhHoj7S7zD+BP4jVbWs+odsniw5TA3E0sLomhTKOKjF86wf11PuQ==",
+ "dev": true,
+ "requires": {
+ "encoding": "^0.1.13",
+ "minipass": "^5.0.0",
+ "minipass-sized": "^1.0.3",
+ "minizlib": "^2.1.2"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz",
+ "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==",
+ "dev": true
+ }
+ }
+ },
+ "minipass-flush": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz",
+ "integrity": "sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw==",
+ "dev": true,
+ "requires": {
+ "minipass": "^3.0.0"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "minipass-json-stream": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/minipass-json-stream/-/minipass-json-stream-1.0.1.tgz",
+ "integrity": "sha512-ODqY18UZt/I8k+b7rl2AENgbWE8IDYam+undIJONvigAz8KR5GWblsFTEfQs0WODsjbSXWlm+JHEv8Gr6Tfdbg==",
+ "dev": true,
+ "requires": {
+ "jsonparse": "^1.3.1",
+ "minipass": "^3.0.0"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "minipass-pipeline": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz",
+ "integrity": "sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A==",
+ "dev": true,
+ "requires": {
+ "minipass": "^3.0.0"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "minipass-sized": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/minipass-sized/-/minipass-sized-1.0.3.tgz",
+ "integrity": "sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g==",
+ "dev": true,
+ "requires": {
+ "minipass": "^3.0.0"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "minizlib": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz",
+ "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==",
+ "dev": true,
+ "requires": {
+ "minipass": "^3.0.0",
+ "yallist": "^4.0.0"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "mkdirp": {
+ "version": "0.5.6",
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz",
+ "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==",
+ "dev": true,
+ "requires": {
+ "minimist": "^1.2.6"
+ }
+ },
+ "ms": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
+ "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
+ "dev": true
+ },
+ "multicast-dns": {
+ "version": "7.2.5",
+ "resolved": "https://registry.npmjs.org/multicast-dns/-/multicast-dns-7.2.5.tgz",
+ "integrity": "sha512-2eznPJP8z2BFLX50tf0LuODrpINqP1RVIm/CObbTcBRITQgmC/TjcREF1NeTBzIcR5XO/ukWo+YHOjBbFwIupg==",
+ "dev": true,
+ "requires": {
+ "dns-packet": "^5.2.2",
+ "thunky": "^1.0.2"
+ }
+ },
+ "mute-stream": {
+ "version": "0.0.8",
+ "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz",
+ "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==",
+ "dev": true
+ },
+ "nanoid": {
+ "version": "3.3.4",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz",
+ "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==",
+ "dev": true
+ },
+ "needle": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/needle/-/needle-3.2.0.tgz",
+ "integrity": "sha512-oUvzXnyLiVyVGoianLijF9O/RecZUf7TkBfimjGrLM4eQhXyeJwM6GeAWccwfQ9aa4gMCZKqhAOuLaMIcQxajQ==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "debug": "^3.2.6",
+ "iconv-lite": "^0.6.3",
+ "sax": "^1.2.4"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "3.2.7",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz",
+ "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "ms": "^2.1.1"
+ }
+ },
+ "iconv-lite": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz",
+ "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "safer-buffer": ">= 2.1.2 < 3.0.0"
+ }
+ }
+ }
+ },
+ "negotiator": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz",
+ "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==",
+ "dev": true
+ },
+ "neo-async": {
+ "version": "2.6.2",
+ "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz",
+ "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==",
+ "dev": true
+ },
+ "ngx-echarts": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmjs.org/ngx-echarts/-/ngx-echarts-8.0.1.tgz",
+ "integrity": "sha512-CP+WnCcnMCNpCL9BVmDIZmhGSVPnkJhhFbQEKt0nrwV0L6d4QTAGZ+e4y6G1zTTFKkIMPHpaO0nhtDRgSXAW/w==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "ngx-sortablejs": {
+ "version": "11.1.0",
+ "resolved": "https://registry.npmjs.org/ngx-sortablejs/-/ngx-sortablejs-11.1.0.tgz",
+ "integrity": "sha512-eM4dHwWSmXDcvF5gUmyMMQ0qqcqBXWCSZ9IRpqx4UkBKfo4N7pk/QuYh5io2fXVHWVFDaxW1yhn2FNpqxV6Jqw==",
+ "requires": {
+ "tslib": "^2.0.0"
+ }
+ },
+ "nice-napi": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/nice-napi/-/nice-napi-1.0.2.tgz",
+ "integrity": "sha512-px/KnJAJZf5RuBGcfD+Sp2pAKq0ytz8j+1NehvgIGFkvtvFrDM3T8E4x/JJODXK9WZow8RRGrbA9QQ3hs+pDhA==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "node-addon-api": "^3.0.0",
+ "node-gyp-build": "^4.2.2"
+ }
+ },
+ "node-addon-api": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.2.1.tgz",
+ "integrity": "sha512-mmcei9JghVNDYydghQmeDX8KoAm0FAiYyIcUt/N4nhyAipB17pllZQDOJD2fotxABnt4Mdz+dKTO7eftLg4d0A==",
+ "dev": true,
+ "optional": true
+ },
+ "node-forge": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz",
+ "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==",
+ "dev": true
+ },
+ "node-gyp": {
+ "version": "9.4.0",
+ "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-9.4.0.tgz",
+ "integrity": "sha512-dMXsYP6gc9rRbejLXmTbVRYjAHw7ppswsKyMxuxJxxOHzluIO1rGp9TOQgjFJ+2MCqcOcQTOPB/8Xwhr+7s4Eg==",
+ "dev": true,
+ "requires": {
+ "env-paths": "^2.2.0",
+ "exponential-backoff": "^3.1.1",
+ "glob": "^7.1.4",
+ "graceful-fs": "^4.2.6",
+ "make-fetch-happen": "^11.0.3",
+ "nopt": "^6.0.0",
+ "npmlog": "^6.0.0",
+ "rimraf": "^3.0.2",
+ "semver": "^7.3.5",
+ "tar": "^6.1.2",
+ "which": "^2.0.2"
+ },
+ "dependencies": {
+ "brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "requires": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "requires": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ }
+ },
+ "minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^1.1.7"
+ }
+ },
+ "which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ }
+ }
+ },
+ "node-gyp-build": {
+ "version": "4.6.0",
+ "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.6.0.tgz",
+ "integrity": "sha512-NTZVKn9IylLwUzaKjkas1e4u2DLNcV4rdYagA4PWdPwW87Bi7z+BznyKSRwS/761tV/lzCGXplWsiaMjLqP2zQ==",
+ "dev": true,
+ "optional": true
+ },
+ "node-releases": {
+ "version": "2.0.8",
+ "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.8.tgz",
+ "integrity": "sha512-dFSmB8fFHEH/s81Xi+Y/15DQY6VHW81nXRj86EMSL3lmuTmK1e+aT4wrFCkTbm+gSwkw4KpX+rT/pMM2c1mF+A==",
+ "dev": true
+ },
+ "nopt": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/nopt/-/nopt-6.0.0.tgz",
+ "integrity": "sha512-ZwLpbTgdhuZUnZzjd7nb1ZV+4DoiC6/sfiVKok72ym/4Tlf+DFdlHYmT2JPmcNNWV6Pi3SDf1kT+A4r9RTuT9g==",
+ "dev": true,
+ "requires": {
+ "abbrev": "^1.0.0"
+ }
+ },
+ "normalize-package-data": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-5.0.0.tgz",
+ "integrity": "sha512-h9iPVIfrVZ9wVYQnxFgtw1ugSvGEMOlyPWWtm8BMJhnwyEL/FLbYbTY3V3PpjI/BUK67n9PEWDu6eHzu1fB15Q==",
+ "dev": true,
+ "requires": {
+ "hosted-git-info": "^6.0.0",
+ "is-core-module": "^2.8.1",
+ "semver": "^7.3.5",
+ "validate-npm-package-license": "^3.0.4"
+ }
+ },
+ "normalize-path": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
+ "dev": true
+ },
+ "normalize-range": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz",
+ "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==",
+ "dev": true
+ },
+ "npm-bundled": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-3.0.0.tgz",
+ "integrity": "sha512-Vq0eyEQy+elFpzsKjMss9kxqb9tG3YHg4dsyWuUENuzvSUWe1TCnW/vV9FkhvBk/brEDoDiVd+M1Btosa6ImdQ==",
+ "dev": true,
+ "requires": {
+ "npm-normalize-package-bin": "^3.0.0"
+ }
+ },
+ "npm-install-checks": {
+ "version": "6.1.1",
+ "resolved": "https://registry.npmjs.org/npm-install-checks/-/npm-install-checks-6.1.1.tgz",
+ "integrity": "sha512-dH3GmQL4vsPtld59cOn8uY0iOqRmqKvV+DLGwNXV/Q7MDgD2QfOADWd/mFXcIE5LVhYYGjA3baz6W9JneqnuCw==",
+ "dev": true,
+ "requires": {
+ "semver": "^7.1.1"
+ }
+ },
+ "npm-normalize-package-bin": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-3.0.1.tgz",
+ "integrity": "sha512-dMxCf+zZ+3zeQZXKxmyuCKlIDPGuv8EF940xbkC4kQVDTtqoh6rJFO+JTKSA6/Rwi0getWmtuy4Itup0AMcaDQ==",
+ "dev": true
+ },
+ "npm-package-arg": {
+ "version": "10.1.0",
+ "resolved": "https://registry.npmjs.org/npm-package-arg/-/npm-package-arg-10.1.0.tgz",
+ "integrity": "sha512-uFyyCEmgBfZTtrKk/5xDfHp6+MdrqGotX/VoOyEEl3mBwiEE5FlBaePanazJSVMPT7vKepcjYBY2ztg9A3yPIA==",
+ "dev": true,
+ "requires": {
+ "hosted-git-info": "^6.0.0",
+ "proc-log": "^3.0.0",
+ "semver": "^7.3.5",
+ "validate-npm-package-name": "^5.0.0"
+ }
+ },
+ "npm-packlist": {
+ "version": "7.0.4",
+ "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-7.0.4.tgz",
+ "integrity": "sha512-d6RGEuRrNS5/N84iglPivjaJPxhDbZmlbTwTDX2IbcRHG5bZCdtysYMhwiPvcF4GisXHGn7xsxv+GQ7T/02M5Q==",
+ "dev": true,
+ "requires": {
+ "ignore-walk": "^6.0.0"
+ }
+ },
+ "npm-pick-manifest": {
+ "version": "8.0.1",
+ "resolved": "https://registry.npmjs.org/npm-pick-manifest/-/npm-pick-manifest-8.0.1.tgz",
+ "integrity": "sha512-mRtvlBjTsJvfCCdmPtiu2bdlx8d/KXtF7yNXNWe7G0Z36qWA9Ny5zXsI2PfBZEv7SXgoxTmNaTzGSbbzDZChoA==",
+ "dev": true,
+ "requires": {
+ "npm-install-checks": "^6.0.0",
+ "npm-normalize-package-bin": "^3.0.0",
+ "npm-package-arg": "^10.0.0",
+ "semver": "^7.3.5"
+ }
+ },
+ "npm-registry-fetch": {
+ "version": "14.0.5",
+ "resolved": "https://registry.npmjs.org/npm-registry-fetch/-/npm-registry-fetch-14.0.5.tgz",
+ "integrity": "sha512-kIDMIo4aBm6xg7jOttupWZamsZRkAqMqwqqbVXnUqstY5+tapvv6bkH/qMR76jdgV+YljEUCyWx3hRYMrJiAgA==",
+ "dev": true,
+ "requires": {
+ "make-fetch-happen": "^11.0.0",
+ "minipass": "^5.0.0",
+ "minipass-fetch": "^3.0.0",
+ "minipass-json-stream": "^1.0.1",
+ "minizlib": "^2.1.2",
+ "npm-package-arg": "^10.0.0",
+ "proc-log": "^3.0.0"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-5.0.0.tgz",
+ "integrity": "sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==",
+ "dev": true
+ }
+ }
+ },
+ "npm-run-path": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz",
+ "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==",
+ "dev": true,
+ "requires": {
+ "path-key": "^3.0.0"
+ }
+ },
+ "npmlog": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-6.0.2.tgz",
+ "integrity": "sha512-/vBvz5Jfr9dT/aFWd0FIRf+T/Q2WBsLENygUaFUqstqsycmZAP/t5BvFJTK0viFmSUxiUKTUplWy5vt+rvKIxg==",
+ "dev": true,
+ "requires": {
+ "are-we-there-yet": "^3.0.0",
+ "console-control-strings": "^1.1.0",
+ "gauge": "^4.0.3",
+ "set-blocking": "^2.0.0"
+ }
+ },
+ "nth-check": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz",
+ "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==",
+ "dev": true,
+ "requires": {
+ "boolbase": "^1.0.0"
+ }
+ },
+ "object-assign": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
+ "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==",
+ "dev": true
+ },
+ "object-inspect": {
+ "version": "1.12.2",
+ "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz",
+ "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==",
+ "dev": true
+ },
+ "obuf": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz",
+ "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==",
+ "dev": true
+ },
+ "on-finished": {
+ "version": "2.4.1",
+ "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz",
+ "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==",
+ "dev": true,
+ "requires": {
+ "ee-first": "1.1.1"
+ }
+ },
+ "on-headers": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz",
+ "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==",
+ "dev": true
+ },
+ "once": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
+ "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==",
+ "dev": true,
+ "requires": {
+ "wrappy": "1"
+ }
+ },
+ "onetime": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz",
+ "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==",
+ "dev": true,
+ "requires": {
+ "mimic-fn": "^2.1.0"
+ }
+ },
+ "open": {
+ "version": "8.4.1",
+ "resolved": "https://registry.npmjs.org/open/-/open-8.4.1.tgz",
+ "integrity": "sha512-/4b7qZNhv6Uhd7jjnREh1NjnPxlTq+XNWPG88Ydkj5AILcA5m3ajvcg57pB24EQjKv0dK62XnDqk9c/hkIG5Kg==",
+ "dev": true,
+ "requires": {
+ "define-lazy-prop": "^2.0.0",
+ "is-docker": "^2.1.1",
+ "is-wsl": "^2.2.0"
+ }
+ },
+ "ora": {
+ "version": "5.4.1",
+ "resolved": "https://registry.npmjs.org/ora/-/ora-5.4.1.tgz",
+ "integrity": "sha512-5b6Y85tPxZZ7QytO+BQzysW31HJku27cRIlkbAXaNx+BdcVi+LlRFmVXzeF6a7JCwJpyw5c4b+YSVImQIrBpuQ==",
+ "dev": true,
+ "requires": {
+ "bl": "^4.1.0",
+ "chalk": "^4.1.0",
+ "cli-cursor": "^3.1.0",
+ "cli-spinners": "^2.5.0",
+ "is-interactive": "^1.0.0",
+ "is-unicode-supported": "^0.1.0",
+ "log-symbols": "^4.1.0",
+ "strip-ansi": "^6.0.0",
+ "wcwidth": "^1.0.1"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^2.0.1"
+ }
+ },
+ "chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ }
+ }
+ },
+ "os-tmpdir": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
+ "integrity": "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==",
+ "dev": true
+ },
+ "p-limit": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
+ "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
+ "dev": true,
+ "requires": {
+ "p-try": "^2.0.0"
+ }
+ },
+ "p-locate": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
+ "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
+ "dev": true,
+ "requires": {
+ "p-limit": "^2.2.0"
+ }
+ },
+ "p-map": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz",
+ "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==",
+ "dev": true,
+ "requires": {
+ "aggregate-error": "^3.0.0"
+ }
+ },
+ "p-retry": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-4.6.2.tgz",
+ "integrity": "sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ==",
+ "dev": true,
+ "requires": {
+ "@types/retry": "0.12.0",
+ "retry": "^0.13.1"
+ },
+ "dependencies": {
+ "retry": {
+ "version": "0.13.1",
+ "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz",
+ "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==",
+ "dev": true
+ }
+ }
+ },
+ "p-try": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
+ "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
+ "dev": true
+ },
+ "pacote": {
+ "version": "15.1.0",
+ "resolved": "https://registry.npmjs.org/pacote/-/pacote-15.1.0.tgz",
+ "integrity": "sha512-FFcjtIl+BQNfeliSm7MZz5cpdohvUV1yjGnqgVM4UnVF7JslRY0ImXAygdaCDV0jjUADEWu4y5xsDV8brtrTLg==",
+ "dev": true,
+ "requires": {
+ "@npmcli/git": "^4.0.0",
+ "@npmcli/installed-package-contents": "^2.0.1",
+ "@npmcli/promise-spawn": "^6.0.1",
+ "@npmcli/run-script": "^6.0.0",
+ "cacache": "^17.0.0",
+ "fs-minipass": "^3.0.0",
+ "minipass": "^4.0.0",
+ "npm-package-arg": "^10.0.0",
+ "npm-packlist": "^7.0.0",
+ "npm-pick-manifest": "^8.0.0",
+ "npm-registry-fetch": "^14.0.0",
+ "proc-log": "^3.0.0",
+ "promise-retry": "^2.0.1",
+ "read-package-json": "^6.0.0",
+ "read-package-json-fast": "^3.0.0",
+ "sigstore": "^1.0.0",
+ "ssri": "^10.0.0",
+ "tar": "^6.1.11"
+ }
+ },
+ "pako": {
+ "version": "1.0.11",
+ "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz",
+ "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==",
+ "dev": true
+ },
+ "parent-module": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
+ "dev": true,
+ "requires": {
+ "callsites": "^3.0.0"
+ }
+ },
+ "parse-json": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
+ "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
+ "dev": true,
+ "requires": {
+ "@babel/code-frame": "^7.0.0",
+ "error-ex": "^1.3.1",
+ "json-parse-even-better-errors": "^2.3.0",
+ "lines-and-columns": "^1.1.6"
+ }
+ },
+ "parse-node-version": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parse-node-version/-/parse-node-version-1.0.1.tgz",
+ "integrity": "sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA==",
+ "dev": true
+ },
+ "parse5": {
+ "version": "7.1.2",
+ "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.2.tgz",
+ "integrity": "sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw==",
+ "devOptional": true,
+ "requires": {
+ "entities": "^4.4.0"
+ },
+ "dependencies": {
+ "entities": {
+ "version": "4.4.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-4.4.0.tgz",
+ "integrity": "sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA==",
+ "devOptional": true
+ }
+ }
+ },
+ "parse5-html-rewriting-stream": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/parse5-html-rewriting-stream/-/parse5-html-rewriting-stream-7.0.0.tgz",
+ "integrity": "sha512-mazCyGWkmCRWDI15Zp+UiCqMp/0dgEmkZRvhlsqqKYr4SsVm/TvnSpD9fCvqCA2zoWJcfRym846ejWBBHRiYEg==",
+ "dev": true,
+ "requires": {
+ "entities": "^4.3.0",
+ "parse5": "^7.0.0",
+ "parse5-sax-parser": "^7.0.0"
+ },
+ "dependencies": {
+ "entities": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz",
+ "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==",
+ "dev": true
+ }
+ }
+ },
+ "parse5-htmlparser2-tree-adapter": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-6.0.1.tgz",
+ "integrity": "sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA==",
+ "dev": true,
+ "requires": {
+ "parse5": "^6.0.1"
+ },
+ "dependencies": {
+ "parse5": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz",
+ "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==",
+ "dev": true
+ }
+ }
+ },
+ "parse5-sax-parser": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/parse5-sax-parser/-/parse5-sax-parser-7.0.0.tgz",
+ "integrity": "sha512-5A+v2SNsq8T6/mG3ahcz8ZtQ0OUFTatxPbeidoMB7tkJSGDY3tdfl4MHovtLQHkEn5CGxijNWRQHhRQ6IRpXKg==",
+ "dev": true,
+ "requires": {
+ "parse5": "^7.0.0"
+ }
+ },
+ "parseurl": {
+ "version": "1.3.3",
+ "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
+ "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==",
+ "dev": true
+ },
+ "particles.js": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/particles.js/-/particles.js-2.0.0.tgz",
+ "integrity": "sha512-8e0JIqkRbMMPlFBnF9f+92hX1s07jdkd3tqB8uHE9L+cwGGjIYjQM7QLgt0FQ5MZp6SFFYYDm/Y48pqK3ZvJOQ=="
+ },
+ "path-exists": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
+ "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
+ "dev": true
+ },
+ "path-is-absolute": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
+ "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==",
+ "dev": true
+ },
+ "path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true
+ },
+ "path-parse": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz",
+ "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==",
+ "dev": true
+ },
+ "path-scurry": {
+ "version": "1.10.1",
+ "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.1.tgz",
+ "integrity": "sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ==",
+ "dev": true,
+ "requires": {
+ "lru-cache": "^9.1.1 || ^10.0.0",
+ "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0"
+ },
+ "dependencies": {
+ "lru-cache": {
+ "version": "10.0.0",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.0.0.tgz",
+ "integrity": "sha512-svTf/fzsKHffP42sujkO/Rjs37BCIsQVRCeNYIm9WN8rgT7ffoUnRtZCqU+6BqcSBdv8gwJeTz8knJpgACeQMw==",
+ "dev": true
+ },
+ "minipass": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.2.tgz",
+ "integrity": "sha512-eL79dXrE1q9dBbDCLg7xfn/vl7MS4F1gvJAgjJrQli/jbQWdUttuVawphqpffoIYfRdq78LHx6GP4bU/EQ2ATA==",
+ "dev": true
+ }
+ }
+ },
+ "path-to-regexp": {
+ "version": "0.1.7",
+ "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
+ "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==",
+ "dev": true
+ },
+ "path-type": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
+ "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
+ "dev": true
+ },
+ "picocolors": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
+ "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
+ "dev": true
+ },
+ "picomatch": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
+ "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
+ "dev": true
+ },
+ "pify": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz",
+ "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==",
+ "dev": true,
+ "optional": true
+ },
+ "piscina": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/piscina/-/piscina-3.2.0.tgz",
+ "integrity": "sha512-yn/jMdHRw+q2ZJhFhyqsmANcbF6V2QwmD84c6xRau+QpQOmtrBCoRGdvTfeuFDYXB5W2m6MfLkjkvQa9lUSmIA==",
+ "dev": true,
+ "requires": {
+ "eventemitter-asyncresource": "^1.0.0",
+ "hdr-histogram-js": "^2.0.1",
+ "hdr-histogram-percentiles-obj": "^3.0.0",
+ "nice-napi": "^1.0.2"
+ }
+ },
+ "pkg-dir": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz",
+ "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==",
+ "dev": true,
+ "requires": {
+ "find-up": "^4.0.0"
+ }
+ },
+ "postcss": {
+ "version": "8.4.21",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.21.tgz",
+ "integrity": "sha512-tP7u/Sn/dVxK2NnruI4H9BG+x+Wxz6oeZ1cJ8P6G/PZY0IKk4k/63TDsQf2kQq3+qoJeLm2kIBUNlZe3zgb4Zg==",
+ "dev": true,
+ "requires": {
+ "nanoid": "^3.3.4",
+ "picocolors": "^1.0.0",
+ "source-map-js": "^1.0.2"
+ }
+ },
+ "postcss-loader": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-7.0.2.tgz",
+ "integrity": "sha512-fUJzV/QH7NXUAqV8dWJ9Lg4aTkDCezpTS5HgJ2DvqznexTbSTxgi/dTECvTZ15BwKTtk8G/bqI/QTu2HPd3ZCg==",
+ "dev": true,
+ "requires": {
+ "cosmiconfig": "^7.0.0",
+ "klona": "^2.0.5",
+ "semver": "^7.3.8"
+ }
+ },
+ "postcss-modules-extract-imports": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz",
+ "integrity": "sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw==",
+ "dev": true
+ },
+ "postcss-modules-local-by-default": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.0.tgz",
+ "integrity": "sha512-sT7ihtmGSF9yhm6ggikHdV0hlziDTX7oFoXtuVWeDd3hHObNkcHRo9V3yg7vCAY7cONyxJC/XXCmmiHHcvX7bQ==",
+ "dev": true,
+ "requires": {
+ "icss-utils": "^5.0.0",
+ "postcss-selector-parser": "^6.0.2",
+ "postcss-value-parser": "^4.1.0"
+ }
+ },
+ "postcss-modules-scope": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz",
+ "integrity": "sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg==",
+ "dev": true,
+ "requires": {
+ "postcss-selector-parser": "^6.0.4"
+ }
+ },
+ "postcss-modules-values": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz",
+ "integrity": "sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ==",
+ "dev": true,
+ "requires": {
+ "icss-utils": "^5.0.0"
+ }
+ },
+ "postcss-selector-parser": {
+ "version": "6.0.11",
+ "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.11.tgz",
+ "integrity": "sha512-zbARubNdogI9j7WY4nQJBiNqQf3sLS3wCP4WfOidu+p28LofJqDH1tcXypGrcmMHhDk2t9wGhCsYe/+szLTy1g==",
+ "dev": true,
+ "requires": {
+ "cssesc": "^3.0.0",
+ "util-deprecate": "^1.0.2"
+ }
+ },
+ "postcss-value-parser": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz",
+ "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==",
+ "dev": true
+ },
+ "pretty-bytes": {
+ "version": "5.6.0",
+ "resolved": "https://registry.npmjs.org/pretty-bytes/-/pretty-bytes-5.6.0.tgz",
+ "integrity": "sha512-FFw039TmrBqFK8ma/7OL3sDz/VytdtJr044/QUJtH0wK9lb9jLq9tJyIxUwtQJHwar2BqtiA4iCWSwo9JLkzFg==",
+ "dev": true
+ },
+ "proc-log": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/proc-log/-/proc-log-3.0.0.tgz",
+ "integrity": "sha512-++Vn7NS4Xf9NacaU9Xq3URUuqZETPsf8L4j5/ckhaRYsfPeRyzGw+iDjFhV/Jr3uNmTvvddEJFWh5R1gRgUH8A==",
+ "dev": true
+ },
+ "process-nextick-args": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
+ "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==",
+ "dev": true
+ },
+ "promise-inflight": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz",
+ "integrity": "sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g==",
+ "dev": true
+ },
+ "promise-retry": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/promise-retry/-/promise-retry-2.0.1.tgz",
+ "integrity": "sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g==",
+ "dev": true,
+ "requires": {
+ "err-code": "^2.0.2",
+ "retry": "^0.12.0"
+ }
+ },
+ "proxy-addr": {
+ "version": "2.0.7",
+ "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
+ "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
+ "dev": true,
+ "requires": {
+ "forwarded": "0.2.0",
+ "ipaddr.js": "1.9.1"
+ },
+ "dependencies": {
+ "ipaddr.js": {
+ "version": "1.9.1",
+ "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
+ "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==",
+ "dev": true
+ }
+ }
+ },
+ "prr": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz",
+ "integrity": "sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==",
+ "dev": true,
+ "optional": true
+ },
+ "punycode": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.2.0.tgz",
+ "integrity": "sha512-LN6QV1IJ9ZhxWTNdktaPClrNfp8xdSAYS0Zk2ddX7XsXZAxckMHPCBcHRo0cTcEIgYPRiGEkmji3Idkh2yFtYw==",
+ "dev": true
+ },
+ "qjobs": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/qjobs/-/qjobs-1.2.0.tgz",
+ "integrity": "sha512-8YOJEHtxpySA3fFDyCRxA+UUV+fA+rTWnuWvylOK/NCjhY+b4ocCtmu8TtsWb+mYeU+GCHf/S66KZF/AsteKHg==",
+ "dev": true
+ },
+ "qs": {
+ "version": "6.11.0",
+ "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz",
+ "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==",
+ "dev": true,
+ "requires": {
+ "side-channel": "^1.0.4"
+ }
+ },
+ "queue-microtask": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
+ "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
+ "dev": true
+ },
+ "randombytes": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz",
+ "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==",
+ "dev": true,
+ "requires": {
+ "safe-buffer": "^5.1.0"
+ }
+ },
+ "range-parser": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
+ "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==",
+ "dev": true
+ },
+ "raw-body": {
+ "version": "2.5.1",
+ "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz",
+ "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==",
+ "dev": true,
+ "requires": {
+ "bytes": "3.1.2",
+ "http-errors": "2.0.0",
+ "iconv-lite": "0.4.24",
+ "unpipe": "1.0.0"
+ }
+ },
+ "read-package-json": {
+ "version": "6.0.4",
+ "resolved": "https://registry.npmjs.org/read-package-json/-/read-package-json-6.0.4.tgz",
+ "integrity": "sha512-AEtWXYfopBj2z5N5PbkAOeNHRPUg5q+Nen7QLxV8M2zJq1ym6/lCz3fYNTCXe19puu2d06jfHhrP7v/S2PtMMw==",
+ "dev": true,
+ "requires": {
+ "glob": "^10.2.2",
+ "json-parse-even-better-errors": "^3.0.0",
+ "normalize-package-data": "^5.0.0",
+ "npm-normalize-package-bin": "^3.0.0"
+ },
+ "dependencies": {
+ "glob": {
+ "version": "10.3.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.3.tgz",
+ "integrity": "sha512-92vPiMb/iqpmEgsOoIDvTjc50wf9CCCvMzsi6W0JLPeUKE8TWP1a73PgqSrqy7iAZxaSD1YdzU7QZR5LF51MJw==",
+ "dev": true,
+ "requires": {
+ "foreground-child": "^3.1.0",
+ "jackspeak": "^2.0.3",
+ "minimatch": "^9.0.1",
+ "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0",
+ "path-scurry": "^1.10.1"
+ }
+ },
+ "json-parse-even-better-errors": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-3.0.0.tgz",
+ "integrity": "sha512-iZbGHafX/59r39gPwVPRBGw0QQKnA7tte5pSMrhWOW7swGsVvVTjmfyAV9pNqk8YGT7tRCdxRu8uzcgZwoDooA==",
+ "dev": true
+ },
+ "minimatch": {
+ "version": "9.0.3",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz",
+ "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^2.0.1"
+ }
+ },
+ "minipass": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.0.2.tgz",
+ "integrity": "sha512-eL79dXrE1q9dBbDCLg7xfn/vl7MS4F1gvJAgjJrQli/jbQWdUttuVawphqpffoIYfRdq78LHx6GP4bU/EQ2ATA==",
+ "dev": true
+ }
+ }
+ },
+ "read-package-json-fast": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/read-package-json-fast/-/read-package-json-fast-3.0.2.tgz",
+ "integrity": "sha512-0J+Msgym3vrLOUB3hzQCuZHII0xkNGCtz/HJH9xZshwv9DbDwkw1KaE3gx/e2J5rpEY5rtOy6cyhKOPrkP7FZw==",
+ "dev": true,
+ "requires": {
+ "json-parse-even-better-errors": "^3.0.0",
+ "npm-normalize-package-bin": "^3.0.0"
+ },
+ "dependencies": {
+ "json-parse-even-better-errors": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-3.0.0.tgz",
+ "integrity": "sha512-iZbGHafX/59r39gPwVPRBGw0QQKnA7tte5pSMrhWOW7swGsVvVTjmfyAV9pNqk8YGT7tRCdxRu8uzcgZwoDooA==",
+ "dev": true
+ }
+ }
+ },
+ "readable-stream": {
+ "version": "3.6.0",
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz",
+ "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==",
+ "dev": true,
+ "requires": {
+ "inherits": "^2.0.3",
+ "string_decoder": "^1.1.1",
+ "util-deprecate": "^1.0.1"
+ }
+ },
+ "readdirp": {
+ "version": "3.6.0",
+ "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz",
+ "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==",
+ "dev": true,
+ "requires": {
+ "picomatch": "^2.2.1"
+ }
+ },
+ "reflect-metadata": {
+ "version": "0.1.13",
+ "resolved": "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz",
+ "integrity": "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==",
+ "dev": true
+ },
+ "regenerate": {
+ "version": "1.4.2",
+ "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz",
+ "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==",
+ "dev": true
+ },
+ "regenerate-unicode-properties": {
+ "version": "10.1.0",
+ "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz",
+ "integrity": "sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ==",
+ "dev": true,
+ "requires": {
+ "regenerate": "^1.4.2"
+ }
+ },
+ "regenerator-runtime": {
+ "version": "0.13.11",
+ "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz",
+ "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==",
+ "dev": true
+ },
+ "regenerator-transform": {
+ "version": "0.15.1",
+ "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.1.tgz",
+ "integrity": "sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg==",
+ "dev": true,
+ "requires": {
+ "@babel/runtime": "^7.8.4"
+ }
+ },
+ "regex-parser": {
+ "version": "2.2.11",
+ "resolved": "https://registry.npmjs.org/regex-parser/-/regex-parser-2.2.11.tgz",
+ "integrity": "sha512-jbD/FT0+9MBU2XAZluI7w2OBs1RBi6p9M83nkoZayQXXU9e8Robt69FcZc7wU4eJD/YFTjn1JdCk3rbMJajz8Q==",
+ "dev": true
+ },
+ "regexpu-core": {
+ "version": "5.2.2",
+ "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.2.2.tgz",
+ "integrity": "sha512-T0+1Zp2wjF/juXMrMxHxidqGYn8U4R+zleSJhX9tQ1PUsS8a9UtYfbsF9LdiVgNX3kiX8RNaKM42nfSgvFJjmw==",
+ "dev": true,
+ "requires": {
+ "regenerate": "^1.4.2",
+ "regenerate-unicode-properties": "^10.1.0",
+ "regjsgen": "^0.7.1",
+ "regjsparser": "^0.9.1",
+ "unicode-match-property-ecmascript": "^2.0.0",
+ "unicode-match-property-value-ecmascript": "^2.1.0"
+ }
+ },
+ "regjsgen": {
+ "version": "0.7.1",
+ "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.7.1.tgz",
+ "integrity": "sha512-RAt+8H2ZEzHeYWxZ3H2z6tF18zyyOnlcdaafLrm21Bguj7uZy6ULibiAFdXEtKQY4Sy7wDTwDiOazasMLc4KPA==",
+ "dev": true
+ },
+ "regjsparser": {
+ "version": "0.9.1",
+ "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz",
+ "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==",
+ "dev": true,
+ "requires": {
+ "jsesc": "~0.5.0"
+ },
+ "dependencies": {
+ "jsesc": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz",
+ "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==",
+ "dev": true
+ }
+ }
+ },
+ "require-directory": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
+ "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==",
+ "dev": true
+ },
+ "require-from-string": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz",
+ "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==",
+ "dev": true
+ },
+ "requires-port": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz",
+ "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==",
+ "dev": true
+ },
+ "resolve": {
+ "version": "1.22.1",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz",
+ "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==",
+ "dev": true,
+ "requires": {
+ "is-core-module": "^2.9.0",
+ "path-parse": "^1.0.7",
+ "supports-preserve-symlinks-flag": "^1.0.0"
+ }
+ },
+ "resolve-from": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
+ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
+ "dev": true
+ },
+ "resolve-url-loader": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-url-loader/-/resolve-url-loader-5.0.0.tgz",
+ "integrity": "sha512-uZtduh8/8srhBoMx//5bwqjQ+rfYOUq8zC9NrMUGtjBiGTtFJM42s58/36+hTqeqINcnYe08Nj3LkK9lW4N8Xg==",
+ "dev": true,
+ "requires": {
+ "adjust-sourcemap-loader": "^4.0.0",
+ "convert-source-map": "^1.7.0",
+ "loader-utils": "^2.0.0",
+ "postcss": "^8.2.14",
+ "source-map": "0.6.1"
+ },
+ "dependencies": {
+ "loader-utils": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz",
+ "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==",
+ "dev": true,
+ "requires": {
+ "big.js": "^5.2.2",
+ "emojis-list": "^3.0.0",
+ "json5": "^2.1.2"
+ }
+ },
+ "source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true
+ }
+ }
+ },
+ "restore-cursor": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz",
+ "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==",
+ "dev": true,
+ "requires": {
+ "onetime": "^5.1.0",
+ "signal-exit": "^3.0.2"
+ }
+ },
+ "retry": {
+ "version": "0.12.0",
+ "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz",
+ "integrity": "sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow==",
+ "dev": true
+ },
+ "reusify": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz",
+ "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==",
+ "dev": true
+ },
+ "rfdc": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz",
+ "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==",
+ "dev": true
+ },
+ "rimraf": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
+ "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
+ "dev": true,
+ "requires": {
+ "glob": "^7.1.3"
+ },
+ "dependencies": {
+ "brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "requires": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "requires": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ }
+ },
+ "minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^1.1.7"
+ }
+ }
+ }
+ },
+ "run-async": {
+ "version": "2.4.1",
+ "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.4.1.tgz",
+ "integrity": "sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==",
+ "dev": true
+ },
+ "run-parallel": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
+ "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
+ "dev": true,
+ "requires": {
+ "queue-microtask": "^1.2.2"
+ }
+ },
+ "rxjs": {
+ "version": "6.6.7",
+ "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.6.7.tgz",
+ "integrity": "sha512-hTdwr+7yYNIT5n4AMYp85KA6yw2Va0FLa3Rguvbpa4W3I5xynaBZo41cM3XM+4Q6fRMj3sBYIR1VAmZMXYJvRQ==",
+ "requires": {
+ "tslib": "^1.9.0"
+ },
+ "dependencies": {
+ "tslib": {
+ "version": "1.14.1",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz",
+ "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg=="
+ }
+ }
+ },
+ "safe-buffer": {
+ "version": "5.2.1",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
+ "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
+ "dev": true
+ },
+ "safer-buffer": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
+ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==",
+ "dev": true
+ },
+ "safevalues": {
+ "version": "0.3.4",
+ "resolved": "https://registry.npmjs.org/safevalues/-/safevalues-0.3.4.tgz",
+ "integrity": "sha512-LRneZZRXNgjzwG4bDQdOTSbze3fHm1EAKN/8bePxnlEZiBmkYEDggaHbuvHI9/hoqHbGfsEA7tWS9GhYHZBBsw=="
+ },
+ "sass": {
+ "version": "1.58.1",
+ "resolved": "https://registry.npmjs.org/sass/-/sass-1.58.1.tgz",
+ "integrity": "sha512-bnINi6nPXbP1XNRaranMFEBZWUfdW/AF16Ql5+ypRxfTvCRTTKrLsMIakyDcayUt2t/RZotmL4kgJwNH5xO+bg==",
+ "dev": true,
+ "requires": {
+ "chokidar": ">=3.0.0 <4.0.0",
+ "immutable": "^4.0.0",
+ "source-map-js": ">=0.6.2 <2.0.0"
+ }
+ },
+ "sass-loader": {
+ "version": "13.2.0",
+ "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-13.2.0.tgz",
+ "integrity": "sha512-JWEp48djQA4nbZxmgC02/Wh0eroSUutulROUusYJO9P9zltRbNN80JCBHqRGzjd4cmZCa/r88xgfkjGD0TXsHg==",
+ "dev": true,
+ "requires": {
+ "klona": "^2.0.4",
+ "neo-async": "^2.6.2"
+ }
+ },
+ "sax": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz",
+ "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==",
+ "dev": true,
+ "optional": true
+ },
+ "schema-utils": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.0.0.tgz",
+ "integrity": "sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg==",
+ "dev": true,
+ "requires": {
+ "@types/json-schema": "^7.0.9",
+ "ajv": "^8.8.0",
+ "ajv-formats": "^2.1.1",
+ "ajv-keywords": "^5.0.0"
+ }
+ },
+ "select-hose": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz",
+ "integrity": "sha512-mEugaLK+YfkijB4fx0e6kImuJdCIt2LxCRcbEYPqRGCs4F2ogyfZU5IAZRdjCP8JPq2AtdNoC/Dux63d9Kiryg==",
+ "dev": true
+ },
+ "selfsigned": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz",
+ "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==",
+ "dev": true,
+ "requires": {
+ "node-forge": "^1"
+ }
+ },
+ "semver": {
+ "version": "7.5.3",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.3.tgz",
+ "integrity": "sha512-QBlUtyVk/5EeHbi7X0fw6liDZc7BBmEaSYn01fMU1OUYbf6GPsbTtd8WmnqbI20SeycoHSeiybkE/q1Q+qlThQ==",
+ "dev": true,
+ "requires": {
+ "lru-cache": "^6.0.0"
+ },
+ "dependencies": {
+ "lru-cache": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
+ "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "send": {
+ "version": "0.18.0",
+ "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz",
+ "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==",
+ "dev": true,
+ "requires": {
+ "debug": "2.6.9",
+ "depd": "2.0.0",
+ "destroy": "1.2.0",
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "etag": "~1.8.1",
+ "fresh": "0.5.2",
+ "http-errors": "2.0.0",
+ "mime": "1.6.0",
+ "ms": "2.1.3",
+ "on-finished": "2.4.1",
+ "range-parser": "~1.2.1",
+ "statuses": "2.0.1"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ },
+ "dependencies": {
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ }
+ }
+ },
+ "mime": {
+ "version": "1.6.0",
+ "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
+ "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
+ "dev": true
+ },
+ "ms": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
+ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
+ "dev": true
+ },
+ "statuses": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
+ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
+ "dev": true
+ }
+ }
+ },
+ "serialize-javascript": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.1.tgz",
+ "integrity": "sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w==",
+ "dev": true,
+ "requires": {
+ "randombytes": "^2.1.0"
+ }
+ },
+ "serve-index": {
+ "version": "1.9.1",
+ "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz",
+ "integrity": "sha512-pXHfKNP4qujrtteMrSBb0rc8HJ9Ms/GrXwcUtUtD5s4ewDJI8bT3Cz2zTVRMKtri49pLx2e0Ya8ziP5Ya2pZZw==",
+ "dev": true,
+ "requires": {
+ "accepts": "~1.3.4",
+ "batch": "0.6.1",
+ "debug": "2.6.9",
+ "escape-html": "~1.0.3",
+ "http-errors": "~1.6.2",
+ "mime-types": "~2.1.17",
+ "parseurl": "~1.3.2"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "depd": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz",
+ "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==",
+ "dev": true
+ },
+ "http-errors": {
+ "version": "1.6.3",
+ "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz",
+ "integrity": "sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A==",
+ "dev": true,
+ "requires": {
+ "depd": "~1.1.2",
+ "inherits": "2.0.3",
+ "setprototypeof": "1.1.0",
+ "statuses": ">= 1.4.0 < 2"
+ }
+ },
+ "inherits": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
+ "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==",
+ "dev": true
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==",
+ "dev": true
+ },
+ "setprototypeof": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz",
+ "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==",
+ "dev": true
+ }
+ }
+ },
+ "serve-static": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz",
+ "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==",
+ "dev": true,
+ "requires": {
+ "encodeurl": "~1.0.2",
+ "escape-html": "~1.0.3",
+ "parseurl": "~1.3.3",
+ "send": "0.18.0"
+ }
+ },
+ "set-blocking": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz",
+ "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==",
+ "dev": true
+ },
+ "setprototypeof": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
+ "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==",
+ "dev": true
+ },
+ "shallow-clone": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz",
+ "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.2"
+ }
+ },
+ "shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "requires": {
+ "shebang-regex": "^3.0.0"
+ }
+ },
+ "shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true
+ },
+ "side-channel": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz",
+ "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==",
+ "dev": true,
+ "requires": {
+ "call-bind": "^1.0.0",
+ "get-intrinsic": "^1.0.2",
+ "object-inspect": "^1.9.0"
+ }
+ },
+ "signal-exit": {
+ "version": "3.0.7",
+ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz",
+ "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==",
+ "dev": true
+ },
+ "sigstore": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmjs.org/sigstore/-/sigstore-1.8.0.tgz",
+ "integrity": "sha512-ogU8qtQ3VFBawRJ8wjsBEX/vIFeHuGs1fm4jZtjWQwjo8pfAt7T/rh+udlAN4+QUe0IzA8qRSc/YZ7dHP6kh+w==",
+ "dev": true,
+ "requires": {
+ "@sigstore/bundle": "^1.0.0",
+ "@sigstore/protobuf-specs": "^0.2.0",
+ "@sigstore/tuf": "^1.0.3",
+ "make-fetch-happen": "^11.0.1"
+ }
+ },
+ "slash": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-4.0.0.tgz",
+ "integrity": "sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew==",
+ "dev": true
+ },
+ "smart-buffer": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz",
+ "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==",
+ "dev": true
+ },
+ "socket.io": {
+ "version": "4.6.1",
+ "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-4.6.1.tgz",
+ "integrity": "sha512-KMcaAi4l/8+xEjkRICl6ak8ySoxsYG+gG6/XfRCPJPQ/haCRIJBTL4wIl8YCsmtaBovcAXGLOShyVWQ/FG8GZA==",
+ "dev": true,
+ "requires": {
+ "accepts": "~1.3.4",
+ "base64id": "~2.0.0",
+ "debug": "~4.3.2",
+ "engine.io": "~6.4.1",
+ "socket.io-adapter": "~2.5.2",
+ "socket.io-parser": "~4.2.1"
+ }
+ },
+ "socket.io-adapter": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/socket.io-adapter/-/socket.io-adapter-2.5.2.tgz",
+ "integrity": "sha512-87C3LO/NOMc+eMcpcxUBebGjkpMDkNBS9tf7KJqcDsmL936EChtVva71Dw2q4tQcuVC+hAUy4an2NO/sYXmwRA==",
+ "dev": true,
+ "requires": {
+ "ws": "~8.11.0"
+ }
+ },
+ "socket.io-parser": {
+ "version": "4.2.3",
+ "resolved": "https://registry.npmjs.org/socket.io-parser/-/socket.io-parser-4.2.3.tgz",
+ "integrity": "sha512-JMafRntWVO2DCJimKsRTh/wnqVvO4hrfwOqtO7f+uzwsQMuxO6VwImtYxaQ+ieoyshWOTJyV0fA21lccEXRPpQ==",
+ "dev": true,
+ "requires": {
+ "@socket.io/component-emitter": "~3.1.0",
+ "debug": "~4.3.1"
+ }
+ },
+ "sockjs": {
+ "version": "0.3.24",
+ "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.24.tgz",
+ "integrity": "sha512-GJgLTZ7vYb/JtPSSZ10hsOYIvEYsjbNU+zPdIHcUaWVNUEPivzxku31865sSSud0Da0W4lEeOPlmw93zLQchuQ==",
+ "dev": true,
+ "requires": {
+ "faye-websocket": "^0.11.3",
+ "uuid": "^8.3.2",
+ "websocket-driver": "^0.7.4"
+ }
+ },
+ "socks": {
+ "version": "2.7.1",
+ "resolved": "https://registry.npmjs.org/socks/-/socks-2.7.1.tgz",
+ "integrity": "sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==",
+ "dev": true,
+ "requires": {
+ "ip": "^2.0.0",
+ "smart-buffer": "^4.2.0"
+ }
+ },
+ "socks-proxy-agent": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-7.0.0.tgz",
+ "integrity": "sha512-Fgl0YPZ902wEsAyiQ+idGd1A7rSFx/ayC1CQVMw5P+EQx2V0SgpGtf6OKFhVjPflPUl9YMmEOnmfjCdMUsygww==",
+ "dev": true,
+ "requires": {
+ "agent-base": "^6.0.2",
+ "debug": "^4.3.3",
+ "socks": "^2.6.2"
+ }
+ },
+ "sortablejs": {
+ "version": "1.15.0",
+ "resolved": "https://registry.npmjs.org/sortablejs/-/sortablejs-1.15.0.tgz",
+ "integrity": "sha512-bv9qgVMjUMf89wAvM6AxVvS/4MX3sPeN0+agqShejLU5z5GX4C75ow1O2e5k4L6XItUyAK3gH6AxSbXrOM5e8w=="
+ },
+ "source-map": {
+ "version": "0.7.4",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz",
+ "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==",
+ "dev": true
+ },
+ "source-map-js": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
+ "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
+ "dev": true
+ },
+ "source-map-loader": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/source-map-loader/-/source-map-loader-4.0.1.tgz",
+ "integrity": "sha512-oqXpzDIByKONVY8g1NUPOTQhe0UTU5bWUl32GSkqK2LjJj0HmwTMVKxcUip0RgAYhY1mqgOxjbQM48a0mmeNfA==",
+ "dev": true,
+ "requires": {
+ "abab": "^2.0.6",
+ "iconv-lite": "^0.6.3",
+ "source-map-js": "^1.0.2"
+ },
+ "dependencies": {
+ "iconv-lite": {
+ "version": "0.6.3",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz",
+ "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==",
+ "dev": true,
+ "requires": {
+ "safer-buffer": ">= 2.1.2 < 3.0.0"
+ }
+ }
+ }
+ },
+ "source-map-support": {
+ "version": "0.5.21",
+ "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz",
+ "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==",
+ "dev": true,
+ "requires": {
+ "buffer-from": "^1.0.0",
+ "source-map": "^0.6.0"
+ },
+ "dependencies": {
+ "source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true
+ }
+ }
+ },
+ "spdx-correct": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz",
+ "integrity": "sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==",
+ "dev": true,
+ "requires": {
+ "spdx-expression-parse": "^3.0.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "spdx-exceptions": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz",
+ "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==",
+ "dev": true
+ },
+ "spdx-expression-parse": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz",
+ "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==",
+ "dev": true,
+ "requires": {
+ "spdx-exceptions": "^2.1.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "spdx-license-ids": {
+ "version": "3.0.13",
+ "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.13.tgz",
+ "integrity": "sha512-XkD+zwiqXHikFZm4AX/7JSCXA98U5Db4AFd5XUg/+9UNtnH75+Z9KxtpYiJZx36mUDVOwH83pl7yvCer6ewM3w==",
+ "dev": true
+ },
+ "spdy": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/spdy/-/spdy-4.0.2.tgz",
+ "integrity": "sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA==",
+ "dev": true,
+ "requires": {
+ "debug": "^4.1.0",
+ "handle-thing": "^2.0.0",
+ "http-deceiver": "^1.2.7",
+ "select-hose": "^2.0.0",
+ "spdy-transport": "^3.0.0"
+ }
+ },
+ "spdy-transport": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz",
+ "integrity": "sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw==",
+ "dev": true,
+ "requires": {
+ "debug": "^4.1.0",
+ "detect-node": "^2.0.4",
+ "hpack.js": "^2.1.6",
+ "obuf": "^1.1.2",
+ "readable-stream": "^3.0.6",
+ "wbuf": "^1.7.3"
+ }
+ },
+ "sprintf-js": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz",
+ "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==",
+ "dev": true
+ },
+ "ssr-window": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/ssr-window/-/ssr-window-4.0.2.tgz",
+ "integrity": "sha512-ISv/Ch+ig7SOtw7G2+qkwfVASzazUnvlDTwypdLoPoySv+6MqlOV10VwPSE6EWkGjhW50lUmghPmpYZXMu/+AQ=="
+ },
+ "ssri": {
+ "version": "10.0.1",
+ "resolved": "https://registry.npmjs.org/ssri/-/ssri-10.0.1.tgz",
+ "integrity": "sha512-WVy6di9DlPOeBWEjMScpNipeSX2jIZBGEn5Uuo8Q7aIuFEuDX0pw8RxcOjlD1TWP4obi24ki7m/13+nFpcbXrw==",
+ "dev": true,
+ "requires": {
+ "minipass": "^4.0.0"
+ }
+ },
+ "statuses": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz",
+ "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==",
+ "dev": true
+ },
+ "streamroller": {
+ "version": "3.1.4",
+ "resolved": "https://registry.npmjs.org/streamroller/-/streamroller-3.1.4.tgz",
+ "integrity": "sha512-Ha1Ccw2/N5C/IF8Do6zgNe8F3jQo8MPBnMBGvX0QjNv/I97BcNRzK6/mzOpZHHK7DjMLTI3c7Xw7Y1KvdChkvw==",
+ "dev": true,
+ "requires": {
+ "date-format": "^4.0.14",
+ "debug": "^4.3.4",
+ "fs-extra": "^8.1.0"
+ }
+ },
+ "string_decoder": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz",
+ "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==",
+ "dev": true,
+ "requires": {
+ "safe-buffer": "~5.2.0"
+ }
+ },
+ "string-width": {
+ "version": "4.2.3",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
+ "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
+ "dev": true,
+ "requires": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.1"
+ }
+ },
+ "string-width-cjs": {
+ "version": "npm:string-width@4.2.3",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
+ "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
+ "dev": true,
+ "requires": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.1"
+ }
+ },
+ "strip-ansi": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^5.0.1"
+ }
+ },
+ "strip-ansi-cjs": {
+ "version": "npm:strip-ansi@6.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
+ "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^5.0.1"
+ }
+ },
+ "strip-final-newline": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz",
+ "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^3.0.0"
+ }
+ },
+ "supports-preserve-symlinks-flag": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
+ "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
+ "dev": true
+ },
+ "swiper": {
+ "version": "8.4.7",
+ "resolved": "https://registry.npmjs.org/swiper/-/swiper-8.4.7.tgz",
+ "integrity": "sha512-VwO/KU3i9IV2Sf+W2NqyzwWob4yX9Qdedq6vBtS0rFqJ6Fa5iLUJwxQkuD4I38w0WDJwmFl8ojkdcRFPHWD+2g==",
+ "requires": {
+ "dom7": "^4.0.4",
+ "ssr-window": "^4.0.2"
+ }
+ },
+ "symbol-observable": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-4.0.0.tgz",
+ "integrity": "sha512-b19dMThMV4HVFynSAM1++gBHAbk2Tc/osgLIBZMKsyqh34jb2e8Os7T6ZW/Bt3pJFdBTd2JwAnAAEQV7rSNvcQ==",
+ "dev": true
+ },
+ "tapable": {
+ "version": "2.2.1",
+ "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz",
+ "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==",
+ "dev": true
+ },
+ "tar": {
+ "version": "6.1.13",
+ "resolved": "https://registry.npmjs.org/tar/-/tar-6.1.13.tgz",
+ "integrity": "sha512-jdIBIN6LTIe2jqzay/2vtYLlBHa3JF42ot3h1dW8Q0PaAG4v8rm0cvpVePtau5C6OKXGGcgO9q2AMNSWxiLqKw==",
+ "dev": true,
+ "requires": {
+ "chownr": "^2.0.0",
+ "fs-minipass": "^2.0.0",
+ "minipass": "^4.0.0",
+ "minizlib": "^2.1.1",
+ "mkdirp": "^1.0.3",
+ "yallist": "^4.0.0"
+ },
+ "dependencies": {
+ "fs-minipass": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz",
+ "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==",
+ "dev": true,
+ "requires": {
+ "minipass": "^3.0.0"
+ },
+ "dependencies": {
+ "minipass": {
+ "version": "3.3.6",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.3.6.tgz",
+ "integrity": "sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw==",
+ "dev": true,
+ "requires": {
+ "yallist": "^4.0.0"
+ }
+ }
+ }
+ },
+ "mkdirp": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz",
+ "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==",
+ "dev": true
+ },
+ "yallist": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
+ "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
+ "dev": true
+ }
+ }
+ },
+ "terser": {
+ "version": "5.16.3",
+ "resolved": "https://registry.npmjs.org/terser/-/terser-5.16.3.tgz",
+ "integrity": "sha512-v8wWLaS/xt3nE9dgKEWhNUFP6q4kngO5B8eYFUuebsu7Dw/UNAnpUod6UHo04jSSkv8TzKHjZDSd7EXdDQAl8Q==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/source-map": "^0.3.2",
+ "acorn": "^8.5.0",
+ "commander": "^2.20.0",
+ "source-map-support": "~0.5.20"
+ }
+ },
+ "terser-webpack-plugin": {
+ "version": "5.3.9",
+ "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.9.tgz",
+ "integrity": "sha512-ZuXsqE07EcggTWQjXUj+Aot/OMcD0bMKGgF63f7UxYcu5/AJF53aIpK1YoP5xR9l6s/Hy2b+t1AM0bLNPRuhwA==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/trace-mapping": "^0.3.17",
+ "jest-worker": "^27.4.5",
+ "schema-utils": "^3.1.1",
+ "serialize-javascript": "^6.0.1",
+ "terser": "^5.16.8"
+ },
+ "dependencies": {
+ "ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "requires": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ }
+ },
+ "ajv-keywords": {
+ "version": "3.5.2",
+ "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz",
+ "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==",
+ "dev": true
+ },
+ "json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "schema-utils": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz",
+ "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==",
+ "dev": true,
+ "requires": {
+ "@types/json-schema": "^7.0.8",
+ "ajv": "^6.12.5",
+ "ajv-keywords": "^3.5.2"
+ }
+ },
+ "terser": {
+ "version": "5.19.2",
+ "resolved": "https://registry.npmjs.org/terser/-/terser-5.19.2.tgz",
+ "integrity": "sha512-qC5+dmecKJA4cpYxRa5aVkKehYsQKc+AHeKl0Oe62aYjBL8ZA33tTljktDHJSaxxMnbI5ZYw+o/S2DxxLu8OfA==",
+ "dev": true,
+ "requires": {
+ "@jridgewell/source-map": "^0.3.3",
+ "acorn": "^8.8.2",
+ "commander": "^2.20.0",
+ "source-map-support": "~0.5.20"
+ }
+ }
+ }
+ },
+ "test-exclude": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz",
+ "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==",
+ "dev": true,
+ "requires": {
+ "@istanbuljs/schema": "^0.1.2",
+ "glob": "^7.1.4",
+ "minimatch": "^3.0.4"
+ },
+ "dependencies": {
+ "brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "requires": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "glob": {
+ "version": "7.2.3",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
+ "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
+ "dev": true,
+ "requires": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.1.1",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ }
+ },
+ "minimatch": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
+ "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^1.1.7"
+ }
+ }
+ }
+ },
+ "text-table": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
+ "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
+ "dev": true
+ },
+ "through": {
+ "version": "2.3.8",
+ "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz",
+ "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==",
+ "dev": true
+ },
+ "thunky": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz",
+ "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==",
+ "dev": true
+ },
+ "tinymce": {
+ "version": "6.4.2",
+ "resolved": "https://registry.npmjs.org/tinymce/-/tinymce-6.4.2.tgz",
+ "integrity": "sha512-te+4c8PoAwTKPMBQtMQehnSZlOO9Ay5tDgaRFJKBehYb6SlX2PYZ0v3oe/cmiv5EfqdwZLkEMXk2MNOeApZZLg=="
+ },
+ "tmp": {
+ "version": "0.0.33",
+ "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz",
+ "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==",
+ "dev": true,
+ "requires": {
+ "os-tmpdir": "~1.0.2"
+ }
+ },
+ "to-fast-properties": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
+ "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
+ "dev": true
+ },
+ "to-regex-range": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
+ "dev": true,
+ "requires": {
+ "is-number": "^7.0.0"
+ }
+ },
+ "toidentifier": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
+ "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==",
+ "dev": true
+ },
+ "tree-kill": {
+ "version": "1.2.2",
+ "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz",
+ "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==",
+ "dev": true
+ },
+ "tslib": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz",
+ "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg=="
+ },
+ "tuf-js": {
+ "version": "1.1.7",
+ "resolved": "https://registry.npmjs.org/tuf-js/-/tuf-js-1.1.7.tgz",
+ "integrity": "sha512-i3P9Kgw3ytjELUfpuKVDNBJvk4u5bXL6gskv572mcevPbSKCV3zt3djhmlEQ65yERjIbOSncy7U4cQJaB1CBCg==",
+ "dev": true,
+ "requires": {
+ "@tufjs/models": "1.0.4",
+ "debug": "^4.3.4",
+ "make-fetch-happen": "^11.1.1"
+ }
+ },
+ "type-fest": {
+ "version": "0.21.3",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz",
+ "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==",
+ "dev": true
+ },
+ "type-is": {
+ "version": "1.6.18",
+ "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
+ "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
+ "dev": true,
+ "requires": {
+ "media-typer": "0.3.0",
+ "mime-types": "~2.1.24"
+ }
+ },
+ "typed-assert": {
+ "version": "1.0.9",
+ "resolved": "https://registry.npmjs.org/typed-assert/-/typed-assert-1.0.9.tgz",
+ "integrity": "sha512-KNNZtayBCtmnNmbo5mG47p1XsCyrx6iVqomjcZnec/1Y5GGARaxPs6r49RnSPeUP3YjNYiU9sQHAtY4BBvnZwg==",
+ "dev": true
+ },
+ "typescript": {
+ "version": "4.9.4",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.4.tgz",
+ "integrity": "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==",
+ "dev": true
+ },
+ "ua-parser-js": {
+ "version": "0.7.35",
+ "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.35.tgz",
+ "integrity": "sha512-veRf7dawaj9xaWEu9HoTVn5Pggtc/qj+kqTOFvNiN1l0YdxwC1kvel57UCjThjGa3BHBihE8/UJAHI+uQHmd/g==",
+ "dev": true
+ },
+ "unicode-canonical-property-names-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==",
+ "dev": true
+ },
+ "unicode-match-property-ecmascript": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz",
+ "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==",
+ "dev": true,
+ "requires": {
+ "unicode-canonical-property-names-ecmascript": "^2.0.0",
+ "unicode-property-aliases-ecmascript": "^2.0.0"
+ }
+ },
+ "unicode-match-property-value-ecmascript": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz",
+ "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==",
+ "dev": true
+ },
+ "unicode-property-aliases-ecmascript": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz",
+ "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==",
+ "dev": true
+ },
+ "unique-filename": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-3.0.0.tgz",
+ "integrity": "sha512-afXhuC55wkAmZ0P18QsVE6kp8JaxrEokN2HGIoIVv2ijHQd419H0+6EigAFcIzXeMIkcIkNBpB3L/DXB3cTS/g==",
+ "dev": true,
+ "requires": {
+ "unique-slug": "^4.0.0"
+ }
+ },
+ "unique-slug": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-4.0.0.tgz",
+ "integrity": "sha512-WrcA6AyEfqDX5bWige/4NQfPZMtASNVxdmWR76WESYQVAACSgWcR6e9i0mofqqBxYFtL4oAxPIptY73/0YE1DQ==",
+ "dev": true,
+ "requires": {
+ "imurmurhash": "^0.1.4"
+ }
+ },
+ "universalify": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz",
+ "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==",
+ "dev": true
+ },
+ "unpipe": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
+ "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==",
+ "dev": true
+ },
+ "update-browserslist-db": {
+ "version": "1.0.10",
+ "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz",
+ "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==",
+ "dev": true,
+ "requires": {
+ "escalade": "^3.1.1",
+ "picocolors": "^1.0.0"
+ }
+ },
+ "uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "requires": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "util-deprecate": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
+ "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==",
+ "dev": true
+ },
+ "utils-merge": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
+ "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==",
+ "dev": true
+ },
+ "uuid": {
+ "version": "8.3.2",
+ "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
+ "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==",
+ "dev": true
+ },
+ "validate-npm-package-license": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
+ "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
+ "dev": true,
+ "requires": {
+ "spdx-correct": "^3.0.0",
+ "spdx-expression-parse": "^3.0.0"
+ }
+ },
+ "validate-npm-package-name": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/validate-npm-package-name/-/validate-npm-package-name-5.0.0.tgz",
+ "integrity": "sha512-YuKoXDAhBYxY7SfOKxHBDoSyENFeW5VvIIQp2TGQuit8gpK6MnWaQelBKxso72DoxTZfZdcP3W90LqpSkgPzLQ==",
+ "dev": true,
+ "requires": {
+ "builtins": "^5.0.0"
+ }
+ },
+ "vary": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz",
+ "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==",
+ "dev": true
+ },
+ "void-elements": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/void-elements/-/void-elements-2.0.1.tgz",
+ "integrity": "sha512-qZKX4RnBzH2ugr8Lxa7x+0V6XD9Sb/ouARtiasEQCHB1EVU4NXtmHsDDrx1dO4ne5fc3J6EW05BP1Dl0z0iung==",
+ "dev": true
+ },
+ "watchpack": {
+ "version": "2.4.0",
+ "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.4.0.tgz",
+ "integrity": "sha512-Lcvm7MGST/4fup+ifyKi2hjyIAwcdI4HRgtvTpIUxBRhB+RFtUh8XtDOxUfctVCnhVi+QQj49i91OyvzkJl6cg==",
+ "dev": true,
+ "requires": {
+ "glob-to-regexp": "^0.4.1",
+ "graceful-fs": "^4.1.2"
+ }
+ },
+ "wbuf": {
+ "version": "1.7.3",
+ "resolved": "https://registry.npmjs.org/wbuf/-/wbuf-1.7.3.tgz",
+ "integrity": "sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA==",
+ "dev": true,
+ "requires": {
+ "minimalistic-assert": "^1.0.0"
+ }
+ },
+ "wcwidth": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz",
+ "integrity": "sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg==",
+ "dev": true,
+ "requires": {
+ "defaults": "^1.0.3"
+ }
+ },
+ "webpack": {
+ "version": "5.76.1",
+ "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.76.1.tgz",
+ "integrity": "sha512-4+YIK4Abzv8172/SGqObnUjaIHjLEuUasz9EwQj/9xmPPkYJy2Mh03Q/lJfSD3YLzbxy5FeTq5Uw0323Oh6SJQ==",
+ "dev": true,
+ "requires": {
+ "@types/eslint-scope": "^3.7.3",
+ "@types/estree": "^0.0.51",
+ "@webassemblyjs/ast": "1.11.1",
+ "@webassemblyjs/wasm-edit": "1.11.1",
+ "@webassemblyjs/wasm-parser": "1.11.1",
+ "acorn": "^8.7.1",
+ "acorn-import-assertions": "^1.7.6",
+ "browserslist": "^4.14.5",
+ "chrome-trace-event": "^1.0.2",
+ "enhanced-resolve": "^5.10.0",
+ "es-module-lexer": "^0.9.0",
+ "eslint-scope": "5.1.1",
+ "events": "^3.2.0",
+ "glob-to-regexp": "^0.4.1",
+ "graceful-fs": "^4.2.9",
+ "json-parse-even-better-errors": "^2.3.1",
+ "loader-runner": "^4.2.0",
+ "mime-types": "^2.1.27",
+ "neo-async": "^2.6.2",
+ "schema-utils": "^3.1.0",
+ "tapable": "^2.1.1",
+ "terser-webpack-plugin": "^5.1.3",
+ "watchpack": "^2.4.0",
+ "webpack-sources": "^3.2.3"
+ },
+ "dependencies": {
+ "ajv": {
+ "version": "6.12.6",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
+ "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
+ "dev": true,
+ "requires": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ }
+ },
+ "ajv-keywords": {
+ "version": "3.5.2",
+ "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz",
+ "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==",
+ "dev": true
+ },
+ "json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "schema-utils": {
+ "version": "3.3.0",
+ "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz",
+ "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==",
+ "dev": true,
+ "requires": {
+ "@types/json-schema": "^7.0.8",
+ "ajv": "^6.12.5",
+ "ajv-keywords": "^3.5.2"
+ }
+ }
+ }
+ },
+ "webpack-dev-middleware": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-6.0.1.tgz",
+ "integrity": "sha512-PZPZ6jFinmqVPJZbisfggDiC+2EeGZ1ZByyMP5sOFJcPPWSexalISz+cvm+j+oYPT7FIJyxT76esjnw9DhE5sw==",
+ "dev": true,
+ "requires": {
+ "colorette": "^2.0.10",
+ "memfs": "^3.4.12",
+ "mime-types": "^2.1.31",
+ "range-parser": "^1.2.1",
+ "schema-utils": "^4.0.0"
+ }
+ },
+ "webpack-dev-server": {
+ "version": "4.11.1",
+ "resolved": "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-4.11.1.tgz",
+ "integrity": "sha512-lILVz9tAUy1zGFwieuaQtYiadImb5M3d+H+L1zDYalYoDl0cksAB1UNyuE5MMWJrG6zR1tXkCP2fitl7yoUJiw==",
+ "dev": true,
+ "requires": {
+ "@types/bonjour": "^3.5.9",
+ "@types/connect-history-api-fallback": "^1.3.5",
+ "@types/express": "^4.17.13",
+ "@types/serve-index": "^1.9.1",
+ "@types/serve-static": "^1.13.10",
+ "@types/sockjs": "^0.3.33",
+ "@types/ws": "^8.5.1",
+ "ansi-html-community": "^0.0.8",
+ "bonjour-service": "^1.0.11",
+ "chokidar": "^3.5.3",
+ "colorette": "^2.0.10",
+ "compression": "^1.7.4",
+ "connect-history-api-fallback": "^2.0.0",
+ "default-gateway": "^6.0.3",
+ "express": "^4.17.3",
+ "graceful-fs": "^4.2.6",
+ "html-entities": "^2.3.2",
+ "http-proxy-middleware": "^2.0.3",
+ "ipaddr.js": "^2.0.1",
+ "open": "^8.0.9",
+ "p-retry": "^4.5.0",
+ "rimraf": "^3.0.2",
+ "schema-utils": "^4.0.0",
+ "selfsigned": "^2.1.1",
+ "serve-index": "^1.9.1",
+ "sockjs": "^0.3.24",
+ "spdy": "^4.0.2",
+ "webpack-dev-middleware": "^5.3.1",
+ "ws": "^8.4.2"
+ },
+ "dependencies": {
+ "webpack-dev-middleware": {
+ "version": "5.3.3",
+ "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-5.3.3.tgz",
+ "integrity": "sha512-hj5CYrY0bZLB+eTO+x/j67Pkrquiy7kWepMHmUMoPsmcUaeEnQJqFzHJOyxgWlq746/wUuA64p9ta34Kyb01pA==",
+ "dev": true,
+ "requires": {
+ "colorette": "^2.0.10",
+ "memfs": "^3.4.3",
+ "mime-types": "^2.1.31",
+ "range-parser": "^1.2.1",
+ "schema-utils": "^4.0.0"
+ }
+ },
+ "ws": {
+ "version": "8.12.0",
+ "resolved": "https://registry.npmjs.org/ws/-/ws-8.12.0.tgz",
+ "integrity": "sha512-kU62emKIdKVeEIOIKVegvqpXMSTAMLJozpHZaJNDYqBjzlSYXQGviYwN1osDLJ9av68qHd4a2oSjd7yD4pacig==",
+ "dev": true
+ }
+ }
+ },
+ "webpack-merge": {
+ "version": "5.8.0",
+ "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-5.8.0.tgz",
+ "integrity": "sha512-/SaI7xY0831XwP6kzuwhKWVKDP9t1QY1h65lAFLbZqMPIuYcD9QAW4u9STIbU9kaJbPBB/geU/gLr1wDjOhQ+Q==",
+ "dev": true,
+ "requires": {
+ "clone-deep": "^4.0.1",
+ "wildcard": "^2.0.0"
+ }
+ },
+ "webpack-sources": {
+ "version": "3.2.3",
+ "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz",
+ "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==",
+ "dev": true
+ },
+ "webpack-subresource-integrity": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/webpack-subresource-integrity/-/webpack-subresource-integrity-5.1.0.tgz",
+ "integrity": "sha512-sacXoX+xd8r4WKsy9MvH/q/vBtEHr86cpImXwyg74pFIpERKt6FmB8cXpeuh0ZLgclOlHI4Wcll7+R5L02xk9Q==",
+ "dev": true,
+ "requires": {
+ "typed-assert": "^1.0.8"
+ }
+ },
+ "websocket-driver": {
+ "version": "0.7.4",
+ "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz",
+ "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==",
+ "dev": true,
+ "requires": {
+ "http-parser-js": ">=0.5.1",
+ "safe-buffer": ">=5.1.0",
+ "websocket-extensions": ">=0.1.1"
+ }
+ },
+ "websocket-extensions": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz",
+ "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==",
+ "dev": true
+ },
+ "which": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
+ "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ },
+ "wide-align": {
+ "version": "1.1.5",
+ "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz",
+ "integrity": "sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==",
+ "dev": true,
+ "requires": {
+ "string-width": "^1.0.2 || 2 || 3 || 4"
+ }
+ },
+ "wildcard": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/wildcard/-/wildcard-2.0.0.tgz",
+ "integrity": "sha512-JcKqAHLPxcdb9KM49dufGXn2x3ssnfjbcaQdLlfZsL9rH9wgDQjUtDxbo8NE0F6SFvydeu1VhZe7hZuHsB2/pw==",
+ "dev": true
+ },
+ "wrap-ansi": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
+ "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.0.0",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^2.0.1"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ }
+ }
+ },
+ "wrap-ansi-cjs": {
+ "version": "npm:wrap-ansi@7.0.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
+ "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.0.0",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^2.0.1"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ }
+ }
+ },
+ "wrappy": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
+ "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==",
+ "dev": true
+ },
+ "ws": {
+ "version": "8.11.0",
+ "resolved": "https://registry.npmjs.org/ws/-/ws-8.11.0.tgz",
+ "integrity": "sha512-HPG3wQd9sNQoT9xHyNCXoDUa+Xw/VevmY9FoHyQ+g+rrMn4j6FB4np7Z0OhdTgjx6MgQLK7jwSy1YecU1+4Asg==",
+ "dev": true
+ },
+ "y18n": {
+ "version": "5.0.8",
+ "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz",
+ "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==",
+ "dev": true
+ },
+ "yallist": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
+ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
+ "dev": true
+ },
+ "yaml": {
+ "version": "1.10.2",
+ "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz",
+ "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==",
+ "dev": true
+ },
+ "yargs": {
+ "version": "17.6.2",
+ "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.6.2.tgz",
+ "integrity": "sha512-1/9UrdHjDZc0eOU0HxOHoS78C69UD3JRMvzlJ7S79S2nTaWRA/whGCTV8o9e/N/1Va9YIV7Q4sOxD8VV4pCWOw==",
+ "dev": true,
+ "requires": {
+ "cliui": "^8.0.1",
+ "escalade": "^3.1.1",
+ "get-caller-file": "^2.0.5",
+ "require-directory": "^2.1.1",
+ "string-width": "^4.2.3",
+ "y18n": "^5.0.5",
+ "yargs-parser": "^21.1.1"
+ }
+ },
+ "yargs-parser": {
+ "version": "21.1.1",
+ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz",
+ "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==",
+ "dev": true
+ },
+ "zone.js": {
+ "version": "0.11.8",
+ "resolved": "https://registry.npmjs.org/zone.js/-/zone.js-0.11.8.tgz",
+ "integrity": "sha512-82bctBg2hKcEJ21humWIkXRlLBBmrc3nN7DFh5LGGhcyycO2S7FN8NmdvlcKaGFDNVL4/9kFLmwmInTavdJERA==",
+ "requires": {
+ "tslib": "^2.3.0"
+ }
+ },
+ "zrender": {
+ "version": "5.4.1",
+ "resolved": "https://registry.npmjs.org/zrender/-/zrender-5.4.1.tgz",
+ "integrity": "sha512-M4Z05BHWtajY2241EmMPHglDQAJ1UyHQcYsxDNzD9XLSkPDqMq4bB28v9Pb4mvHnVQ0GxyTklZ/69xCFP6RXBA==",
+ "requires": {
+ "tslib": "2.3.0"
+ },
+ "dependencies": {
+ "tslib": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.0.tgz",
+ "integrity": "sha512-N82ooyxVNm6h1riLCoyS9e3fuJ3AMG2zIZs2Gd1ATcSFjSA23Q0fzjjZeh0jbJvWVDZ0cJT8yaNNaaXHzueNjg=="
+ }
+ }
+ }
+ }
+}
diff --git a/package.json b/package.json
new file mode 100644
index 0000000..1b29734
--- /dev/null
+++ b/package.json
@@ -0,0 +1,51 @@
+{
+ "name": "front",
+ "version": "0.0.0",
+ "scripts": {
+ "ng": "ng",
+ "start": "ng serve",
+ "build": "ng build",
+ "watch": "ng build --watch --configuration development",
+ "test": "ng test"
+ },
+ "private": true,
+ "dependencies": {
+ "@angular/animations": "~15.1.0",
+ "@angular/cdk": "^15.0.0",
+ "@angular/common": "~15.1.0",
+ "@angular/compiler": "~15.1.0",
+ "@angular/core": "~15.1.0",
+ "@angular/forms": "~15.1.0",
+ "@angular/material": "^15.0.0",
+ "@angular/platform-browser": "~15.1.0",
+ "@angular/platform-browser-dynamic": "~15.1.0",
+ "@angular/router": "~15.1.0",
+ "@tinymce/tinymce-angular": "^7.0.0",
+ "echarts": "^5.4.0",
+ "ngx-echarts": "^8.0.1",
+ "ngx-sortablejs": "^11.1.0",
+ "particles.js": "^2.0.0",
+ "rxjs": "~6.6.0",
+ "sortablejs": "^1.15.0",
+ "swiper": "^8.4.7",
+ "tinymce": "^6.4.2",
+ "tslib": "^2.3.0",
+ "zone.js": "~0.11.4"
+ },
+ "devDependencies": {
+ "@angular-devkit/build-angular": "^15.1.0",
+ "@angular/cli": "^15.2.9",
+ "@angular/compiler-cli": "~15.1.0",
+ "@types/echarts": "^4.9.12",
+ "@types/jasmine": "^4.0.0",
+ "@types/node": "^12.11.1",
+ "@types/sortablejs": "^1.15.1",
+ "jasmine-core": "^4.0.0",
+ "karma": "^6.4.1",
+ "karma-chrome-launcher": "^3.1.0",
+ "karma-coverage": "^2.0.3",
+ "karma-jasmine": "^4.0.0",
+ "karma-jasmine-html-reporter": "^1.7.0",
+ "typescript": "~4.9.3"
+ }
+}
diff --git a/src/app/_directives/particles.directive.ts b/src/app/_directives/particles.directive.ts
new file mode 100644
index 0000000..9110e94
--- /dev/null
+++ b/src/app/_directives/particles.directive.ts
@@ -0,0 +1,468 @@
+import { Directive, ElementRef, Input, OnDestroy, HostListener, OnInit } from "@angular/core";
+
+/*
+ Variables to be used outside of directive scope
+ To improve performance.
+*/
+const TAU: number = Math.PI * 2;
+const QUADTREE_CAPACITY: number = 4;
+let linkBatches: number = 10;
+let mouse: {x: number,y: number} = {x: 0, y: 0};
+
+
+/*
+ Variables to be initiated
+*/
+let linkDistance: number;
+let linkDistance2: number;
+let repulseDistance: number;
+let particleSpeed: number;
+let particleSize: number;
+let bounce: boolean;
+let quadTree: QuadTree;
+let canvas: HTMLCanvasElement;
+let ctx: CanvasRenderingContext2D;
+
+
+
+@Directive({
+ selector: "[repulse-particles]"
+})
+export class ParticlesDirective implements OnDestroy, OnInit {
+
+ @Input() number: number = 80;
+ @Input() speed: number = 6;
+ @Input() linkWidth: number = .5;
+ @Input() linkDistance: number = 140;
+ @Input() size: number = 3;
+ @Input() repulseDistance: number = 140;
+ @Input() particleHex: string = "#FFF";
+ @Input() linkHex: string = "#FFF";
+ @Input() bounce: boolean = true;
+ @Input() densityArea: number = 800;
+
+
+ particlesNumber: number;
+ particlesList: Particle[] = [];
+ links: Link[][] = [];
+ linkBatchAlphas: number[] = [];
+ linkPool: Link[] = [];
+ candidates: Particle[] = [];
+ boundary: Bounds;
+
+ animationFrame;
+
+ constructor(
+ public el: ElementRef,
+ ) {
+ canvas = this.el.nativeElement;
+ canvas.style.height = "100%";
+ canvas.style.width = "100%";
+ ctx = canvas.getContext("2d");
+ for (var i = 1/(linkBatches + 1); i < 1; i += 1/(linkBatches + 1)) {
+ this.links.push([]);
+ this.linkBatchAlphas.push(i);
+ }
+ this.initVariables();
+ }
+
+ ngOnInit() {
+ this.setCanvasSize();
+ this.animate();
+ }
+
+ @HostListener("window:resize") onResize() {
+ this.setCanvasSize();
+ }
+
+ @HostListener("mouseleave") onMouseLeave() {
+ this.stopMouse()
+ }
+
+ @HostListener("touchend") onTouchEnd() {
+ this.stopMouse()
+ }
+
+ @HostListener("mousemove", ["$event"]) onMouseMove(e) {
+ this.setMousePos(e.offsetX, e.offsetY);
+ }
+
+ @HostListener("touchmove", ["$event"]) onTouchMove(e) {
+ this.setMousePos(e.touches[0].clientX, e.touches[0].clientY);
+ }
+
+ @HostListener("change") ngOnChanges() {
+ this.initVariables();
+ this.resetParticles();
+ }
+
+ setMousePos(x, y) {
+ mouse.x = x;
+ mouse.y = y;
+ }
+
+ stopMouse() {
+ mouse.x = null;
+ }
+
+ initVariables() {
+ linkDistance = this.linkDistance;
+ linkDistance2 = (0.7 * linkDistance) ** 2;
+ repulseDistance = this.repulseDistance;
+ particleSpeed = this.speed;
+ particleSize = this.size;
+ bounce = this.bounce;
+ if (this.densityArea) this.scaleDensity();
+ }
+
+
+ animate() {
+ ctx.clearRect(0, 0, canvas.width, canvas.height);
+ this.updateParticles();
+ this.updateLinks();
+ this.animationFrame = requestAnimationFrame(this.animate.bind(this));
+ }
+
+ updateParticles() {
+ quadTree.close();
+ ctx.fillStyle = this.particleHex;
+ ctx.beginPath();
+ for (const p of this.particlesList) p.update(ctx, true);
+ ctx.fill();
+ }
+
+ updateLinks() {
+ let i: number;
+ let link: Link;
+ let alphaIdx = 0;
+
+ for (const p1 of this.particlesList) {
+ p1.explored = true;
+ const count = quadTree.query(p1, 0, this.candidates);
+ for (i = 0; i < count; i++) {
+ const p2 = this.candidates[i];
+ if (!p2.explored) {
+ link = this.linkPool.length ? this.linkPool.pop() : new Link();
+ link.init(p1, p2);
+ this.links[link.batchId].push(link);
+ }
+ }
+ }
+
+ ctx.lineWidth = this.linkWidth;
+ ctx.strokeStyle = this.linkHex;
+ for (const l of this.links) {
+ ctx.globalAlpha = this.linkBatchAlphas[alphaIdx++];
+ ctx.beginPath();
+ while (l.length) this.linkPool.push(l.pop().addPath(ctx));
+ ctx.stroke();
+ }
+ ctx.globalAlpha = 1;
+ }
+
+ resetParticles() {
+ this.particlesList = [];
+ for (let i = 0; i < this.particlesNumber; i++) {
+ this.particlesList.push(new Particle(canvas, particleSize))
+ }
+ quadTree = new QuadTree();
+ for (const p of this.particlesList) p.reset(canvas);
+ }
+
+ scaleDensity() {
+ var area = canvas.width * canvas.height / 1000;
+ this.particlesNumber = (area * this.number / this.densityArea) | 0;
+ }
+
+ setCanvasSize() {
+ canvas.height = canvas.offsetHeight;
+ canvas.width = canvas.offsetWidth;
+ if (this.densityArea) this.scaleDensity();
+ this.resetParticles();
+ }
+
+ ngOnDestroy(): void {
+ cancelAnimationFrame(this.animationFrame);
+ }
+}
+
+class Link {
+ p1: Particle;
+ p2: Particle;
+ alpha: number;
+ batchId: number;
+ constructor() { }
+ init(p1: Particle, p2: Particle) {
+ this.p1 = p1;
+ this.p2 = p2;
+ const dx = p1.x - p2.x;
+ const dy = p1.y - p2.y;
+ this.alpha = 1 - (dx * dx + dy * dy) / linkDistance2;
+ this.batchId = this.alpha * linkBatches | 0;
+ this.batchId = this.batchId >= linkBatches ? linkBatches : this.batchId;
+ }
+ addPath(ctx) {
+ ctx.moveTo(this.p1.x, this.p1.y);
+ ctx.lineTo(this.p2.x, this.p2.y);
+ return this;
+ }
+
+}
+
+
+class Particle {
+ r: number;
+ speedScale: number;
+ x: number;
+ y: number;
+ vx: number;
+ vy: number;
+ quad: QuadTree;
+ explored: boolean;
+ constructor (canvas, r) {
+ this.r = r;
+ this.speedScale = particleSpeed / 2;
+ this.reset(canvas, r);
+ }
+ reset(canvas, r = this.r) {
+ const W = canvas.width - r * 2;
+ const H = canvas.height - r * 2;
+ this.x = Math.random() * W + r;
+ this.y = Math.random() * H + r;
+ this.vx = Math.random() - 0.5;
+ this.vy = Math.random() - 0.5;
+ this.quad = undefined;
+ this.explored = false;
+
+ }
+ addPath(ctx) {
+ ctx.moveTo(this.x + this.r, this.y);
+ ctx.arc(this.x, this.y, this.r, 0, TAU);
+ }
+ near(p) {
+ return ((p.x - this.x) ** 2 + (p.y - this.y) ** 2) <= linkDistance2;
+ }
+ intersects(range) {
+ const xd = Math.abs(range.x - this.x);
+ const yd = Math.abs(range.y - this.y);
+ const r = linkDistance;
+ const w = range.w;
+ const h = range.h;
+ if (xd > r + w || yd > r + h) { return false }
+ if (xd <= w || yd <= h) { return true }
+ return ((xd - w) ** 2 + (yd - h) ** 2) <= linkDistance2;
+
+ }
+ update(ctx, repulse = true) {
+ this.explored = false;
+ const r = this.r;
+ let W, H;
+ this.x += this.vx * this.speedScale;
+ this.y += this.vy * this.speedScale;
+
+ if (bounce) {
+ W = ctx.canvas.width - r;
+ H = ctx.canvas.height - r;
+ if (this.x > W || this.x < 0) {
+ this.vx = -this.vx;
+ }
+ if (this.y > H || this.y < 0) {
+ this.vy = -this.vy;
+ }
+ } else {
+ W = ctx.canvas.width + r;
+ H = ctx.canvas.height + r;
+ if (this.x > W) {
+ this.x = 0;
+ this.y = Math.random() * (H - r);
+ } else if (this.x < -r) {
+ this.x = W - r;
+ this.y = Math.random() * (H - r);
+ }
+ if (this.y > H) {
+ this.y = 0
+ this.x = Math.random() * (W - r);
+ } else if (this.y < -r) {
+ this.y = H - r;
+ this.x = Math.random() * (W - r);
+ }
+ }
+ repulse && mouse.x && this.repulse();
+ this.addPath(ctx);
+ quadTree.insert(this);
+ this.quad && (this.quad.drawn = false)
+ }
+ repulse() {
+ var dx = this.x - mouse.x;
+ var dy = this.y - mouse.y;
+
+ const dist = (dx * dx + dy * dy) ** 0.5;
+ var rf = ((1 - (dist / repulseDistance) ** 2) * 100);
+ rf = (rf < 0 ? 0 : rf > 50 ? 50 : rf) / dist;
+
+ var posX = this.x + dx * rf;
+ var posY = this.y + dy * rf;
+
+ if (bounce) {
+ if (posX - particleSize > 0 && posX + particleSize < canvas.width) this.x = posX;
+ if (posY - particleSize > 0 && posY + particleSize < canvas.height) this.y = posY;
+ } else {
+ this.x = posX;
+ this.y = posY;
+ }
+ }
+}
+
+class Bounds {
+ x: number;
+ y: number;
+ w: number;
+ h: number;
+ left: number;
+ right: number;
+ top: number;
+ bottom: number;
+ diagonal: number;
+ constructor(x, y, w, h) { this.init(x, y, w, h) }
+ init(x,y,w,h) {
+ this.x = x;
+ this.y = y;
+ this.w = w;
+ this.h = h;
+ this.left = x - w;
+ this.right = x + w;
+ this.top = y - h;
+ this.bottom = y + h;
+ this.diagonal = (w * w + h * h);
+ }
+
+ contains(p) {
+ return (p.x >= this.left && p.x <= this.right && p.y >= this.top && p.y <= this.bottom);
+ }
+
+ near(p) {
+ if (!this.contains(p)) {
+ const dx = p.x - this.x;
+ const dy = p.y - this.y;
+ const dist = (dx * dx + dy * dy) - this.diagonal - linkDistance2;
+ return dist < 0;
+ }
+ return true;
+ }
+}
+
+class QuadTree {
+ boundary: Bounds;
+ divided: boolean;
+ points: Particle[];
+ pointCount: number;
+ drawn: boolean;
+ depth: number;
+
+ NE: QuadTree;
+ NW: QuadTree;
+ SE: QuadTree;
+ SW: QuadTree;
+ constructor(boundary: Bounds = new Bounds(canvas.width / 2,canvas.height / 2,canvas.width / 2 ,canvas.height / 2), depth = 0) {
+ this.boundary = boundary;
+ this.divided = false;
+ this.points = depth > 1 ? [] : null;
+ this.pointCount = 0
+ this.drawn = false;
+ this.depth = depth;
+ if(depth === 0) { // BM67 Fix on resize
+ this.subdivide();
+ this.NE.subdivide();
+ this.NW.subdivide();
+ this.SE.subdivide();
+ this.SW.subdivide();
+ }
+ }
+
+ addPath() {
+ const b = this.boundary;
+ ctx.rect(b.left, b.top, b.w * 2, b.h * 2);
+ this.drawn = true;
+ }
+ addToSubQuad(particle) {
+ if (this.NE.insert(particle)) { return true }
+ if (this.NW.insert(particle)) { return true }
+ if (this.SE.insert(particle)) { return true }
+ if (this.SW.insert(particle)) { return true }
+ particle.quad = undefined;
+ }
+ insert(particle) {
+ if (this.depth > 0 && !this.boundary.contains(particle)) { return false }
+
+ if (this.depth > 1 && this.pointCount < QUADTREE_CAPACITY) {
+ this.points[this.pointCount++] = particle;
+ particle.quad = this;
+ return true;
+ }
+ if (!this.divided) { this.subdivide() }
+ return this.addToSubQuad(particle);
+ }
+
+ subdivide() {
+ if (!this.NW) {
+ const x = this.boundary.x;
+ const y = this.boundary.y;
+ const w = this.boundary.w / 2;
+ const h = this.boundary.h / 2;
+ const depth = this.depth + 1;
+
+ this.NE = new QuadTree(new Bounds(x + w, y - h, w, h), depth);
+ this.NW = new QuadTree(new Bounds(x - w, y - h, w, h), depth);
+ this.SE = new QuadTree(new Bounds(x + w, y + h, w, h), depth);
+ this.SW = new QuadTree(new Bounds(x - w, y + h, w, h), depth);
+ } else {
+ this.NE.pointCount = 0;
+ this.NW.pointCount = 0;
+ this.SE.pointCount = 0;
+ this.SW.pointCount = 0;
+ }
+
+ this.divided = true;
+ }
+ query(part, fc, found) {
+ var i = this.pointCount;
+ if (this.depth === 0 || this.boundary.near(part)) {
+ if (this.depth > 1) {
+ while (i--) {
+ const p = this.points[i];
+ if (!p.explored && part.near(p)) { found[fc++] = p }
+ }
+ if (this.divided) {
+ fc = this.NE.pointCount ? this.NE.query(part, fc, found) : fc;
+ fc = this.NW.pointCount ? this.NW.query(part, fc, found) : fc;
+ fc = this.SE.pointCount ? this.SE.query(part, fc, found) : fc;
+ fc = this.SW.pointCount ? this.SW.query(part, fc, found) : fc;
+ }
+ } else if(this.divided) {
+ fc = this.NE.query(part, fc, found);
+ fc = this.NW.query(part, fc, found);
+ fc = this.SE.query(part, fc, found);
+ fc = this.SW.query(part, fc, found);
+ }
+ }
+ return fc;
+ }
+
+ close() {
+ if (this.divided) {
+ this.NE.close();
+ this.NW.close();
+ this.SE.close();
+ this.SW.close();
+ }
+
+ if (this.depth === 2 && this.divided) {
+ this.NE.pointCount = 0;
+ this.NW.pointCount = 0;
+ this.SE.pointCount = 0;
+ this.SW.pointCount = 0;
+ } else if (this.depth > 2) {
+ this.divided = false;
+ }
+ }
+}
diff --git a/src/app/_helpers/auth.guard.ts b/src/app/_helpers/auth.guard.ts
new file mode 100644
index 0000000..8b720cb
--- /dev/null
+++ b/src/app/_helpers/auth.guard.ts
@@ -0,0 +1,24 @@
+import { Injectable } from '@angular/core';
+import { Router, CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot } from '@angular/router';
+
+import { AuthenticationService } from '@app/_services';
+
+@Injectable({ providedIn: 'root' })
+export class AuthGuard implements CanActivate {
+ constructor(private router: Router, private authenticationService: AuthenticationService) {
+ }
+
+ canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
+ const oauthToken = this.authenticationService.oauthTokenValue;
+ if (oauthToken) {
+ // logged in so return true
+ return true;
+ }
+
+ // not logged in so redirect to login page with the return url
+ this.authenticationService.popup('login');
+
+ //this.router.navigate(['/login'], { queryParams: { returnUrl: state.url } });
+ return false;
+ }
+}
diff --git a/src/app/_helpers/error.interceptor.ts b/src/app/_helpers/error.interceptor.ts
new file mode 100644
index 0000000..0431d26
--- /dev/null
+++ b/src/app/_helpers/error.interceptor.ts
@@ -0,0 +1,24 @@
+import { Injectable } from '@angular/core';
+import { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';
+import { Observable, throwError } from 'rxjs';
+import { catchError } from 'rxjs/operators';
+import { AuthenticationService } from '@app/_services';
+import {Router} from "@angular/router";
+
+@Injectable()
+export class ErrorInterceptor implements HttpInterceptor {
+ constructor(private authenticationService: AuthenticationService, private router: Router) {
+ }
+
+ intercept(request: HttpRequest, next: HttpHandler): Observable> {
+ return next.handle(request).pipe(catchError(err => {
+ if (err.status === 401) {
+ this.authenticationService.logout();
+ this.authenticationService.popup('login');
+ }
+
+ const error = err.error || err.statusText;
+ return throwError(error);
+ }));
+ }
+}
diff --git a/src/app/_helpers/fake-backend.ts b/src/app/_helpers/fake-backend.ts
new file mode 100644
index 0000000..23442e1
--- /dev/null
+++ b/src/app/_helpers/fake-backend.ts
@@ -0,0 +1,77 @@
+import { Injectable } from '@angular/core';
+import { HttpRequest, HttpResponse, HttpHandler, HttpEvent, HttpInterceptor, HTTP_INTERCEPTORS } from '@angular/common/http';
+import { Observable, of, throwError } from 'rxjs';
+import { delay, mergeMap, materialize, dematerialize } from 'rxjs/operators';
+
+const users = [{ id: 1, username: 'test', password: 'test', firstName: 'Test', lastName: 'User' }];
+
+@Injectable()
+export class FakeBackendInterceptor implements HttpInterceptor {
+ intercept(request: HttpRequest, next: HttpHandler): Observable> {
+ const { url, method, headers, body } = request;
+
+ // wrap in delayed observable to simulate server api call
+ return of(null)
+ .pipe(mergeMap(handleRoute))
+ .pipe(materialize()) // call materialize and dematerialize to ensure delay even if an error is thrown (https://github.com/Reactive-Extensions/RxJS/issues/648)
+ .pipe(delay(500))
+ .pipe(dematerialize());
+
+ function handleRoute() {
+ switch (true) {
+ case url.endsWith('/users/authenticate') && method === 'POST':
+ return authenticate();
+ case url.endsWith('/users') && method === 'GET':
+ return getUsers();
+ default:
+ // pass through any requests not handled above
+ return next.handle(request);
+ }
+ }
+
+ // route functions
+
+ function authenticate() {
+ const { username, password } = body;
+ const user = users.find(x => x.username === username && x.password === password);
+ if (!user) return error('Username or password is incorrect');
+ return ok({
+ id: user.id,
+ username: user.username,
+ firstName: user.firstName,
+ lastName: user.lastName,
+ token: 'fake-jwt-token'
+ })
+ }
+
+ function getUsers() {
+ if (!isLoggedIn()) return unauthorized();
+ return ok(users);
+ }
+
+ // helper functions
+
+ function ok(body?) {
+ return of(new HttpResponse({ status: 200, body }))
+ }
+
+ function error(message) {
+ return throwError({ error: { message } });
+ }
+
+ function unauthorized() {
+ return throwError({ status: 401, error: { message: 'Unauthorised' } });
+ }
+
+ function isLoggedIn() {
+ return headers.get('Authorization') === 'Bearer fake-jwt-token';
+ }
+ }
+}
+
+export let fakeBackendProvider = {
+ // use fake backend in place of Http service for backend-less development
+ provide: HTTP_INTERCEPTORS,
+ useClass: FakeBackendInterceptor,
+ multi: true
+};
\ No newline at end of file
diff --git a/src/app/_helpers/index.ts b/src/app/_helpers/index.ts
new file mode 100644
index 0000000..175f9e2
--- /dev/null
+++ b/src/app/_helpers/index.ts
@@ -0,0 +1,4 @@
+export * from './auth.guard';
+export * from './error.interceptor';
+export * from './fake-backend';
+export * from './jwt.interceptor';
\ No newline at end of file
diff --git a/src/app/_helpers/jwt.interceptor.ts b/src/app/_helpers/jwt.interceptor.ts
new file mode 100644
index 0000000..c5431b0
--- /dev/null
+++ b/src/app/_helpers/jwt.interceptor.ts
@@ -0,0 +1,26 @@
+import { Injectable } from '@angular/core';
+import { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';
+import { Observable } from 'rxjs';
+
+import { environment } from '@environments/environment';
+import { AuthenticationService } from '@app/_services';
+
+@Injectable()
+export class JwtInterceptor implements HttpInterceptor {
+ constructor(private authenticationService: AuthenticationService) { }
+
+ intercept(request: HttpRequest, next: HttpHandler): Observable> {
+ const oauthToken = this.authenticationService.token.value;
+ const isLoggedIn = oauthToken && oauthToken.access_token;
+ const isApiUrl = request.url.startsWith(environment.apiUrl);
+ if (isLoggedIn && isApiUrl) {
+ request = request.clone({
+ setHeaders: {
+ Authorization: `${oauthToken.token_type} ${oauthToken.access_token}`
+ }
+ });
+ }
+
+ return next.handle(request);
+ }
+}
diff --git a/src/app/_models/asset.ts b/src/app/_models/asset.ts
new file mode 100644
index 0000000..54e5c0e
--- /dev/null
+++ b/src/app/_models/asset.ts
@@ -0,0 +1,29 @@
+import {UserData} from "@app/_models/user";
+
+export class Asset {
+ id: string;
+ type: string;
+ path: string;
+ mime: string;
+ filename: string;
+ extension: string;
+ createdAt: string;
+ coordinates?: any;
+ links?: AssetLinks;
+ user?: UserData;
+}
+
+export class AssetsList {
+ data: Asset[];
+}
+
+export class AssetData {
+ data: Asset;
+}
+
+export class AssetLinks {
+ open?: string;
+ download?: string;
+ full?: string;
+ thumb?: string;
+}
diff --git a/src/app/_models/index.ts b/src/app/_models/index.ts
new file mode 100644
index 0000000..0246f3c
--- /dev/null
+++ b/src/app/_models/index.ts
@@ -0,0 +1,3 @@
+export * from './asset';
+export * from './oauthToken';
+export * from './user';
diff --git a/src/app/_models/oauthToken.ts b/src/app/_models/oauthToken.ts
new file mode 100644
index 0000000..61886f5
--- /dev/null
+++ b/src/app/_models/oauthToken.ts
@@ -0,0 +1,6 @@
+export class OauthToken {
+ access_token: string;
+ expires_in: number;
+ refresh_token: string;
+ token_type: string;
+}
diff --git a/src/app/_models/user.ts b/src/app/_models/user.ts
new file mode 100644
index 0000000..c61f68d
--- /dev/null
+++ b/src/app/_models/user.ts
@@ -0,0 +1,23 @@
+export class User {
+ id: string;
+ name: string;
+ firstName: string;
+ lastName: string;
+ initials: string;
+ email: string;
+ phone: string;
+ avatar?: any;
+ isPrivileged: boolean;
+ roles?: any;
+ membership?: any;
+ privileges?: any;
+}
+
+export class UsersList {
+ data: User[];
+}
+
+export class UserData {
+ data: User;
+}
+
diff --git a/src/app/_modules/administration/administration.module.ts b/src/app/_modules/administration/administration.module.ts
new file mode 100644
index 0000000..de3a9cd
--- /dev/null
+++ b/src/app/_modules/administration/administration.module.ts
@@ -0,0 +1,35 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {RouterModule} from "@angular/router";
+import {AuthGuard} from "@app/_helpers";
+import {AdministrationPageComponent} from "@app/_modules/administration/page/administration-page.component";
+import {BrowserModule} from "@angular/platform-browser";
+import {AdministrateCompanyComponent} from "@app/_modules/administration/company/administrate-company.component";
+import {AdministrateCommitteeComponent} from "@app/_modules/administration/committee/administrate-committee.component";
+import {AdvisoriesModule} from "@app/_modules/advisories/advisories.module";
+import {CompaniesModule} from "@app/_modules/companies/companies.module";
+
+type PathMatch = "full" | "prefix" | undefined;
+const routes = [
+ {path: 'administrate', redirectTo: 'administrate/company', pathMatch: 'full' as PathMatch},
+ {path: 'administrate/:tab', component: AdministrationPageComponent, canActivate: [AuthGuard]}
+];
+
+@NgModule({
+ imports: [
+ BrowserModule,
+ CommonModule,
+ RouterModule.forRoot(routes),
+ AdvisoriesModule,
+ CompaniesModule
+ ],
+ declarations: [
+ AdministrationPageComponent,
+ AdministrateCompanyComponent,
+ AdministrateCommitteeComponent
+ ],
+ exports: [
+ RouterModule
+ ]
+})
+export class AdministrationModule {}
diff --git a/src/app/_modules/administration/committee/administrate-committee.component.html b/src/app/_modules/administration/committee/administrate-committee.component.html
new file mode 100644
index 0000000..1b1c466
--- /dev/null
+++ b/src/app/_modules/administration/committee/administrate-committee.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/administration/committee/administrate-committee.component.scss b/src/app/_modules/administration/committee/administrate-committee.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/administration/committee/administrate-committee.component.ts b/src/app/_modules/administration/committee/administrate-committee.component.ts
new file mode 100644
index 0000000..1cf95be
--- /dev/null
+++ b/src/app/_modules/administration/committee/administrate-committee.component.ts
@@ -0,0 +1,20 @@
+import {Component} from '@angular/core';
+
+@Component({
+ selector: 'administrate-committee',
+ templateUrl: 'administrate-committee.component.html',
+ styleUrls: ['administrate-committee.component.scss']
+})
+export class AdministrateCommitteeComponent {
+
+ constructor() {
+ }
+
+ ngOnInit() {
+
+ }
+
+ ngOnDestroy() {
+ }
+
+}
diff --git a/src/app/_modules/administration/company/administrate-company.component.html b/src/app/_modules/administration/company/administrate-company.component.html
new file mode 100644
index 0000000..cf5c8db
--- /dev/null
+++ b/src/app/_modules/administration/company/administrate-company.component.html
@@ -0,0 +1,2 @@
+
+
diff --git a/src/app/_modules/administration/company/administrate-company.component.scss b/src/app/_modules/administration/company/administrate-company.component.scss
new file mode 100644
index 0000000..ba5dfec
--- /dev/null
+++ b/src/app/_modules/administration/company/administrate-company.component.scss
@@ -0,0 +1,4 @@
+company {
+ display: block;
+ margin-bottom: 24px;
+}
diff --git a/src/app/_modules/administration/company/administrate-company.component.ts b/src/app/_modules/administration/company/administrate-company.component.ts
new file mode 100644
index 0000000..9b407d6
--- /dev/null
+++ b/src/app/_modules/administration/company/administrate-company.component.ts
@@ -0,0 +1,47 @@
+import {Component, Input} from '@angular/core';
+import {CompaniesService} from "@app/_services/companies.service";
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+
+@Component({
+ selector: 'administrate-company',
+ templateUrl: 'administrate-company.component.html',
+ styleUrls: ['administrate-company.component.scss']
+})
+export class AdministrateCompanyComponent {
+ @Input() companyId: string;
+ public company: any;
+
+ subscription: Subscription;
+
+ constructor(private companiesService: CompaniesService, private listsService: ListsService) {
+ }
+
+
+ get permissions() {
+ return this.company?.permissions;
+ }
+ get isEditable() {
+ return this.permissions?.edit || this.permissions?.anything;
+ }
+
+
+ ngOnInit() {
+ this.subscription = this.listsService.controls('company-main-info').subscribe(res => {
+ this.fetch();
+ });
+ }
+
+ ngOnDestroy() {
+ this.subscription?.unsubscribe();
+ }
+
+
+ fetch() {
+ let include = ['phones', 'emails', 'legalAddress', 'logo', 'permissions'];
+ this.companiesService.fetch(this.company?.id || this.companyId, {include: include.join(',')}).subscribe(res => {
+ this.company = res.data;
+ });
+ }
+
+}
diff --git a/src/app/_modules/administration/page/administration-page.component.html b/src/app/_modules/administration/page/administration-page.component.html
new file mode 100644
index 0000000..4d1002d
--- /dev/null
+++ b/src/app/_modules/administration/page/administration-page.component.html
@@ -0,0 +1,11 @@
+
+
Панель управления
+
+
+
+
+
diff --git a/src/app/_modules/administration/page/administration-page.component.scss b/src/app/_modules/administration/page/administration-page.component.scss
new file mode 100644
index 0000000..f02274e
--- /dev/null
+++ b/src/app/_modules/administration/page/administration-page.component.scss
@@ -0,0 +1,5 @@
+.container {
+ h1 {
+ margin-top: 40px;
+ }
+}
diff --git a/src/app/_modules/administration/page/administration-page.component.ts b/src/app/_modules/administration/page/administration-page.component.ts
new file mode 100644
index 0000000..d22610c
--- /dev/null
+++ b/src/app/_modules/administration/page/administration-page.component.ts
@@ -0,0 +1,36 @@
+import {Component} from '@angular/core';
+import {ActivatedRoute, NavigationEnd, Router} from "@angular/router";
+import {Subscription} from "rxjs";
+
+@Component({
+ templateUrl: 'administration-page.component.html',
+ styleUrls: ['administration-page.component.scss']
+})
+export class AdministrationPageComponent {
+ public tabs = [{name: 'company', title: 'Структура ФАУ «ФЦС»'}, {name: 'committee', title: 'Структура ТК 465'}];
+ routeSubscription: Subscription;
+
+ constructor(private route: ActivatedRoute, private router: Router) {
+ this.routeSubscription = this.router.events.subscribe(event => {
+ if (event instanceof NavigationEnd && (this.route.snapshot.paramMap.get('tab') !== this.tab?.name)) this.switchTab(this.route.snapshot.paramMap.get('tab'));
+ });
+ }
+
+ get tab() {
+ return this.tabs.filter(tab => {return tab.active})[0];
+ }
+
+ ngOnInit() {
+
+ }
+
+ ngOnDestroy() {
+ this.routeSubscription?.unsubscribe();
+ }
+
+
+ switchTab(name: string) {
+ this.tabs.map(tab => {tab.active = tab.name === name});
+ }
+
+}
diff --git a/src/app/_modules/advisories/advisories.module.ts b/src/app/_modules/advisories/advisories.module.ts
new file mode 100644
index 0000000..02de898
--- /dev/null
+++ b/src/app/_modules/advisories/advisories.module.ts
@@ -0,0 +1,23 @@
+import {NgModule} from '@angular/core'
+import {CommonModule} from '@angular/common'
+import {AdvisoriesTreeComponent} from "@app/_modules/advisories/tree/advisories-tree.component";
+import {AdvisoriesTreeAdvisoryComponent} from "@app/_modules/advisories/tree/advisory/advisories-tree-advisory.component";
+import {AdvisoriesTreeCompanyComponent} from "@app/_modules/advisories/tree/company/advisories-tree-company.component";
+import {AdvisoriesTreeMemberComponent} from "@app/_modules/advisories/tree/member/advisories-tree-member.component";
+
+@NgModule({
+ imports: [
+ CommonModule
+ ],
+ declarations: [
+ AdvisoriesTreeComponent,
+ AdvisoriesTreeAdvisoryComponent,
+ AdvisoriesTreeCompanyComponent,
+ AdvisoriesTreeMemberComponent
+ ],
+ exports: [
+ AdvisoriesTreeComponent,
+ AdvisoriesTreeCompanyComponent
+ ]
+})
+export class AdvisoriesModule {}
diff --git a/src/app/_modules/advisories/tree/advisories-tree.component.html b/src/app/_modules/advisories/tree/advisories-tree.component.html
new file mode 100644
index 0000000..738b1ba
--- /dev/null
+++ b/src/app/_modules/advisories/tree/advisories-tree.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/advisories/tree/advisories-tree.component.scss b/src/app/_modules/advisories/tree/advisories-tree.component.scss
new file mode 100644
index 0000000..795a644
--- /dev/null
+++ b/src/app/_modules/advisories/tree/advisories-tree.component.scss
@@ -0,0 +1,158 @@
+.item {
+ &.committee {
+ >.bar .mid .info .logo {
+ border: #F9B417 solid 1px;
+ color: #F9B417;
+ background-color: transparent;
+ }
+ &.main {
+ >.bar .mid .info .logo {
+ background: #3E3D40 none;
+ border: none;
+ color: #ffffff;
+ font-weight: bold;
+ }
+ }
+ }
+ &.workgroup {
+ >.bar .mid .info .logo {
+ border: #86898E solid 1px;
+ color: #86898E;
+ background-color: transparent;
+ }
+ }
+
+ .bar {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 16px 0;
+ border-bottom: #E0E0E0 solid 1px;
+ .left {
+ flex-shrink: 0;
+ cursor: pointer;
+ &:before {
+ display: block;
+ width: 40px;
+ height: 24px;
+ background: transparent url("~src/assets/images/icons/circle_plus_24.svg") 50% 50% no-repeat;
+ content: "";
+ }
+ }
+ .mid {
+ flex-grow: 1;
+ padding: 0 16px;
+ .info {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ .logo {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ position: relative;
+ flex-shrink: 0;
+ width: 40px;
+ height: 40px;
+ margin-right: 16px;
+ border-radius: 100px;
+ background: #F9B417 url('~src/assets/images/icons/architecture_24.svg') 50% 50% no-repeat;
+ img {
+ width: 100%;
+ height: 100%;
+ border-radius: 100px;
+ object-fit: cover;
+ background-color: #ffffff;
+ }
+ &.voter:before {
+ position: absolute;
+ right: -1px;
+ bottom: -1px;
+ width: 14px;
+ height: 14px;
+ border: #ffffff solid 1px;
+ border-radius: 100px;
+ //background: transparent url('~src/assets/images/icons/star_sign.svg') 50% 50% no-repeat;
+ content: '';
+ }
+ }
+ .name {
+ p {
+ margin: 0;
+ &.sub {
+ color: #7f7f7f;
+ }
+ }
+ }
+ }
+ }
+ .right {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ flex-shrink: 0;
+ button {
+ margin-left: 24px;
+ &.edit {
+ background-image: url('~src/assets/images/icons/edit_24dp.svg');
+ }
+ &.add-company {
+ background-image: url('~src/assets/images/icons/note_add_20.svg');
+ }
+ &.add-person {
+ background-image: url('~src/assets/images/icons/note_add_20.svg');
+ }
+ &.add-group {
+ background-image: url('~src/assets/images/icons/add_folder_24.svg');
+ }
+ &.add-child {
+ background-image: url('~src/assets/images/icons/add_library_dark_24.svg');
+ }
+ &.delete {
+ background-image: url('~src/assets/images/icons/close_24dp.svg');
+ }
+ }
+ }
+ }
+ .items {
+ display: none;
+ padding-left: 56px;
+ }
+ &.active {
+ >.bar {
+ .left {
+ &:before {
+ background-image: url('~src/assets/images/icons/circle_minus_24.svg');
+ }
+ }
+ }
+ >.items {
+ display: block;
+ }
+ }
+}
+
+
+@media screen and (max-width: 767px) {
+ .item {
+ .bar {
+ .mid {
+ padding: 0 12px;
+ .info .logo {
+ display: none;
+ }
+ }
+ .right {
+ display: none;
+ }
+ }
+ .items {
+ padding-left: 16px;
+ }
+ &.company {
+ .items {
+ padding-left: 40px;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/advisories/tree/advisories-tree.component.ts b/src/app/_modules/advisories/tree/advisories-tree.component.ts
new file mode 100644
index 0000000..d2bf581
--- /dev/null
+++ b/src/app/_modules/advisories/tree/advisories-tree.component.ts
@@ -0,0 +1,31 @@
+import {Component} from '@angular/core';
+import {AdvisoriesService} from "@app/_services/advisories.service";
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+
+@Component({
+ selector: 'advisories-tree',
+ templateUrl: 'advisories-tree.component.html',
+ styleUrls: ['advisories-tree.component.scss']
+})
+export class AdvisoriesTreeComponent {
+ public advisories: any[];
+ public controlsSubscription?: Subscription;
+
+ constructor(private advisoriesService: AdvisoriesService, private listsService: ListsService) {
+ }
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls().subscribe(val => {
+ this.fetch();
+ });
+ }
+
+ fetch() {
+ this.advisoriesService.show('main', {include: 'logo,permissions'}).subscribe(res => {
+ this.advisories = [res.data];
+ });
+ }
+
+
+}
diff --git a/src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.html b/src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.html
new file mode 100644
index 0000000..0ef1065
--- /dev/null
+++ b/src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.html
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+

+
{{noLogoLetters}}
+
+
+
{{advisory?.caption}}. Посмотреть
+
Секретарь - {{secretary?.user?.data.name}}
+
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.scss b/src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.ts b/src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.ts
new file mode 100644
index 0000000..d846ab5
--- /dev/null
+++ b/src/app/_modules/advisories/tree/advisory/advisories-tree-advisory.component.ts
@@ -0,0 +1,112 @@
+import {Component, Input} from '@angular/core';
+import {AdvisoriesService} from "@app/_services/advisories.service";
+import {FormsService, ListsService} from "@app/_services";
+import {Subscription} from "rxjs";
+
+@Component({
+ selector: 'advisories-tree-advisory',
+ templateUrl: 'advisories-tree-advisory.component.html',
+ styleUrls: ['../advisories-tree.component.scss', 'advisories-tree-advisory.component.scss']
+})
+export class AdvisoriesTreeAdvisoryComponent {
+ @Input() advisory: any;
+ @Input() parent: any;
+ @Input() active = false;
+ public controlsSubscription?: Subscription;
+
+ public touched = false;
+
+
+ constructor(private advisoriesService: AdvisoriesService, private listsService: ListsService, private formsService: FormsService) {
+ }
+
+
+ get type() {
+ return this.advisory?.type;
+ }
+ get logo() {
+ return this.advisory?.logo?.data.links?.full;
+ }
+ get noLogoLetters() {
+ let result = '';
+ if (this.type?.name === 'committee') result = this.advisory.isMain ? 'ТК' : 'ПК';
+ if (this.type?.name === 'workgroup') result = 'РГ';
+ return result;
+ }
+ get companies() {
+ return this.advisoryCompanies.map(item => {return item.company?.data}) || [];
+ }
+ get advisoryCompanies() {
+ return this.advisory?.advisoryCompanies?.data || [];
+ }
+ get children() {
+ return this.advisory?.children?.data || [];
+ }
+ get secretary() {
+ return this.advisory?.secretary?.data;
+ }
+ get permissions() {
+ return this.advisory?.permissions;
+ }
+ get isEditable() {
+ return this.permissions?.edit || this.permissions?.anything;
+ }
+ get isDeletable() {
+ return this.isEditable && !this.advisory.isMain;
+ }
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls(this.advisory.id).subscribe(val => {
+ if (this.active || this.touched) this.fetch();
+ });
+ }
+
+ ngOnDestroy() {
+ if (this.controlsSubscription) this.controlsSubscription.unsubscribe();
+ }
+
+
+ fetch() {
+ let include = ['logo', 'children.logo' ,'advisoryCompanies.company.logo', 'advisoryCompanies.voter.companyMember.user', 'secretary.user', 'children.secretary.user',
+ 'permissions', 'children.permissions', 'advisoryCompanies.permissions', 'advisoryCompanies.company.permissions'];
+ //let include = 'logo,children.logo,advisoryCompanies.company.logo,permissions,children.permissions,advisoryCompanies.company.permissions';
+ this.advisoriesService.show(this.advisory.id, {include: include.join(',')}).subscribe(res => {
+ this.advisory = res.data;
+ this.active = true;
+ });
+ }
+
+
+
+ edit() {
+ this.formsService.editModel(this.type?.name ? 'advisory' : 'advisoryGroup', this.advisory.id, null, this.advisory.id);
+ }
+
+ delete() {
+ if (confirm(`Удалить ${this.advisory.caption}`)) this.advisoriesService.delete(this.advisory.id).subscribe(res => {
+ this.listsService.refresh(this.parent.id);
+ });
+ }
+
+ addAdvisory() {
+ this.formsService.createModel('advisory', {extraProps: {parent: this.advisory.id}}, this.advisory.id);
+ }
+
+ addGroup() {
+ this.formsService.createModel('advisoryGroup', {extraProps: {parent: this.advisory.id}}, this.advisory.id);
+ }
+
+
+ info() {
+ this.formsService.editModel('advisoryInfo', this.advisory.id);
+ }
+
+
+
+ toggle() {
+ if (!this.advisory.children) this.fetch();
+ else this.active = !this.active;
+ }
+
+
+}
diff --git a/src/app/_modules/advisories/tree/company/advisories-tree-company.component.html b/src/app/_modules/advisories/tree/company/advisories-tree-company.component.html
new file mode 100644
index 0000000..166d5ca
--- /dev/null
+++ b/src/app/_modules/advisories/tree/company/advisories-tree-company.component.html
@@ -0,0 +1,21 @@
+
+
+
+
+
+
+
+
{{company?.name || advisory?.caption}}. {{company ? 'Перейти' : 'Посмотреть'}}
+
С правом голоса - {{voter?.user?.data.name}}
+
+
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/advisories/tree/company/advisories-tree-company.component.scss b/src/app/_modules/advisories/tree/company/advisories-tree-company.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/advisories/tree/company/advisories-tree-company.component.ts b/src/app/_modules/advisories/tree/company/advisories-tree-company.component.ts
new file mode 100644
index 0000000..4834302
--- /dev/null
+++ b/src/app/_modules/advisories/tree/company/advisories-tree-company.component.ts
@@ -0,0 +1,99 @@
+import {Component, Input} from '@angular/core';
+import {Router} from "@angular/router";
+import {AdvisoryCompaniesService} from "@app/_services/advisory-companies.service";
+import {FormsService, ListsService} from "@app/_services";
+import {Subscription} from "rxjs";
+
+@Component({
+ selector: 'advisories-tree-company',
+ templateUrl: 'advisories-tree-company.component.html',
+ styleUrls: ['../advisories-tree.component.scss', 'advisories-tree-company.component.scss']
+})
+export class AdvisoriesTreeCompanyComponent {
+ @Input() advisoryCompany: any;
+ @Input() parent: any;
+ @Input() active = false;
+ public controlsSubscription?: Subscription;
+
+ public touched = false;
+
+
+ constructor(private advisoryCompaniesService: AdvisoryCompaniesService, private listsService: ListsService, private formsService: FormsService, private router: Router) {
+ }
+
+
+ get logo() {
+ return this.advisory?.logo?.data.links?.full || this.company?.logo?.data.links?.full;
+ }
+ get company() {
+ return this.advisoryCompany?.company?.data;
+ }
+ get advisory() {
+ return this.advisoryCompany?.advisory?.data;
+ }
+ get members() {
+ return this.advisoryCompany?.advisoryMembers?.data;
+ }
+ get voter() {
+ return this.advisoryCompany?.voter?.data.companyMember?.data;
+ }
+
+ get parentPermissions() {
+ return this.parent?.permissions;
+ }
+ get isEditable() {
+ return this.parentPermissions?.edit || this.parentPermissions?.anything;
+ }
+ get permissions() {
+ return this.company?.permissions;
+ }
+ get isViewable() {
+ return this.permissions?.view || this.permissions?.anything || this.isEditable;
+ }
+
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls(this.advisoryCompany.id).subscribe(val => {
+ if (this.active || this.touched) this.fetch();
+ });
+ }
+
+ ngOnDestroy() {
+ if (this.controlsSubscription) this.controlsSubscription.unsubscribe();
+ }
+
+
+
+ fetch() {
+ this.advisoryCompaniesService.show(this.advisoryCompany.id, {include: 'advisoryMembers.companyMember.user.avatar,voter.companyMember.user'}).subscribe(res => {
+ this.advisoryCompany.voter = res.data.voter;
+ this.advisoryCompany.advisoryMembers = res.data.advisoryMembers;
+ this.active = true;
+ });
+ }
+
+
+ toggle() {
+ if (!this.members) this.fetch();
+ else this.active = !this.active;
+ }
+
+ open() {
+ if (this.company) this.router.navigate(['companies', this.company?.id]).then();
+ else this.formsService.editModel('advisoryInfo', this.advisory.id);
+ }
+
+ addMembers() {
+ this.formsService.editModel('advisoryCompanyMembers', this.advisoryCompany.id, null, this.advisoryCompany.id);
+ }
+
+
+ delete() {
+ if (confirm('Исключить организацию из списка участников комитета?')) {
+ this.advisoryCompaniesService.delete(this.advisoryCompany.id).subscribe(res => {
+ this.listsService.refresh(this.parent?.id);
+ });
+ }
+ }
+
+}
diff --git a/src/app/_modules/advisories/tree/member/advisories-tree-member.component.html b/src/app/_modules/advisories/tree/member/advisories-tree-member.component.html
new file mode 100644
index 0000000..8115c96
--- /dev/null
+++ b/src/app/_modules/advisories/tree/member/advisories-tree-member.component.html
@@ -0,0 +1,16 @@
+
+
+
+
+
+

+
{{user?.abbreviationName}}
+
+
{{user?.name}}
{{member.position}}
+
+
+
+
+
+
+
diff --git a/src/app/_modules/advisories/tree/member/advisories-tree-member.component.scss b/src/app/_modules/advisories/tree/member/advisories-tree-member.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/advisories/tree/member/advisories-tree-member.component.ts b/src/app/_modules/advisories/tree/member/advisories-tree-member.component.ts
new file mode 100644
index 0000000..dea9840
--- /dev/null
+++ b/src/app/_modules/advisories/tree/member/advisories-tree-member.component.ts
@@ -0,0 +1,52 @@
+import {Component, Input} from '@angular/core';
+import {AdvisoryMembersService} from "@app/_services/advisory-members.service";
+import {ListsService} from "@app/_services";
+
+@Component({
+ selector: 'advisories-tree-member',
+ templateUrl: 'advisories-tree-member.component.html',
+ styleUrls: ['../advisories-tree.component.scss', 'advisories-tree-member.component.scss']
+})
+export class AdvisoriesTreeMemberComponent {
+ @Input() advisoryMember: any;
+ @Input() parent: any;
+
+ constructor(private advisoryMembersService: AdvisoryMembersService, private listsService: ListsService) {
+ }
+
+
+ get member() {
+ return this.advisoryMember?.companyMember?.data;
+ }
+ get user() {
+ return this.member?.user?.data;
+ }
+ get avatar() {
+ return this.user.avatar?.data.links?.full;
+ }
+ get isVoter() {
+ return this.advisoryMember?.rank.name === 'voter';
+ }
+ get parentPermissions() {
+ return this.parent?.permissions;
+ }
+ get isEditable() {
+ return this.parentPermissions?.edit || this.parentPermissions?.anything;
+ }
+
+
+ ngOnInit() {
+
+ }
+
+
+ delete() {
+ if (confirm('Исключить сотрудника из участников комитета?')) {
+ this.advisoryMembersService.delete(this.advisoryMember.id).subscribe(res => {
+ this.listsService.refresh(this.parent?.id);
+ });
+ }
+ }
+
+
+}
diff --git a/src/app/_modules/applications/applications.module.ts b/src/app/_modules/applications/applications.module.ts
new file mode 100644
index 0000000..a2dddd9
--- /dev/null
+++ b/src/app/_modules/applications/applications.module.ts
@@ -0,0 +1,31 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {RouterModule} from "@angular/router";
+import {AuthGuard} from "@app/_helpers";
+import {ReactiveFormsModule} from "@angular/forms";
+import {PaginationModule} from "@app/_modules/pagination/pagination.module";
+import {ApplicationsPageComponent} from "@app/_modules/applications/page/applications-page.component";
+import {ApplicationsListComponent} from "@app/_modules/applications/list/applications-list.component";
+import {ApplicationsListItemComponent} from "@app/_modules/applications/list/item/applications-list-item.component";
+
+const routes = [
+ {path: 'applications', component: ApplicationsPageComponent, canActivate: [AuthGuard]}
+];
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule,
+ RouterModule.forRoot(routes),
+ PaginationModule,
+ ],
+ declarations: [
+ ApplicationsPageComponent,
+ ApplicationsListComponent,
+ ApplicationsListItemComponent
+ ],
+ exports: [
+ RouterModule
+ ]
+})
+export class ApplicationsModule {}
diff --git a/src/app/_modules/applications/list/applications-list.component.html b/src/app/_modules/applications/list/applications-list.component.html
new file mode 100644
index 0000000..fb3e753
--- /dev/null
+++ b/src/app/_modules/applications/list/applications-list.component.html
@@ -0,0 +1,5 @@
+
+
+
diff --git a/src/app/_modules/applications/list/applications-list.component.scss b/src/app/_modules/applications/list/applications-list.component.scss
new file mode 100644
index 0000000..8e0d698
--- /dev/null
+++ b/src/app/_modules/applications/list/applications-list.component.scss
@@ -0,0 +1,18 @@
+.items {
+ margin: 24px 0;
+}
+applications-list-item {
+ display: block;
+ padding: 12px 24px;
+ border-bottom: #E8E8E8 solid 1px;
+ &:first-child {
+ border-top: #E8E8E8 solid 1px;
+ }
+}
+
+@media screen and (max-width: 526px) {
+ applications-list-item {
+ padding-left: 0;
+ padding-right: 0;
+ }
+}
diff --git a/src/app/_modules/applications/list/applications-list.component.ts b/src/app/_modules/applications/list/applications-list.component.ts
new file mode 100644
index 0000000..73da1e4
--- /dev/null
+++ b/src/app/_modules/applications/list/applications-list.component.ts
@@ -0,0 +1,41 @@
+import {Component, Input} from '@angular/core';
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+import {ApplicationsService} from "@app/_services/applications.service";
+
+@Component({
+ selector: 'applications-list',
+ templateUrl: 'applications-list.component.html',
+ styleUrls: ['applications-list.component.scss']
+})
+export class ApplicationsListComponent {
+ public items = [];
+
+ private controlsSubscription: Subscription;
+ private resultSubscription: Subscription;
+
+ constructor(private applicationsService: ApplicationsService, private listsService: ListsService) {
+ }
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls().subscribe(controls => {
+ this.fetch(controls);
+ });
+ this.resultSubscription = this.listsService.result().subscribe(res => {
+ this.items = res?.data || [];
+ });
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ this.resultSubscription?.unsubscribe();
+ }
+
+ fetch(controls: any) {
+ let include = ['submitter', 'product', 'permissions'];
+ this.applicationsService.list({page: controls.page || 0, filters: JSON.stringify(controls.filters), include: include.join(',')}).subscribe(res => {
+ this.listsService.result().next(res);
+ });
+ }
+
+}
diff --git a/src/app/_modules/applications/list/item/applications-list-item.component.html b/src/app/_modules/applications/list/item/applications-list-item.component.html
new file mode 100644
index 0000000..c209edc
--- /dev/null
+++ b/src/app/_modules/applications/list/item/applications-list-item.component.html
@@ -0,0 +1,38 @@
+
+
+
{{application.title}}
+
{{status?.title}}
+
+ | Hаименование продукции | {{product?.name}} |
+ | Hазначение продукции | {{product?.purpose}} |
+ | Заявитель | {{application?.applicant}} |
+
+
+
+
+
+
+ | Дата формирования заявки | {{application?.createdAt | date: 'dd.MM.yyyy HH:mm'}} |
+ | Область применения продукции | {{product?.usage || '—'}} |
+ | Нормативно-технический документ | {{product?.normative || '—'}} |
+ | Изготовитель / разработчик | {{product?.producer || '—'}} |
+ | Ф.И.О. контактного лица | {{submitter?.name || '—'}} |
+
+ | Документы |
+
+
+ —
+ |
+
+
+
+ | Эксперт | {{expert?.name}} |
+ | Дата ответа | {{conclusion?.createdAt | date: 'dd.MM.yyyy HH:mm'}} |
+ | Мнение эксперта | |
+
+
+
diff --git a/src/app/_modules/applications/list/item/applications-list-item.component.scss b/src/app/_modules/applications/list/item/applications-list-item.component.scss
new file mode 100644
index 0000000..65a750d
--- /dev/null
+++ b/src/app/_modules/applications/list/item/applications-list-item.component.scss
@@ -0,0 +1,51 @@
+.main {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ .left {
+ flex-grow: 1;
+ }
+ .right {
+ margin-left: 24px;
+ flex-shrink: 0;
+ .toggle {
+ width: 32px;
+ height: 32px;
+ background: transparent url('~src/assets/images/icons/expand_less_20.svg') 50% 50% no-repeat;
+ transform: rotateZ(180deg);
+ transition: transform 0.3s;
+ &.active {
+ transform: rotateZ(0);
+ }
+ }
+ }
+
+ .title {
+ margin-bottom: 8px;
+ font-weight: bold;
+ }
+ .status {
+ margin-bottom: 8px;
+ color: #86898E;
+ &.completed {color: #28A814;}
+ &.processing {color: #7714A8;}
+ }
+}
+
+.details {
+ .reply {
+ margin-top: 12px;
+ .btn {
+ padding: 7px 16px;
+ }
+ }
+}
+
+.documents.list.default {
+ .items {
+ .item {
+ margin: 0 0 8px;
+ &:last-child {margin: 0;}
+ }
+ }
+}
diff --git a/src/app/_modules/applications/list/item/applications-list-item.component.ts b/src/app/_modules/applications/list/item/applications-list-item.component.ts
new file mode 100644
index 0000000..6f957c0
--- /dev/null
+++ b/src/app/_modules/applications/list/item/applications-list-item.component.ts
@@ -0,0 +1,74 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService, ObjectsService} from "@app/_services";
+import {ApplicationsService} from "@app/_services/applications.service";
+import {Subscription} from "rxjs";
+
+@Component({
+ selector: 'applications-list-item',
+ templateUrl: 'applications-list-item.component.html',
+ styleUrls: ['applications-list-item.component.scss']
+})
+export class ApplicationsListItemComponent {
+ @Input() application: any;
+ public active = false;
+
+ subscription: Subscription;
+
+ constructor(private applicationsService: ApplicationsService, private formsService: FormsService, private objectsService: ObjectsService, private listsService: ListsService) {
+ }
+
+ get status() {
+ return this.application?.status;
+ }
+ get submitter() {
+ return this.application?.submitter?.data;
+ }
+ get product() {
+ return this.application?.product?.data;
+ }
+ get conclusion() {
+ return this.application?.conclusions?.data[0];
+ }
+ get expert() {
+ return this.conclusion?.author?.data;
+ }
+ get properties() {
+ return this.application?.properties?.data;
+ }
+ get documents() {
+ return this.objectsService.getValue(this.properties, 'documents');
+ }
+
+ get permissions() {
+ return this.application?.permissions;
+ }
+
+ ngOnInit() {
+ this.subscription = this.listsService.controls(this.application.id).subscribe(controls => {
+ if (this.active) this.fetch();
+ });
+ }
+
+ ngOnDestroy() {
+ this.subscription?.unsubscribe();
+ }
+
+
+ fetch() {
+ let include = ['submitter', 'product', 'permissions', 'properties.groups.fields.value', 'conclusions.author'];
+ this.applicationsService.show(this.application.id, {include: include.join(',')}).subscribe(res => {
+ this.application = res.data;
+ });
+ }
+
+
+ reply() {
+ this.formsService.createModel('applicationConclusion', {extraProps: {application: this.application.id}}, this.application.id);
+ }
+
+ toggle() {
+ this.active = !this.active;
+ if (this.active) this.listsService.refresh(this.application.id);
+ }
+
+}
diff --git a/src/app/_modules/applications/page/applications-page.component.html b/src/app/_modules/applications/page/applications-page.component.html
new file mode 100644
index 0000000..087ecc9
--- /dev/null
+++ b/src/app/_modules/applications/page/applications-page.component.html
@@ -0,0 +1,19 @@
+
+
Журнал заявок
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/applications/page/applications-page.component.scss b/src/app/_modules/applications/page/applications-page.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/applications/page/applications-page.component.ts b/src/app/_modules/applications/page/applications-page.component.ts
new file mode 100644
index 0000000..70ce209
--- /dev/null
+++ b/src/app/_modules/applications/page/applications-page.component.ts
@@ -0,0 +1,36 @@
+import {Component} from '@angular/core';
+import {FormGroup, FormControl} from "@angular/forms";
+import {debounceTime} from "rxjs/operators";
+import {AuthenticationService, FiltersService, FormsService, ListsService} from "@app/_services";
+
+@Component({
+ templateUrl: 'applications-page.component.html',
+ styleUrls: ['applications-page.component.scss']
+})
+export class ApplicationsPageComponent {
+ public filters: FormGroup;
+
+ constructor(private listsService: ListsService, private formsService: FormsService, private filtersService: FiltersService, public authService: AuthenticationService) {
+ }
+
+ ngOnInit() {
+ this.filters = new FormGroup({search: new FormControl('')});
+ this.filters.valueChanges.pipe(debounceTime(200)).subscribe(val => {
+ this.listsService.addFilters(val);
+ });
+ }
+
+ ngOnDestroy() {
+ }
+
+
+ create() {
+ this.formsService.createModel('application');
+ }
+
+
+ showFilters() {
+ this.filtersService.slider('model', 'applications');
+ }
+
+}
diff --git a/src/app/_modules/auth/auth.module.ts b/src/app/_modules/auth/auth.module.ts
new file mode 100644
index 0000000..990bdd5
--- /dev/null
+++ b/src/app/_modules/auth/auth.module.ts
@@ -0,0 +1,38 @@
+import {NgModule} from '@angular/core'
+import {CommonModule} from '@angular/common'
+import {RouterModule} from "@angular/router";
+import {LoginComponent} from "@app/_modules/auth/login/login.component";
+import {BrowserModule} from "@angular/platform-browser";
+import {FormsModule, ReactiveFormsModule} from "@angular/forms";
+import {ForgetComponent} from "@app/_modules/auth/forget/forget.component";
+import {PasswordResetComponent} from "@app/_modules/auth/reset/password-reset.component";
+import {SignupComponent} from "@app/_modules/auth/signup/signup.component";
+import {AuthFormComponent} from "@app/_modules/auth/form/form.component";
+
+const routes = [
+ {path: 'login', component: AuthFormComponent, outlet: 'auth'},
+ {path: 'signup', component: AuthFormComponent, outlet: 'auth'},
+ {path: 'password/forget', component: AuthFormComponent, outlet: 'auth'},
+ {path: 'password/reset/:token/:email', component: PasswordResetComponent}
+];
+
+@NgModule({
+ imports: [
+ BrowserModule,
+ FormsModule,
+ ReactiveFormsModule,
+ CommonModule,
+ RouterModule.forRoot(routes),
+ ],
+ exports: [
+ RouterModule,
+ ],
+ declarations: [
+ AuthFormComponent,
+ LoginComponent,
+ SignupComponent,
+ ForgetComponent,
+ PasswordResetComponent,
+ ],
+})
+export class AuthModule {}
diff --git a/src/app/_modules/auth/forget/forget.component.html b/src/app/_modules/auth/forget/forget.component.html
new file mode 100644
index 0000000..8fd173f
--- /dev/null
+++ b/src/app/_modules/auth/forget/forget.component.html
@@ -0,0 +1,24 @@
+
diff --git a/src/app/_modules/auth/forget/forget.component.scss b/src/app/_modules/auth/forget/forget.component.scss
new file mode 100644
index 0000000..9dc6678
--- /dev/null
+++ b/src/app/_modules/auth/forget/forget.component.scss
@@ -0,0 +1,5 @@
+.success {
+ h3, p {
+ margin: 0;
+ }
+}
diff --git a/src/app/_modules/auth/forget/forget.component.ts b/src/app/_modules/auth/forget/forget.component.ts
new file mode 100644
index 0000000..7fbe1fe
--- /dev/null
+++ b/src/app/_modules/auth/forget/forget.component.ts
@@ -0,0 +1,59 @@
+import {Component, OnInit} from '@angular/core';
+import {Router, ActivatedRoute} from '@angular/router';
+import {FormBuilder, FormGroup, Validators} from '@angular/forms';
+
+import {AuthenticationService} from '@app/_services';
+
+@Component({
+ selector: 'auth-forget',
+ templateUrl: 'forget.component.html',
+ styleUrls: ['forget.component.scss', '../login/login.component.scss']
+})
+export class ForgetComponent implements OnInit {
+ form: FormGroup;
+ loading = false;
+ success = false;
+ error = '';
+
+ constructor(private formBuilder: FormBuilder, private route: ActivatedRoute, private router: Router, private authenticationService: AuthenticationService) {
+ //if (this.authenticationService.oauthTokenValue) this.router.navigate(['']).then();
+ }
+
+ ngOnInit() {
+ this.form = this.formBuilder.group({
+ email: ['', [Validators.required, Validators.email]]
+ });
+ }
+
+ get f() {
+ return this.form.controls;
+ }
+ get email() {
+ return this.f?.email?.value;
+ }
+
+ onSubmit() {
+ if (this.form.invalid) return;
+ this.loading = true;
+ this.authenticationService.forget(this.email).subscribe(res => {
+ this.success = true;
+ this.loading = false;
+ }, error => {
+ this.setError(error.message);
+ this.loading = false;
+ });
+ }
+
+ setError(error: string) {
+ let trans = {'The given data was invalid.': 'Указанный адрес почты не найден'};
+ this.error = trans[error] || error;
+ }
+
+ login() {
+ this.authenticationService.popup('login');
+ }
+
+ close() {
+ this.authenticationService.popup(null);
+ }
+}
diff --git a/src/app/_modules/auth/form/form.component.html b/src/app/_modules/auth/form/form.component.html
new file mode 100644
index 0000000..76fe7f8
--- /dev/null
+++ b/src/app/_modules/auth/form/form.component.html
@@ -0,0 +1,7 @@
+
diff --git a/src/app/_modules/auth/form/form.component.scss b/src/app/_modules/auth/form/form.component.scss
new file mode 100644
index 0000000..86223eb
--- /dev/null
+++ b/src/app/_modules/auth/form/form.component.scss
@@ -0,0 +1,26 @@
+.auth {
+ position: fixed;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ padding: 24px;
+ background-color: rgba(62, 61, 64, 70%);
+ display: flex;
+ align-items: center;
+ z-index: 1000;
+ .form {
+ max-width: 520px;
+ width: 100%;
+ max-height: 632px;
+ height: 100%;
+ border-radius: 24px;
+ background-color: var(--white);
+ margin: 0 auto;
+ }
+}
+@media screen and (max-width: 600px) {
+ .auth {
+ padding: 0;
+ }
+}
diff --git a/src/app/_modules/auth/form/form.component.ts b/src/app/_modules/auth/form/form.component.ts
new file mode 100644
index 0000000..e3ee86a
--- /dev/null
+++ b/src/app/_modules/auth/form/form.component.ts
@@ -0,0 +1,26 @@
+import {Component, OnInit} from '@angular/core';
+import {ActivatedRoute} from '@angular/router';
+import {Subscription} from "rxjs";
+import {AuthenticationService} from "@app/_services";
+
+@Component({
+ templateUrl: 'form.component.html',
+ styleUrls: ['form.component.scss']
+})
+export class AuthFormComponent implements OnInit {
+ public subscription: Subscription;
+
+ constructor(private authService: AuthenticationService, private route: ActivatedRoute) {
+ this.subscription = this.authService.user.subscribe(user => {
+ if (user) window.location.reload();
+ });
+ }
+
+ ngOnInit() {
+ }
+
+
+ get path() {
+ return this.route?.snapshot?.routeConfig?.path;
+ }
+}
diff --git a/src/app/_modules/auth/login/login.component.html b/src/app/_modules/auth/login/login.component.html
new file mode 100644
index 0000000..e586290
--- /dev/null
+++ b/src/app/_modules/auth/login/login.component.html
@@ -0,0 +1,31 @@
+
diff --git a/src/app/_modules/auth/login/login.component.scss b/src/app/_modules/auth/login/login.component.scss
new file mode 100644
index 0000000..04e37a5
--- /dev/null
+++ b/src/app/_modules/auth/login/login.component.scss
@@ -0,0 +1,151 @@
+.popup {
+ display: flex;
+ flex-direction: column;
+ height: 100%;
+ form {
+ display: flex;
+ flex-direction: column;
+ height: 100%;
+ .header {
+ flex-grow: 0;
+ border-radius: 24px 24px 0 0;
+ padding: 20px 24px;
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ background-color: #F5F4F4;
+ border-bottom: 1px solid #3E3D40;
+ h2 {
+ margin: 0;
+ font-weight: 400;
+ font-size: 1.5rem;
+ line-height: 30px;
+ color: #000000;
+ }
+ .close {
+ width: 24px;
+ height: 24px;
+ margin-left: auto;
+ background: transparent url(/assets/images/icons/close_24dp.svg) 50% 50% no-repeat;
+ }
+ }
+ .body {
+ display: flex;
+ flex-direction: column;
+ flex-grow: 1;
+ height: 100%;
+ overflow: auto;
+ padding: 20px 24px;
+ -webkit-overflow-scrolling: touch;
+ row-gap: 24px;
+ .field {
+ display: flex;
+ flex-direction: column;
+ row-gap: 4px;
+ position: relative;
+ label {
+ font-style: normal;
+ font-weight: 400;
+ font-size: 1rem;
+ line-height: normal;
+ }
+ input {
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ appearance: none;
+ border-radius: 12px;
+ border: 1px solid #BFBFBF;
+ padding: 10px 16px;
+ }
+ .eye {
+ position: absolute;
+ bottom: 8px;
+ right: 12px;
+ width: 24px;
+ height: 24px;
+ background-position: center;
+ background-repeat: no-repeat;
+ cursor: pointer;
+ &.show {background-image: url("~src/assets/images/icons/visibility_on_24dp.svg");}
+ &.hide {background-image: url("~src/assets/images/icons/visibility_off_24dp.svg");}
+ }
+ }
+ .error {
+ color: red;
+ }
+ .bar {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ width: 100%;
+ flex-wrap: wrap;
+ row-gap: 18px;
+ .remember {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ input {
+ width: 16px;
+ height: 16px;
+ margin-right: 8px;
+ border-radius: 2px;
+ border: 1px solid #86898E;
+ }
+ }
+ .forget {
+ margin-left: auto;
+ cursor: pointer;
+ }
+ }
+ }
+ .footer {
+ display: flex;
+ flex-grow: 0;
+ border-top: 1px solid #3E3D40;
+ border-radius: 0 0 24px 24px;
+ padding: 20px 24px;
+ justify-content: flex-end;
+ background-color: #F5F4F4;
+ gap: 24px;
+ flex-wrap: wrap;
+ .btn {
+ font-size: 0.875rem;
+ font-style: normal;
+ font-weight: 700;
+ line-height: 18px;
+ letter-spacing: 0.28px;
+ }
+ }
+ }
+}
+
+@media screen and (max-width: 960px) {
+ .authentication {
+ flex-direction: column;
+ justify-content: center;
+ .logo {
+ width: 100%;
+ height: 76px;
+ margin-bottom: 50px;
+ background-color: transparent;
+ background-size: contain;
+ }
+ .block {
+ width: 100%;
+ }
+ }
+}
+@media screen and (max-width: 600px) {
+ .popup {
+ form {
+ .header, .footer {
+ border-radius: 0;
+ }
+ .footer {
+ .btn {
+ width: 100%;
+ }
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/auth/login/login.component.ts b/src/app/_modules/auth/login/login.component.ts
new file mode 100644
index 0000000..0798c25
--- /dev/null
+++ b/src/app/_modules/auth/login/login.component.ts
@@ -0,0 +1,74 @@
+import {Component, OnInit} from '@angular/core';
+import {Router, ActivatedRoute} from '@angular/router';
+import {FormBuilder, FormGroup, Validators} from '@angular/forms';
+
+import {AuthenticationService} from '@app/_services';
+import {Subscription} from "rxjs";
+
+@Component({
+ selector: 'auth-login',
+ templateUrl: 'login.component.html',
+ styleUrls: ['login.component.scss']
+})
+export class LoginComponent implements OnInit {
+ form: FormGroup;
+ loading = false;
+ error = '';
+ subscription: Subscription;
+ public type: string = 'password';
+
+ constructor(private formBuilder: FormBuilder, private router: Router, private route: ActivatedRoute, private authenticationService: AuthenticationService) {
+ //this.subscription = this.authenticationService.user.subscribe(user => {
+ // if (user) this.router.navigate([this.route.snapshot.queryParamMap.get('returnUrl')?.split('(')[0] || '']).then();
+ //});
+ }
+
+ ngOnInit() {
+ this.form = this.formBuilder.group({
+ username: ['', [Validators.required, Validators.email]],
+ password: ['', Validators.required]
+ });
+ }
+
+ ngOnDestroy() {
+ this.subscription?.unsubscribe();
+ }
+
+ get f() {
+ return this.form.controls;
+ }
+ get username() {
+ return this.f.username.value;
+ }
+ get password() {
+ return this.f.password.value;
+ }
+
+ onSubmit() {
+ if (this.form.invalid) return;
+ this.loading = true;
+ this.authenticationService.getToken(this.username, this.password).subscribe(res => {
+ this.authenticationService.saveToken(res);
+ }, error => {
+ this.setError(error.message);
+ this.loading = false;
+ });
+ }
+
+ setError(error: string) {
+ let trans = {'The user credentials were incorrect.': 'Имя пользователя или пароль указаны неверно.'};
+ this.error = trans[error] || error;
+ }
+
+ forget() {
+ this.authenticationService.popup(['password','forget']);
+ }
+
+ close() {
+ this.authenticationService.popup(null);
+ }
+
+ signup() {
+ this.authenticationService.popup('signup');
+ }
+}
diff --git a/src/app/_modules/auth/reset/password-reset.component.html b/src/app/_modules/auth/reset/password-reset.component.html
new file mode 100644
index 0000000..20ea0db
--- /dev/null
+++ b/src/app/_modules/auth/reset/password-reset.component.html
@@ -0,0 +1,24 @@
+
+
diff --git a/src/app/_modules/auth/reset/password-reset.component.scss b/src/app/_modules/auth/reset/password-reset.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/auth/reset/password-reset.component.ts b/src/app/_modules/auth/reset/password-reset.component.ts
new file mode 100644
index 0000000..9e52850
--- /dev/null
+++ b/src/app/_modules/auth/reset/password-reset.component.ts
@@ -0,0 +1,65 @@
+import {Component, OnInit} from '@angular/core';
+import {Router, ActivatedRoute} from '@angular/router';
+import {FormBuilder, FormGroup, Validators} from '@angular/forms';
+
+import {AuthenticationService} from '@app/_services';
+
+@Component({
+ templateUrl: 'password-reset.component.html',
+ styleUrls: ['password-reset.component.scss', '../login/login.component.scss']
+})
+export class PasswordResetComponent implements OnInit {
+ form: FormGroup;
+ loading = false;
+ error = '';
+
+ constructor(private formBuilder: FormBuilder, private route: ActivatedRoute, private router: Router, private authenticationService: AuthenticationService) {
+ //if (this.authenticationService.oauthTokenValue) this.router.navigate(['']).then();
+ }
+
+ ngOnInit() {
+ this.form = this.formBuilder.group({
+ password: ['', [Validators.required, Validators.minLength(8)]],
+ confirmation: ['', [Validators.required]]
+ });
+ }
+
+ get f() {
+ return this.form.controls;
+ }
+ get password() {
+ return this.f?.password?.value;
+ }
+ get confirmation() {
+ return this.f?.confirmation?.value;
+ }
+ get token() {
+ return this.route.snapshot.paramMap.get('token');
+ }
+ get email() {
+ return this.route.snapshot.paramMap.get('email');
+ }
+
+ onSubmit() {
+ this.error = '';
+ if (this.form.invalid) return;
+ if (this.password !== this.confirmation) {
+ this.setError('Пароль и подтверждение пароля не совпадают');
+ return;
+ }
+
+ this.loading = true;
+ this.authenticationService.restore({email: this.email, token: this.token, password: this.password}).subscribe(res => {
+ this.router.navigate(['login']).then();
+ }, error => {
+ this.setError(error);
+ this.loading = false;
+ });
+ }
+
+ setError(error: string) {
+ let trans = {'The user credentials were incorrect.': 'Имя пользователя или пароль указаны неверно.'};
+ this.error = trans[error] || error;
+ }
+
+}
diff --git a/src/app/_modules/auth/signup/signup.component.html b/src/app/_modules/auth/signup/signup.component.html
new file mode 100644
index 0000000..f498bca
--- /dev/null
+++ b/src/app/_modules/auth/signup/signup.component.html
@@ -0,0 +1,43 @@
+
+
diff --git a/src/app/_modules/auth/signup/signup.component.scss b/src/app/_modules/auth/signup/signup.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/auth/signup/signup.component.ts b/src/app/_modules/auth/signup/signup.component.ts
new file mode 100644
index 0000000..255be35
--- /dev/null
+++ b/src/app/_modules/auth/signup/signup.component.ts
@@ -0,0 +1,87 @@
+import {Component, OnInit} from '@angular/core';
+import {Router, ActivatedRoute} from '@angular/router';
+import {FormBuilder, FormGroup, Validators} from '@angular/forms';
+
+import {AuthenticationService} from '@app/_services';
+import {Subscription} from "rxjs";
+
+@Component({
+ selector: 'auth-signup',
+ templateUrl: 'signup.component.html',
+ styleUrls: ['signup.component.scss', '../login/login.component.scss']
+})
+export class SignupComponent implements OnInit {
+ form: FormGroup;
+ loading = false;
+ error = '';
+ asyncErrors: any = {};
+ subscription: Subscription;
+
+ constructor(private formBuilder: FormBuilder, private router: Router, private route: ActivatedRoute, private authenticationService: AuthenticationService) {
+ //this.subscription = this.authenticationService.user.subscribe(user => {
+ // if (user) this.router.navigate([this.route.snapshot.queryParamMap.get('returnUrl')?.split('(')[0] || 'applications']).then();
+ //});
+ }
+
+ ngOnInit() {
+ this.form = this.formBuilder.group({
+ email: ['', [Validators.required, Validators.email]],
+ name: ['', Validators.required],
+ phone: [''],
+ password: ['', Validators.required],
+ passwordConfirmation: ['', Validators.required]
+ });
+ }
+
+ ngOnDestroy() {
+ this.subscription?.unsubscribe();
+ }
+
+ get f() {
+ return this.form.controls;
+ }
+ get email() {
+ return this.f.email;
+ }
+ get name() {
+ return this.f.name;
+ }
+ get password() {
+ return this.f.password;
+ }
+ get confirmation() {
+ return this.f.passwordConfirmation;
+ }
+
+ onSubmit() {
+ this.form.markAllAsTouched();
+ if (this.form.invalid) return;
+ this.loading = true;
+ this.authenticationService.signup(this.form.value).subscribe(res => {
+ this.authenticationService.getToken(this.email.value, this.password.value).subscribe(res => {
+ this.authenticationService.saveToken(res);
+ this.close();
+ });
+ }, error => {
+ this.setError(error);
+ this.loading = false;
+ });
+ }
+
+ setError(error: any) {
+ this.asyncErrors = error.errors;
+ for (let prop in error.errors) {
+ if (error.errors.hasOwnProperty(prop)) this.f[prop].setErrors({custom: true});
+ }
+ let trans = {'The given data was invalid.': 'Проверьте правильность заполнения формы'};
+ this.error = trans[error.message] || error.message;
+ }
+
+ close() {
+ this.authenticationService.popup(null);
+ }
+
+ login() {
+ this.authenticationService.popup('login');
+ }
+}
diff --git a/src/app/_modules/companies/advisories/company-advisories.component.html b/src/app/_modules/companies/advisories/company-advisories.component.html
new file mode 100644
index 0000000..48cca7b
--- /dev/null
+++ b/src/app/_modules/companies/advisories/company-advisories.component.html
@@ -0,0 +1,6 @@
+
+
+
+
Организация не является членом ТК или ПК
+
+
diff --git a/src/app/_modules/companies/advisories/company-advisories.component.scss b/src/app/_modules/companies/advisories/company-advisories.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/companies/advisories/company-advisories.component.ts b/src/app/_modules/companies/advisories/company-advisories.component.ts
new file mode 100644
index 0000000..cacdf66
--- /dev/null
+++ b/src/app/_modules/companies/advisories/company-advisories.component.ts
@@ -0,0 +1,37 @@
+import {Component, Input} from '@angular/core';
+import {CompaniesService} from "@app/_services/companies.service";
+
+@Component({
+ selector: 'company-advisories',
+ templateUrl: 'company-advisories.component.html',
+ styleUrls: ['company-advisories.component.scss']
+})
+export class CompanyAdvisoriesComponent {
+ @Input() companyId: string;
+ @Input() editable = false;
+ public company: any;
+
+ constructor(private companiesService: CompaniesService) {
+ }
+
+
+ get advisoryCompanies() {
+ return this.company?.advisoryCompanies?.data;
+ }
+
+
+ ngOnInit() {
+ this.fetch();
+ }
+
+
+ fetch() {
+ this.companiesService.fetch(this.companyId, {include: 'advisoryCompanies.advisory.logo'}).subscribe(res => {
+ this.company = res.data;
+ });
+ }
+
+
+
+
+}
diff --git a/src/app/_modules/companies/companies.module.ts b/src/app/_modules/companies/companies.module.ts
new file mode 100644
index 0000000..ebb361e
--- /dev/null
+++ b/src/app/_modules/companies/companies.module.ts
@@ -0,0 +1,30 @@
+import {NgModule} from '@angular/core'
+import {CommonModule} from '@angular/common'
+import {CompanyMembersComponent} from "@app/_modules/companies/members/company-members.component";
+import {CompanyStructureComponent} from "@app/_modules/companies/structure/company-structure.component";
+import {CompanyDepartmentComponent} from "@app/_modules/companies/structure/department/company-department.component";
+import {CompanyMemberComponent} from "@app/_modules/companies/members/member/company-member.component";
+import {CompanyAdvisoriesComponent} from "@app/_modules/companies/advisories/company-advisories.component";
+import {CompanyComponent} from "@app/_modules/companies/company/company.component";
+
+
+@NgModule({
+ imports: [
+ CommonModule
+ ],
+ declarations: [
+ CompanyComponent,
+ CompanyMembersComponent,
+ CompanyMemberComponent,
+ CompanyStructureComponent,
+ CompanyDepartmentComponent,
+ CompanyAdvisoriesComponent
+ ],
+ exports: [
+ CompanyComponent,
+ CompanyMembersComponent,
+ CompanyStructureComponent,
+ CompanyAdvisoriesComponent
+ ]
+})
+export class CompaniesModule {}
diff --git a/src/app/_modules/companies/company/company.component.html b/src/app/_modules/companies/company/company.component.html
new file mode 100644
index 0000000..07a6a1c
--- /dev/null
+++ b/src/app/_modules/companies/company/company.component.html
@@ -0,0 +1,12 @@
+
+
+ | Юридический адрес | {{company?.legalAddress?.data.full}} |
+ | Электронная почта | {{emails}} |
+ | Телефон | {{phones}} |
+
+
+
diff --git a/src/app/_modules/companies/company/company.component.scss b/src/app/_modules/companies/company/company.component.scss
new file mode 100644
index 0000000..8e5f381
--- /dev/null
+++ b/src/app/_modules/companies/company/company.component.scss
@@ -0,0 +1,149 @@
+.main {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ margin-bottom: 24px;
+ .left {
+ margin-right: 16px;
+ .logo {
+ width: 120px;
+ height: 120px;
+ border-radius: 100%;
+ border: #E8E8E8 solid 1px;
+ background-size: 60%;
+ overflow: hidden;
+ img {
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+ }
+ }
+ .mid {
+ .name {
+ font-size: 1.5rem;
+ }
+ }
+ .right {
+ margin-left: auto;
+ .menu {
+ button {
+ width: 24px;
+ height: 24px;
+ background: transparent url('~src/assets/images/icons/edit_24dp.svg') 50% 50% no-repeat;
+ }
+ }
+ }
+}
+
+
+.intro {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ .left {
+ .logo {
+ width: 160px;
+ height: 160px;
+ margin-right: 16px;
+ border-radius: 100%;
+ border: #0033661F solid 2px;
+ //background: #ffffff url('~src/assets/images/icons/factory_96dp.svg') 50% 50% no-repeat;
+ overflow: hidden;
+ img {
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+ }
+ }
+ .right {
+ .line {
+ margin-bottom: 6px;
+ &:last-child {
+ margin-bottom: 0;
+ }
+ }
+ .name {
+ font-size: 1.25rem;
+ }
+ }
+}
+
+.content {
+ padding: 24px 40px;
+ background-color: #FFFFFF;
+ border-bottom: #6c6c6c solid 1px;
+ .properties {
+ display: flex;
+ flex-direction: row;
+ margin-bottom: 16px;
+ .left {
+ flex-grow: 1;
+ .title {
+ margin-bottom: 4px;
+ font-weight: bold;
+ }
+ }
+ .right {
+ margin-left: 24px;
+ flex-shrink: 0;
+ .edit {
+ background-image: url('~src/assets/images/icons/edit_24dp.svg');
+ }
+ }
+ }
+}
+
+@media screen and (max-width: 983px) {
+ .content {
+ padding: 24px;
+ .properties {
+ margin-bottom: 0;
+ }
+ }
+}
+
+@media screen and (max-width: 600px) {
+ .intro {
+ .left {
+ .logo {
+ width: 80px;
+ height: 80px;
+ background-size: 50%;
+ }
+ }
+ }
+ .content {
+ .properties {
+ .left {
+ .default {
+ tr {
+ td {
+ display: block;
+ &:first-child {
+ margin: 12px 0 0;
+ padding: 0;
+ }
+ &:last-child {
+ margin: 0;
+ padding: 0;
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+}
+
+@media screen and (max-width: 960px) {
+ .main {
+ .left {
+ margin-right: 0;
+ .logo {
+ display: none;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/companies/company/company.component.ts b/src/app/_modules/companies/company/company.component.ts
new file mode 100644
index 0000000..c6feb7f
--- /dev/null
+++ b/src/app/_modules/companies/company/company.component.ts
@@ -0,0 +1,57 @@
+import {Component, Input} from '@angular/core';
+import {FormsService} from "@app/_services";
+
+@Component({
+ selector: 'company',
+ templateUrl: 'company.component.html',
+ styleUrls: ['company.component.scss']
+})
+export class CompanyComponent {
+ @Input() company: any;
+
+ constructor(private formsService: FormsService) {
+ }
+
+ ngOnInit() {
+
+ }
+
+ ngOnDestroy() {
+ }
+
+ get logo() {
+ return this.company?.logo?.data.links?.full;
+ }
+ get phones() {
+ return this.company?.phones?.data.map(item => {
+ return item.value;
+ }).join('; ') || 'не указан';
+ }
+ get emails() {
+ return this.company?.emails?.data.map(item => {
+ return item.value;
+ }).join('; ') || 'не указана';
+ }
+ get types() {
+ return this.company?.types?.data.map(item => {
+ return item.title;
+ }).join(', ');
+ }
+ get permissions() {
+ return this.company?.permissions;
+ }
+ get isViewable() {
+ return this.permissions?.view || this.permissions?.anything;
+ }
+ get isEditable() {
+ return this.permissions?.edit || this.permissions?.anything;
+ }
+
+
+
+ edit() {
+ this.formsService.editModel('company', this.company.id, null, 'company-main-info');
+ }
+
+
+}
diff --git a/src/app/_modules/companies/members/company-members.component.html b/src/app/_modules/companies/members/company-members.component.html
new file mode 100644
index 0000000..40e0cec
--- /dev/null
+++ b/src/app/_modules/companies/members/company-members.component.html
@@ -0,0 +1,3 @@
+
+Сотрудники отсутствуют
+
diff --git a/src/app/_modules/companies/members/company-members.component.scss b/src/app/_modules/companies/members/company-members.component.scss
new file mode 100644
index 0000000..ab863d0
--- /dev/null
+++ b/src/app/_modules/companies/members/company-members.component.scss
@@ -0,0 +1,3 @@
+.buttons {
+ margin-top: 24px;
+}
diff --git a/src/app/_modules/companies/members/company-members.component.ts b/src/app/_modules/companies/members/company-members.component.ts
new file mode 100644
index 0000000..6ec7daa
--- /dev/null
+++ b/src/app/_modules/companies/members/company-members.component.ts
@@ -0,0 +1,46 @@
+import {Component, Input} from '@angular/core';
+import {CompaniesService} from "@app/_services/companies.service";
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+
+@Component({
+ selector: 'company-members',
+ templateUrl: 'company-members.component.html',
+ styleUrls: ['company-members.component.scss']
+})
+export class CompanyMembersComponent {
+ @Input() companyId: string;
+ @Input() editable = false;
+ public company: any;
+ public controlsSubscription?: Subscription;
+
+ constructor(private companiesService: CompaniesService, private listsService: ListsService) {
+ }
+
+
+ get members() {
+ return this.company?.members?.data;
+ }
+
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls().subscribe(val => {
+ this.fetch();
+ });
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ }
+
+
+ fetch() {
+ this.companiesService.fetch(this.companyId, {include: 'members.user.avatar'}).subscribe(res => {
+ this.company = res.data;
+ });
+ }
+
+
+
+
+}
diff --git a/src/app/_modules/companies/members/member/company-member.component.html b/src/app/_modules/companies/members/member/company-member.component.html
new file mode 100644
index 0000000..b8aa52d
--- /dev/null
+++ b/src/app/_modules/companies/members/member/company-member.component.html
@@ -0,0 +1,16 @@
+
+
+
+
![]()
+
{{user?.initials}}
+
+
+
+
{{user?.name}}. {{member.position}}
+
{{role?.title}}
+
+
+
+
+
+
diff --git a/src/app/_modules/companies/members/member/company-member.component.scss b/src/app/_modules/companies/members/member/company-member.component.scss
new file mode 100644
index 0000000..ab0596d
--- /dev/null
+++ b/src/app/_modules/companies/members/member/company-member.component.scss
@@ -0,0 +1,58 @@
+.member {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ width: 100%;
+ padding: 12px 0;
+ border-bottom: #E0E0E0 solid 1px;
+ overflow: hidden;
+ .left {
+ flex-shrink: 0;
+ .avatar {
+ width: 40px;
+ height: 40px;
+ border-radius: 100px;
+ border: #86898E solid 1px;
+ background-color: #ffffff;
+ overflow: hidden;
+ .initials {
+ line-height: 40px;
+ text-align: center;
+ color: #86898E;
+ }
+ img {
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+ }
+ }
+ .mid {
+ padding: 0 16px;
+ flex-grow: 1;
+ .name {
+ }
+ .sub {
+ color: #86898E;
+ }
+ }
+ .right {
+ flex-shrink: 0;
+ button {
+ margin-left: 20px;
+ &.edit {background-image: url('~src/assets/images/icons/edit_24dp.svg');}
+ &.delete {background-image: url('~src/assets/images/icons/close_24dp.svg');}
+ }
+ }
+}
+
+
+@media screen and (max-width: 960px) {
+ .member {
+ .left {
+ .avatar {
+ display: none;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/companies/members/member/company-member.component.ts b/src/app/_modules/companies/members/member/company-member.component.ts
new file mode 100644
index 0000000..d68fb6b
--- /dev/null
+++ b/src/app/_modules/companies/members/member/company-member.component.ts
@@ -0,0 +1,50 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService} from "@app/_services";
+import {CompanyMembersService} from "@app/_services/company-members.service";
+
+@Component({
+ selector: 'company-member',
+ templateUrl: 'company-member.component.html',
+ styleUrls: ['company-member.component.scss']
+})
+export class CompanyMemberComponent {
+ @Input() member: any;
+ @Input() parent: any;
+
+ @Input() editable = false;
+ @Input() draggable = false;
+
+ constructor(private membersService: CompanyMembersService, private formsService: FormsService, private listsService: ListsService) {
+ }
+
+ get user() {
+ return this.member?.user?.data;
+ }
+ get phone() {
+ return this.user?.phone;
+ }
+ get email() {
+ return this.user?.email;
+ }
+ get avatar() {
+ return this.user?.avatar?.data.links?.thumb;
+ }
+ get role() {
+ return this.member?.role;
+ }
+
+ ngOnInit() {
+ }
+
+
+ edit() {
+ this.formsService.editModel('companyMember', this.member.id, null, this.parent?.id || null);
+ }
+
+ delete() {
+ if (confirm(`Удалить сотрудника «${this.user.name}»?`)) this.membersService.delete(this.member.id).subscribe(res => {
+ this.listsService.refresh(this.parent.id);
+ });
+ }
+
+}
diff --git a/src/app/_modules/companies/structure/company-structure.component.html b/src/app/_modules/companies/structure/company-structure.component.html
new file mode 100644
index 0000000..208761e
--- /dev/null
+++ b/src/app/_modules/companies/structure/company-structure.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/companies/structure/company-structure.component.scss b/src/app/_modules/companies/structure/company-structure.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/companies/structure/company-structure.component.ts b/src/app/_modules/companies/structure/company-structure.component.ts
new file mode 100644
index 0000000..604513a
--- /dev/null
+++ b/src/app/_modules/companies/structure/company-structure.component.ts
@@ -0,0 +1,40 @@
+import {Component, Input} from '@angular/core';
+import {CompaniesService} from "@app/_services/companies.service";
+
+@Component({
+ selector: 'company-structure',
+ templateUrl: 'company-structure.component.html',
+ styleUrls: ['company-structure.component.scss']
+})
+export class CompanyStructureComponent {
+ @Input() companyId: string;
+ @Input() editable = false;
+ public company: any;
+
+ constructor(private companiesService: CompaniesService) {
+ }
+
+
+ get department() {
+ return this.company?.rootDepartment?.data;
+ }
+
+ get members() {
+ return this.company?.rootMembers?.data;
+ }
+
+
+
+ ngOnInit() {
+ this.fetch();
+ }
+
+ fetch() {
+ this.companiesService.fetch(this.companyId, {include: 'rootDepartment.children,rootDepartment.members.user.avatar,rootMembers.user'}).subscribe(res => {
+ this.company = res.data;
+ });
+ }
+
+
+
+}
diff --git a/src/app/_modules/companies/structure/department/company-department.component.html b/src/app/_modules/companies/structure/department/company-department.component.html
new file mode 100644
index 0000000..af281ba
--- /dev/null
+++ b/src/app/_modules/companies/structure/department/company-department.component.html
@@ -0,0 +1,17 @@
+
+
+
+
{{ftl}}
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/companies/structure/department/company-department.component.scss b/src/app/_modules/companies/structure/department/company-department.component.scss
new file mode 100644
index 0000000..638bfc3
--- /dev/null
+++ b/src/app/_modules/companies/structure/department/company-department.component.scss
@@ -0,0 +1,87 @@
+.department {
+ .bar {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 12px 0;
+ border-bottom: #E8E8E8 solid 1px;
+ cursor: pointer;
+ .left {
+ flex-shrink: 0;
+ &:before {
+ display: block;
+ width: 40px;
+ height: 24px;
+ background: transparent url("~src/assets/images/icons/circle_plus_24.svg") 50% 50% no-repeat;
+ content: "";
+ }
+ }
+ .logo {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ width: 40px;
+ height: 40px;
+ margin-left: 16px;
+ border-radius: 200px;
+ background-color: #F9B417;
+ color: #ffffff;
+ font-weight: 700;
+ }
+ .mid {
+ flex-grow: 1;
+ padding: 0 16px;
+ .name {
+ }
+ }
+ .right {
+ flex-shrink: 0;
+ button {
+ margin-left: 20px;
+ &.edit {
+ background-image: url('~src/assets/images/icons/edit_24dp.svg');
+ }
+ &.add-member {
+ background-image: url('~src/assets/images/icons/add_person_24.svg');
+ }
+ &.add-department {
+ background-image: url('~src/assets/images/icons/add_library_dark_24.svg');
+ }
+ &.delete {
+ background-image: url('~src/assets/images/icons/close_24dp.svg');
+ }
+ }
+ }
+ }
+ .items {
+ display: none;
+ padding-left: 56px;
+ }
+ &.active {
+ >.bar {
+ .left {
+ &:before {
+ background-image: url("~src/assets/images/icons/circle_minus_24.svg");
+ }
+ }
+ }
+ >.items {
+ display: block;
+ }
+ }
+}
+
+
+@media screen and (max-width: 767px) {
+ .department {
+ .bar {
+ .logo {
+ display: none;
+ }
+ //.right {display: none;}
+ }
+ .items {
+ padding-left: 16px;
+ }
+ }
+}
diff --git a/src/app/_modules/companies/structure/department/company-department.component.ts b/src/app/_modules/companies/structure/department/company-department.component.ts
new file mode 100644
index 0000000..ba3e114
--- /dev/null
+++ b/src/app/_modules/companies/structure/department/company-department.component.ts
@@ -0,0 +1,87 @@
+import {Component, Input} from '@angular/core';
+import {DepartmentsService} from "@app/_services/departments.service";
+import {FormsService, ListsService} from "@app/_services";
+import {Subscription} from "rxjs";
+
+@Component({
+ selector: 'company-department',
+ templateUrl: 'company-department.component.html',
+ styleUrls: ['company-department.component.scss']
+})
+export class CompanyDepartmentComponent {
+ @Input() department: any;
+ @Input() active = false;
+ @Input() parent: any;
+ @Input() editable = false;
+ public controlsSubscription?: Subscription;
+
+ public touched = false;
+
+ constructor(private departmentsService: DepartmentsService, private listsService: ListsService, private formsService: FormsService) {
+ }
+
+
+ get ftl() {
+ return this.department.title.substring(0, 2);
+ }
+ get isRoot() {
+ return this.department.name === 'root';
+ }
+ get isDeletable() {
+ return !this.isRoot;
+ }
+
+ get departments() {
+ return this.department?.children?.data || [];
+ }
+ get members() {
+ return this.department?.members?.data || [];
+ }
+
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls(this.department?.id).subscribe(val => {
+ if (this.active || this.touched) this.fetch();
+ });
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ }
+
+
+ fetch() {
+ this.departmentsService.fetch(this.department?.id, {include: 'members.user.avatar,children'}).subscribe(res => {
+ this.department = res.data;
+ this.active = true;
+ });
+ }
+
+
+
+ edit() {
+ this.formsService.editModel('department', this.department.id, null, this.department.id);
+ }
+
+ addMember() {
+ this.formsService.createModel('companyMember', {extraProps: {department: this.department.id}}, this.department.id);
+ }
+
+ addDepartment() {
+ this.formsService.createModel('department', {extraProps: {department: this.department.id}}, this.department.id);
+ }
+
+ delete() {
+ if (confirm(`Удалить подразделение «${this.department.title}»?`)) this.departmentsService.delete(this.department.id).subscribe(res => {
+ this.listsService.refresh(this.parent.id);
+ });
+ }
+
+
+ toggle() {
+ if (!this.department.children) this.fetch();
+ else this.active = !this.active;
+ }
+
+
+}
diff --git a/src/app/_modules/filter-fields/field/filter-field.component.html b/src/app/_modules/filter-fields/field/filter-field.component.html
new file mode 100644
index 0000000..2cb47ea
--- /dev/null
+++ b/src/app/_modules/filter-fields/field/filter-field.component.html
@@ -0,0 +1,18 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
field type {{field.type}} filter is undefined
+
+
+
diff --git a/src/app/_modules/filter-fields/field/filter-field.component.scss b/src/app/_modules/filter-fields/field/filter-field.component.scss
new file mode 100644
index 0000000..c30e330
--- /dev/null
+++ b/src/app/_modules/filter-fields/field/filter-field.component.scss
@@ -0,0 +1,25 @@
+.field {
+ display: flex;
+ flex-direction: row;
+ width: 100%;
+ margin: 0 0 24px;
+ .caption {
+ width: 256px;
+ margin-right: 16px;
+ padding: 10px 0 2px;
+ flex-shrink: 0;
+ color: #6c6c6c;
+ }
+ .value {
+ flex-grow: 1;
+ }
+ &.hidden {
+ display: none;
+ }
+}
+@media screen and (max-width: 983px) {
+ .field {
+ flex-direction: column;
+ margin-bottom: 8px;
+ }
+}
diff --git a/src/app/_modules/filter-fields/field/filter-field.component.ts b/src/app/_modules/filter-fields/field/filter-field.component.ts
new file mode 100644
index 0000000..3afa534
--- /dev/null
+++ b/src/app/_modules/filter-fields/field/filter-field.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+import {FormControl, FormGroup} from "@angular/forms";
+import {FormFieldsService} from "@app/_services/form-fields.service";
+
+@Component({
+ selector: 'filter-field',
+ templateUrl: 'filter-field.component.html',
+ styleUrls: ['filter-field.component.scss']
+})
+export class FilterFieldComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor(private fieldsService: FormFieldsService) {
+ }
+
+ ngOnInit() {
+ this.field.value = {data: this.fieldsService.prepareFieldValue(this.field)};
+ this.formGroup.addControl(this.field.name, new FormControl(), {emitEvent: false});
+ }
+}
diff --git a/src/app/_modules/filter-fields/filter-fields.module.ts b/src/app/_modules/filter-fields/filter-fields.module.ts
new file mode 100644
index 0000000..55adb73
--- /dev/null
+++ b/src/app/_modules/filter-fields/filter-fields.module.ts
@@ -0,0 +1,34 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {
+ FilterFieldBooleanModule,
+ FilterFieldDateModule,
+ FilterFieldDatetimeModule,
+ FilterFieldFloatModule,
+ FilterFieldIntegerModule,
+ FilterFieldRelationModule,
+ FilterFieldStringModule,
+ FilterFieldTextModule,
+} from "@app/_modules/filter-fields/types";
+import {FilterFieldComponent} from "@app/_modules/filter-fields/field/filter-field.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ FilterFieldStringModule,
+ FilterFieldTextModule,
+ FilterFieldIntegerModule,
+ FilterFieldFloatModule,
+ FilterFieldBooleanModule,
+ FilterFieldDateModule,
+ FilterFieldDatetimeModule,
+ FilterFieldRelationModule,
+ ],
+ declarations: [
+ FilterFieldComponent
+ ],
+ exports: [
+ FilterFieldComponent
+ ]
+})
+export class FilterFieldsModule {}
diff --git a/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.html b/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.html
new file mode 100644
index 0000000..22cf21b
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.html
@@ -0,0 +1,10 @@
+
+
+
+
+
+
diff --git a/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.scss b/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.scss
new file mode 100644
index 0000000..ad0f711
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.scss
@@ -0,0 +1,17 @@
+.radio {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 10px 0;
+ label {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ margin-right: 36px;
+ }
+ input {
+ width: 18px;
+ height: 18px;
+ margin: 0 8px 0 0;
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.ts b/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.ts
new file mode 100644
index 0000000..1c8d794
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.component.ts
@@ -0,0 +1,28 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'filter-field-boolean',
+ templateUrl: 'filter-field-boolean.component.html',
+ styleUrls: ['filter-field-boolean.component.scss']
+})
+export class FilterFieldBooleanComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ this.control.setValue(this.initialValue, {emitEvent: false});
+ }
+
+ get initialValue() {
+ return this.field.value?.data[0] || '';
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+
+
+}
diff --git a/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.module.ts b/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.module.ts
new file mode 100644
index 0000000..232b686
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/boolean/filter-field-boolean.module.ts
@@ -0,0 +1,18 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FilterFieldBooleanComponent} from "@app/_modules/filter-fields/types/boolean/filter-field-boolean.component";
+import {ReactiveFormsModule} from "@angular/forms";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FilterFieldBooleanComponent
+ ],
+ exports: [
+ FilterFieldBooleanComponent
+ ]
+})
+export class FilterFieldBooleanModule {}
diff --git a/src/app/_modules/filter-fields/types/date/filter-field-date.component.html b/src/app/_modules/filter-fields/types/date/filter-field-date.component.html
new file mode 100644
index 0000000..3004b78
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/date/filter-field-date.component.html
@@ -0,0 +1,13 @@
+
+
+
diff --git a/src/app/_modules/filter-fields/types/date/filter-field-date.component.scss b/src/app/_modules/filter-fields/types/date/filter-field-date.component.scss
new file mode 100644
index 0000000..9551530
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/date/filter-field-date.component.scss
@@ -0,0 +1,13 @@
+.row {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ input {
+ padding-right: 50px;
+ //background: transparent url('~src/assets/images/icons/notification_date.svg') calc(100% - 20px) 50% no-repeat;
+ background-size: 16px;
+ }
+ p {
+ padding: 0 16px;
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/date/filter-field-date.component.ts b/src/app/_modules/filter-fields/types/date/filter-field-date.component.ts
new file mode 100644
index 0000000..2904d9f
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/date/filter-field-date.component.ts
@@ -0,0 +1,56 @@
+import {Component, Input} from '@angular/core';
+import {FormControl, FormGroup} from "@angular/forms";
+import {debounceTime} from "rxjs/operators";
+import {MatDatepickerInputEvent} from "@angular/material/datepicker";
+import {DatePipe} from "@angular/common";
+
+@Component({
+ selector: 'filter-field-date',
+ templateUrl: 'filter-field-date.component.html',
+ styleUrls: ['filter-field-date.component.scss']
+})
+export class FilterFieldDateComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+ public controlGroup: FormGroup;
+
+ constructor(private datePipe: DatePipe) {
+ }
+
+
+ ngOnInit() {
+ this.controlGroup = new FormGroup({gt: new FormControl(this.initialValue?.gt || null), lt: new FormControl(this.initialValue?.lt || null)});
+ this.control.setValue(this.controlGroup.value, {emitEvent: false});
+ this.controlGroup.valueChanges.pipe(debounceTime(700)).subscribe(res => {this.value = res});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0] || this.field.value?.data || {};
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control.value;
+ }
+ set value(val: any) {
+ val.gt = val.gt ? this.datePipe.transform(val.gt, 'yyyy-MM-dd') : null;
+ val.lt = val.lt ? this.datePipe.transform(val.lt, 'yyyy-MM-dd') : null;
+ this.control?.setValue(val);
+ }
+
+ get min() {
+ return this.field?.range?.min || null;
+ }
+ get max() {
+ return this.field?.range?.max || null;
+ }
+
+
+ onChange(prop: string, event: MatDatepickerInputEvent) {
+ this.value = event.value;
+ }
+
+
+}
diff --git a/src/app/_modules/filter-fields/types/date/filter-field-date.module.ts b/src/app/_modules/filter-fields/types/date/filter-field-date.module.ts
new file mode 100644
index 0000000..95524b0
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/date/filter-field-date.module.ts
@@ -0,0 +1,28 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FilterFieldDateComponent} from "@app/_modules/filter-fields/types/date/filter-field-date.component";
+import {ReactiveFormsModule} from "@angular/forms";
+import {MatFormFieldModule} from "@angular/material/form-field";
+import {MatInputModule} from "@angular/material/input";
+import {MatDatepickerModule} from "@angular/material/datepicker";
+import {MatNativeDateModule} from "@angular/material/core";
+import {NoopAnimationsModule} from "@angular/platform-browser/animations";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule,
+ MatFormFieldModule,
+ MatInputModule,
+ MatDatepickerModule,
+ MatNativeDateModule,
+ NoopAnimationsModule
+ ],
+ declarations: [
+ FilterFieldDateComponent
+ ],
+ exports: [
+ FilterFieldDateComponent
+ ]
+})
+export class FilterFieldDateModule {}
diff --git a/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.html b/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.html
new file mode 100644
index 0000000..4670381
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.scss b/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.scss
new file mode 100644
index 0000000..48ef8ae
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.scss
@@ -0,0 +1,8 @@
+.row {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ p {
+ padding: 0 16px;
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.ts b/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.ts
new file mode 100644
index 0000000..43f57ac
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.component.ts
@@ -0,0 +1,22 @@
+import {Component, Input} from '@angular/core';
+import {FormControl, FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'filter-field-datetime',
+ templateUrl: 'filter-field-datetime.component.html',
+ styleUrls: ['filter-field-datetime.component.scss']
+})
+export class FilterFieldDatetimeComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+ public controlGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ this.controlGroup = new FormGroup({gt: new FormControl(), lt: new FormControl()});
+ this.formGroup.addControl(this.field.name, this.controlGroup, {emitEvent: false});
+ }
+
+}
diff --git a/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.module.ts b/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.module.ts
new file mode 100644
index 0000000..e3460a8
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/datetime/filter-field-datetime.module.ts
@@ -0,0 +1,19 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FilterFieldDatetimeComponent} from "@app/_modules/filter-fields/types/datetime/filter-field-datetime.component";
+import {ReactiveFormsModule} from "@angular/forms";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FilterFieldDatetimeComponent
+ ],
+ exports: [
+ FilterFieldDatetimeComponent
+
+ ]
+})
+export class FilterFieldDatetimeModule {}
diff --git a/src/app/_modules/filter-fields/types/float/filter-field-float.component.html b/src/app/_modules/filter-fields/types/float/filter-field-float.component.html
new file mode 100644
index 0000000..c5f393f
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/float/filter-field-float.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/filter-fields/types/float/filter-field-float.component.scss b/src/app/_modules/filter-fields/types/float/filter-field-float.component.scss
new file mode 100644
index 0000000..48ef8ae
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/float/filter-field-float.component.scss
@@ -0,0 +1,8 @@
+.row {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ p {
+ padding: 0 16px;
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/float/filter-field-float.component.ts b/src/app/_modules/filter-fields/types/float/filter-field-float.component.ts
new file mode 100644
index 0000000..dbc418a
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/float/filter-field-float.component.ts
@@ -0,0 +1,43 @@
+import {Component, Input} from '@angular/core';
+import {FormControl, FormGroup} from "@angular/forms";
+import {debounceTime} from "rxjs/operators";
+
+@Component({
+ selector: 'filter-field-float',
+ templateUrl: 'filter-field-float.component.html',
+ styleUrls: ['filter-field-float.component.scss']
+})
+export class FilterFieldFloatComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+ public controlGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ this.controlGroup = new FormGroup({gt: new FormControl(this.initialValue?.gt || null), lt: new FormControl(this.initialValue?.lt || null)});
+ this.controlGroup.valueChanges.pipe(debounceTime(700)).subscribe(res => {this.value = res});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0] || {};
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ set value(val: any) {
+ if (val.gt && (val.gt < this.min)) val.gt = this.min;
+ if (val.lt && (val.lt > this.max)) val.lt = this.max;
+ this.control?.setValue(val);
+ }
+
+ get min() {
+ return this.field?.range?.min || 0;
+ }
+ get max() {
+ return this.field?.range?.max || 0;
+ }
+
+}
diff --git a/src/app/_modules/filter-fields/types/float/filter-field-float.module.ts b/src/app/_modules/filter-fields/types/float/filter-field-float.module.ts
new file mode 100644
index 0000000..f920e9b
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/float/filter-field-float.module.ts
@@ -0,0 +1,18 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FilterFieldFloatComponent} from "@app/_modules/filter-fields/types/float/filter-field-float.component";
+import {ReactiveFormsModule} from "@angular/forms";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FilterFieldFloatComponent
+ ],
+ exports: [
+ FilterFieldFloatComponent
+ ]
+})
+export class FilterFieldFloatModule {}
diff --git a/src/app/_modules/filter-fields/types/index.ts b/src/app/_modules/filter-fields/types/index.ts
new file mode 100644
index 0000000..efe9bee
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/index.ts
@@ -0,0 +1,8 @@
+export * from './boolean/filter-field-boolean.module';
+export * from './date/filter-field-date.module';
+export * from './datetime/filter-field-datetime.module';
+export * from './float/filter-field-float.module';
+export * from './integer/filter-field-integer.module';
+export * from './relation/filter-field-relation.module';
+export * from './string/filter-field-string.module';
+export * from './text/filter-field-text.module';
diff --git a/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.html b/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.html
new file mode 100644
index 0000000..706a509
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.scss b/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.scss
new file mode 100644
index 0000000..48ef8ae
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.scss
@@ -0,0 +1,8 @@
+.row {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ p {
+ padding: 0 16px;
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.ts b/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.ts
new file mode 100644
index 0000000..cbe3edb
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/integer/filter-field-integer.component.ts
@@ -0,0 +1,43 @@
+import {Component, Input} from '@angular/core';
+import {FormControl, FormGroup} from "@angular/forms";
+import {debounceTime} from "rxjs/operators";
+
+@Component({
+ selector: 'filter-field-integer',
+ templateUrl: 'filter-field-integer.component.html',
+ styleUrls: ['filter-field-integer.component.scss']
+})
+export class FilterFieldIntegerComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+ public controlGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ this.controlGroup = new FormGroup({gt: new FormControl(this.initialValue?.gt || null), lt: new FormControl(this.initialValue?.lt || null)});
+ this.controlGroup.valueChanges.pipe(debounceTime(700)).subscribe(res => {this.value = res});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0] || {};
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ set value(val: any) {
+ if (val.gt && (val.gt < this.min)) val.gt = this.min;
+ if (val.lt && (val.lt > this.max)) val.lt = this.max;
+ this.control?.setValue(val);
+ }
+
+ get min() {
+ return this.field?.range?.min || 0;
+ }
+ get max() {
+ return this.field?.range?.max || 0;
+ }
+
+}
diff --git a/src/app/_modules/filter-fields/types/integer/filter-field-integer.module.ts b/src/app/_modules/filter-fields/types/integer/filter-field-integer.module.ts
new file mode 100644
index 0000000..fafda93
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/integer/filter-field-integer.module.ts
@@ -0,0 +1,18 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FilterFieldIntegerComponent} from "@app/_modules/filter-fields/types/integer/filter-field-integer.component";
+import {ReactiveFormsModule} from "@angular/forms";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FilterFieldIntegerComponent
+ ],
+ exports: [
+ FilterFieldIntegerComponent
+ ]
+})
+export class FilterFieldIntegerModule {}
diff --git a/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.html b/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.html
new file mode 100644
index 0000000..8d94d47
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.html
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.scss b/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.scss
new file mode 100644
index 0000000..9c001ff
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.scss
@@ -0,0 +1,22 @@
+.block {
+ .title {
+ font-weight: bold;
+ }
+ .options {
+ padding-top: 10px;
+ .option {
+ margin-bottom: 10px;
+ input {
+ flex-shrink: 0;
+ width: 18px;
+ height: 18px;
+ margin: 0;
+ }
+ label {
+ display: flex;
+ column-gap: 12px;
+ align-items: center;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.ts b/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.ts
new file mode 100644
index 0000000..2d9f6ec
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component.ts
@@ -0,0 +1,61 @@
+import {Component, OnInit, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'relation-checkbox',
+ templateUrl: 'relation-checkbox.component.html',
+ styleUrls: ['relation-checkbox.component.scss']
+})
+export class RelationCheckboxComponent implements OnInit {
+ @Input() formGroup!: FormGroup;
+ @Input() field!: any;
+
+ public selected = [];
+
+ ngOnInit(): void {
+ this.initValue();
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data || [];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get options() {
+ return this.field.represented?.data || [];
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(value: any[]) {
+ this.selected = value;
+ this.control.setValue(value.map(val => {return val.id}).filter(val => {return (val !== undefined) && (val !== null)}));
+ }
+
+ initValue() {
+ this.selected = this.initialValue;
+ this.control.setValue(this.initialValue.map(val => {return val.id}).filter(val => {return (val !== undefined) && (val !== null)}), {emitEvent: false});
+ }
+
+
+ onChange(event: any, option: any) {
+ event.target.checked ? this.addValue(option) : this.removeValue(option);
+ }
+
+ isChecked(option: any) {
+ return this.value.indexOf(option.id) !== -1;
+ }
+
+ addValue(option: any) {
+ let val = this.selected;
+ val.push(option);
+ this.value = val;
+ }
+ removeValue(option: any) {
+ this.value = this.selected.filter(val => {return option.id !== val.id});
+ }
+
+
+}
diff --git a/src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.html b/src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.html
new file mode 100644
index 0000000..8f66f2a
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.html
@@ -0,0 +1,31 @@
+
+
+
+
+ -
+
+
{{option.caption || option.title || option.name}}
+
{{option.subtitle}}
+
+
+ -
+ Результатов не найдено, укажите менее строгий запрос
+
+
+
+
+
+
+
+
{{val.caption || val.title || val.name}}
+
{{val.subtitle}}
+
+
+
+
+
diff --git a/src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.scss b/src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.ts b/src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.ts
new file mode 100644
index 0000000..94bd877
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/combobox/relation-combobox.component.ts
@@ -0,0 +1,87 @@
+import {Component, OnInit, Input, HostListener, ElementRef, ViewChild} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {UtilityService} from "@app/_services/utility.service";
+
+@Component({
+ selector: 'relation-combobox',
+ templateUrl: 'relation-combobox.component.html',
+ styleUrls: ['relation-combobox.component.scss', '../filter-field-relation.component.scss']
+})
+export class RelationComboboxComponent implements OnInit {
+ @Input() formGroup!: FormGroup;
+ @Input() field!: any;
+ @ViewChild("searchInput") searchInput?: ElementRef;
+
+ public active = false;
+ public options = [];
+ public selected = [];
+ public search = '';
+
+ constructor(private eRef: ElementRef, private utilityService: UtilityService) {
+ }
+
+ @HostListener('document:click', ['$event.target'])
+ onClick(target: any) {
+ if (!this.eRef.nativeElement.contains(target)) this.active = false;
+ }
+
+ ngOnInit(): void {
+ this.initValue();
+ this.updateOptions();
+ }
+
+ get initialValue() {
+ return this.field.value?.data || [];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(value: any[]) {
+ this.selected = value;
+ this.control.setValue(value.map(val => {return val.id}).filter(val => {return (val !== undefined) && (val !== null)}));
+ }
+
+ get caption() {
+ return this.value?.length ? `Выбрано ${this.value?.length} значений` : 'Не выбрано';
+ }
+
+
+ initValue() {
+ this.selected = this.initialValue;
+ this.control.setValue(this.initialValue.map(val => {return val.id}).filter(val => {return (val !== undefined) && (val !== null)}), {emitEvent: false});
+ }
+
+
+ onInput(event) {
+ this.search = event.target.value;
+ this.updateOptions();
+ }
+
+ updateOptions() {
+ this.options = this.utilityService.filterOptions(this.search, this.field.represented?.data || []);
+ }
+
+ toggleValue(option: any) {
+ this.isSelected(option) ? this.removeValue(option) : this.addValue(option);
+ this.active = false;
+ }
+ addValue(option: any) {
+ let val = this.selected;
+ val.push(option);
+ this.value = val;
+ }
+ removeValue(option: any) {
+ this.value = this.selected.filter(val => {return option.id !== val.id});
+ }
+ isSelected(option: any) {
+ return this.value.indexOf(option.id) !== -1;
+ }
+
+ toggleActivity() {
+ this.active = !this.active;
+ if (this.active) setTimeout(() => {this.searchInput?.nativeElement.focus()}, 10);
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.html b/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.html
new file mode 100644
index 0000000..a2eacdc
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.scss b/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.scss
new file mode 100644
index 0000000..6750bf5
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.scss
@@ -0,0 +1,169 @@
+.combobox {
+ position: relative;
+ border: #9f9f9f solid 1px;
+ border-radius: 4px;
+
+ .toggle {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ width: 100%;
+ height: 40px;
+ padding: 0 12px 0 16px;
+ font-size: 1rem;
+ box-sizing: border-box;
+ cursor: pointer;
+ .caption {
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ p {
+ padding: 0;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ &.faded {
+ font-size: 0.875rem;
+ color: #7f7f7f;
+ }
+ }
+ }
+ .filter {
+ display: none;
+ width: 100%;
+ input {
+ width: 100%;
+ padding: 8px 0;
+ border: 0;
+ }
+ }
+
+ &:after {
+ display: block;
+ width: 24px;
+ height: 20px;
+ margin-left: auto;
+ background: transparent url('~src/assets/images/icons/arrow_drop_down_24dp.svg') 50% 50% no-repeat;
+ content: "";
+ transition: transform 0.2s;
+ }
+ }
+
+ .dropdown {
+ display: none;
+ position: absolute;
+ top: calc(100% + 1px);
+ left: -1px;
+ width: calc(100% + 2px);
+ margin-bottom: 50px;
+ background-color: #ffffff;
+ border: #dfdfdf solid 1px;
+ border-radius: 4px;
+ box-shadow: rgba(0, 0, 0, 0.16) 0 2px 3px 0;
+ overflow: hidden;
+ z-index: 100;
+
+ ul {
+ padding: 0;
+ margin: 0;
+ max-height: 280px;
+ overflow: auto;
+ -webkit-overflow-scrolling: touch;
+ .empty {
+ padding: 10px 16px;
+ background-color: #f7f7f7;
+ color: #7f7f7f;
+ .add {
+ display: block;
+ color: #2c86cd;
+ cursor: pointer;
+ }
+ }
+
+ li {
+ .title {
+ padding: 10px 16px;
+ border-bottom: #dfdfdf solid 1px;
+ cursor: pointer;
+ p {
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ margin: 0;
+ padding: 0;
+ &.faded {
+ font-size: 0.875rem;
+ color: #7f7f7f;
+ }
+ }
+ &:hover {
+ background-color: #f7f7f7;
+ }
+ &.selected {
+ background-color: #e3eff9;
+ }
+ }
+ }
+ }
+ }
+
+ &.active {
+ .toggle {
+ .caption {
+ display: none;
+ }
+ .filter {
+ display: block;
+ }
+ &::after {
+ transform: rotateZ(180deg);
+ }
+ }
+ .dropdown {
+ display: block;
+ }
+ }
+}
+
+
+.values {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ flex-wrap: wrap;
+
+ .item {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 4px 8px 4px 12px;
+ margin: 8px 8px 0 0;
+ background-color: #E3EFF9;
+ border-radius: 16px;
+
+ .name {
+ padding-right: 8px;
+ font-size: 0.875rem;
+ line-height: 20px;
+
+ p {
+ margin: 0;
+ }
+
+ .faded {
+ color: #7f7f7f;
+
+ }
+ }
+
+ .remove {
+ width: 16px;
+ height: 16px;
+ padding: 0;
+ margin: auto;
+ flex-shrink: 0;
+ border: none;
+ background: transparent url('~src/assets/images/icons/close_16dp.svg') 50% 50% no-repeat;
+ cursor: pointer;
+ }
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.ts b/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.ts
new file mode 100644
index 0000000..037fd58
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/filter-field-relation.component.ts
@@ -0,0 +1,21 @@
+import {Component, EventEmitter, Input, Output} from '@angular/core';
+import {FormControl, FormGroup} from "@angular/forms";
+
+
+@Component({
+ selector: 'filter-field-relation',
+ templateUrl: 'filter-field-relation.component.html',
+ styleUrls: ['filter-field-relation.component.scss']
+})
+export class FilterFieldRelationComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ //this.formGroup.addControl(this.field.name, new FormControl(''), {emitEvent: false});
+ }
+
+}
diff --git a/src/app/_modules/filter-fields/types/relation/filter-field-relation.module.ts b/src/app/_modules/filter-fields/types/relation/filter-field-relation.module.ts
new file mode 100644
index 0000000..7a890ce
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/filter-field-relation.module.ts
@@ -0,0 +1,26 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+
+import {FilterFieldRelationComponent} from "@app/_modules/filter-fields/types/relation/filter-field-relation.component";
+import {RelationCheckboxComponent} from "@app/_modules/filter-fields/types/relation/checkbox/relation-checkbox.component";
+import {RelationComboboxComponent} from "@app/_modules/filter-fields/types/relation/combobox/relation-combobox.component";
+import {RelationRadioComponent} from "@app/_modules/filter-fields/types/relation/radio/relation-radio.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FilterFieldRelationComponent,
+ RelationCheckboxComponent,
+ RelationComboboxComponent,
+ RelationRadioComponent
+ ],
+ exports: [
+ FilterFieldRelationComponent,
+ RelationCheckboxComponent
+ ]
+})
+export class FilterFieldRelationModule {}
diff --git a/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.html b/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.html
new file mode 100644
index 0000000..3a8214e
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.html
@@ -0,0 +1,12 @@
+
diff --git a/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.scss b/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.scss
new file mode 100644
index 0000000..9c001ff
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.scss
@@ -0,0 +1,22 @@
+.block {
+ .title {
+ font-weight: bold;
+ }
+ .options {
+ padding-top: 10px;
+ .option {
+ margin-bottom: 10px;
+ input {
+ flex-shrink: 0;
+ width: 18px;
+ height: 18px;
+ margin: 0;
+ }
+ label {
+ display: flex;
+ column-gap: 12px;
+ align-items: center;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.ts b/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.ts
new file mode 100644
index 0000000..8563e06
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/relation/radio/relation-radio.component.ts
@@ -0,0 +1,32 @@
+import {Component, OnInit, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'relation-radio',
+ templateUrl: 'relation-radio.component.html',
+ styleUrls: ['relation-radio.component.scss']
+})
+export class RelationRadioComponent implements OnInit {
+ @Input() formGroup!: FormGroup;
+ @Input() field!: any;
+
+ ngOnInit(): void {
+ this.initValue();
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0]?.id || '';
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get options() {
+ return this.field.represented?.data || [];
+ }
+
+ initValue() {
+ this.control.setValue(this.initialValue, {emitEvent: false});
+ }
+
+}
diff --git a/src/app/_modules/filter-fields/types/string/filter-field-string.component.html b/src/app/_modules/filter-fields/types/string/filter-field-string.component.html
new file mode 100644
index 0000000..cc42c2b
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/string/filter-field-string.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/filter-fields/types/string/filter-field-string.component.scss b/src/app/_modules/filter-fields/types/string/filter-field-string.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/filter-fields/types/string/filter-field-string.component.ts b/src/app/_modules/filter-fields/types/string/filter-field-string.component.ts
new file mode 100644
index 0000000..508c9f4
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/string/filter-field-string.component.ts
@@ -0,0 +1,29 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'filter-field-string',
+ templateUrl: 'filter-field-string.component.html',
+ styleUrls: ['filter-field-string.component.scss']
+})
+export class FilterFieldStringComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ this.control.setValue(this.initialValue, {emitEvent: false});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0] || '';
+ }
+
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+
+}
diff --git a/src/app/_modules/filter-fields/types/string/filter-field-string.module.ts b/src/app/_modules/filter-fields/types/string/filter-field-string.module.ts
new file mode 100644
index 0000000..79666c5
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/string/filter-field-string.module.ts
@@ -0,0 +1,18 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+import {FilterFieldStringComponent} from "@app/_modules/filter-fields/types/string/filter-field-string.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FilterFieldStringComponent
+ ],
+ exports: [
+ FilterFieldStringComponent
+ ]
+})
+export class FilterFieldStringModule {}
diff --git a/src/app/_modules/filter-fields/types/text/filter-field-text.component.html b/src/app/_modules/filter-fields/types/text/filter-field-text.component.html
new file mode 100644
index 0000000..f322165
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/text/filter-field-text.component.html
@@ -0,0 +1 @@
+field type is not filterable
diff --git a/src/app/_modules/filter-fields/types/text/filter-field-text.component.scss b/src/app/_modules/filter-fields/types/text/filter-field-text.component.scss
new file mode 100644
index 0000000..15f2dc8
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/text/filter-field-text.component.scss
@@ -0,0 +1,13 @@
+.textbox {
+ width: 100%;
+ min-height: 40px;
+ padding: 10px 16px;
+ border-radius: 4px;
+ border: solid 1px #939393;
+ font-size: 1rem;
+ color: #111111;
+ &:focus, &:focus-visible {
+ border-color: #111111;
+ outline: none;
+ }
+}
diff --git a/src/app/_modules/filter-fields/types/text/filter-field-text.component.ts b/src/app/_modules/filter-fields/types/text/filter-field-text.component.ts
new file mode 100644
index 0000000..9fd9603
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/text/filter-field-text.component.ts
@@ -0,0 +1,25 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'filter-field-text',
+ templateUrl: 'filter-field-text.component.html',
+ styleUrls: ['filter-field-text.component.scss']
+})
+export class FilterFieldTextComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+ @Input() maxLength = 0;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+
+}
diff --git a/src/app/_modules/filter-fields/types/text/filter-field-text.module.ts b/src/app/_modules/filter-fields/types/text/filter-field-text.module.ts
new file mode 100644
index 0000000..0dcbd38
--- /dev/null
+++ b/src/app/_modules/filter-fields/types/text/filter-field-text.module.ts
@@ -0,0 +1,16 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FilterFieldTextComponent} from "@app/_modules/filter-fields/types/text/filter-field-text.component";
+
+@NgModule({
+ imports: [
+ CommonModule
+ ],
+ declarations: [
+ FilterFieldTextComponent
+ ],
+ exports: [
+ FilterFieldTextComponent
+ ]
+})
+export class FilterFieldTextModule {}
diff --git a/src/app/_modules/form-fields/field/form-field.component.html b/src/app/_modules/form-fields/field/form-field.component.html
new file mode 100644
index 0000000..e726219
--- /dev/null
+++ b/src/app/_modules/form-fields/field/form-field.component.html
@@ -0,0 +1,26 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
{{field.type}} field control is undefined
+
+
Это поле обязательно для заполнения
+
+
+
diff --git a/src/app/_modules/form-fields/field/form-field.component.scss b/src/app/_modules/form-fields/field/form-field.component.scss
new file mode 100644
index 0000000..c918044
--- /dev/null
+++ b/src/app/_modules/form-fields/field/form-field.component.scss
@@ -0,0 +1,43 @@
+.field {
+ display: flex;
+ flex-direction: column;
+ width: 100%;
+ margin: 0 0 24px;
+ row-gap: 8px;
+
+ .caption {
+ color: var(--grey-4);
+ font-size: 1rem;
+ font-style: normal;
+ font-weight: 400;
+ line-height: 20px;
+ padding-top: 8px;
+ }
+ .value {
+ .error {
+ margin-top: 2px;
+ font-size: 0.875rem;
+ color: #e60046;
+ }
+ }
+ &.readonly {
+ margin: 0 0 12px;
+ .caption {
+ //padding: 0;
+ }
+ }
+}
+@media screen and (max-width: 600px) {
+ .field {
+ margin-bottom: 8px;
+ .caption {
+ width: 100%;
+ padding: 0;
+ margin: 0 0 8px;
+ }
+ .value {
+ width: 100%;
+ margin: 0 0 16px;
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/field/form-field.component.ts b/src/app/_modules/form-fields/field/form-field.component.ts
new file mode 100644
index 0000000..6684fb1
--- /dev/null
+++ b/src/app/_modules/form-fields/field/form-field.component.ts
@@ -0,0 +1,64 @@
+import {Component, Input} from '@angular/core';
+import {FormArray, FormControl, FormGroup, Validators} from "@angular/forms";
+import {debounceTime} from "rxjs/operators";
+import {isNumeric} from "rxjs/internal-compatibility";
+//import {CompaniesService} from "@app/_services/companies.service";
+import {FormFieldsService} from "@app/_services/form-fields.service";
+
+@Component({
+ selector: 'form-field',
+ templateUrl: 'form-field.component.html',
+ styleUrls: ['form-field.component.scss']
+})
+export class FormFieldComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+ @Input() readonly = false;
+ @Input() params?: any = {};
+
+ constructor(private fieldsService: FormFieldsService, /*private companiesService: CompaniesService*/) {
+ }
+
+ ngOnInit() {
+ this.field.value = {data: this.fieldsService.prepareFieldValue(this.field)};
+ if (this.readonly) this.field.readonly = true;
+ if (!this.field.readonly) this.formGroup.addControl(this.field.name, this.makeControl());
+ }
+
+ get control() {
+ return this.formGroup?.controls[this.field.name];
+ }
+
+ get isInvalid() {
+ return this.control?.invalid && (this.control?.touched || this.control?.dirty);
+ }
+
+
+
+ makeControl() {
+ let control = new FormControl(null, (this.field.required && !this.field.hidden) ? Validators.required : null);
+ if (this.field.name === 'inn') control.valueChanges.pipe(debounceTime(300)).subscribe(val => {
+ if (isNumeric(val) && (`${val}`.length === 10)) this.getCompanyData(val);
+ });
+ return control;
+ }
+
+
+ getCompanyData(inn) {
+ /*
+ this.companiesService.getDataByInn(inn).subscribe(res => {
+ this.setControlValue('name', res.company?.name);
+ this.setControlValue('address', res.address?.full);
+ });
+ */
+ }
+
+ setControlValue(name, value) {
+ let control = this.formGroup.controls[name];
+ if (control && value) {
+ control.setValue(value);
+ control.updateValueAndValidity();
+ }
+ }
+
+}
diff --git a/src/app/_modules/form-fields/form-fields.module.ts b/src/app/_modules/form-fields/form-fields.module.ts
new file mode 100644
index 0000000..a4c605d
--- /dev/null
+++ b/src/app/_modules/form-fields/form-fields.module.ts
@@ -0,0 +1,47 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FormFieldComponent} from "@app/_modules/form-fields/field/form-field.component";
+import {
+ FormFieldBooleanModule,
+ FormFieldDateModule,
+ FormFieldDatetimeModule,
+ FormFieldDocumentModule,
+ FormFieldImageModule,
+ FormFieldFloatModule,
+ FormFieldIntegerModule,
+ FormFieldRelationModule,
+ FormFieldStringModule,
+ FormFieldTextModule,
+ FormFieldTimeModule,
+ FormFieldTopicsModule,
+ FormFieldHiddenModule,
+ FormFieldHtmlModule,
+} from "@app/_modules/form-fields/types";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ FormFieldStringModule,
+ FormFieldTextModule,
+ FormFieldIntegerModule,
+ FormFieldFloatModule,
+ FormFieldBooleanModule,
+ FormFieldDateModule,
+ FormFieldDatetimeModule,
+ FormFieldRelationModule,
+ FormFieldDocumentModule,
+ FormFieldImageModule,
+ FormFieldTimeModule,
+ FormFieldTopicsModule,
+ FormFieldHiddenModule,
+ FormFieldHtmlModule,
+ ],
+ declarations: [
+ FormFieldComponent
+ ],
+ exports: [
+ FormFieldComponent,
+ ]
+})
+export class FormFieldsModule {
+}
diff --git a/src/app/_modules/form-fields/types/boolean/form-field-boolean.component.html b/src/app/_modules/form-fields/types/boolean/form-field-boolean.component.html
new file mode 100644
index 0000000..97b9e36
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/form-field-boolean.component.html
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/boolean/form-field-boolean.component.scss b/src/app/_modules/form-fields/types/boolean/form-field-boolean.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/boolean/form-field-boolean.component.ts b/src/app/_modules/form-fields/types/boolean/form-field-boolean.component.ts
new file mode 100644
index 0000000..bb7905c
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/form-field-boolean.component.ts
@@ -0,0 +1,20 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-boolean',
+ templateUrl: 'form-field-boolean.component.html',
+ styleUrls: ['form-field-boolean.component.scss']
+})
+export class FormFieldBooleanComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/boolean/form-field-boolean.module.ts b/src/app/_modules/form-fields/types/boolean/form-field-boolean.module.ts
new file mode 100644
index 0000000..5432d91
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/form-field-boolean.module.ts
@@ -0,0 +1,22 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FormFieldBooleanComponent} from "@app/_modules/form-fields/types/boolean/form-field-boolean.component";
+import {ReactiveFormsModule} from "@angular/forms";
+import {FieldBooleanReadonlyComponent} from "@app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component";
+import {FieldBooleanSingleComponent} from "@app/_modules/form-fields/types/boolean/single/field-boolean-single.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldBooleanComponent,
+ FieldBooleanReadonlyComponent,
+ FieldBooleanSingleComponent
+ ],
+ exports: [
+ FormFieldBooleanComponent
+ ]
+})
+export class FormFieldBooleanModule {}
diff --git a/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.html b/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.html
new file mode 100644
index 0000000..4f484cd
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.html
@@ -0,0 +1 @@
+{{caption}}
diff --git a/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.scss b/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.ts b/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.ts
new file mode 100644
index 0000000..9f69ab8
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/readonly/field-boolean-readonly.component.ts
@@ -0,0 +1,25 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-boolean-readonly',
+ templateUrl: 'field-boolean-readonly.component.html',
+ styleUrls: ['field-boolean-readonly.component.scss']
+})
+export class FieldBooleanReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+
+ get value() {
+ return this.field.value?.data[0];
+ }
+ get caption() {
+ return ((this.value === undefined) || (this.value === null)) ? 'Не указано' : (this.value ? 'Да' : 'Нет');
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.html b/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.html
new file mode 100644
index 0000000..b13b9e6
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.html
@@ -0,0 +1,3 @@
+
diff --git a/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.scss b/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.scss
new file mode 100644
index 0000000..29c95f0
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.scss
@@ -0,0 +1,3 @@
+.bar {
+ padding: 10px 0;
+}
diff --git a/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.ts b/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.ts
new file mode 100644
index 0000000..f0b4626
--- /dev/null
+++ b/src/app/_modules/form-fields/types/boolean/single/field-boolean-single.component.ts
@@ -0,0 +1,40 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-boolean-single',
+ templateUrl: 'field-boolean-single.component.html',
+ styleUrls: ['field-boolean-single.component.scss']
+})
+export class FieldBooleanSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ this.value = this.initialValue;
+ }
+
+
+
+ get initialValue() {
+ return !!this.field.value?.data[0] || null;
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value) {
+ this.control?.setValue(value);
+ }
+
+
+
+ toggle() {
+ this.value = !this.value;
+ }
+}
diff --git a/src/app/_modules/form-fields/types/date/form-field-date.component.html b/src/app/_modules/form-fields/types/date/form-field-date.component.html
new file mode 100644
index 0000000..eb54836
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/form-field-date.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/date/form-field-date.component.scss b/src/app/_modules/form-fields/types/date/form-field-date.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/date/form-field-date.component.ts b/src/app/_modules/form-fields/types/date/form-field-date.component.ts
new file mode 100644
index 0000000..34e6228
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/form-field-date.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-date',
+ templateUrl: 'form-field-date.component.html',
+ styleUrls: ['form-field-date.component.scss']
+})
+export class FormFieldDateComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/date/form-field-date.module.ts b/src/app/_modules/form-fields/types/date/form-field-date.module.ts
new file mode 100644
index 0000000..2b1847e
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/form-field-date.module.ts
@@ -0,0 +1,37 @@
+import {NgModule} from '@angular/core';
+import {CommonModule, DatePipe} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+
+import {FormFieldDateComponent} from "@app/_modules/form-fields/types/date/form-field-date.component";
+import {FieldDateReadonlyComponent} from "@app/_modules/form-fields/types/date/readonly/field-date-readonly.component";
+import {FieldDateSingleComponent} from "@app/_modules/form-fields/types/date/single/field-date-single.component";
+import {MatDatepickerModule} from "@angular/material/datepicker";
+import {MatFormFieldModule} from "@angular/material/form-field";
+import {MatNativeDateModule} from "@angular/material/core";
+import {MatInputModule} from "@angular/material/input";
+import {NoopAnimationsModule} from "@angular/platform-browser/animations";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule,
+ MatFormFieldModule,
+ MatInputModule,
+ MatDatepickerModule,
+ MatNativeDateModule,
+ NoopAnimationsModule
+ ],
+ declarations: [
+ FormFieldDateComponent,
+ FieldDateReadonlyComponent,
+ FieldDateSingleComponent
+ ],
+ exports: [
+ FormFieldDateComponent,
+ FieldDateSingleComponent
+ ],
+ providers: [
+ DatePipe
+ ]
+})
+export class FormFieldDateModule {}
diff --git a/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.html b/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.html
new file mode 100644
index 0000000..c6f767d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.html
@@ -0,0 +1,2 @@
+{{val | date: 'dd.MM.yyyy'}}
+-
diff --git a/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.scss b/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.ts b/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.ts
new file mode 100644
index 0000000..eb79267
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/readonly/field-date-readonly.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-date-readonly',
+ templateUrl: 'field-date-readonly.component.html',
+ styleUrls: ['field-date-readonly.component.scss']
+})
+export class FieldDateReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/date/single/field-date-single.component.html b/src/app/_modules/form-fields/types/date/single/field-date-single.component.html
new file mode 100644
index 0000000..93f07ad
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/single/field-date-single.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/date/single/field-date-single.component.scss b/src/app/_modules/form-fields/types/date/single/field-date-single.component.scss
new file mode 100644
index 0000000..51c9313
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/single/field-date-single.component.scss
@@ -0,0 +1,6 @@
+input {
+ max-width: 160px;
+ padding-right: 50px;
+ //background: transparent url('~src/assets/images/icons/notification_date.svg') calc(100% - 20px) 50% no-repeat;
+ background-size: 16px;
+}
diff --git a/src/app/_modules/form-fields/types/date/single/field-date-single.component.ts b/src/app/_modules/form-fields/types/date/single/field-date-single.component.ts
new file mode 100644
index 0000000..690ddf8
--- /dev/null
+++ b/src/app/_modules/form-fields/types/date/single/field-date-single.component.ts
@@ -0,0 +1,50 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {DatePipe} from "@angular/common";
+import {MatDatepickerInputEvent} from "@angular/material/datepicker";
+
+@Component({
+ selector: 'field-date-single',
+ templateUrl: 'field-date-single.component.html',
+ styleUrls: ['field-date-single.component.scss']
+})
+export class FieldDateSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor(private datePipe: DatePipe) {
+ }
+
+ ngOnInit() {
+ setTimeout(() => {this.value = this.value || this.initialValue || null});
+ }
+
+
+ get initialValue() {
+ return this.field?.value?.data[0];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value) {
+ this.control?.setValue(value ? this.datePipe.transform(value, 'yyyy-MM-dd') : null);
+ }
+
+ get min() {
+ return this.field?.range?.min || null;
+ }
+ get max() {
+ return this.field?.range?.max || null;
+ }
+
+
+
+ onChange(event: MatDatepickerInputEvent) {
+ this.value = event.value;
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/datetime/form-field-datetime.component.html b/src/app/_modules/form-fields/types/datetime/form-field-datetime.component.html
new file mode 100644
index 0000000..77a8df1
--- /dev/null
+++ b/src/app/_modules/form-fields/types/datetime/form-field-datetime.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/datetime/form-field-datetime.component.scss b/src/app/_modules/form-fields/types/datetime/form-field-datetime.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/datetime/form-field-datetime.component.ts b/src/app/_modules/form-fields/types/datetime/form-field-datetime.component.ts
new file mode 100644
index 0000000..fc78d7f
--- /dev/null
+++ b/src/app/_modules/form-fields/types/datetime/form-field-datetime.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-datetime',
+ templateUrl: 'form-field-datetime.component.html',
+ styleUrls: ['form-field-datetime.component.scss']
+})
+export class FormFieldDatetimeComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/datetime/form-field-datetime.module.ts b/src/app/_modules/form-fields/types/datetime/form-field-datetime.module.ts
new file mode 100644
index 0000000..81eba1c
--- /dev/null
+++ b/src/app/_modules/form-fields/types/datetime/form-field-datetime.module.ts
@@ -0,0 +1,25 @@
+import {NgModule} from '@angular/core';
+import {CommonModule, DatePipe} from '@angular/common';
+import {FormFieldDatetimeComponent} from "@app/_modules/form-fields/types/datetime/form-field-datetime.component";
+import {ReactiveFormsModule} from "@angular/forms";
+import {FieldDatetimeReadonlyComponent} from "@app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component";
+import {FieldDatetimeSingleComponent} from "@app/_modules/form-fields/types/datetime/single/field-datetime-single.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldDatetimeComponent,
+ FieldDatetimeReadonlyComponent,
+ FieldDatetimeSingleComponent
+ ],
+ exports: [
+ FormFieldDatetimeComponent
+ ],
+ providers: [
+ DatePipe
+ ]
+})
+export class FormFieldDatetimeModule {}
diff --git a/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.html b/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.html
new file mode 100644
index 0000000..5d980ef
--- /dev/null
+++ b/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.html
@@ -0,0 +1,2 @@
+{{val | date: 'dd.MM.yyyy HH:mm'}}
+-
diff --git a/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.scss b/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.ts b/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.ts
new file mode 100644
index 0000000..2b802bb
--- /dev/null
+++ b/src/app/_modules/form-fields/types/datetime/readonly/field-datetime-readonly.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-datetime-readonly',
+ templateUrl: 'field-datetime-readonly.component.html',
+ styleUrls: ['field-datetime-readonly.component.scss']
+})
+export class FieldDatetimeReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.html b/src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.html
new file mode 100644
index 0000000..6d2d9c2
--- /dev/null
+++ b/src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.scss b/src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.ts b/src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.ts
new file mode 100644
index 0000000..3a7369c
--- /dev/null
+++ b/src/app/_modules/form-fields/types/datetime/single/field-datetime-single.component.ts
@@ -0,0 +1,35 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {DatePipe} from "@angular/common";
+
+@Component({
+ selector: 'field-datetime-single',
+ templateUrl: 'field-datetime-single.component.html',
+ styleUrls: ['field-datetime-single.component.scss']
+})
+export class FieldDatetimeSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor(private datePipe: DatePipe) {
+ }
+
+ ngOnInit() {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field?.value?.data[0];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value) {
+ this.control?.setValue(this.datePipe.transform(value, 'yyyy-MM-dd HH:mm'));
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/document/form-field-document.component.html b/src/app/_modules/form-fields/types/document/form-field-document.component.html
new file mode 100644
index 0000000..75013ed
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/form-field-document.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/document/form-field-document.component.scss b/src/app/_modules/form-fields/types/document/form-field-document.component.scss
new file mode 100644
index 0000000..e9f7cfe
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/form-field-document.component.scss
@@ -0,0 +1,82 @@
+.area {
+ position: relative;
+ display: flex;
+ height: 100px;
+ padding: 16px;
+ border: var(--orange-2) dashed 1px;
+ border-radius: 4px;
+ overflow: hidden;
+ &.hover {
+ background-color: #e0e0e0;
+ }
+ p {
+ margin: auto;
+ color: #c0c0c0;
+ text-align: center;
+ span {
+ color: var(--orange-2);
+ cursor: pointer;
+ }
+ }
+ input {
+ display: none;
+ }
+ .indicator {
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ padding: 16px;
+ background-color: #f7f7f7;
+ .label {
+ margin-bottom: 4px;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ }
+ .progress {
+ height: 4px;
+ background-color: #dfdfdf;
+ overflow: hidden;
+ .fill {
+ width: 0;
+ height: 100%;
+ background-color: #3ca128;
+ }
+ }
+ }
+}
+
+.values {
+ .item {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ margin-top: 10px;
+
+ &:before {
+ width: 20px;
+ height: 20px;
+ margin-right: 8px;
+ flex-shrink: 0;
+ background: transparent url("~src/assets/images/icons/document_20dp.svg") 50% 50% no-repeat;
+ content: '';
+ }
+ .archive {
+ width: 20px;
+ height: 20px;
+ margin-left: 8px;
+ flex-shrink: 0;
+ background: transparent url("~src/assets/images/icons/close_20dp.svg") 50% 50% no-repeat;
+ opacity: 0.5;
+ content: '';
+ &:hover {
+ opacity: 1;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/document/form-field-document.component.ts b/src/app/_modules/form-fields/types/document/form-field-document.component.ts
new file mode 100644
index 0000000..0d1a607
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/form-field-document.component.ts
@@ -0,0 +1,18 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-document',
+ templateUrl: 'form-field-document.component.html',
+ styleUrls: ['form-field-document.component.scss']
+})
+export class FormFieldDocumentComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/form-fields/types/document/form-field-document.module.ts b/src/app/_modules/form-fields/types/document/form-field-document.module.ts
new file mode 100644
index 0000000..272b98c
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/form-field-document.module.ts
@@ -0,0 +1,24 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+import {FormFieldDocumentComponent} from "@app/_modules/form-fields/types/document/form-field-document.component";
+import {FieldDocumentReadonlyComponent} from "@app/_modules/form-fields/types/document/readonly/field-document-readonly.component";
+import {FieldDocumentSingleComponent} from "@app/_modules/form-fields/types/document/single/field-document-single.component";
+import {FieldDocumentMultipleComponent} from "@app/_modules/form-fields/types/document/multiple/field-document-multiple.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldDocumentComponent,
+ FieldDocumentReadonlyComponent,
+ FieldDocumentSingleComponent,
+ FieldDocumentMultipleComponent
+ ],
+ exports: [
+ FormFieldDocumentComponent
+ ]
+})
+export class FormFieldDocumentModule {}
diff --git a/src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.html b/src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.html
new file mode 100644
index 0000000..ab951b3
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.html
@@ -0,0 +1,14 @@
+
+
+
Перетащите сюда или выберите файлы в формате PDF, XLS, DOC, JPG, PPTX
+
+
Загружается файл {{upload.file?.name}}
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.scss b/src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.ts b/src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.ts
new file mode 100644
index 0000000..cdddebd
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/multiple/field-document-multiple.component.ts
@@ -0,0 +1,98 @@
+import {Component, HostListener, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {AssetsService} from "@app/_services/assets.service";
+import {HttpEventType, HttpResponse} from "@angular/common/http";
+
+@Component({
+ selector: 'field-document-multiple',
+ templateUrl: 'field-document-multiple.component.html',
+ styleUrls: ['../form-field-document.component.scss', 'field-document-multiple.component.scss']
+})
+export class FieldDocumentMultipleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+ public assets = [];
+
+ public upload: any = {file: null, progress: 0};
+ public dragOver = false;
+
+ @HostListener("dragover", ["$event"])
+ @HostListener("dragenter", ["$event"])
+ @HostListener("dragend", ["$event"])
+ @HostListener("dragleave", ["$event"])
+ @HostListener("drop", ["$event"])
+ onDragEvent(event: DragEvent) {
+ if ((event.type === 'drop') && this.dragOver && event.dataTransfer?.files.length) {
+ this.uploadFiles(event.dataTransfer?.files);
+ }
+ this.dragOver = event.type === 'dragover';
+ event.preventDefault()
+ }
+
+
+ constructor(private assetsService: AssetsService) {
+ }
+
+ ngOnInit(): void {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data || [];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(value: any[]) {
+ this.assets = value;
+ this.control?.setValue(value.map(val => {return val.id}).filter(val => {return val}));
+ }
+
+
+ addValue(asset: any) {
+ let value = this.assets;
+ value.push(asset);
+ this.value = value;
+ }
+ removeValue(asset: any) {
+ this.control.markAsTouched();
+ this.value = this.assets.filter((item: any) => {
+ return item.id !== asset.id;
+ });
+ }
+ clear() {
+ this.value = [];
+ }
+
+
+
+ onFileInput(event: any) {
+ this.uploadFiles(event.target.files);
+ event.target.value = null;
+ }
+
+ uploadFiles(files: any) {
+ for (let file of files) {
+ this.uploadFile(file);
+ }
+ }
+ uploadFile(file: File) {
+ this.upload.file = file;
+ this.assetsService.upload(file).subscribe((result) => {
+ if (result.type === HttpEventType.UploadProgress) {
+ this.upload.progress = Math.round(100 * result.loaded / result.total);
+ } else if (result instanceof HttpResponse) {
+ this.upload = {file: null, progress: 0};
+ this.addValue(result.body.data);
+ this.control.markAsTouched();
+ }
+ }, error => {
+ this.upload = {file: null, progress: 0};
+ alert(error.error.message);
+ });
+ }
+}
diff --git a/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.html b/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.html
new file mode 100644
index 0000000..3d363eb
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.html
@@ -0,0 +1,6 @@
+
diff --git a/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.scss b/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.scss
new file mode 100644
index 0000000..55313a6
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.scss
@@ -0,0 +1,3 @@
+.none {
+ padding: 10px 0;
+}
diff --git a/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.ts b/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.ts
new file mode 100644
index 0000000..07b4353
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/readonly/field-document-readonly.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-document-readonly',
+ templateUrl: 'field-document-readonly.component.html',
+ styleUrls: ['../form-field-document.component.scss', 'field-document-readonly.component.scss']
+})
+export class FieldDocumentReadonlyComponent {
+ @Input() field!: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/document/single/field-document-single.component.html b/src/app/_modules/form-fields/types/document/single/field-document-single.component.html
new file mode 100644
index 0000000..70c2c78
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/single/field-document-single.component.html
@@ -0,0 +1,14 @@
+
+
+
Перетащите сюда или выберите файл в формате PDF, XLS, DOC, JPG, PPTX
+
+
Загружается файл {{upload.file?.name}}
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/document/single/field-document-single.component.scss b/src/app/_modules/form-fields/types/document/single/field-document-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/document/single/field-document-single.component.ts b/src/app/_modules/form-fields/types/document/single/field-document-single.component.ts
new file mode 100644
index 0000000..b9b48bd
--- /dev/null
+++ b/src/app/_modules/form-fields/types/document/single/field-document-single.component.ts
@@ -0,0 +1,89 @@
+import {Component, HostListener, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {HttpEventType, HttpResponse} from "@angular/common/http";
+import {AssetsService} from "@app/_services/assets.service";
+import {isNumeric} from "rxjs/internal-compatibility";
+
+@Component({
+ selector: 'field-document-single',
+ templateUrl: 'field-document-single.component.html',
+ styleUrls: ['../form-field-document.component.scss', 'field-document-single.component.scss']
+})
+export class FieldDocumentSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+ public asset: any;
+
+ public upload: any = {file: null, progress: 0};
+ public dragOver = false;
+
+ @HostListener("dragover", ["$event"])
+ @HostListener("dragenter", ["$event"])
+ @HostListener("dragend", ["$event"])
+ @HostListener("dragleave", ["$event"])
+ @HostListener("drop", ["$event"])
+ onDragEvent(event: DragEvent) {
+ if ((event.type === 'drop') && this.dragOver && event.dataTransfer?.files.length) {
+ this.uploadFiles(event.dataTransfer?.files);
+ }
+ this.dragOver = event.type === 'dragover';
+ event.preventDefault()
+ }
+
+
+ constructor(private assetsService: AssetsService) {
+ }
+
+ ngOnInit(): void {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(asset: any) {
+ this.asset = asset;
+ this.control?.setValue(asset?.id);
+ }
+
+
+
+ clear() {
+ this.control.markAsTouched();
+ this.value = null;
+ }
+
+
+
+ onFileInput(event: any) {
+ this.uploadFiles(event.target.files);
+ event.target.value = null;
+ }
+ uploadFiles(files: any) {
+ for (let file of files) {
+ this.uploadFile(file);
+ }
+ }
+ uploadFile(file: File) {
+ this.upload.file = file;
+ this.assetsService.upload(file).subscribe((result) => {
+ if (result.type === HttpEventType.UploadProgress) {
+ this.upload.progress = Math.round(100 * result.loaded / result.total);
+ } else if (result instanceof HttpResponse) {
+ this.upload = {file: null, progress: 0};
+ this.value = result.body.data;
+ this.control.markAsTouched();
+ }
+ }, error => {
+ this.upload = {file: null, progress: 0};
+ alert(error.error.message);
+ });
+ }
+}
diff --git a/src/app/_modules/form-fields/types/float/form-field-float.component.html b/src/app/_modules/form-fields/types/float/form-field-float.component.html
new file mode 100644
index 0000000..66f8625
--- /dev/null
+++ b/src/app/_modules/form-fields/types/float/form-field-float.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/float/form-field-float.component.scss b/src/app/_modules/form-fields/types/float/form-field-float.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/float/form-field-float.component.ts b/src/app/_modules/form-fields/types/float/form-field-float.component.ts
new file mode 100644
index 0000000..28880f3
--- /dev/null
+++ b/src/app/_modules/form-fields/types/float/form-field-float.component.ts
@@ -0,0 +1,20 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-float',
+ templateUrl: 'form-field-float.component.html',
+ styleUrls: ['form-field-float.component.scss']
+})
+export class FormFieldFloatComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/float/form-field-float.module.ts b/src/app/_modules/form-fields/types/float/form-field-float.module.ts
new file mode 100644
index 0000000..5fe6fb9
--- /dev/null
+++ b/src/app/_modules/form-fields/types/float/form-field-float.module.ts
@@ -0,0 +1,22 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FormFieldFloatComponent} from "@app/_modules/form-fields/types/float/form-field-float.component";
+import {ReactiveFormsModule} from "@angular/forms";
+import {FieldFloatReadonlyComponent} from "@app/_modules/form-fields/types/float/readonly/field-float-readonly.component";
+import {FieldFloatSingleComponent} from "@app/_modules/form-fields/types/float/single/field-float-single.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldFloatComponent,
+ FieldFloatReadonlyComponent,
+ FieldFloatSingleComponent
+ ],
+ exports: [
+ FormFieldFloatComponent
+ ]
+})
+export class FormFieldFloatModule {}
diff --git a/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.html b/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.html
new file mode 100644
index 0000000..3465ea7
--- /dev/null
+++ b/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.html
@@ -0,0 +1,2 @@
+{{val}}
+-
diff --git a/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.scss b/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.ts b/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.ts
new file mode 100644
index 0000000..54a2179
--- /dev/null
+++ b/src/app/_modules/form-fields/types/float/readonly/field-float-readonly.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-float-readonly',
+ templateUrl: 'field-float-readonly.component.html',
+ styleUrls: ['field-float-readonly.component.scss']
+})
+export class FieldFloatReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/float/single/field-float-single.component.html b/src/app/_modules/form-fields/types/float/single/field-float-single.component.html
new file mode 100644
index 0000000..fc0f27a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/float/single/field-float-single.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/form-fields/types/float/single/field-float-single.component.scss b/src/app/_modules/form-fields/types/float/single/field-float-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/float/single/field-float-single.component.ts b/src/app/_modules/form-fields/types/float/single/field-float-single.component.ts
new file mode 100644
index 0000000..72aa8cd
--- /dev/null
+++ b/src/app/_modules/form-fields/types/float/single/field-float-single.component.ts
@@ -0,0 +1,36 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-float-single',
+ templateUrl: 'field-float-single.component.html',
+ styleUrls: ['field-float-single.component.scss']
+})
+export class FieldFloatSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value) {
+ this.control?.setValue(value);
+ }
+
+
+
+}
diff --git a/src/app/_modules/form-fields/types/hidden/form-field-hidden.component.html b/src/app/_modules/form-fields/types/hidden/form-field-hidden.component.html
new file mode 100644
index 0000000..8bd5c98
--- /dev/null
+++ b/src/app/_modules/form-fields/types/hidden/form-field-hidden.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/form-fields/types/hidden/form-field-hidden.component.scss b/src/app/_modules/form-fields/types/hidden/form-field-hidden.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/hidden/form-field-hidden.component.ts b/src/app/_modules/form-fields/types/hidden/form-field-hidden.component.ts
new file mode 100644
index 0000000..427cda1
--- /dev/null
+++ b/src/app/_modules/form-fields/types/hidden/form-field-hidden.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-hidden',
+ templateUrl: 'form-field-hidden.component.html',
+ styleUrls: ['form-field-hidden.component.scss']
+})
+export class FormFieldHiddenComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ setTimeout(() => {this.control.setValue(this.field.value?.data)});
+ }
+
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+}
diff --git a/src/app/_modules/form-fields/types/hidden/form-field-hidden.module.ts b/src/app/_modules/form-fields/types/hidden/form-field-hidden.module.ts
new file mode 100644
index 0000000..a9eaa55
--- /dev/null
+++ b/src/app/_modules/form-fields/types/hidden/form-field-hidden.module.ts
@@ -0,0 +1,19 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+
+import {FormFieldHiddenComponent} from "@app/_modules/form-fields/types/hidden/form-field-hidden.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldHiddenComponent
+ ],
+ exports: [
+ FormFieldHiddenComponent
+ ]
+})
+export class FormFieldHiddenModule {}
diff --git a/src/app/_modules/form-fields/types/html/form-field-html.component.html b/src/app/_modules/form-fields/types/html/form-field-html.component.html
new file mode 100644
index 0000000..f917a0c
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/form-field-html.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/html/form-field-html.component.scss b/src/app/_modules/form-fields/types/html/form-field-html.component.scss
new file mode 100644
index 0000000..daf4659
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/form-field-html.component.scss
@@ -0,0 +1,4 @@
+textarea {
+ height: 100px;
+ resize: vertical;
+}
diff --git a/src/app/_modules/form-fields/types/html/form-field-html.component.ts b/src/app/_modules/form-fields/types/html/form-field-html.component.ts
new file mode 100644
index 0000000..4a0c529
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/form-field-html.component.ts
@@ -0,0 +1,19 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-html',
+ templateUrl: 'form-field-html.component.html',
+ styleUrls: ['form-field-html.component.scss']
+})
+export class FormFieldHtmlComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/html/form-field-html.module.ts b/src/app/_modules/form-fields/types/html/form-field-html.module.ts
new file mode 100644
index 0000000..1ee9477
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/form-field-html.module.ts
@@ -0,0 +1,28 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+import {FormFieldHtmlComponent} from "@app/_modules/form-fields/types/html/form-field-html.component";
+import {FieldHtmlReadonlyComponent} from "@app/_modules/form-fields/types/html/readonly/field-html-readonly.component";
+import {FieldHtmlSingleComponent} from "@app/_modules/form-fields/types/html/single/field-html-single.component";
+import {EditorModule, TINYMCE_SCRIPT_SRC} from "@tinymce/tinymce-angular";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule,
+ EditorModule
+ ],
+ declarations: [
+ FormFieldHtmlComponent,
+ FieldHtmlReadonlyComponent,
+ FieldHtmlSingleComponent
+ ],
+ exports: [
+ FormFieldHtmlComponent
+ ],
+ providers: [
+ {provide: TINYMCE_SCRIPT_SRC, useValue: 'tinymce/tinymce.min.js'}
+ ]
+})
+export class FormFieldHtmlModule {
+}
diff --git a/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.html b/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.html
new file mode 100644
index 0000000..94ae3f3
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.html
@@ -0,0 +1,2 @@
+Предпросмотр недоступен
+-
diff --git a/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.scss b/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.ts b/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.ts
new file mode 100644
index 0000000..50c1be1
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/readonly/field-html-readonly.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-html-readonly',
+ templateUrl: 'field-html-readonly.component.html',
+ styleUrls: ['field-html-readonly.component.scss']
+})
+export class FieldHtmlReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/html/single/field-html-single.component.html b/src/app/_modules/form-fields/types/html/single/field-html-single.component.html
new file mode 100644
index 0000000..3bdda2d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/single/field-html-single.component.html
@@ -0,0 +1,7 @@
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/html/single/field-html-single.component.scss b/src/app/_modules/form-fields/types/html/single/field-html-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/html/single/field-html-single.component.ts b/src/app/_modules/form-fields/types/html/single/field-html-single.component.ts
new file mode 100644
index 0000000..8ec29f1
--- /dev/null
+++ b/src/app/_modules/form-fields/types/html/single/field-html-single.component.ts
@@ -0,0 +1,63 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-html-single',
+ templateUrl: 'field-html-single.component.html',
+ styleUrls: ['field-html-single.component.scss', '../form-field-html.component.scss']
+})
+export class FieldHtmlSingleComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+
+ public config: any = {
+ base_url: '/tinymce',
+ suffix: '.min',
+ language: 'ru',
+ language_url: '/assets/lang/ru.js',
+ menubar: false,
+ plugins: 'lists link image paste help wordcount hr',
+ toolbar: 'bold italic removeformat | link hr forecolor | bullist numlist outdent indent',
+ color_map: [
+ '3E3D40', 'grey-1',
+ '696A6D', 'grey-2',
+ '86898E', 'grey-3',
+ 'FCC620', 'yellow-1',
+ 'F4B417', 'yellow-2',
+ 'F49B1B', 'yellow-3',
+ 'BFBFBF', 'grey-4',
+ 'E8E8E8', 'grey-5',
+ 'F5F4F4', 'grey-6',
+ ]
+ };
+
+
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ if (this.value) this.field.value = {data: [this.value]};
+ setTimeout(() => {
+ this.value = this.value || this.initialValue
+ });
+ }
+
+
+
+ get initialValue() {
+ return this.field.value?.data[0] || null;
+ }
+
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+
+ get value() {
+ return this.control?.value;
+ }
+
+ set value(value) {
+ this.control?.setValue(value);
+ }
+}
diff --git a/src/app/_modules/form-fields/types/image/form-field-image.component.html b/src/app/_modules/form-fields/types/image/form-field-image.component.html
new file mode 100644
index 0000000..bfc2815
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/form-field-image.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/image/form-field-image.component.scss b/src/app/_modules/form-fields/types/image/form-field-image.component.scss
new file mode 100644
index 0000000..d3a9c02
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/form-field-image.component.scss
@@ -0,0 +1,91 @@
+.area {
+ position: relative;
+ display: flex;
+ height: 100px;
+ padding: 16px;
+ border: var(--orange-2) dashed 1px;
+ border-radius: 4px;
+ overflow: hidden;
+ &.hover {
+ background-color: #e0e0e0;
+ }
+ p {
+ margin: auto;
+ color: #c0c0c0;
+ text-align: center;
+ span {
+ color: var(--orange-2);
+ cursor: pointer;
+ }
+ }
+ input {
+ display: none;
+ }
+ .indicator {
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ padding: 16px;
+ background-color: #f7f7f7;
+ .label {
+ margin-bottom: 4px;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ }
+ .progress {
+ height: 4px;
+ background-color: #dfdfdf;
+ overflow: hidden;
+ .fill {
+ width: 0;
+ height: 100%;
+ background-color: #3ca128;
+ }
+ }
+ }
+}
+
+.values {
+ display: flex;
+ flex-direction: row;
+ flex-wrap: wrap;
+ column-gap: 24px;
+ row-gap: 12px;
+ margin-top: 8px;
+ overflow: hidden;
+ .item {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ .preview {
+ width: 80px;
+ height: 80px;
+ border: #0033661F solid 2px;
+ overflow: hidden;
+ img {
+ display: block;
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+ }
+ .remove {
+ margin-left: 8px;
+ flex-shrink: 0;
+ width: 20px;
+ height: 20px;
+ background: transparent url("~src/assets/images/icons/close_20dp.svg") 50% 50% no-repeat;
+ opacity: 0.5;
+ content: '';
+ &:hover {
+ opacity: 1;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/image/form-field-image.component.ts b/src/app/_modules/form-fields/types/image/form-field-image.component.ts
new file mode 100644
index 0000000..30a87e4
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/form-field-image.component.ts
@@ -0,0 +1,18 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-image',
+ templateUrl: 'form-field-image.component.html',
+ styleUrls: ['form-field-image.component.scss']
+})
+export class FormFieldImageComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/form-fields/types/image/form-field-image.module.ts b/src/app/_modules/form-fields/types/image/form-field-image.module.ts
new file mode 100644
index 0000000..0fcac10
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/form-field-image.module.ts
@@ -0,0 +1,26 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+import {FormFieldImageComponent} from "@app/_modules/form-fields/types/image/form-field-image.component";
+import {FieldImageReadonlyComponent} from "@app/_modules/form-fields/types/image/readonly/field-image-readonly.component";
+import {FieldImageSingleComponent} from "@app/_modules/form-fields/types/image/single/field-image-single.component";
+import {FieldImageMultipleComponent} from "@app/_modules/form-fields/types/image/multiple/field-image-multiple.component";
+import {SortablejsModule} from "ngx-sortablejs";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule,
+ SortablejsModule
+ ],
+ declarations: [
+ FormFieldImageComponent,
+ FieldImageReadonlyComponent,
+ FieldImageSingleComponent,
+ FieldImageMultipleComponent
+ ],
+ exports: [
+ FormFieldImageComponent
+ ]
+})
+export class FormFieldImageModule {}
diff --git a/src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.html b/src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.html
new file mode 100644
index 0000000..e863abe
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.html
@@ -0,0 +1,14 @@
+
+
+
Перетащите сюда или выберите файл в формате JPEG или PNG общим объемом не более 10 Мбайт.
+
+
Загружается файл {{upload.file?.name}}
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.scss b/src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.ts b/src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.ts
new file mode 100644
index 0000000..bb33006
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/multiple/field-image-multiple.component.ts
@@ -0,0 +1,98 @@
+import {Component, HostListener, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {HttpEventType, HttpResponse} from "@angular/common/http";
+import {AssetsService} from "@app/_services/assets.service";
+
+@Component({
+ selector: 'field-image-multiple',
+ templateUrl: 'field-image-multiple.component.html',
+ styleUrls: ['../form-field-image.component.scss', 'field-image-multiple.component.scss']
+})
+export class FieldImageMultipleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+ public assets = [];
+
+ public upload: any = {file: null, progress: 0};
+ public dragOver = false;
+
+ @HostListener("dragover", ["$event"])
+ @HostListener("dragenter", ["$event"])
+ @HostListener("dragend", ["$event"])
+ @HostListener("dragleave", ["$event"])
+ @HostListener("drop", ["$event"])
+ onDragEvent(event: DragEvent) {
+ if ((event.type === 'drop') && this.dragOver && event.dataTransfer?.files.length) {
+ this.uploadFiles(event.dataTransfer?.files);
+ }
+ this.dragOver = event.type === 'dragover';
+ event.preventDefault()
+ }
+
+
+ constructor(private assetsService: AssetsService) {
+ }
+
+ ngOnInit(): void {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data || [];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(value: any[]) {
+ this.assets = value;
+ this.control?.setValue(value.map(val => {return val.id}).filter(val => {return val}));
+ }
+
+
+ addValue(asset: any) {
+ let value = this.assets;
+ value.push(asset);
+ this.value = value;
+ }
+ removeValue(asset: any) {
+ this.control.markAsTouched();
+ this.value = this.assets.filter((item: any) => {
+ return item.id !== asset.id;
+ });
+ }
+ clear() {
+ this.value = [];
+ }
+
+
+
+ onFileInput(event: any) {
+ this.uploadFiles(event.target.files);
+ event.target.value = null;
+ }
+
+ uploadFiles(files: any) {
+ for (let file of files) {
+ this.uploadFile(file);
+ }
+ }
+ uploadFile(file: File) {
+ this.upload.file = file;
+ this.assetsService.upload(file).subscribe((result) => {
+ if (result.type === HttpEventType.UploadProgress) {
+ this.upload.progress = Math.round(100 * result.loaded / result.total);
+ } else if (result instanceof HttpResponse) {
+ this.upload = {file: null, progress: 0};
+ this.addValue(result.body.data);
+ this.control.markAsTouched();
+ }
+ }, error => {
+ this.upload = {file: null, progress: 0};
+ alert(error.error.message);
+ });
+ }
+}
diff --git a/src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.html b/src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.html
new file mode 100644
index 0000000..06263ce
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.scss b/src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.ts b/src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.ts
new file mode 100644
index 0000000..031d018
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/readonly/field-image-readonly.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-image-readonly',
+ templateUrl: 'field-image-readonly.component.html',
+ styleUrls: ['../form-field-image.component.scss', 'field-image-readonly.component.scss']
+})
+export class FieldImageReadonlyComponent {
+ @Input() field!: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/image/single/field-image-single.component.html b/src/app/_modules/form-fields/types/image/single/field-image-single.component.html
new file mode 100644
index 0000000..fc88ad0
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/single/field-image-single.component.html
@@ -0,0 +1,14 @@
+
+
+
Перетащите сюда или выберите файл в формате JPEG или PNG общим объемом не более 10 Мбайт.
+
+
Загружается файл {{upload.file?.name}}
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/image/single/field-image-single.component.scss b/src/app/_modules/form-fields/types/image/single/field-image-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/image/single/field-image-single.component.ts b/src/app/_modules/form-fields/types/image/single/field-image-single.component.ts
new file mode 100644
index 0000000..c32a037
--- /dev/null
+++ b/src/app/_modules/form-fields/types/image/single/field-image-single.component.ts
@@ -0,0 +1,93 @@
+import {Component, HostListener, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {HttpEventType, HttpResponse} from "@angular/common/http";
+import {AssetsService} from "@app/_services/assets.service";
+
+@Component({
+ selector: 'field-image-single',
+ templateUrl: 'field-image-single.component.html',
+ styleUrls: ['../form-field-image.component.scss', 'field-image-single.component.scss']
+})
+export class FieldImageSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+ public asset: any;
+
+ public upload: any = {file: null, progress: 0};
+ public dragOver = false;
+
+ @HostListener("dragover", ["$event"])
+ @HostListener("dragenter", ["$event"])
+ @HostListener("dragend", ["$event"])
+ @HostListener("dragleave", ["$event"])
+ @HostListener("drop", ["$event"])
+ onDragEvent(event: DragEvent) {
+ if ((event.type === 'drop') && this.dragOver && event.dataTransfer?.files.length) {
+ this.uploadFiles(event.dataTransfer?.files);
+ }
+ this.dragOver = event.type === 'dragover';
+ event.preventDefault()
+ }
+
+
+ constructor(private assetsService: AssetsService) {
+ }
+
+ ngOnInit(): void {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(asset: any) {
+ this.asset = asset;
+ this.control?.setValue(asset?.id);
+ }
+
+
+ setValue(value: any) {
+ this.control.setValue(value);
+ this.control.markAsTouched();
+ }
+
+ clear() {
+ this.control.markAsTouched();
+ this.value = null;
+ }
+
+
+
+ onFileInput(event: any) {
+ this.uploadFiles(event.target.files);
+ event.target.value = null;
+ }
+
+ uploadFiles(files: any) {
+ for (let file of files) {
+ this.uploadFile(file);
+ }
+ }
+ uploadFile(file: File) {
+ this.upload.file = file;
+ this.assetsService.upload(file).subscribe((result) => {
+ if (result.type === HttpEventType.UploadProgress) {
+ this.upload.progress = Math.round(100 * result.loaded / result.total);
+ } else if (result instanceof HttpResponse) {
+ this.upload = {file: null, progress: 0};
+ this.value = result.body.data;
+ this.control.markAsTouched();
+ }
+ }, error => {
+ this.upload = {file: null, progress: 0};
+ alert(error.error.message);
+ });
+ }
+}
diff --git a/src/app/_modules/form-fields/types/index.ts b/src/app/_modules/form-fields/types/index.ts
new file mode 100644
index 0000000..dc29ea0
--- /dev/null
+++ b/src/app/_modules/form-fields/types/index.ts
@@ -0,0 +1,14 @@
+export * from './boolean/form-field-boolean.module';
+export * from './date/form-field-date.module';
+export * from './datetime/form-field-datetime.module';
+export * from './document/form-field-document.module';
+export * from './image/form-field-image.module';
+export * from './float/form-field-float.module';
+export * from './integer/form-field-integer.module';
+export * from './relation/form-field-relation.module';
+export * from './string/form-field-string.module';
+export * from './text/form-field-text.module';
+export * from './time/form-field-time.module';
+export * from './topics/form-field-topics.module';
+export * from './hidden/form-field-hidden.module';
+export * from './html/form-field-html.module';
diff --git a/src/app/_modules/form-fields/types/integer/form-field-integer.component.html b/src/app/_modules/form-fields/types/integer/form-field-integer.component.html
new file mode 100644
index 0000000..3d840ee
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/form-field-integer.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/integer/form-field-integer.component.scss b/src/app/_modules/form-fields/types/integer/form-field-integer.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/integer/form-field-integer.component.ts b/src/app/_modules/form-fields/types/integer/form-field-integer.component.ts
new file mode 100644
index 0000000..d6db729
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/form-field-integer.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-integer',
+ templateUrl: 'form-field-integer.component.html',
+ styleUrls: ['form-field-integer.component.scss']
+})
+export class FormFieldIntegerComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+
+
+}
diff --git a/src/app/_modules/form-fields/types/integer/form-field-integer.module.ts b/src/app/_modules/form-fields/types/integer/form-field-integer.module.ts
new file mode 100644
index 0000000..6109cd8
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/form-field-integer.module.ts
@@ -0,0 +1,24 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FormFieldIntegerComponent} from "@app/_modules/form-fields/types/integer/form-field-integer.component";
+import {ReactiveFormsModule} from "@angular/forms";
+import {FieldIntegerReadonlyComponent} from "@app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component";
+import {FieldIntegerSingleComponent} from "@app/_modules/form-fields/types/integer/single/field-integer-single.component";
+import {FieldIntegerMultipleComponent} from "@app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldIntegerComponent,
+ FieldIntegerReadonlyComponent,
+ FieldIntegerSingleComponent,
+ FieldIntegerMultipleComponent
+ ],
+ exports: [
+ FormFieldIntegerComponent
+ ]
+})
+export class FormFieldIntegerModule {}
diff --git a/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.html b/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.html
new file mode 100644
index 0000000..468b119
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.html
@@ -0,0 +1,9 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.scss b/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.scss
new file mode 100644
index 0000000..5b92e5d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.scss
@@ -0,0 +1,41 @@
+.values {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ flex-wrap: wrap;
+
+ .item {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 4px 8px 4px 12px;
+ margin: 8px 8px 0 0;
+ background-color: #E3EFF9;
+ border-radius: 16px;
+
+ .name {
+ padding-right: 8px;
+ font-size: 0.875rem;
+ line-height: 20px;
+
+ p {
+ margin: 0;
+ }
+
+ .faded {
+ color: #7f7f7f;
+
+ }
+ }
+
+ .remove {
+ width: 16px;
+ height: 16px;
+ padding: 0;
+ margin: auto;
+ border: none;
+ //background: transparent url('~src/assets/images/icons/close_16dp.svg') 50% 50% no-repeat;
+ cursor: pointer;
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.ts b/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.ts
new file mode 100644
index 0000000..eeb031f
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/multiple/field-integer-multiple.component.ts
@@ -0,0 +1,56 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-integer-multiple',
+ templateUrl: 'field-integer-multiple.component.html',
+ styleUrls: ['field-integer-multiple.component.scss']
+})
+export class FieldIntegerMultipleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data || [];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(value) {
+ this.control?.setValue(value);
+ }
+
+
+ onKeyDown(event: any) {
+ if (event.key === 'Enter') {
+ this.addValue(event.target.value);
+ event.target.value = '';
+ }
+ }
+
+ addValue(val: number) {
+ let value = this.value;
+ if (value.indexOf(val) === -1) value.push(val);
+ this.value = value;
+ }
+
+ removeValue(val: number) {
+ this.value = this.value.filter(item => {
+ return item !== val;
+ });
+ }
+
+
+
+}
diff --git a/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.html b/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.html
new file mode 100644
index 0000000..3465ea7
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.html
@@ -0,0 +1,2 @@
+{{val}}
+-
diff --git a/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.scss b/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.ts b/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.ts
new file mode 100644
index 0000000..6fb7ae9
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/readonly/field-integer-readonly.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-integer-readonly',
+ templateUrl: 'field-integer-readonly.component.html',
+ styleUrls: ['field-integer-readonly.component.scss']
+})
+export class FieldIntegerReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/integer/single/field-integer-single.component.html b/src/app/_modules/form-fields/types/integer/single/field-integer-single.component.html
new file mode 100644
index 0000000..4926214
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/single/field-integer-single.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/form-fields/types/integer/single/field-integer-single.component.scss b/src/app/_modules/form-fields/types/integer/single/field-integer-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/integer/single/field-integer-single.component.ts b/src/app/_modules/form-fields/types/integer/single/field-integer-single.component.ts
new file mode 100644
index 0000000..e76d1c2
--- /dev/null
+++ b/src/app/_modules/form-fields/types/integer/single/field-integer-single.component.ts
@@ -0,0 +1,36 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-integer-single',
+ templateUrl: 'field-integer-single.component.html',
+ styleUrls: ['field-integer-single.component.scss']
+})
+export class FieldIntegerSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value) {
+ this.control?.setValue(value);
+ }
+
+
+
+}
diff --git a/src/app/_modules/form-fields/types/relation/form-field-relation.component.html b/src/app/_modules/form-fields/types/relation/form-field-relation.component.html
new file mode 100644
index 0000000..bc1537e
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/form-field-relation.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/relation/form-field-relation.component.scss b/src/app/_modules/form-fields/types/relation/form-field-relation.component.scss
new file mode 100644
index 0000000..26d50e9
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/form-field-relation.component.scss
@@ -0,0 +1,168 @@
+.combobox {
+ position: relative;
+ border: solid 1px var(--grey-3);
+ border-radius: var(--radius-1);
+
+ .toggle {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ width: 100%;
+ height: 40px;
+ padding: 0 12px 0 16px;
+ font-size: 1rem;
+ box-sizing: border-box;
+ cursor: pointer;
+ .caption {
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ p {
+ padding: 0;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ &.faded {
+ font-size: 0.875rem;
+ color: #7f7f7f;
+ }
+ }
+ }
+ .filter {
+ display: none;
+ width: 100%;
+ input {
+ width: 100%;
+ padding: 8px 0;
+ border: 0;
+ }
+ }
+
+ &:after {
+ display: block;
+ width: 24px;
+ height: 20px;
+ margin-left: auto;
+ background: url('~src/assets/images/icons/arrow_drop_down_24dp.svg') 50% 50% no-repeat;
+ content: "";
+ transition: transform 0.2s;
+ }
+ }
+
+ .dropdown {
+ display: none;
+ position: absolute;
+ top: calc(100% + 1px);
+ left: -1px;
+ width: calc(100% + 2px);
+ margin-bottom: 50px;
+ background-color: #ffffff;
+ border: #dfdfdf solid 1px;
+ border-radius: 4px;
+ box-shadow: rgba(0, 0, 0, 0.16) 0 2px 3px 0;
+ overflow: hidden;
+ z-index: 100;
+
+ ul {
+ padding: 0;
+ margin: 0;
+ max-height: 280px;
+ overflow: auto;
+ -webkit-overflow-scrolling: touch;
+ .empty {
+ padding: 10px 16px;
+ background-color: #f7f7f7;
+ color: #7f7f7f;
+ .add {
+ display: block;
+ color: #2c86cd;
+ cursor: pointer;
+ }
+ }
+
+ li {
+ .title {
+ padding: 10px 16px;
+ border-bottom: #dfdfdf solid 1px;
+ cursor: pointer;
+ p {
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ margin: 0;
+ padding: 0;
+ &.faded {
+ font-size: 0.875rem;
+ color: #7f7f7f;
+ }
+ }
+ &:hover {
+ background-color: #f7f7f7;
+ }
+ &.selected {
+ background-color: #e3eff9;
+ }
+ }
+ }
+ }
+ }
+
+ &.active {
+ .toggle {
+ .caption {
+ display: none;
+ }
+ .filter {
+ display: block;
+ }
+ &::after {
+ transform: rotateZ(180deg);
+ }
+ }
+ .dropdown {
+ display: block;
+ }
+ }
+}
+
+
+.values {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ flex-wrap: wrap;
+
+ .item {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 4px 8px 4px 12px;
+ margin: 8px 8px 0 0;
+ background-color: #E3EFF9;
+ border-radius: 16px;
+
+ .name {
+ padding-right: 8px;
+ font-size: 0.875rem;
+ line-height: 20px;
+
+ p {
+ margin: 0;
+ }
+
+ .faded {
+ color: #7f7f7f;
+
+ }
+ }
+
+ .remove {
+ width: 16px;
+ height: 16px;
+ padding: 0;
+ margin: auto;
+ border: none;
+ //background: transparent url('~src/assets/images/icons/close_16dp.svg') 50% 50% no-repeat;
+ cursor: pointer;
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/relation/form-field-relation.component.ts b/src/app/_modules/form-fields/types/relation/form-field-relation.component.ts
new file mode 100644
index 0000000..b3c9585
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/form-field-relation.component.ts
@@ -0,0 +1,18 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-relation',
+ templateUrl: 'form-field-relation.component.html',
+ styleUrls: ['form-field-relation.component.scss']
+})
+export class FormFieldRelationComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/form-fields/types/relation/form-field-relation.module.ts b/src/app/_modules/form-fields/types/relation/form-field-relation.module.ts
new file mode 100644
index 0000000..06c586d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/form-field-relation.module.ts
@@ -0,0 +1,33 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+
+import {FormFieldRelationComponent} from "@app/_modules/form-fields/types/relation/form-field-relation.component";
+import {FieldRelationReadonlyComponent} from "@app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component";
+import {FieldRelationSingleComponent} from "@app/_modules/form-fields/types/relation/single/field-relation-single.component";
+import {FieldRelationMultipleComponent} from "@app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component";
+import {ComboboxMultipleComponent} from "@app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component";
+import {RelationCheckboxComponent} from "@app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component";
+import {ComboboxSingleComponent} from "@app/_modules/form-fields/types/relation/single/combobox/combobox-single.component";
+import {RelationRadioComponent} from "@app/_modules/form-fields/types/relation/single/radio/relation-radio.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldRelationComponent,
+ FieldRelationReadonlyComponent,
+ FieldRelationSingleComponent,
+ FieldRelationMultipleComponent,
+ ComboboxSingleComponent,
+ RelationRadioComponent,
+ ComboboxMultipleComponent,
+ RelationCheckboxComponent,
+ ],
+ exports: [
+ FormFieldRelationComponent
+ ]
+})
+export class FormFieldRelationModule {}
diff --git a/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.html b/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.html
new file mode 100644
index 0000000..67d6b48
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.html
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.scss b/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.scss
new file mode 100644
index 0000000..7a2bc81
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.scss
@@ -0,0 +1,147 @@
+$white: #FFFFFF;
+$black: #111111;
+
+$blue: #2C86CD;
+$blue-hover: #2776B4;
+$blue-pressed: #21659A;
+$grey: #7F7F7F;
+$grey-light: #BFBFBF;
+
+.block {
+ .title {
+ font-weight: bold;
+ }
+ .options {
+ padding-top: 10px;
+
+ .option {
+ margin-bottom: 10px;
+ display: flex;
+ column-gap: 12px;
+ align-items: center;
+
+ input {
+ margin: 0;
+ }
+
+ input[type="checkbox"]:checked,
+ input[type="checkbox"]:not(:checked){
+ position: absolute;
+ left: -9999px;
+
+ }
+
+ input[type="checkbox"]:checked + label,
+ input[type="checkbox"]:not(:checked) + label {
+ display: inline-block;
+ position: relative;
+ padding-left: 30px;
+ line-height: 20px;
+ cursor: pointer;
+
+ }
+
+ input[type="checkbox"]:checked + label:before {
+ content: "";
+ position: absolute;
+ left: 0;
+ top: 0;
+ width: 18px;
+ height: 18px;
+ border: 1px solid $blue;
+ background-color: $blue;
+
+ }
+
+ input[type="checkbox"]:checked + label:hover:before {
+ border-color: $blue-hover;
+ background-color: $blue-hover;
+
+ }
+
+ input[type="checkbox"]:checked + label:active:before {
+ border-color: $blue-pressed;
+ background-color: $blue-pressed;
+
+ }
+
+ input[type="checkbox"]:disabled:checked + label:before,
+ input[type="checkbox"]:disabled:checked + label:hover:before {
+ border-color: $grey-light;
+ background-color: $grey-light;
+
+ }
+
+ input[type="checkbox"]:not(:checked) + label:before {
+ content: "";
+ position: absolute;
+ left: 0;
+ top: 0;
+ width: 18px;
+ height: 18px;
+ border: 1px solid $grey;
+ background-color: $white;
+
+ }
+
+ input[type="checkbox"]:disabled:not(:checked) + label:before,
+ input[type="checkbox"]:disabled:not(:checked) + label:hover:before {
+ border-color: $grey-light;
+
+ }
+
+ input[type="checkbox"]:not(:checked) + label:hover:before {
+ border-color: $blue-hover;
+
+ }
+
+ input[type="checkbox"]:not(:checked) + label:active:before {
+ border-color: $blue-pressed;
+
+ }
+
+ input[type="checkbox"]:checked + label:before,
+ input[type="checkbox"]:not(:checked) + label:before {
+ border-radius: 2px;
+
+ }
+
+ input[type="checkbox"]:checked + label:after,
+ input[type="checkbox"]:not(:checked) + label:after {
+ content: "";
+ position: absolute;
+ -webkit-transition: all 0.2s ease;
+ -moz-transition: all 0.2s ease;
+ -o-transition: all 0.2s ease;
+ transition: all 0.2s ease;
+
+ }
+
+ input[type="checkbox"]:checked + label:after,
+ input[type="checkbox"]:not(:checked) + label:after {
+ left: 5px;
+ top: 5px;
+ width: 9px;
+ height: 5px;
+ border-left: 2.5px solid $white;
+ border-bottom: 2.5px solid $white;
+ -webkit-transform: rotate(-45deg);
+ -moz-transform: rotate(-45deg);
+ -ms-transform: rotate(-45deg);
+ -o-transform: rotate(-45deg);
+ transform: rotate(-45deg);
+
+ }
+
+ input[type="checkbox"]:not(:checked) + label:after {
+ opacity: 0;
+
+ }
+
+ input[type="checkbox"]:checked + label:after {
+ opacity: 1;
+
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.ts b/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.ts
new file mode 100644
index 0000000..11f8e1f
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/multiple/checkbox/relation-checkbox.component.ts
@@ -0,0 +1,54 @@
+import {Component, OnInit, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'relation-checkbox',
+ templateUrl: 'relation-checkbox.component.html',
+ styleUrls: ['relation-checkbox.component.scss']
+})
+export class RelationCheckboxComponent implements OnInit {
+ @Input() formGroup!: FormGroup;
+ @Input() field!: any;
+
+ ngOnInit(): void {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return (this.value?.length) ? this.value : (this.field.value?.data || []);
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get options() {
+ return this.field.options?.data || [];
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(value: any[]) {
+ this.control.setValue(value);
+ }
+
+
+ onChange(event: any, option: any) {
+ this.control.markAsTouched();
+ event.target.checked ? this.addValue(option) : this.removeValue(option);
+ }
+ addValue(option: any) {
+ let val = this.value;
+ val.push(option);
+ this.value = val;
+ }
+ removeValue(option: any) {
+ this.value = this.value.filter(val => {return option.id !== val.id});
+ }
+
+ isSelected(option: any) {
+ for (let i = 0; i < this.value?.length; i++) {
+ if (this.value[i]?.id === option.id) return true;
+ }
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.html b/src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.html
new file mode 100644
index 0000000..a0c3ae5
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.html
@@ -0,0 +1,29 @@
+
+
+
+
+ -
+
+
{{option.caption || option.title || option.name}}
+
{{option.subtitle}}
+
+
+ - Результатов не найдено, укажите менее строгий запрос
+
+
+
+
+
+
+
{{val.caption || val.title || val.name}}
+
{{val.subtitle}}
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.scss b/src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.ts b/src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.ts
new file mode 100644
index 0000000..526000a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/multiple/combobox/combobox-multiple.component.ts
@@ -0,0 +1,86 @@
+import {Component, OnInit, Input, HostListener, ElementRef, ViewChild} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {UtilityService} from "@app/_services/utility.service";
+
+@Component({
+ selector: 'combobox-multiple',
+ templateUrl: 'combobox-multiple.component.html',
+ styleUrls: ['combobox-multiple.component.scss', '../../form-field-relation.component.scss']
+})
+export class ComboboxMultipleComponent implements OnInit {
+ @Input() formGroup!: FormGroup;
+ @Input() field!: any;
+ @ViewChild("searchInput") searchInput?: ElementRef;
+
+ public active = false;
+ public options = [];
+ public search = '';
+
+ constructor(private eRef: ElementRef, private utilityService: UtilityService) {
+ }
+
+ @HostListener('document:click', ['$event.target'])
+ onClick(target: any) {
+ if (!this.eRef.nativeElement.contains(target)) this.active = false;
+ }
+
+ ngOnInit() {
+ }
+
+ ngOnChanges(): void {
+ setTimeout(() => {this.value = this.initialValue});
+ this.updateOptions();
+ }
+
+ get initialValue() {
+ return (this.value?.length) ? this.value : (this.field.value?.data || []);
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(value: any[]) {
+ this.control.setValue(value);
+ }
+
+ get caption() {
+ return this.value?.length ? `Выбрано ${this.value?.length} значений` : 'Не выбрано';
+ }
+
+
+ onInput(event) {
+ this.search = event.target.value;
+ this.updateOptions();
+ }
+
+ updateOptions() {
+ this.options = this.utilityService.filterOptions(this.search, this.field.options?.data || []);
+ }
+
+ toggleValue(option: any) {
+ this.isSelected(option) ? this.removeValue(option) : this.addValue(option);
+ this.active = false;
+ }
+ addValue(option: any) {
+ this.control.markAsTouched();
+ let val = this.value;
+ val.push(option);
+ this.value = val;
+ }
+ removeValue(option: any) {
+ this.control.markAsTouched();
+ this.value = this.value.filter(val => {return option.id !== val.id});
+ }
+ isSelected(option: any) {
+ for (let i = 0; i < this.value?.length; i++) {
+ if (this.value[i]?.id === option.id) return true;
+ }
+ }
+
+ toggleActivity() {
+ this.active = !this.active;
+ if (this.active) setTimeout(() => {this.searchInput?.nativeElement.focus()}, 10);
+ }
+}
diff --git a/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.html b/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.html
new file mode 100644
index 0000000..e48ddfd
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.scss b/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.scss
new file mode 100644
index 0000000..a91b87f
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.scss
@@ -0,0 +1,3 @@
+.empty {
+ text-align: left !important;
+}
diff --git a/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.ts b/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.ts
new file mode 100644
index 0000000..5c7e8da
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/multiple/field-relation-multiple.component.ts
@@ -0,0 +1,19 @@
+import {Component, OnInit, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-relation-multiple',
+ templateUrl: 'field-relation-multiple.component.html',
+ styleUrls: ['field-relation-multiple.component.scss']
+})
+export class FieldRelationMultipleComponent implements OnInit {
+ @Input() formGroup!: FormGroup;
+ @Input() field!: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.html b/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.html
new file mode 100644
index 0000000..6ac6d38
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.html
@@ -0,0 +1,5 @@
+
+
{{val.caption || val.title || val.name}}
+
{{val.subtitle}}
+
+-
diff --git a/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.scss b/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.scss
new file mode 100644
index 0000000..942511b
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.scss
@@ -0,0 +1,9 @@
+.value {
+ padding: 10px 0 0;
+ p {
+ margin: 0;
+ &.sub {
+ color: #7f7f7f;
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.ts b/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.ts
new file mode 100644
index 0000000..fe0b61d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/readonly/field-relation-readonly.component.ts
@@ -0,0 +1,20 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-relation-readonly',
+ templateUrl: 'field-relation-readonly.component.html',
+ styleUrls: ['field-relation-readonly.component.scss']
+})
+export class FieldRelationReadonlyComponent {
+ @Input() field!: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+}
diff --git a/src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.html b/src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.html
new file mode 100644
index 0000000..9e8ab5a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.html
@@ -0,0 +1,20 @@
+
+
+
+
+ -
+
+
{{option.caption || option.title || option.name}}
+
{{option.subtitle}}
+
+
+ - Результатов не найдено, укажите менее строгий запрос
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.scss b/src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.ts b/src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.ts
new file mode 100644
index 0000000..62330cd
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/single/combobox/combobox-single.component.ts
@@ -0,0 +1,80 @@
+import {Component, OnInit, Input, HostListener, ElementRef, ViewChild} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {UtilityService} from "@app/_services/utility.service";
+
+@Component({
+ selector: 'combobox-single',
+ templateUrl: 'combobox-single.component.html',
+ styleUrls: ['combobox-single.component.scss', '../../form-field-relation.component.scss']
+})
+export class ComboboxSingleComponent implements OnInit {
+ @Input() formGroup!: FormGroup;
+ @Input() field!: any;
+ @ViewChild("searchInput") searchInput?: ElementRef;
+
+ public active = false;
+ public options = [];
+ public search = '';
+
+ constructor(
+ private eRef: ElementRef,
+ private utilityService: UtilityService
+ ) {
+ }
+
+ @HostListener('document:click', ['$event.target'])
+ onClick(target: any) {
+ if (!this.eRef.nativeElement.contains(target)) this.active = false;
+ }
+
+ ngOnInit(): void {
+ setTimeout(() => {this.value = this.initialValue});
+ this.updateOptions();
+ //if (!this.value && this.field.required && (this.options.length === 1)) this.value = this.options[0];
+ }
+
+
+ get initialValue() {
+ return this.value || this.field.value?.data[0] || null;
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value: any) {
+ this.control.setValue(value);
+ }
+
+ get caption() {
+ return this.value?.caption || this.value?.title || this.value?.name || 'Не выбрано';
+ }
+
+
+ toggleValue(option: any) {
+ this.control.markAsTouched();
+ this.isSelected(option) ? (this.value = null) : (this.value = option);
+ this.active = false;
+ }
+ isSelected(option: any) {
+ return option.id === this.value?.id;
+ }
+
+
+ onInput(event) {
+ this.search = event.target.value;
+ this.updateOptions();
+ }
+ updateOptions() {
+ this.options = this.utilityService.filterOptions(this.search, this.field.options?.data || []);
+ }
+
+
+
+ toggleActivity() {
+ this.active = !this.active;
+ if (this.active) setTimeout(() => {this.searchInput?.nativeElement.focus()}, 10);
+ }
+}
+
diff --git a/src/app/_modules/form-fields/types/relation/single/field-relation-single.component.html b/src/app/_modules/form-fields/types/relation/single/field-relation-single.component.html
new file mode 100644
index 0000000..96adac4
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/single/field-relation-single.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/relation/single/field-relation-single.component.scss b/src/app/_modules/form-fields/types/relation/single/field-relation-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/relation/single/field-relation-single.component.ts b/src/app/_modules/form-fields/types/relation/single/field-relation-single.component.ts
new file mode 100644
index 0000000..30e02e6
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/single/field-relation-single.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-relation-single',
+ templateUrl: 'field-relation-single.component.html',
+ styleUrls: ['field-relation-single.component.scss']
+})
+export class FieldRelationSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.html b/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.html
new file mode 100644
index 0000000..a3e1f4c
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.html
@@ -0,0 +1,6 @@
+
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.scss b/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.scss
new file mode 100644
index 0000000..c796890
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.scss
@@ -0,0 +1,155 @@
+$white: #FFFFFF;
+$black: #111111;
+
+$blue: #0079C2;
+$blue-hover: #005694;
+$blue-pressed: #003366;
+$blue-disabled: #9ECCE8;
+
+$grey: #939393;
+$grey-hover: #6C6C6C;
+$grey-pressed: #707070;
+$grey-disabled: #E0E0E0;
+
+.options {
+ padding-top: 10px;
+ .option {
+ margin-bottom: 8px;
+
+ display: flex;
+ column-gap: 10px;
+
+ input {
+ width: 18px;
+ height: 18px;
+
+ };
+
+ input[type="radio"]:checked,
+ input[type="radio"]:not(:checked) {
+ position: absolute;
+ left: -9999px;
+
+ }
+
+ input[type="radio"]:checked + label,
+ input[type="radio"]:not(:checked) + label {
+ display: inline-block;
+ position: relative;
+ padding-left: 30px;
+ line-height: 20px;
+ cursor: pointer;
+
+ }
+
+ input[type="radio"]:checked + label:before {
+ content: "";
+ position: absolute;
+ left: 0;
+ top: 0;
+ width: 18px;
+ height: 18px;
+ border: 4px solid $blue;
+ background-color: $white;
+
+ }
+
+ input[type="radio"]:checked + label:hover:before {
+ border-color: $blue-hover;
+
+ }
+
+ input[type="radio"]:checked + label:active:before {
+ border-color: $blue-pressed;
+
+ }
+
+ input[type="radio"]:not(:checked) + label:before {
+ content: "";
+ position: absolute;
+ left: 0;
+ top: 0;
+ width: 18px;
+ height: 18px;
+ border: 1px solid $grey;
+ background-color: $white;
+
+ }
+
+ input[type="radio"]:disabled:checked + label:before,
+ input[type="radio"]:disabled:checked + label:hover:before,
+ input[type="radio"]:disabled:not(:checked) + label:before,
+ input[type="radio"]:disabled:not(:checked) + label:hover:before {
+ border-color: $grey-disabled;
+
+ }
+
+ input[type="radio"]:not(:checked) + label:hover:before {
+ border-color: $grey-hover;
+
+ }
+
+ input[type="radio"]:not(:checked) + label:active:before {
+ border-color: $grey-pressed;
+
+ }
+
+ input[type="radio"]:checked + label:before,
+ input[type="radio"]:not(:checked) + label:before {
+ border-radius: 100%;
+
+ }
+
+ input[type="radio"]:checked + label:after,
+ input[type="radio"]:not(:checked) + label:after {
+ content: "";
+ position: absolute;
+ -webkit-transition: all 0.2s ease;
+ -moz-transition: all 0.2s ease;
+ -o-transition: all 0.2s ease;
+ transition: all 0.2s ease;
+
+ }
+
+ input[type="radio"]:checked + label:after,
+ input[type="radio"]:not(:checked) + label:after {
+ left: 4px;
+ top: 4px;
+ width: 10px;
+ height: 10px;
+ border-radius: 100%;
+ background-color: $white;
+
+ }
+
+ input[type="radio"]:checked + label:hover:after {
+ background-color: $white;
+
+ }
+
+ input[type="radio"]:checked + label:active:after {
+ background-color: $grey-disabled;
+
+ }
+
+ input[type="radio"]:disabled:checked + label:after,
+ input[type="radio"]:disabled:checked + label:hover:after {
+ background-color: $blue-disabled;
+
+ }
+
+ input[type="radio"]:not(:checked) + label:after {
+ opacity: 0;
+
+ }
+
+ input[type="radio"]:checked + label:after {
+ opacity: 1;
+
+ }
+
+ label {
+ color: $black;
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.ts b/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.ts
new file mode 100644
index 0000000..bd12fe8
--- /dev/null
+++ b/src/app/_modules/form-fields/types/relation/single/radio/relation-radio.component.ts
@@ -0,0 +1,39 @@
+import {Component, OnInit, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'relation-radio',
+ templateUrl: 'relation-radio.component.html',
+ styleUrls: ['relation-radio.component.scss']
+})
+export class RelationRadioComponent implements OnInit {
+ @Input() formGroup!: FormGroup;
+ @Input() field!: any;
+
+ ngOnInit(): void {
+ setTimeout(() => {this.value = this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.value || this.optionByValue(this.field.value?.data[0]) || null;
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get options() {
+ return this.field.options?.data || [];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value: any) {
+ this.control?.setValue(value);
+ }
+
+
+ optionByValue(value: any) {
+ return this.field.options?.data.filter(option => {return option.id === value?.id})[0];
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/string/form-field-string.component.html b/src/app/_modules/form-fields/types/string/form-field-string.component.html
new file mode 100644
index 0000000..a637458
--- /dev/null
+++ b/src/app/_modules/form-fields/types/string/form-field-string.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/string/form-field-string.component.scss b/src/app/_modules/form-fields/types/string/form-field-string.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/string/form-field-string.component.ts b/src/app/_modules/form-fields/types/string/form-field-string.component.ts
new file mode 100644
index 0000000..dfa0f5c
--- /dev/null
+++ b/src/app/_modules/form-fields/types/string/form-field-string.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-string',
+ templateUrl: 'form-field-string.component.html',
+ styleUrls: ['form-field-string.component.scss']
+})
+export class FormFieldStringComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/string/form-field-string.module.ts b/src/app/_modules/form-fields/types/string/form-field-string.module.ts
new file mode 100644
index 0000000..49bd5ac
--- /dev/null
+++ b/src/app/_modules/form-fields/types/string/form-field-string.module.ts
@@ -0,0 +1,22 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FormFieldStringComponent} from "@app/_modules/form-fields/types/string/form-field-string.component";
+import {ReactiveFormsModule} from "@angular/forms";
+import {FieldStringSingleComponent} from "@app/_modules/form-fields/types/string/single/field-string-single.component";
+import {FieldStringReadonlyComponent} from "@app/_modules/form-fields/types/string/readonly/field-string-readonly.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldStringComponent,
+ FieldStringSingleComponent,
+ FieldStringReadonlyComponent
+ ],
+ exports: [
+ FormFieldStringComponent
+ ]
+})
+export class FormFieldStringModule {}
diff --git a/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.html b/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.html
new file mode 100644
index 0000000..3465ea7
--- /dev/null
+++ b/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.html
@@ -0,0 +1,2 @@
+{{val}}
+-
diff --git a/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.scss b/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.ts b/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.ts
new file mode 100644
index 0000000..51ff0f4
--- /dev/null
+++ b/src/app/_modules/form-fields/types/string/readonly/field-string-readonly.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-string-readonly',
+ templateUrl: 'field-string-readonly.component.html',
+ styleUrls: ['field-string-readonly.component.scss']
+})
+export class FieldStringReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/string/single/field-string-single.component.html b/src/app/_modules/form-fields/types/string/single/field-string-single.component.html
new file mode 100644
index 0000000..dbe839d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/string/single/field-string-single.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/form-fields/types/string/single/field-string-single.component.scss b/src/app/_modules/form-fields/types/string/single/field-string-single.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/string/single/field-string-single.component.ts b/src/app/_modules/form-fields/types/string/single/field-string-single.component.ts
new file mode 100644
index 0000000..e118831
--- /dev/null
+++ b/src/app/_modules/form-fields/types/string/single/field-string-single.component.ts
@@ -0,0 +1,37 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-string-single',
+ templateUrl: 'field-string-single.component.html',
+ styleUrls: ['field-string-single.component.scss']
+})
+export class FieldStringSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ setTimeout(() => {this.value = this.initialValue || this.value || null});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value) {
+ this.control?.setValue(value);
+ }
+ get maxLength() {
+ return this?.field?.maxLength || 255;
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/text/form-field-text.component.html b/src/app/_modules/form-fields/types/text/form-field-text.component.html
new file mode 100644
index 0000000..cfd6f36
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/form-field-text.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/text/form-field-text.component.scss b/src/app/_modules/form-fields/types/text/form-field-text.component.scss
new file mode 100644
index 0000000..daf4659
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/form-field-text.component.scss
@@ -0,0 +1,4 @@
+textarea {
+ height: 100px;
+ resize: vertical;
+}
diff --git a/src/app/_modules/form-fields/types/text/form-field-text.component.ts b/src/app/_modules/form-fields/types/text/form-field-text.component.ts
new file mode 100644
index 0000000..7017dae
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/form-field-text.component.ts
@@ -0,0 +1,20 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-text',
+ templateUrl: 'form-field-text.component.html',
+ styleUrls: ['form-field-text.component.scss']
+})
+export class FormFieldTextComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/text/form-field-text.module.ts b/src/app/_modules/form-fields/types/text/form-field-text.module.ts
new file mode 100644
index 0000000..ec7aa6d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/form-field-text.module.ts
@@ -0,0 +1,26 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FormFieldTextComponent} from "@app/_modules/form-fields/types/text/form-field-text.component";
+import {FieldTextReadonlyComponent} from "@app/_modules/form-fields/types/text/readonly/field-text-readonly.component";
+import {FieldTextSingleComponent} from "@app/_modules/form-fields/types/text/single/field-text-single.component";
+import {ReactiveFormsModule} from "@angular/forms";
+import {FieldTextMultipleComponent} from "@app/_modules/form-fields/types/text/multiple/field-text-multiple.component";
+import {SortablejsModule} from "ngx-sortablejs";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule,
+ SortablejsModule
+ ],
+ declarations: [
+ FormFieldTextComponent,
+ FieldTextReadonlyComponent,
+ FieldTextSingleComponent,
+ FieldTextMultipleComponent
+ ],
+ exports: [
+ FormFieldTextComponent
+ ]
+})
+export class FormFieldTextModule {}
diff --git a/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.html b/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.html
new file mode 100644
index 0000000..9f4c4d3
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.html
@@ -0,0 +1,11 @@
+
diff --git a/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.scss b/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.scss
new file mode 100644
index 0000000..77dc1ed
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.scss
@@ -0,0 +1,20 @@
+.items {
+ .item {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ width: 100%;
+ margin-bottom: 12px;
+ &:last-child {
+ margin-bottom: 0;
+ }
+ .left {
+ width: 100%;
+ flex-grow: 1;
+ }
+ .right {
+ margin-left: 12px;
+ flex-shrink: 0;
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.ts b/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.ts
new file mode 100644
index 0000000..9742e1d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/multiple/field-text-multiple.component.ts
@@ -0,0 +1,52 @@
+import {Component, Input} from '@angular/core';
+import {FormArray, FormGroup, FormControl, FormBuilder, Validators} from "@angular/forms";
+
+@Component({
+ selector: 'field-text-multiple',
+ templateUrl: 'field-text-multiple.component.html',
+ styleUrls: ['field-text-multiple.component.scss', '../form-field-text.component.scss']
+})
+export class FieldTextMultipleComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ //let control = this.formGroup.controls[this.field.name];
+ this.formGroup.setControl(this.field.name, new FormArray([]));
+ if (this.initialValue?.length) this.initialValue.forEach(val => {this.add(val, true);});
+ else this.add('', true);
+ }
+
+
+
+ get initialValue() {
+ return (this.value?.length) ? this.value : (this.field.value?.data || []);
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name] as FormArray;
+ }
+ get value() {
+ return this.control?.value || [];
+ }
+ set value(value) {
+ this.control?.setValue(value);
+ }
+
+
+ add(value = '', required = false) {
+ this.control.push(new FormControl(value, required ? [Validators.required] : null));
+ }
+
+ remove(i: number) {
+ this.control.removeAt(i);
+ }
+
+
+ get maxLength() {
+ return this?.field?.maxLength || 65535;
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.html b/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.html
new file mode 100644
index 0000000..3465ea7
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.html
@@ -0,0 +1,2 @@
+{{val}}
+-
diff --git a/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.scss b/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.ts b/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.ts
new file mode 100644
index 0000000..b0f570e
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/readonly/field-text-readonly.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-text-readonly',
+ templateUrl: 'field-text-readonly.component.html',
+ styleUrls: ['field-text-readonly.component.scss']
+})
+export class FieldTextReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+
+}
diff --git a/src/app/_modules/form-fields/types/text/single/field-text-single.component.html b/src/app/_modules/form-fields/types/text/single/field-text-single.component.html
new file mode 100644
index 0000000..7eb746a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/single/field-text-single.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/form-fields/types/text/single/field-text-single.component.scss b/src/app/_modules/form-fields/types/text/single/field-text-single.component.scss
new file mode 100644
index 0000000..02c6f6f
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/single/field-text-single.component.scss
@@ -0,0 +1,6 @@
+textarea {
+ //resize: vertical;
+ //box-sizing: border-box;
+ //display: inline-block;
+ //vertical-align: top;
+}
diff --git a/src/app/_modules/form-fields/types/text/single/field-text-single.component.ts b/src/app/_modules/form-fields/types/text/single/field-text-single.component.ts
new file mode 100644
index 0000000..8df25f3
--- /dev/null
+++ b/src/app/_modules/form-fields/types/text/single/field-text-single.component.ts
@@ -0,0 +1,38 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'field-text-single',
+ templateUrl: 'field-text-single.component.html',
+ styleUrls: ['field-text-single.component.scss', '../form-field-text.component.scss']
+})
+export class FieldTextSingleComponent {
+ @Input() field: any;
+ @Input() formGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ if (this.value) this.field.value = {data: [this.value]};
+ setTimeout(() => {this.value = this.value || this.initialValue});
+ }
+
+
+ get initialValue() {
+ return this.field.value?.data[0] || null;
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value) {
+ this.control?.setValue(value);
+ }
+ get maxLength() {
+ return this?.field?.maxLength || 65535;
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/time/form-field-time.component.html b/src/app/_modules/form-fields/types/time/form-field-time.component.html
new file mode 100644
index 0000000..a398f05
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/form-field-time.component.html
@@ -0,0 +1,4 @@
+
+
+
+
diff --git a/src/app/_modules/form-fields/types/time/form-field-time.component.scss b/src/app/_modules/form-fields/types/time/form-field-time.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/form-fields/types/time/form-field-time.component.ts b/src/app/_modules/form-fields/types/time/form-field-time.component.ts
new file mode 100644
index 0000000..9e0ce89
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/form-field-time.component.ts
@@ -0,0 +1,13 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-time',
+ templateUrl: 'form-field-time.component.html',
+ styleUrls: ['form-field-time.component.scss']
+})
+export class FormFieldTimeComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+}
diff --git a/src/app/_modules/form-fields/types/time/form-field-time.module.ts b/src/app/_modules/form-fields/types/time/form-field-time.module.ts
new file mode 100644
index 0000000..7875f94
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/form-field-time.module.ts
@@ -0,0 +1,23 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+
+import {FormFieldTimeComponent} from "@app/_modules/form-fields/types/time/form-field-time.component";
+import {FieldTimeReadonlyComponent} from "@app/_modules/form-fields/types/time/readonly/field-time-readonly.component";
+import {FieldTimeSingleComponent} from "@app/_modules/form-fields/types/time/single/field-time-single.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule
+ ],
+ declarations: [
+ FormFieldTimeComponent,
+ FieldTimeReadonlyComponent,
+ FieldTimeSingleComponent,
+ ],
+ exports: [
+ FormFieldTimeComponent
+ ]
+})
+export class FormFieldTimeModule {}
diff --git a/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.html b/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.html
new file mode 100644
index 0000000..bb682fe
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.html
@@ -0,0 +1,2 @@
+{{val | date: 'HH:mm'}}
+-
diff --git a/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.scss b/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.scss
new file mode 100644
index 0000000..d7fbc1a
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.scss
@@ -0,0 +1,3 @@
+.value {
+ padding: 10px 0 0;
+}
diff --git a/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.ts b/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.ts
new file mode 100644
index 0000000..a70a6dc
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/readonly/field-time-readonly.component.ts
@@ -0,0 +1,21 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'field-time-readonly',
+ templateUrl: 'field-time-readonly.component.html',
+ styleUrls: ['field-time-readonly.component.scss']
+})
+export class FieldTimeReadonlyComponent {
+ @Input() field: any;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+ get value() {
+ return this.field.value?.data || [];
+ }
+
+}
diff --git a/src/app/_modules/form-fields/types/time/single/field-time-single.component.html b/src/app/_modules/form-fields/types/time/single/field-time-single.component.html
new file mode 100644
index 0000000..5a65c9d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/single/field-time-single.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/form-fields/types/time/single/field-time-single.component.scss b/src/app/_modules/form-fields/types/time/single/field-time-single.component.scss
new file mode 100644
index 0000000..55c39fa
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/single/field-time-single.component.scss
@@ -0,0 +1,3 @@
+input {
+ max-width: 160px;
+}
diff --git a/src/app/_modules/form-fields/types/time/single/field-time-single.component.ts b/src/app/_modules/form-fields/types/time/single/field-time-single.component.ts
new file mode 100644
index 0000000..4a1467d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/time/single/field-time-single.component.ts
@@ -0,0 +1,34 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {DatePipe} from "@angular/common";
+
+@Component({
+ selector: 'field-time-single',
+ templateUrl: 'field-time-single.component.html',
+ styleUrls: ['field-time-single.component.scss']
+})
+export class FieldTimeSingleComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ constructor(private datePipe: DatePipe) {
+ }
+
+ ngOnInit() {
+ setTimeout(() => {this.value = this.initialValue || this.value || null});
+ }
+
+
+ get initialValue() {
+ return this.field?.value?.data[0];
+ }
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+ get value() {
+ return this.control?.value;
+ }
+ set value(value) {
+ this.control?.setValue((value?.length > 5) ? this.datePipe.transform(value, 'HH:mm') : value);
+ }
+}
diff --git a/src/app/_modules/form-fields/types/topics/form-field-topics.component.html b/src/app/_modules/form-fields/types/topics/form-field-topics.component.html
new file mode 100644
index 0000000..040f79d
--- /dev/null
+++ b/src/app/_modules/form-fields/types/topics/form-field-topics.component.html
@@ -0,0 +1,22 @@
+
+
+
+
Вопрос №{{i+1}}
+
+
+
+
+
+
+
+
+

+ Добавить вопрос
+
diff --git a/src/app/_modules/form-fields/types/topics/form-field-topics.component.scss b/src/app/_modules/form-fields/types/topics/form-field-topics.component.scss
new file mode 100644
index 0000000..44b0bd5
--- /dev/null
+++ b/src/app/_modules/form-fields/types/topics/form-field-topics.component.scss
@@ -0,0 +1,72 @@
+.questions {
+ display: flex;
+ flex-direction: column;
+
+ .question {
+ display: flex;
+ flex-direction: column;
+
+ .head {
+ display: flex;
+ margin-bottom: 20px;
+
+ .title {
+ display: flex;
+ align-items: center;
+ color: #111111;
+ font-size: 1rem;
+ font-weight: bold;
+ line-height: 20px;
+
+ }
+ .close {
+ &:before {
+ display: block;
+ width: 16px;
+ height: 16px;
+ //background: transparent url("~src/assets/images/icons/close_16dp.svg") 50% 50%;
+ content: '';
+ }
+ }
+ }
+
+ .row {
+ display: flex;
+ align-items: center;
+ margin-bottom: 20px;
+ flex-direction: row;
+
+ &.document {
+ align-items: normal;
+
+ .name {
+ padding-top: 10px;
+
+ }
+ }
+
+ .name {
+ width: 256px;
+ color: #6c6c6c;
+
+ }
+ .field {
+ width: calc(100% - 256px);
+
+ }
+ }
+ }
+}
+
+.question-add {
+ display: flex;
+ color: var(--orange-2);
+ cursor: pointer;
+ font-size: 1rem;
+ line-height: 20px;
+ align-items: center;
+
+ img {
+ margin-right: 10px;
+ }
+}
diff --git a/src/app/_modules/form-fields/types/topics/form-field-topics.component.ts b/src/app/_modules/form-fields/types/topics/form-field-topics.component.ts
new file mode 100644
index 0000000..d8f05a9
--- /dev/null
+++ b/src/app/_modules/form-fields/types/topics/form-field-topics.component.ts
@@ -0,0 +1,69 @@
+import {Component, Input} from '@angular/core';
+import {FormControl, FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'form-field-topics',
+ templateUrl: 'form-field-topics.component.html',
+ styleUrls: ['form-field-topics.component.scss']
+})
+export class FormFieldTopicsComponent {
+ @Input() field!: any;
+ @Input() formGroup!: FormGroup;
+
+ public topics: any[] = [];
+
+ public emptyItem = [
+ {name: "name", title: 'Формулировка', type: "text", required: true},
+ {name: "speakers", title: 'ФИО и должность докладчика', type: "text", required: true},
+ {name: "attachments", title: "Прилагаемые материалы", type: "document", multiple: true, required: true}
+ ];
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ this.field.items.forEach((item: any) => {
+ let topic = new FormGroup({});
+ item.forEach((row: any) => {
+ topic.addControl(row.name, new FormControl([row.value?.data || row.value]));
+ });
+ this.topics.push(topic);
+ this.value = this.topics;
+ })
+ }
+
+ set value(value) {
+ this.control.setValue(value);
+ }
+
+ get control() {
+ return this.formGroup.controls[this.field.name];
+ }
+
+ get value() {
+ return this.control.value || [];
+ }
+
+ add(item: any) {
+ let question = new FormGroup({});
+ item.forEach((row: any) => {
+ question.addControl(row.name, new FormControl(row.value?.data));
+ });
+ this.topics.push(question);
+ this.field.items.push(item);
+ this.value = this.topics;
+ }
+
+ remove(index: number) {
+ let number = index + 1;
+ if (confirm(`Удалить "Вопрос №${number}" из повестки?`)) {
+ this.topics = this.topics.filter((question: any, key: any) => {
+ return key !== index;
+ });
+ this.value = this.topics;
+ this.field.items = this.field.items.filter((item: any, key: any) => {
+ return key !== index;
+ });
+ }
+ }
+}
diff --git a/src/app/_modules/form-fields/types/topics/form-field-topics.module.ts b/src/app/_modules/form-fields/types/topics/form-field-topics.module.ts
new file mode 100644
index 0000000..b8fa094
--- /dev/null
+++ b/src/app/_modules/form-fields/types/topics/form-field-topics.module.ts
@@ -0,0 +1,29 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ReactiveFormsModule} from "@angular/forms";
+
+import {FormFieldTopicsComponent} from "@app/_modules/form-fields/types/topics/form-field-topics.component";
+import {
+ FormFieldDocumentModule,
+ FormFieldRelationModule,
+ FormFieldStringModule,
+ FormFieldTextModule
+} from "@app/_modules/form-fields/types";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ ReactiveFormsModule,
+ FormFieldDocumentModule,
+ FormFieldRelationModule,
+ FormFieldStringModule,
+ FormFieldTextModule,
+ ],
+ declarations: [
+ FormFieldTopicsComponent,
+ ],
+ exports: [
+ FormFieldTopicsComponent
+ ]
+})
+export class FormFieldTopicsModule {}
diff --git a/src/app/_modules/layout/footer/footer.component.html b/src/app/_modules/layout/footer/footer.component.html
new file mode 100644
index 0000000..a590c4c
--- /dev/null
+++ b/src/app/_modules/layout/footer/footer.component.html
@@ -0,0 +1,28 @@
+
diff --git a/src/app/_modules/layout/footer/footer.component.scss b/src/app/_modules/layout/footer/footer.component.scss
new file mode 100644
index 0000000..774aba2
--- /dev/null
+++ b/src/app/_modules/layout/footer/footer.component.scss
@@ -0,0 +1,110 @@
+.footer {
+ width: 100%;
+ padding: 32px 40px 48px;
+ margin-top: 40px;
+ border-top: 1px solid;
+ background-color: var(--grey-5);
+ border-top-color: var(--grey-5);
+ .block {
+ max-width: 1240px;
+ display: flex;
+ flex-direction: row;
+ justify-content: space-between;
+ flex-wrap: wrap;
+ gap: 40px;
+ width: 100%;
+ margin: 0 auto;
+ padding: 0 40px;
+ .left {
+ flex-grow: 1;
+ display: flex;
+ flex-direction: column;
+ row-gap: 24px;
+ .logos {
+ display: flex;
+ column-gap: 40px;
+ flex-direction: row;
+ row-gap: 32px;
+ flex-wrap: wrap;
+ .fcs {
+ width: 218px;
+ height: 72px;
+ background: url('~src/assets/images/logo_fcs_white_218x60.svg') no-repeat center;
+ }
+ .minstroy {
+ width: 179px;
+ height: 72px;
+ background: url('~src/assets/images/logo_minstroy_white_179x72.svg') no-repeat center;
+ }
+ }
+ .links {
+ ul {
+ margin: 0;
+ padding: 0;
+ display: flex;
+ flex-direction: column;
+ row-gap: 16px;
+ li {
+ list-style-type: none;
+ a {
+ font-size: 14px;
+ color: var(--white);
+ }
+ }
+ }
+ }
+ }
+ .right {
+ flex-grow: 1;
+ display: flex;
+ row-gap: 24px;
+ flex-direction: column;
+ .title {
+ font-weight: 700;
+ line-height: 24px;
+ color: var(--white);
+ }
+ .phone,
+ .email,
+ .location {
+ position: relative;
+ margin-left: 39px;
+ color: var(--white);
+ &::after {
+ content: "";
+ position: absolute;
+ width: 28px;
+ height: 28px;
+ left: -39px;
+ top: 0;
+ background-size: 28px 28px;
+ background-position: center;
+ background-repeat: no-repeat;
+ }
+ }
+ .phone {&::after {background-image: url("~src/assets/images/icons/phone_white_24dp.svg");} }
+ .email {&::after {background-image: url("~src/assets/images/icons/email_white_24dp.svg");}}
+ .location {&::after {background-image: url("~src/assets/images/icons/location_white_24dp.svg");} }
+ .social-media {
+ display: flex;
+ column-gap: 16px;
+ a {
+ width: 28px;
+ height: 28px;
+ background-size: 28px 28px;
+ background-position: center;
+ background-repeat: no-repeat;
+ }
+ .vk {background-image: url("~src/assets/images/icons/vk_black_24dp.svg");}
+ .ok {background-image: url("~src/assets/images/icons/ok_black_24dp.svg");}
+ .telegram {background-image: url("~src/assets/images/icons/telegram_black_24dp.svg");}
+ }
+ }
+ }
+}
+@media screen and (max-width: 526px) {
+ .footer {
+ padding-left: 0;
+ padding-right: 0;
+ }
+}
diff --git a/src/app/_modules/layout/footer/footer.component.ts b/src/app/_modules/layout/footer/footer.component.ts
new file mode 100644
index 0000000..44c7130
--- /dev/null
+++ b/src/app/_modules/layout/footer/footer.component.ts
@@ -0,0 +1,15 @@
+import {Component} from '@angular/core';
+
+@Component({
+ selector: 'footer',
+ templateUrl: 'footer.component.html',
+ styleUrls: ['footer.component.scss']
+})
+export class FooterComponent {
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+}
diff --git a/src/app/_modules/layout/grid/grid.component.html b/src/app/_modules/layout/grid/grid.component.html
new file mode 100644
index 0000000..a0c73e3
--- /dev/null
+++ b/src/app/_modules/layout/grid/grid.component.html
@@ -0,0 +1,12 @@
+
+
+
diff --git a/src/app/_modules/layout/grid/grid.component.scss b/src/app/_modules/layout/grid/grid.component.scss
new file mode 100644
index 0000000..b7e4c86
--- /dev/null
+++ b/src/app/_modules/layout/grid/grid.component.scss
@@ -0,0 +1,13 @@
+.wrapper {
+ width: 100%;
+ min-height: 100%;
+ display: flex;
+ flex-direction: column;
+ background-color: #ffffff;
+ header, footer {
+ flex-grow: 0;
+ }
+ .content {
+ flex-grow: 1;
+ }
+}
diff --git a/src/app/_modules/layout/grid/grid.component.ts b/src/app/_modules/layout/grid/grid.component.ts
new file mode 100644
index 0000000..125f17c
--- /dev/null
+++ b/src/app/_modules/layout/grid/grid.component.ts
@@ -0,0 +1,34 @@
+import {Component} from '@angular/core';
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+
+@Component({
+ selector: 'grid',
+ templateUrl: 'grid.component.html',
+ styleUrls: ['grid.component.scss']
+})
+export class GridComponent {
+
+ public classActive = '';
+
+ public bright: number = 150;
+ public contrast: number = 100;
+
+ subscription?: Subscription;
+
+ constructor(
+ private listsService: ListsService,
+ ) {
+ }
+
+ ngOnInit() {
+ this.subscription = this.listsService.result('class').subscribe(val => {
+ this.classActive = val;
+ });
+ }
+
+ ngOnDestroy() {
+ this.subscription?.unsubscribe();
+ }
+
+}
diff --git a/src/app/_modules/layout/header/header.component.html b/src/app/_modules/layout/header/header.component.html
new file mode 100644
index 0000000..a591516
--- /dev/null
+++ b/src/app/_modules/layout/header/header.component.html
@@ -0,0 +1,36 @@
+
diff --git a/src/app/_modules/layout/header/header.component.scss b/src/app/_modules/layout/header/header.component.scss
new file mode 100644
index 0000000..ed8239f
--- /dev/null
+++ b/src/app/_modules/layout/header/header.component.scss
@@ -0,0 +1,231 @@
+.header {
+ background: var(--grey-4);
+ position: relative;
+ .top {
+ background-color: var(--white);
+ .limiter {
+ .logos {
+ .fcs { background-image: url('~src/assets/images/logo_fcs_black.svg');}
+ .minstroy { background-image: url('~src/assets/images/logo_minstroy_black.svg');}
+ }
+ .menu {
+ .goggles { background-image: url('~src/assets/images/icons/glasses_24dp.svg');}
+ .dial-pad { background-image: url('~src/assets/images/icons/dialpad_24dp.svg');}
+ .search { background-image: url('~src/assets/images/icons/search_24dp.svg');}
+ .login { background-image: url('~src/assets/images/icons/login_24dp.svg');}
+ }
+ }
+ }
+ .top {
+ padding: 20px 0;
+ .limiter {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ }
+ .logos {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ gap: 40px;
+ .fcs {
+ width: 190px;
+ height: 64px;
+ background-repeat: no-repeat;
+ background-position: center;
+ }
+ .minstroy {
+ width: 155px;
+ height: 64px;
+ background-repeat: no-repeat;
+ background-position: center;
+ }
+ }
+ .menu {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ gap: 24px;
+ .icon {
+ padding: 0;
+ min-width: 24px;
+ height: 24px;
+ background-position: center;
+ background-repeat: no-repeat;
+ background-color: transparent;
+ background-size: auto;
+ transition: transform 0.2s;
+ &:hover {
+ transform: scale(1.5);
+ }
+ }
+ }
+ }
+ .bottom {
+ position: relative;
+ background-color: rgba(62, 61, 64, 40%);
+ border-top: 1px solid #BFBFBF;
+ .limiter {
+ .main-menu {
+ &.hidden {
+ display: none;
+ }
+ }
+ }
+ }
+}
+
+
+
+
+@media screen and (min-width: 961px){
+ .header {
+ .top{
+ .limiter{
+ .main-menu-btn{
+ display: none;
+ width: 24px;
+ height: 24px;
+ }
+ .menu{
+ margin-left: auto;
+ }
+ }
+ }
+ .bottom {
+ .limiter {
+ .close{
+ display: none;
+ }
+ .main-menu {
+ overflow: hidden;
+ }
+ }
+ .ftr{
+ display: none;
+ }
+ }
+ }
+}
+
+
+
+
+@media screen and (max-width: 960px) {
+
+ .header {
+ .top {
+ padding: 12px 0;
+ background-color: var(--grey-4);
+ .limiter {
+ display: flex;
+ justify-content: space-between;
+ padding: 0 24px;
+ .main-menu-btn{
+ flex-grow: 1;
+ flex-basis: 40px;
+ button{
+ width: 48px;
+ height: 48px;
+ margin: 0 0 0 -12px;
+ background: url('~src/assets/images/icons/burger_white_24dp.svg') no-repeat center;
+ }
+ }
+
+ .logos {
+ .fcs { background-image: url('~src/assets/images/logo_fcs_white.svg');}
+ .minstroy {
+ display: none;
+ }
+ }
+ .menu {
+ display: flex;
+ justify-content: flex-end;
+ align-items: center;
+ flex-grow: 1;
+ flex-basis: 40px;
+ .goggles, .dial-pad, .search, .login{
+ display: none;
+ }
+ }
+ }
+ }
+
+ .showmobile{
+ display:flex;
+ }
+ .hidemobile{
+ display: none;
+ }
+
+ .bottom {
+ position:fixed;
+ align-items: flex-start;
+ top:0;
+ border: none;
+ width: 100vw;
+ z-index: 210;
+ overflow-y:scroll;
+
+ .grid-menu{
+ width: 100%;
+ min-height:100%;
+ display: flex;
+ flex-direction: row;
+ flex-wrap: nowrap;
+ justify-content: normal;
+ align-items: stretch;
+ align-content: normal;
+ background-color: rgba(62, 61, 64, 0.70);
+ }
+
+ .limiter {
+ display: block;
+ flex-grow: 1;
+ flex-shrink: 0;
+ flex-basis: 360px;
+ align-self: auto;
+ order: 0;
+ margin:0;
+ background-color: #3E3D40;
+ padding-left: 24px;
+ padding-top: 16px;
+ animation: slide-from-left 0.3s;
+ .close{
+ width: 24px;
+ height: 24px;
+ background: transparent;
+ padding: 0;
+ background: url('~src/assets/images/icons/close_white_24dp.svg') center no-repeat;
+ }
+ }
+ }
+ .front{
+ z-index: 210;
+ }
+ .back{
+
+ display: block;
+ flex-grow: 1;
+ flex-shrink: 1;
+ flex-basis: auto;
+ align-self: stretch;
+ flex-basis: 100vw;
+ }
+ .ftr{
+ color: #FFF;
+ font-family: Open Sans;
+ font-size: 16px;
+ font-style: normal;
+ font-weight: 700;
+ line-height: 24px;
+
+ border-top: 1px solid rgba(255, 255, 255, 0.75);
+ div{
+ margin: 16px 0;
+ cursor: pointer;
+ }
+ }
+ }
+}
+
diff --git a/src/app/_modules/layout/header/header.component.ts b/src/app/_modules/layout/header/header.component.ts
new file mode 100644
index 0000000..f79c875
--- /dev/null
+++ b/src/app/_modules/layout/header/header.component.ts
@@ -0,0 +1,61 @@
+import {Component} from '@angular/core';
+import {PagesService} from "@app/_services/pages.service";
+import {AuthenticationService, ListsService} from "@app/_services";
+import {Router} from "@angular/router";
+import {Subscription} from "rxjs";
+
+@Component({
+ selector: 'header',
+ templateUrl: 'header.component.html',
+ styleUrls: ['header.component.scss']
+})
+export class HeaderComponent {
+ public menuItems = [];
+ public user: any;
+ public loading: boolean = false;
+ public error: string = '';
+ subscription: Subscription;
+ showBottom = false;
+
+ constructor(private router: Router, private pagesService: PagesService, public authenticationService: AuthenticationService, private listsService: ListsService) {
+ this.subscription = this.authenticationService.user.subscribe(user => {
+ this.user = user;
+ });
+ }
+
+ ngOnInit() {
+ this.fetchMenu();
+ let showSettingSite = localStorage.getItem('showSettingSite');
+ if (showSettingSite === null || showSettingSite === 'no') {
+ localStorage.setItem('showSettingSite', 'no');
+ this.listsService.result('showSettingSite').next(false);
+ }
+ }
+
+ ngOnDestroy() {
+ this.subscription?.unsubscribe();
+ }
+
+
+ fetchMenu() {
+ let include = ['children.children'];
+ this.pagesService.root({include: include.join(',')}).subscribe(res => {
+ this.menuItems = res.data;
+ });
+ }
+
+ settingsSite() {
+ let showSettingSite = localStorage.getItem('showSettingSite');
+ showSettingSite = showSettingSite === 'yes' ? 'no' : 'yes';
+ localStorage.setItem('showSettingSite', showSettingSite);
+ this.listsService.result('showSettingSite').next(showSettingSite==='yes');
+ }
+
+ login() {
+ this.authenticationService.popup('login');
+ }
+
+ itemSelect(event:any){
+ if(!event.children?.data.length) this.showBottom = false;
+ }
+}
diff --git a/src/app/_modules/layout/header/user-bar/header-user-bar.component.html b/src/app/_modules/layout/header/user-bar/header-user-bar.component.html
new file mode 100644
index 0000000..3009aef
--- /dev/null
+++ b/src/app/_modules/layout/header/user-bar/header-user-bar.component.html
@@ -0,0 +1,32 @@
+
+
+
![]()
+
{{user.initials}}
+
+
+
+ - Личный кабинет
+ - Журнал заявок
+ - Панель управления
+ - Выход из системы
+
+
+
+
+
diff --git a/src/app/_modules/layout/header/user-bar/header-user-bar.component.scss b/src/app/_modules/layout/header/user-bar/header-user-bar.component.scss
new file mode 100644
index 0000000..00d1657
--- /dev/null
+++ b/src/app/_modules/layout/header/user-bar/header-user-bar.component.scss
@@ -0,0 +1,95 @@
+.user {
+ position: relative;
+ .avatar {
+ width: 40px;
+ height: 40px;
+ color: #86898E;
+ background: #CFD1D4;
+ border-radius: 100%;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ cursor: pointer;
+ overflow: hidden;
+ .initials {
+ }
+ img {
+ display: block;
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+ }
+
+ .dropdown {
+ display: none;
+ }
+
+ &:hover {
+ .dropdown {
+ display: block;
+ width: 250px;
+ right: -24px;
+ top: calc(100% + 8px);
+ position: absolute;
+ background-color: #ffffff;
+ border: #dedede solid 1px;
+ box-shadow: 0 3px 6px 0 rgb(0 0 0 / 16%);
+ z-index: 1;
+ border-radius: 8px;
+ ul {
+ display: flex;
+ flex-direction: column;
+ margin: 0;
+ padding: 0;
+ list-style: none;
+ border-radius: 8px;
+ li {
+ display: block;
+ padding: 12px 16px;
+ color: #000000;
+ cursor: pointer;
+ border-bottom: #E0E0E0 solid 1px;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ &:first-child {
+ border-radius: 8px 8px 0 0;
+ }
+ &:last-child {
+ border-radius: 0 0 8px 8px;
+ a, span {
+ border-bottom: none;
+ }
+ }
+ &:hover {
+ background-color: #f7f7f7;
+ }
+ }
+ }
+
+ &.hidden {
+ display: none;
+ }
+
+ &:before {
+ position: absolute;
+ top: -21px;
+ right: 0;
+ width: 84px;
+ height: 24px;
+ background: url("~src/assets/images/triangle.png") no-repeat center;
+ z-index: 2;
+ content: '';
+ }
+ }
+
+ }
+}
+@media screen and (max-width: 960px) {
+ .user {
+ .avatar {
+ background-color: var(--white);
+ }
+ }
+}
diff --git a/src/app/_modules/layout/header/user-bar/header-user-bar.component.ts b/src/app/_modules/layout/header/user-bar/header-user-bar.component.ts
new file mode 100644
index 0000000..a465f7f
--- /dev/null
+++ b/src/app/_modules/layout/header/user-bar/header-user-bar.component.ts
@@ -0,0 +1,47 @@
+import {Component, Input} from '@angular/core';
+import {AuthenticationService, ListsService} from "@app/_services";
+import {Router} from "@angular/router";
+
+@Component({
+ selector: 'header-user-bar',
+ templateUrl: 'header-user-bar.component.html',
+ styleUrls: ['header-user-bar.component.scss']
+})
+export class HeaderUserBarComponent {
+ @Input() user: any;
+ public menuItems = [];
+ public ddHidden = false;
+
+ constructor(public authService: AuthenticationService, private router: Router) {
+ }
+
+ get avatar() {
+ return this.user?.avatar?.data;
+ }
+ get isJournalVisible() {
+ return !this.authService.isMainCompanyMember || this.authService.isExpert || this.authService.isAdmin;
+ }
+
+ ngOnInit() {
+
+ }
+
+
+ close() {
+ this.ddHidden = true;
+ setTimeout(() => {this.ddHidden = false}, 10);
+ }
+
+ logout() {
+ if (confirm('Вы деествительно хотите выйти из системы?')) {
+ this.authService.logout();
+ this.ddHidden = true;
+ this.router.navigate(['']).then();
+ }
+ }
+
+ link(link: string) {
+ this.ddHidden = true;
+ this.router.navigate([link]).then();
+ }
+}
diff --git a/src/app/_modules/layout/layout.module.ts b/src/app/_modules/layout/layout.module.ts
new file mode 100644
index 0000000..fd1a9cd
--- /dev/null
+++ b/src/app/_modules/layout/layout.module.ts
@@ -0,0 +1,34 @@
+import {NgModule} from '@angular/core';
+import {BrowserModule} from "@angular/platform-browser";
+import {RouterModule} from "@angular/router";
+import {FormsModule, ReactiveFormsModule} from "@angular/forms";
+
+import {PagesModule} from "@app/_modules/pages/pages.module";
+
+import {HeaderComponent} from "@app/_modules/layout/header/header.component";
+import {FooterComponent} from "@app/_modules/layout/footer/footer.component";
+import {GridComponent} from "@app/_modules/layout/grid/grid.component";
+import {SettingSiteComponent} from "@app/_modules/layout/setting-site/setting-site.component";
+import {HeaderUserBarComponent} from "@app/_modules/layout/header/user-bar/header-user-bar.component";
+
+@NgModule({
+ imports: [
+ BrowserModule,
+ FormsModule,
+ ReactiveFormsModule,
+ RouterModule,
+ PagesModule,
+ ],
+ declarations: [
+ GridComponent,
+ HeaderComponent,
+ FooterComponent,
+ SettingSiteComponent,
+ HeaderUserBarComponent,
+ ],
+ exports: [
+ GridComponent,
+ ]
+})
+export class LayoutModule {
+}
diff --git a/src/app/_modules/layout/setting-site/setting-site.component.html b/src/app/_modules/layout/setting-site/setting-site.component.html
new file mode 100644
index 0000000..e37c9ff
--- /dev/null
+++ b/src/app/_modules/layout/setting-site/setting-site.component.html
@@ -0,0 +1,45 @@
+
diff --git a/src/app/_modules/layout/setting-site/setting-site.component.scss b/src/app/_modules/layout/setting-site/setting-site.component.scss
new file mode 100644
index 0000000..f30b5a6
--- /dev/null
+++ b/src/app/_modules/layout/setting-site/setting-site.component.scss
@@ -0,0 +1,90 @@
+.setting-site {
+ width: 100%;
+ border-bottom: 1px solid #000;
+ position: relative;
+ .block {
+ width: 100%;
+ display: flex;
+ margin: 0 auto;
+ column-gap: 40px;
+ max-width: 1240px;
+ padding: 20px 40px;
+ align-items: flex-end;
+ justify-content: center;
+
+ .font, .color, .images, .bright, .contrast, .default {
+ display: flex;
+ flex-direction: column;
+ row-gap: 8px;
+ flex-wrap: wrap;
+
+ .title {
+ text-align: center;
+ font-size: 16px;
+ font-style: normal;
+ font-weight: 700;
+ line-height: 24px;
+ }
+ .controls {
+ display: flex;
+ flex-direction: row;
+ justify-content: center;
+ column-gap: 12px;
+ div {
+ width: 32px;
+ height: 32px;
+ border-radius: 4px;
+ text-align: center;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ border: 1px solid var(--grey-6);
+ font-size: 22px;
+ font-weight: bold;
+ cursor: pointer;
+ &.icon {
+ background-position: center;
+ background-repeat: no-repeat;
+ }
+ &.minus {background-image: url("~src/assets/images/icons/minus_grey_20dp.svg");}
+ &.plus {background-image: url("~src/assets/images/icons/plus_grey_20dp.svg");}
+ &.image {background-image: url("~src/assets/images/icons/image_grey_20dp.svg");}
+ &.ban {background-image: url("~src/assets/images/icons/ban_20dp.svg");}
+ &.sun {background-image: url("~src/assets/images/icons/sun_22dp.svg");}
+ &.circle-half-stroke {background-image: url("~src/assets/images/icons/circle_half_stroke_21dp.svg");}
+
+ &.style-color {
+ color: #28a814;
+ }
+ &.style-brown {
+ background-color: #f7f0d2;
+ }
+ &.style-black-white {
+ color: var(--black);
+ background-color: var(--white);
+ }
+ }
+ }
+ }
+
+ .default {
+ background-color: var(--grey-6);
+ width: 32px;
+ height: 32px;
+ border-radius: 4px;
+ background-image: url("~src/assets/images/icons/return_19dp.svg");
+ background-repeat: no-repeat;
+ background-position: center;
+ cursor: pointer;
+ }
+ }
+ .exit {
+ position: absolute;
+ width: 24px;
+ height: 24px;
+ right: 20px;
+ cursor: pointer;
+ top: 20px;
+ background: url("~src/assets/images/icons/close_20dp.svg") no-repeat center;
+ }
+}
diff --git a/src/app/_modules/layout/setting-site/setting-site.component.ts b/src/app/_modules/layout/setting-site/setting-site.component.ts
new file mode 100644
index 0000000..a798de3
--- /dev/null
+++ b/src/app/_modules/layout/setting-site/setting-site.component.ts
@@ -0,0 +1,92 @@
+import {Component} from '@angular/core';
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+
+@Component({
+ selector: 'setting-site',
+ templateUrl: 'setting-site.component.html',
+ styleUrls: ['setting-site.component.scss']
+})
+export class SettingSiteComponent {
+ resultsSubscription?: Subscription;
+
+ public isShow: boolean = false;
+
+ public classes: any = [{class: 'style-color'}, {class: 'style-brown'}, {class: 'style-white-black'}, {class: 'style-black-white'}];
+ public nameId = 'class';
+ public params = {fontSize: 16, brightRange: 100, contrastRange: 100, class: 'style-color', showImages: true};
+
+ constructor(
+ private listsService: ListsService,
+ ) {
+ }
+ ngOnInit() {
+ this.resultsSubscription = this.listsService.result('showSettingSite').subscribe(val => {
+ this.isShow = val;
+ });
+ this.setMainClass();
+ }
+ ngOnDestroy() {
+ this.resultsSubscription?.unsubscribe();
+ }
+
+
+ get activeClass(): string {
+ let res = this.params.class;
+ if (!this.params.showImages) res += ' image-hidden';
+ return res;
+ }
+
+
+ setClass(type: string) {
+ this.params.class = type;
+ this.setMainClass();
+ }
+ setMainClass() {
+ this.listsService.result(this.nameId).next(this.activeClass);
+ }
+ setImages(isShow: boolean) {
+ this.params.showImages = isShow;
+ this.setMainClass();
+ }
+ setDefaultParams() {
+ this.params = {fontSize: 16, brightRange: 100, contrastRange: 100, class: 'style-color', showImages: true};
+ this.listsService.result(this.nameId).next(this.activeClass);
+ this.applyParams();
+ }
+ setParam(type: string, value: any) {
+ switch (type) {
+ case 'font':
+ switch (value) {
+ case true: ++this.params.fontSize; break;
+ case false: --this.params.fontSize; break;
+ case null: this.params.fontSize = 16; break;
+ }
+ break;
+ case 'bright':
+ switch (value) {
+ case true: this.params.brightRange += 5; break;
+ case false: this.params.brightRange -= 5; break;
+ case null: this.params.brightRange = 100; break;
+ }
+ break;
+ case 'contrast':
+ switch (value) {
+ case true: this.params.contrastRange += 10; break;
+ case false: this.params.contrastRange -= 10; break;
+ case null: this.params.contrastRange = 100; break;
+ }
+ break;
+ }
+ this.applyParams();
+ }
+ applyParams(){
+ let style = document.getElementById('html').style;
+ style.fontSize = this.params.fontSize + 'px';
+ style.filter = 'brightness(' + this.params.brightRange + '%) contrast(' + this.params.contrastRange + '%)';
+ }
+ close() {
+ this.listsService.result('showSettingSite').next(false);
+ localStorage.setItem('showSettingSite', 'no');
+ }
+}
diff --git a/src/app/_modules/layout/sidebar/sidebar.component.html b/src/app/_modules/layout/sidebar/sidebar.component.html
new file mode 100644
index 0000000..d0fe29e
--- /dev/null
+++ b/src/app/_modules/layout/sidebar/sidebar.component.html
@@ -0,0 +1,4 @@
+
+
diff --git a/src/app/_modules/layout/sidebar/sidebar.component.scss b/src/app/_modules/layout/sidebar/sidebar.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/layout/sidebar/sidebar.component.ts b/src/app/_modules/layout/sidebar/sidebar.component.ts
new file mode 100644
index 0000000..2dfa688
--- /dev/null
+++ b/src/app/_modules/layout/sidebar/sidebar.component.ts
@@ -0,0 +1,17 @@
+import {Component} from '@angular/core';
+
+@Component({
+ selector: 'sidebar',
+ templateUrl: 'sidebar.component.html',
+ styleUrls: ['sidebar.component.scss']
+})
+export class SidebarComponent {
+ constructor() {
+
+ }
+
+ ngOnInit() {
+
+ }
+
+}
diff --git a/src/app/_modules/notifications/list/item/notifications-list-item.component.html b/src/app/_modules/notifications/list/item/notifications-list-item.component.html
new file mode 100644
index 0000000..b368120
--- /dev/null
+++ b/src/app/_modules/notifications/list/item/notifications-list-item.component.html
@@ -0,0 +1,13 @@
+
+
+
+
{{notification.createdAt | date:'dd.MM.yyyy HH:mm'}}
+
{{notification.message}}
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/notifications/list/item/notifications-list-item.component.scss b/src/app/_modules/notifications/list/item/notifications-list-item.component.scss
new file mode 100644
index 0000000..1464cb0
--- /dev/null
+++ b/src/app/_modules/notifications/list/item/notifications-list-item.component.scss
@@ -0,0 +1,65 @@
+.notification {
+ display: flex;
+ flex-direction: column;
+
+ &.unread {
+ .top {
+ .message {
+ font-weight: bold;
+ }
+ }
+ }
+
+ .top {
+ display: flex;
+ column-gap: 20px;
+
+ .icon {
+ width: 32px;
+ height: 32px;
+ flex-shrink: 0;
+ background: transparent url("~src/assets/images/icons/notification_date.svg") 50% 50% no-repeat;
+ }
+
+ .date {
+ width: 112px;
+ flex-shrink: 0;
+ }
+
+ .message {
+ }
+ }
+ .bottom {
+ display: flex;
+ justify-content: flex-end;
+ margin: 8px 0 20px;
+
+ button {
+ color: var(--orange-2);
+ font-size: 0.875rem;
+ padding: 4px 8px;
+ margin-left: 16px;
+ border-radius: var(--radius-2);
+ text-transform: uppercase;
+ border: 1px solid var(--orange-2);
+ background-color: #ffffff;
+ }
+ }
+}
+
+
+@media screen and (max-width: 519px) {
+ .notification {
+ .top {
+ .icon {
+ display: none;
+ }
+ .date {
+ width: 80px;
+ }
+ }
+ .bottom {
+ margin-bottom: 12px;
+ }
+ }
+}
diff --git a/src/app/_modules/notifications/list/item/notifications-list-item.component.ts b/src/app/_modules/notifications/list/item/notifications-list-item.component.ts
new file mode 100644
index 0000000..87863d1
--- /dev/null
+++ b/src/app/_modules/notifications/list/item/notifications-list-item.component.ts
@@ -0,0 +1,52 @@
+import {Component, Input} from '@angular/core';
+import {Router} from "@angular/router";
+
+@Component({
+ selector: 'notifications-list-item',
+ templateUrl: 'notifications-list-item.component.html',
+ styleUrls: ['notifications-list-item.component.scss']
+})
+export class NotificationsListItemComponent {
+ @Input() notification: any;
+
+ get plan() {
+ return this.notification.plan?.data;
+ }
+ get normative() {
+ return this.notification.normative?.data;
+ }
+ get application() {
+ return this.notification.application?.data;
+ }
+ get poll() {
+ return this.notification.poll?.data;
+ }
+
+ constructor(private router: Router) {
+ }
+
+ ngOnInit() {
+ }
+
+
+ openPlan() {
+ this.router.navigate(['plans', this.plan?.id]).then(() => {this.close()});
+ }
+ openNormative() {
+ this.router.navigate(['projects', this.normative?.id]).then(() => {this.close()});
+ }
+ openApplication() {
+ this.router.navigate(['applications', this.application?.id]).then(() => {this.close()});
+ }
+ openPoll() {
+ this.router.navigate(['polls', this.poll?.id]).then(() => {this.close()});
+ }
+
+
+
+ close() {
+ this.router.navigate([{outlets: {slider: null}}]).then();
+ }
+
+
+}
diff --git a/src/app/_modules/notifications/list/notifications-list.component.html b/src/app/_modules/notifications/list/notifications-list.component.html
new file mode 100644
index 0000000..b61d6b8
--- /dev/null
+++ b/src/app/_modules/notifications/list/notifications-list.component.html
@@ -0,0 +1,15 @@
+
+
diff --git a/src/app/_modules/notifications/list/notifications-list.component.scss b/src/app/_modules/notifications/list/notifications-list.component.scss
new file mode 100644
index 0000000..7f7aace
--- /dev/null
+++ b/src/app/_modules/notifications/list/notifications-list.component.scss
@@ -0,0 +1,18 @@
+.notifications {
+ display: flex;
+ flex-direction: column;
+ row-gap: 20px;
+ notifications-list-item {
+ border-bottom: 1px solid #E0E0E0;
+ &:last-child {
+ border-bottom: none;
+ }
+ }
+}
+
+@media screen and (max-width: 519px) {
+ .notifications {
+ row-gap: 12px;
+ }
+}
+
diff --git a/src/app/_modules/notifications/list/notifications-list.component.ts b/src/app/_modules/notifications/list/notifications-list.component.ts
new file mode 100644
index 0000000..adfe58b
--- /dev/null
+++ b/src/app/_modules/notifications/list/notifications-list.component.ts
@@ -0,0 +1,31 @@
+import {Component} from '@angular/core';
+import {Router} from "@angular/router";
+import {NotificationService} from "@app/_services/notification.service";
+
+@Component({
+ templateUrl: 'notifications-list.component.html',
+ styleUrls: ['notifications-list.component.scss']
+})
+export class NotificationsListComponent {
+ public notifications: any[] = [];
+
+ constructor(
+ private router: Router,
+ private notificationService: NotificationService,
+ ) {
+ }
+
+ ngOnInit() {
+ this.fetch();
+ }
+
+ close() {
+ this.router.navigate([{outlets: {slider: null}}]).then();
+ }
+
+ fetch() {
+ this.notificationService.getList({include: 'plan,normative,application,poll'}).subscribe(result => {
+ this.notifications = result.data;
+ });
+ }
+}
diff --git a/src/app/_modules/notifications/notifications.module.ts b/src/app/_modules/notifications/notifications.module.ts
new file mode 100644
index 0000000..f5968a5
--- /dev/null
+++ b/src/app/_modules/notifications/notifications.module.ts
@@ -0,0 +1,31 @@
+import {NgModule} from '@angular/core'
+import {CommonModule} from '@angular/common'
+import {RouterModule, Routes} from '@angular/router'
+
+import {AuthGuard} from "@app/_helpers";
+import {ObjectsModule} from "@app/_modules/objects/objects.module";
+import {NotificationsListComponent} from "@app/_modules/notifications/list/notifications-list.component";
+import {FormFieldRelationModule, FormFieldStringModule, FormFieldTextModule} from "@app/_modules/form-fields/types";
+import {NotificationsListItemComponent} from "@app/_modules/notifications/list/item/notifications-list-item.component";
+
+const routes: Routes = [
+ {path: 'notifications', component: NotificationsListComponent, outlet: 'slider', canActivate: [AuthGuard]}
+]
+
+@NgModule({
+ imports: [
+ CommonModule,
+ RouterModule.forChild(routes),
+ ObjectsModule,
+ FormFieldStringModule,
+ FormFieldTextModule,
+ FormFieldRelationModule
+ ],
+ declarations: [
+ NotificationsListComponent,
+ NotificationsListItemComponent
+ ],
+ exports: [
+ ]
+})
+export class NotificationsModule {}
diff --git a/src/app/_modules/objects/filters/group/object-filters-group.component.html b/src/app/_modules/objects/filters/group/object-filters-group.component.html
new file mode 100644
index 0000000..d0eb7b3
--- /dev/null
+++ b/src/app/_modules/objects/filters/group/object-filters-group.component.html
@@ -0,0 +1,6 @@
+
+
{{group.title}}
+
+
+
+
diff --git a/src/app/_modules/objects/filters/group/object-filters-group.component.scss b/src/app/_modules/objects/filters/group/object-filters-group.component.scss
new file mode 100644
index 0000000..dea5a19
--- /dev/null
+++ b/src/app/_modules/objects/filters/group/object-filters-group.component.scss
@@ -0,0 +1,18 @@
+.group {
+ margin: 0 0 32px;
+ .title {
+ margin: 0 0 24px;
+ font-weight: bold;
+ }
+ .fields {
+
+ }
+}
+
+@media screen and (max-width: 983px) {
+ .group {
+ .title {
+ margin-bottom: 8px;
+ }
+ }
+}
diff --git a/src/app/_modules/objects/filters/group/object-filters-group.component.ts b/src/app/_modules/objects/filters/group/object-filters-group.component.ts
new file mode 100644
index 0000000..e1f8393
--- /dev/null
+++ b/src/app/_modules/objects/filters/group/object-filters-group.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ selector: 'object-filters-group',
+ templateUrl: 'object-filters-group.component.html',
+ styleUrls: ['object-filters-group.component.scss']
+})
+export class ObjectFiltersGroupComponent {
+ @Input() group: any;
+ @Input() formGroup: FormGroup;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+ get fields() {
+ return this.group.fields.data || this.group.fields || [];
+ }
+
+}
diff --git a/src/app/_modules/objects/filters/object-filters.component.html b/src/app/_modules/objects/filters/object-filters.component.html
new file mode 100644
index 0000000..fffcdea
--- /dev/null
+++ b/src/app/_modules/objects/filters/object-filters.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/objects/filters/object-filters.component.scss b/src/app/_modules/objects/filters/object-filters.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/objects/filters/object-filters.component.ts b/src/app/_modules/objects/filters/object-filters.component.ts
new file mode 100644
index 0000000..7dad92e
--- /dev/null
+++ b/src/app/_modules/objects/filters/object-filters.component.ts
@@ -0,0 +1,56 @@
+import {Component, Input, Output, EventEmitter} from '@angular/core';
+import {ObjectsService} from "@app/_services/objects.service";
+import {FormGroup} from "@angular/forms";
+import {ListsService} from "@app/_services/lists.service";
+
+@Component({
+ selector: 'object-filters',
+ templateUrl: 'object-filters.component.html',
+ styleUrls: ['object-filters.component.scss']
+})
+export class ObjectFiltersComponent {
+ @Input() formGroup!: FormGroup;
+ @Input() target: string;
+ @Input() type: string;
+ @Input() objectTypeName?: string;
+ @Input() list: string;
+
+ @Output() onFiltersUpdated = new EventEmitter();
+
+ public formData: any;
+
+ constructor(private objectsService: ObjectsService, private listsService: ListsService) {
+ }
+
+ ngOnInit() {
+ this.formGroup.valueChanges.subscribe(data => {
+ this.fetch(data);
+ });
+ this.fetch(this.listsService.controls(this.list).value.filters);
+ }
+
+ get groups() {
+ return this.formData?.groups?.data;
+ }
+
+
+ fetch(filters: any) {
+ (this.target === 'object') ? this.fetchObjectFilters(filters) : this.fetchModelFilters(filters);
+ }
+
+ fetchObjectFilters(filters: any) {
+ this.objectsService.fetchType(this.type, {include: 'groups.fields.represented,groups.fields.range'}).subscribe(res => {
+ this.formData = res.data;
+ });
+ }
+
+ fetchModelFilters(filters: any) {
+ this.objectsService.fetchModelFilters(this.type, {include: 'value,represented,range', filters: JSON.stringify(filters)}).subscribe(res => {
+ this.formGroup.reset(undefined, {emitEvent: false});
+ this.formData = res;
+ this.onFiltersUpdated.emit(res.total || 0);
+ });
+ }
+
+
+}
diff --git a/src/app/_modules/objects/filters/slider/slider-filters.component.html b/src/app/_modules/objects/filters/slider/slider-filters.component.html
new file mode 100644
index 0000000..c8f7499
--- /dev/null
+++ b/src/app/_modules/objects/filters/slider/slider-filters.component.html
@@ -0,0 +1,19 @@
+
+
diff --git a/src/app/_modules/objects/filters/slider/slider-filters.component.scss b/src/app/_modules/objects/filters/slider/slider-filters.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/objects/filters/slider/slider-filters.component.ts b/src/app/_modules/objects/filters/slider/slider-filters.component.ts
new file mode 100644
index 0000000..cd9664a
--- /dev/null
+++ b/src/app/_modules/objects/filters/slider/slider-filters.component.ts
@@ -0,0 +1,62 @@
+import {Component} from '@angular/core';
+import {ActivatedRoute, Router} from "@angular/router";
+import {ListsService} from "@app/_services/lists.service";
+import {FormGroup} from "@angular/forms";
+
+@Component({
+ templateUrl: 'slider-filters.component.html',
+ styleUrls: ['slider-filters.component.scss']
+})
+export class SliderFiltersComponent {
+ public formGroup: FormGroup;
+ public target: string;
+ public type: string;
+ public list: string;
+
+ public total = 0;
+
+ private modelTitles: any = {registryEntries: 'записей реестра', applications: 'заявок'};
+
+
+ constructor(private router: Router, private route: ActivatedRoute, private listsService: ListsService) {
+ }
+
+ get title() {
+ return 'Поиск ' + this.modelTitles[this.type] || '';
+ }
+
+
+ ngOnInit() {
+ this.parseUrlParams(this.route.snapshot.params);
+ this.formGroup = new FormGroup({});
+ }
+
+ parseUrlParams(params) {
+ this.target = params.target;
+ this.type = params.type;
+ this.list = params.list;
+ }
+
+
+
+ save() {
+ this.listsService.setFilters(this.formGroup.value, this.list);
+ this.close();
+ }
+
+ clear() {
+ for (let prop in this.formGroup.value) {
+ if (this.formGroup.value.hasOwnProperty(prop)) {
+ if (prop !== 'registry') this.formGroup.controls[prop].setValue(null, {emitEvent: false});
+ }
+ }
+ this.formGroup.updateValueAndValidity();
+ //this.formGroup.reset();
+ }
+
+ close() {
+ this.router.navigate([{ outlets: { slider: null } }]).then();
+ }
+
+
+}
diff --git a/src/app/_modules/objects/form/frame/form-frame.component.html b/src/app/_modules/objects/form/frame/form-frame.component.html
new file mode 100644
index 0000000..76a2606
--- /dev/null
+++ b/src/app/_modules/objects/form/frame/form-frame.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/objects/form/frame/form-frame.component.scss b/src/app/_modules/objects/form/frame/form-frame.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/objects/form/frame/form-frame.component.ts b/src/app/_modules/objects/form/frame/form-frame.component.ts
new file mode 100644
index 0000000..fed06f6
--- /dev/null
+++ b/src/app/_modules/objects/form/frame/form-frame.component.ts
@@ -0,0 +1,87 @@
+import {Component, Input, Output, EventEmitter} from '@angular/core';
+import {FormGroup, Validators} from "@angular/forms";
+import {FormFieldsService} from "@app/_services/form-fields.service";
+import {FormsService} from "@app/_services";
+
+@Component({
+ selector: 'form-frame',
+ templateUrl: 'form-frame.component.html',
+ styleUrls: ['form-frame.component.scss']
+})
+export class FormFrameComponent {
+ @Input() formGroup!: FormGroup;
+ @Input() form: any;
+ @Input() readonly = false;
+ @Input() params?: any = {};
+
+ public formData: any;
+
+ constructor(private formsService: FormsService, private fieldsService: FormFieldsService) {
+ }
+
+ ngOnInit() {
+ }
+
+ ngOnChanges() {
+ this.setFormData();
+ }
+
+ get groups() {
+ return this.formData?.groups?.data || this.formData?.groups || [];
+ }
+
+
+ setFormData() {
+ let data = this.form?.data || this.form;
+ let groups = (data?.groups?.data || data?.groups || data || []).map(group => {
+ return this.fieldsService.prepareGroup(group, this.params);
+ });
+ this.formData = {groups: {data: groups}};
+ this.applyDynamic();
+ }
+
+
+ applyDynamic() {
+ this.formData.groups.data.map(group => {
+ if (group.dynamic?.length) this.formGroup.valueChanges.subscribe(data => {
+ group.dynamic.forEach(rule => {
+ if (rule.field && this.control(rule.field)) {
+ let value = this.normalizeValue(data[rule.field]);
+ if ((value.indexOf(rule.value) !== -1) || !rule.value) this.applyRule(rule);
+ }
+ });
+ });
+ });
+ }
+ applyRule(rule: any) {
+ this.formData.groups.data = this.formData.groups.data.map(group => {
+ group.fields.data = group.fields.data.map(field => {
+ if (rule.show && (rule.show.indexOf(field.name) !== -1)) field = this.show(field);
+ if (rule.hide && (rule.hide.indexOf(field.name) !== -1)) field = this.hide(field);
+ return field;
+ });
+ return group;
+ });
+ }
+ show(field: any) {
+ field.hidden = false;
+ this.control(field.name)?.setValidators(field.required ? Validators.required : null);
+ this.control(field.name)?.updateValueAndValidity({emitEvent: false});
+ return field;
+ }
+ hide(field: any) {
+ field.hidden = true;
+ this.control(field.name)?.setValidators(null);
+ this.control(field.name)?.updateValueAndValidity({emitEvent: false});
+ return field;
+ }
+ control(name: any) {
+ return this.formGroup.controls[name];
+ }
+
+
+ normalizeValue(value) {
+ return [value?.id, value?.name, value];
+ }
+
+}
diff --git a/src/app/_modules/objects/form/group/object-form-group.component.html b/src/app/_modules/objects/form/group/object-form-group.component.html
new file mode 100644
index 0000000..0111f0c
--- /dev/null
+++ b/src/app/_modules/objects/form/group/object-form-group.component.html
@@ -0,0 +1,6 @@
+
+
{{group.title}}
+
+
+
+
diff --git a/src/app/_modules/objects/form/group/object-form-group.component.scss b/src/app/_modules/objects/form/group/object-form-group.component.scss
new file mode 100644
index 0000000..3f11d04
--- /dev/null
+++ b/src/app/_modules/objects/form/group/object-form-group.component.scss
@@ -0,0 +1,5 @@
+.group {
+ &.site {
+ flex-direction: row;
+ }
+}
diff --git a/src/app/_modules/objects/form/group/object-form-group.component.ts b/src/app/_modules/objects/form/group/object-form-group.component.ts
new file mode 100644
index 0000000..445a537
--- /dev/null
+++ b/src/app/_modules/objects/form/group/object-form-group.component.ts
@@ -0,0 +1,22 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup, Validators} from "@angular/forms";
+
+@Component({
+ selector: 'object-form-group',
+ templateUrl: 'object-form-group.component.html',
+ styleUrls: ['object-form-group.component.scss']
+})
+export class ObjectFormGroupComponent {
+ @Input() group!: any;
+ @Input() formGroup!: FormGroup;
+ @Input() readonly = false;
+ @Input() params?: any = {};
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ if (this.group.readonly !== undefined) this.readonly = this.group.readonly;
+ }
+
+}
diff --git a/src/app/_modules/objects/form/object-form.component.html b/src/app/_modules/objects/form/object-form.component.html
new file mode 100644
index 0000000..4b8309c
--- /dev/null
+++ b/src/app/_modules/objects/form/object-form.component.html
@@ -0,0 +1,2 @@
+
+
diff --git a/src/app/_modules/objects/form/object-form.component.scss b/src/app/_modules/objects/form/object-form.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/objects/form/object-form.component.ts b/src/app/_modules/objects/form/object-form.component.ts
new file mode 100644
index 0000000..e1a7ca1
--- /dev/null
+++ b/src/app/_modules/objects/form/object-form.component.ts
@@ -0,0 +1,41 @@
+import {Component, Input, Output, EventEmitter} from '@angular/core';
+import {FormGroup, Validators} from "@angular/forms";
+import {FormsService} from "@app/_services";
+
+@Component({
+ selector: 'object-form',
+ templateUrl: 'object-form.component.html',
+ styleUrls: ['object-form.component.scss']
+})
+export class ObjectFormComponent {
+ @Input() formGroup!: FormGroup;
+ @Input() target: string;
+ @Input() type?: string;
+ @Input() id?: string;
+ @Input() readonly = false;
+ @Input() params: any = {};
+
+ @Output() onFormActivated = new EventEmitter();
+
+ public form: any;
+
+ constructor(private formsService: FormsService) {
+ }
+
+ ngOnInit() {
+ }
+
+ ngOnChanges() {
+ if (this.target && (this.type || this.id)) this.fetch();
+ }
+
+
+ fetch() {
+ let include = 'groups.fields.value,groups.fields.options';
+ this.formsService.get(this.target, this.type, this.id, {include: include}).subscribe(res => {
+ this.form = res.data || res;
+ });
+ }
+
+
+}
diff --git a/src/app/_modules/objects/form/slider/slider-form.component.html b/src/app/_modules/objects/form/slider/slider-form.component.html
new file mode 100644
index 0000000..4ae9acb
--- /dev/null
+++ b/src/app/_modules/objects/form/slider/slider-form.component.html
@@ -0,0 +1,29 @@
+
+
diff --git a/src/app/_modules/objects/form/slider/slider-form.component.scss b/src/app/_modules/objects/form/slider/slider-form.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/objects/form/slider/slider-form.component.ts b/src/app/_modules/objects/form/slider/slider-form.component.ts
new file mode 100644
index 0000000..e0f322c
--- /dev/null
+++ b/src/app/_modules/objects/form/slider/slider-form.component.ts
@@ -0,0 +1,148 @@
+import {Component} from '@angular/core';
+import {ActivatedRoute, Router} from "@angular/router";
+import {FormControl, FormGroup} from "@angular/forms";
+import {FormsService, ListsService} from "@app/_services";
+import {WindowScrollingService} from "@app/_services/window-scrolling.service";
+
+@Component({
+ templateUrl: 'slider-form.component.html',
+ styleUrls: ['slider-form.component.scss']
+})
+export class SliderFormComponent {
+ public formGroup: FormGroup;
+ public target: string;
+ public type: string;
+ public id: string;
+ public readonly = false;
+ public formParams: any = {};
+
+ public list: string;
+
+ public title = '';
+ public btnSaveHidden = true;
+ public btnSaveLabel = '';
+ public noticeVisible = false;
+ public frames = [];
+
+ constructor(
+ private router: Router,
+ private route: ActivatedRoute,
+ private formsService: FormsService,
+ private listsService: ListsService,
+ private windowScrollingService: WindowScrollingService
+ ) {
+ }
+
+ get activeFrame() {
+ return this.frames[this.activeFrameIndex];
+ }
+ get activeFrameIndex() {
+ for(let i = 0; i <= this.frames.length; i++) {
+ if (this.frames[i]?.active) return i;
+ }
+ }
+ get isFirstFrame() {
+ return this.activeFrameIndex === 0;
+ }
+ get isLastFrame() {
+ return this.activeFrameIndex >= this.frames.length - 1;
+ }
+
+
+ ngOnInit() {
+ this.parseUrlParams(this.route.snapshot.params);
+ this.initFormGroup(JSON.parse(this.route.snapshot.queryParamMap.get('extraProps')));
+ this.formParams = JSON.parse(this.route.snapshot.queryParamMap.get('formParams')) || {};
+ this.fetch();
+ this.windowScrollingService.disable();
+ }
+
+ fetch() {
+ let params = {include: 'groups.fields.value,groups.fields.options,value,options', extraProps: JSON.stringify(this.formGroup.value)};
+ this.formsService.get(this.target, this.type, this.id, params).subscribe(res => {
+ this.title = res.title || res.data?.title || res.data?.typeTitle;
+ this.btnSaveHidden = res.btnSaveHidden;
+ this.btnSaveLabel = res.btnSaveLabel || 'Сохранить';
+ this.frames = res.frames || [res.data || res];
+ this.frames[0].active = true;
+ setTimeout(() => this.noticeVisible = !!Object.keys(this.formGroup.controls).length);
+ });
+ }
+
+ parseUrlParams(params) {
+ this.target = params.target;
+ this.type = params.type;
+ this.id = params.id;
+ this.list = params.list;
+ }
+
+ initFormGroup(props) {
+ this.formGroup = new FormGroup({});
+ for (let prop in props) {
+ if (props.hasOwnProperty(prop)) this.formGroup.addControl(prop, new FormControl(props[prop]));
+ }
+ }
+
+
+
+ activateNextFrame() {
+ this.activateFrame(this.activeFrameIndex + 1);
+ }
+ activatePreviousFrame() {
+ this.removeUnfilledControls();
+ this.activateFrame(this.activeFrameIndex - 1);
+ }
+ activateFrame(index) {
+ this.frames = this.frames.map((frame, i) => {
+ frame.active = i === index;
+ return frame;
+ });
+ }
+
+ removeUnfilledControls() {
+ this.activeFrame.groups?.data.forEach(group => {
+ group.fields?.data.forEach(field => {
+ let val = this.formGroup.controls[field.name]?.value;
+ if (field.required && !(Array.isArray(val) ? val.length : val)) this.formGroup.removeControl(field.name);
+ });
+ });
+ }
+
+
+
+ proceed() {
+ this.formGroup.markAllAsTouched();
+ if (this.formGroup.valid) {
+ this.isLastFrame ? this.save() : this.activateNextFrame();
+ }
+ }
+
+ back() {
+ this.isFirstFrame ? this.close() : this.activatePreviousFrame();
+ }
+
+ save() {
+ this.formGroup.markAllAsTouched();
+ if (this.formGroup.valid) {
+ this.formsService.save(this.target, this.type, this.id, this.formGroup.value).subscribe(res => {
+ if (res?.asset) {
+ window.open(res.asset.data.links[res.action || 'download'], "_blank");
+ } else {
+ this.listsService.refresh(this.list);
+ this.close();
+ }
+ }, error => {
+ console.log(error);
+ //for (let prop in error) {
+ // if (error.hasOwnProperty(prop)) this.formGroup.controls[prop].setErrors(error);
+ //}
+ //this.formGroup.controls[error.field].setErrors(error.message);
+ });
+ }
+ }
+
+ close() {
+ this.windowScrollingService.enable();
+ this.router.navigate([{outlets: {slider: null}}]).then();
+ }
+}
diff --git a/src/app/_modules/objects/objects.module.ts b/src/app/_modules/objects/objects.module.ts
new file mode 100644
index 0000000..81f64f9
--- /dev/null
+++ b/src/app/_modules/objects/objects.module.ts
@@ -0,0 +1,45 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {ObjectFormComponent} from "@app/_modules/objects/form/object-form.component";
+import {ObjectFormGroupComponent} from "@app/_modules/objects/form/group/object-form-group.component";
+import {FormFieldsModule} from "@app/_modules/form-fields/form-fields.module";
+import {ObjectFiltersComponent} from "@app/_modules/objects/filters/object-filters.component";
+import {ObjectFiltersGroupComponent} from "@app/_modules/objects/filters/group/object-filters-group.component";
+import {FilterFieldsModule} from "@app/_modules/filter-fields/filter-fields.module";
+import {RouterModule, Routes} from "@angular/router";
+import {AuthGuard} from "@app/_helpers";
+import {SliderFormComponent} from "@app/_modules/objects/form/slider/slider-form.component";
+import {SliderFiltersComponent} from "@app/_modules/objects/filters/slider/slider-filters.component";
+import {FormFrameComponent} from "@app/_modules/objects/form/frame/form-frame.component";
+
+const routes: Routes = [
+ {path: 'form/:target/:type', component: SliderFormComponent, outlet: 'slider', canActivate: [AuthGuard]},
+ {path: 'form/:target/:type/:id', component: SliderFormComponent, outlet: 'slider', canActivate: [AuthGuard]},
+ {path: 'form/:target/:type/:id/:list', component: SliderFormComponent, outlet: 'slider', canActivate: [AuthGuard]},
+ {path: 'filters/:target/:type', component: SliderFiltersComponent, outlet: 'slider'},
+ {path: 'filters/:target/:type/:list', component: SliderFiltersComponent, outlet: 'slider'}
+]
+
+@NgModule({
+ imports: [
+ CommonModule,
+ RouterModule.forChild(routes),
+ FormFieldsModule,
+ FilterFieldsModule
+ ],
+ declarations: [
+ ObjectFormComponent,
+ ObjectFormGroupComponent,
+ ObjectFiltersComponent,
+ ObjectFiltersGroupComponent,
+ SliderFormComponent,
+ SliderFiltersComponent,
+ FormFrameComponent
+ ],
+ exports: [
+ ObjectFormComponent,
+ ObjectFiltersComponent,
+ ObjectFormGroupComponent
+ ]
+})
+export class ObjectsModule {}
diff --git a/src/app/_modules/pages/home/cards/homepage-cards.component.html b/src/app/_modules/pages/home/cards/homepage-cards.component.html
new file mode 100644
index 0000000..f125e91
--- /dev/null
+++ b/src/app/_modules/pages/home/cards/homepage-cards.component.html
@@ -0,0 +1,7 @@
+
diff --git a/src/app/_modules/pages/home/cards/homepage-cards.component.scss b/src/app/_modules/pages/home/cards/homepage-cards.component.scss
new file mode 100644
index 0000000..dc83e6c
--- /dev/null
+++ b/src/app/_modules/pages/home/cards/homepage-cards.component.scss
@@ -0,0 +1,39 @@
+.items {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ justify-content: space-between;
+ gap: 16px;
+ flex-wrap: wrap;
+ a {
+ width: 216px;
+ height: 184px;
+ padding: 96px 24px 28px;
+ font-weight: 700;
+ text-align: center;
+ color: #252E34;
+ box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.25);
+ background: transparent none 50% 32px no-repeat;
+ transition: transform 0.3s;
+
+ &:first-child {background-image: url('~src/assets/images/normativ.svg');}
+ &:nth-child(2) {background-image: url('~src/assets/images/tehnicheskie.svg');}
+ &:nth-child(3) {background-image: url('~src/assets/images/tk465.svg');}
+ &:nth-child(4) {background-image: url('~src/assets/images/tu.svg');}
+ &:last-child {background-image: url('~src/assets/images/ksi.svg');}
+
+ &:hover {
+ transform: scale(1.1);
+ }
+ }
+}
+@media screen and (max-width: 526px) {
+ .items {
+ justify-content: center;
+ width: 100% !important;
+ a {
+
+ width: 100% !important;
+ }
+ }
+}
diff --git a/src/app/_modules/pages/home/cards/homepage-cards.component.ts b/src/app/_modules/pages/home/cards/homepage-cards.component.ts
new file mode 100644
index 0000000..07d2715
--- /dev/null
+++ b/src/app/_modules/pages/home/cards/homepage-cards.component.ts
@@ -0,0 +1,15 @@
+import {Component} from '@angular/core';
+
+@Component({
+ selector: 'homepage-cards',
+ templateUrl: 'homepage-cards.component.html',
+ styleUrls: ['homepage-cards.component.scss']
+})
+export class HomepageCardsComponent {
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+}
diff --git a/src/app/_modules/pages/home/homepage.component.html b/src/app/_modules/pages/home/homepage.component.html
new file mode 100644
index 0000000..6a92a1f
--- /dev/null
+++ b/src/app/_modules/pages/home/homepage.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/pages/home/homepage.component.scss b/src/app/_modules/pages/home/homepage.component.scss
new file mode 100644
index 0000000..df807b0
--- /dev/null
+++ b/src/app/_modules/pages/home/homepage.component.scss
@@ -0,0 +1,4 @@
+.section {
+ display: block;
+ margin-bottom: 80px;
+}
diff --git a/src/app/_modules/pages/home/homepage.component.ts b/src/app/_modules/pages/home/homepage.component.ts
new file mode 100644
index 0000000..54175d5
--- /dev/null
+++ b/src/app/_modules/pages/home/homepage.component.ts
@@ -0,0 +1,44 @@
+import {Component} from '@angular/core';
+import {Router} from "@angular/router";
+
+import {PublicationsService} from "@app/_services/publications.service";
+
+
+@Component({
+ templateUrl: 'homepage.component.html',
+ styleUrls: ['homepage.component.scss']
+})
+export class HomepageComponent {
+ public news: any[] = [];
+ public portfolio: any[] = [];
+
+ constructor(
+ private publicationsService: PublicationsService,
+ private router: Router,
+ ) {
+ }
+
+ ngOnInit() {
+ this.load();
+ }
+ ngOnDestroy() {
+ }
+
+ load() {
+ // this.fetchNews();
+ // this.fetchPortfolio();
+ }
+ fetchNews() {
+ this.publicationsService.list({subType: 'publication-news'}).subscribe(result => {
+ this.news = result.data;
+ });
+ }
+ seeNews(slug3: string) {
+ this.router.navigate(['press-tsentr', 'novosti', slug3]);
+ }
+ fetchPortfolio() {
+ this.publicationsService.list({subType: 'publication-portfolio', pageLimit: 5}).subscribe(result => {
+ this.portfolio = result.data;
+ });
+ }
+}
diff --git a/src/app/_modules/pages/home/homepage.module.ts b/src/app/_modules/pages/home/homepage.module.ts
new file mode 100644
index 0000000..626fa34
--- /dev/null
+++ b/src/app/_modules/pages/home/homepage.module.ts
@@ -0,0 +1,34 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {HomepageComponent} from "@app/_modules/pages/home/homepage.component";
+import {HomepageIntroComponent} from "@app/_modules/pages/home/intro/homepage-intro.component";
+import {ParticlesDirective} from "@app/_directives/particles.directive";
+import {HomepagePromoComponent} from "@app/_modules/pages/home/intro/promo/homepage-promo.component";
+import {HomepageCardsComponent} from "@app/_modules/pages/home/cards/homepage-cards.component";
+import {RouterModule} from "@angular/router";
+import {HomepagePortfolioComponent} from "@app/_modules/pages/home/portfolio/homepage-portfolio.component";
+import {HomepageNewsComponent} from "@app/_modules/pages/home/news/homepage-news.component";
+import {HomepagePartnersComponent} from "@app/_modules/pages/home/partners/homepage-partners.component";
+import {SwiperModule} from "swiper/angular";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ RouterModule,
+ SwiperModule
+ ],
+ declarations: [
+ HomepageComponent,
+ HomepageIntroComponent,
+ ParticlesDirective,
+ HomepagePromoComponent,
+ HomepageCardsComponent,
+ HomepagePortfolioComponent,
+ HomepageNewsComponent,
+ HomepagePartnersComponent
+ ],
+ exports: [
+ HomepageComponent
+ ]
+})
+export class HomepageModule {}
diff --git a/src/app/_modules/pages/home/intro/homepage-intro.component.html b/src/app/_modules/pages/home/intro/homepage-intro.component.html
new file mode 100644
index 0000000..8a98060
--- /dev/null
+++ b/src/app/_modules/pages/home/intro/homepage-intro.component.html
@@ -0,0 +1,9 @@
+
+
+
+
+
развиваемнормысоздаембудущее
+
+
+
+
diff --git a/src/app/_modules/pages/home/intro/homepage-intro.component.scss b/src/app/_modules/pages/home/intro/homepage-intro.component.scss
new file mode 100644
index 0000000..469d06e
--- /dev/null
+++ b/src/app/_modules/pages/home/intro/homepage-intro.component.scss
@@ -0,0 +1,71 @@
+.fullwidth {
+ display: flex;
+ position: relative;
+ background-color: #86898E;
+}
+
+.particles {
+ position: absolute;
+ left: 0;
+ top: 0;
+ width: 100%;
+ height: 100%;
+}
+
+.row {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ justify-content: space-between;
+ width: 100%;
+ padding-bottom: 40px;
+ overflow: hidden;
+ .tagline {
+ b {
+ display: block;
+ color: var(--white);
+ text-transform: uppercase;
+ font-size: 64px;
+ font-weight: 700;
+ line-height: 96px;
+ font-variant-numeric: lining-nums tabular-nums;
+ -webkit-text-stroke: 2px white;
+ &:first-child {color: transparent;}
+ &:nth-child(2) {font-size: 100px; color: transparent;}
+ &:nth-child(3) {font-size: 78px;}
+ &:nth-child(4) {font-size: 78px;}
+ }
+ }
+ .promo {
+ width: 500px;
+ height: 500px;
+ }
+}
+@media screen and (max-width: 960px) {
+ .row {
+ flex-direction: column;
+ .tagline {
+ text-align: center;
+ }
+ }
+}
+@media screen and (max-width: 512px) {
+ .row {
+ .tagline {
+ b {
+ &:first-child,
+ &:nth-child(2),
+ &:nth-child(3),
+ &:nth-child(4) {
+ font-size: 40px;
+ line-height: 110%;
+ }
+ }
+ }
+ .promo {
+ width: 240px;
+ height: 240px;
+ }
+ }
+}
+
diff --git a/src/app/_modules/pages/home/intro/homepage-intro.component.ts b/src/app/_modules/pages/home/intro/homepage-intro.component.ts
new file mode 100644
index 0000000..6973be3
--- /dev/null
+++ b/src/app/_modules/pages/home/intro/homepage-intro.component.ts
@@ -0,0 +1,15 @@
+import {Component} from '@angular/core';
+
+@Component({
+ selector: 'homepage-intro',
+ templateUrl: 'homepage-intro.component.html',
+ styleUrls: ['homepage-intro.component.scss']
+})
+export class HomepageIntroComponent {
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+}
diff --git a/src/app/_modules/pages/home/intro/promo/homepage-promo.component.html b/src/app/_modules/pages/home/intro/promo/homepage-promo.component.html
new file mode 100644
index 0000000..67c782e
--- /dev/null
+++ b/src/app/_modules/pages/home/intro/promo/homepage-promo.component.html
@@ -0,0 +1,1444 @@
+
diff --git a/src/app/_modules/pages/home/intro/promo/homepage-promo.component.scss b/src/app/_modules/pages/home/intro/promo/homepage-promo.component.scss
new file mode 100644
index 0000000..32a08bc
--- /dev/null
+++ b/src/app/_modules/pages/home/intro/promo/homepage-promo.component.scss
@@ -0,0 +1,64 @@
+.promo-svg {
+ width: 100%;
+ height: 100%;
+ transform: scale(1.8);
+}
+.promo-svg #MAP {
+ animation: slide-bottom 2s ease-in-out forwards;
+}
+
+.promo-svg #MAP .cls-2 {
+ stroke: var(--primary);
+}
+
+@keyframes slide-bottom {
+ 0% {
+ opacity: 0;
+ transform: translateY(-40px);
+ }
+ 33% {
+ opacity: 1;
+ transform: translateY(20px);
+ }
+ 66% {
+ transform: translateY(-10px);
+ }
+ 100% {
+ transform: translateY(0px);
+ }
+}
+.promo-svg #CITY .cls-4 {
+ stroke-dasharray: 1000;
+ stroke-dashoffset: 1000;
+ animation: dash-1 2s linear forwards;
+ animation-delay: 2s;
+}
+
+@keyframes dash-1 {
+ 0% {
+ stroke-dashoffset: 1000;
+ }
+ 75% {
+ stroke-dashoffset: 500;
+ }
+ 100% {
+ stroke-dashoffset: 0;
+ }
+}
+
+
+.promo-svg #CITY *:not(.cls-4),
+.promo-svg image {
+ animation: opacity-1 .1s linear forwards;
+ animation-delay: 4.5s;
+ opacity: 0;
+}
+
+@keyframes opacity-1 {
+ 0% {
+ opacity: 0;
+ }
+ 100% {
+ opacity: 1;
+ }
+}
diff --git a/src/app/_modules/pages/home/intro/promo/homepage-promo.component.ts b/src/app/_modules/pages/home/intro/promo/homepage-promo.component.ts
new file mode 100644
index 0000000..bbabab1
--- /dev/null
+++ b/src/app/_modules/pages/home/intro/promo/homepage-promo.component.ts
@@ -0,0 +1,15 @@
+import {Component} from '@angular/core';
+
+@Component({
+ selector: 'homepage-promo',
+ templateUrl: 'homepage-promo.component.html',
+ styleUrls: ['homepage-promo.component.scss']
+})
+export class HomepagePromoComponent {
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+}
diff --git a/src/app/_modules/pages/home/news/homepage-news.component.html b/src/app/_modules/pages/home/news/homepage-news.component.html
new file mode 100644
index 0000000..ee51a5c
--- /dev/null
+++ b/src/app/_modules/pages/home/news/homepage-news.component.html
@@ -0,0 +1,23 @@
+Новости
+
+
diff --git a/src/app/_modules/pages/home/news/homepage-news.component.scss b/src/app/_modules/pages/home/news/homepage-news.component.scss
new file mode 100644
index 0000000..39095b5
--- /dev/null
+++ b/src/app/_modules/pages/home/news/homepage-news.component.scss
@@ -0,0 +1,106 @@
+h2 {
+ margin: 0 0 24px;
+ font-weight: 500;
+ font-size: 2.5rem;
+}
+
+.swiper-slide {
+ width: 50% !important;
+}
+
+.holder {
+ .slide {
+ position: relative;
+ width: 100%;
+ height: 280px;
+
+ a {
+ display: flex;
+ flex-direction: column;
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ padding: 20px;
+ background-color: rgba(62,61,64,0.5);
+ color: #ffffff;
+ font-weight: bold;
+ .date {
+ font-size: 14px;
+ }
+ .excerpt {
+ margin-top: auto;
+ font-size: 20px;
+ }
+ }
+
+ img {
+ display: block;
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+ }
+
+ .navigation {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ justify-content: space-between;
+ padding-top: 36px;
+
+ .btn.icon {
+ width: 48px;
+ height: 48px;
+ background-image: url('~src/assets/images/icons/chevron_left_48.svg');
+ &.prev {}
+ &.next {transform: rotateZ(180deg);}
+ }
+
+ .bullets {
+ text-align: center;
+ ::ng-deep .swiper-pagination-bullet {
+ width: 16px;
+ height: 16px;
+ margin: 0 12px;
+ background-color: #C4C4C4;
+ }
+ ::ng-deep .swiper-pagination-bullet-active {
+ background-color: #FFB700;
+ }
+ }
+ }
+}
+
+.more {
+ margin-top: 50px;
+ a {
+ display: inline-block;
+ padding-right: 20px;
+ background: transparent url("~src/assets/images/icons/chevron_right_24dp.svg") 100% 50% no-repeat;
+ border-bottom: 1px solid white;
+ &:hover {
+ border-bottom-color: var(--grey-3);
+ }
+ }
+}
+
+
+
+
+.swiper-container {
+ width: 100%;
+}
+
+@media screen and (min-width: 640px) {
+ .swiper-container {
+ width: 640px;
+ }
+}
+
+@media screen and (min-width: 768px) {
+ .swiper-container {
+ width: 768px;
+ }
+}
diff --git a/src/app/_modules/pages/home/news/homepage-news.component.ts b/src/app/_modules/pages/home/news/homepage-news.component.ts
new file mode 100644
index 0000000..08f178b
--- /dev/null
+++ b/src/app/_modules/pages/home/news/homepage-news.component.ts
@@ -0,0 +1,47 @@
+import {Component} from '@angular/core';
+import SwiperCore, {Navigation, Pagination, SwiperOptions} from 'swiper';
+SwiperCore.use([Navigation, Pagination]);
+import {PublicationsService} from "@app/_services/publications.service";
+
+@Component({
+ selector: 'homepage-news',
+ templateUrl: 'homepage-news.component.html',
+ styleUrls: ['homepage-news.component.scss']
+})
+export class HomepageNewsComponent {
+ public config: SwiperOptions | any = {
+ lazy: true,
+ spaceBetween: 40,
+ slidesPerView: 1,
+ pagination: {
+ el: 'homepage-news .bullets',
+ clickable: true
+ },
+ navigation: {
+ prevEl: 'homepage-news .btn.prev',
+ nextEl: 'homepage-news .btn.next'
+ },
+ breakpoints: {
+ 960: {
+ slidesPerView: 2
+ },
+ }
+ };
+
+ public items: any[] = [];
+
+ constructor(
+ private publicationsService: PublicationsService,
+ ) {
+ }
+
+ ngOnInit() {
+ this.fetch();
+ }
+
+ fetch() {
+ this.publicationsService.list({type: 'news', limit: 5}).subscribe(result => {
+ this.items = result.data;
+ });
+ }
+}
diff --git a/src/app/_modules/pages/home/partners/homepage-partners.component.html b/src/app/_modules/pages/home/partners/homepage-partners.component.html
new file mode 100644
index 0000000..5995afa
--- /dev/null
+++ b/src/app/_modules/pages/home/partners/homepage-partners.component.html
@@ -0,0 +1,22 @@
+
+
+

+
Минстрой России
+
+
+

+
Росстандарт
+
+
+

+
Главгосэкспертиза
+
+
+

+
ISO
+
+
+

+
ЕАЭС
+
+
diff --git a/src/app/_modules/pages/home/partners/homepage-partners.component.scss b/src/app/_modules/pages/home/partners/homepage-partners.component.scss
new file mode 100644
index 0000000..18cba29
--- /dev/null
+++ b/src/app/_modules/pages/home/partners/homepage-partners.component.scss
@@ -0,0 +1,15 @@
+.items {
+ display: flex;
+ justify-content: space-between;
+ column-gap: 40px;
+ flex-wrap: wrap;
+
+ .item {
+ text-align: center;
+ p {
+ font-weight: 400;
+ font-size: 1.125rem;
+ line-height: 22px;
+ }
+ }
+}
diff --git a/src/app/_modules/pages/home/partners/homepage-partners.component.ts b/src/app/_modules/pages/home/partners/homepage-partners.component.ts
new file mode 100644
index 0000000..d99b018
--- /dev/null
+++ b/src/app/_modules/pages/home/partners/homepage-partners.component.ts
@@ -0,0 +1,15 @@
+import {Component} from '@angular/core';
+
+@Component({
+ selector: 'homepage-partners',
+ templateUrl: 'homepage-partners.component.html',
+ styleUrls: ['homepage-partners.component.scss']
+})
+export class HomepagePartnersComponent {
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+
+}
diff --git a/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.html b/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.html
new file mode 100644
index 0000000..38e9033
--- /dev/null
+++ b/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.html
@@ -0,0 +1,22 @@
+
+
+
+
+
Портфолио
+
+
+
+
+
+
diff --git a/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.scss b/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.scss
new file mode 100644
index 0000000..9097693
--- /dev/null
+++ b/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.scss
@@ -0,0 +1,102 @@
+.swiper {
+ width: 100%;
+ height: 100%;
+}
+
+.slide {
+ width: 100%;
+ height: 100%;
+ text-align: center;
+ font-size: 18px;
+ background: #fff;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+
+ a {
+ display: block;
+ width: 100%;
+ height: 100%;
+ }
+
+ img {
+ display: block;
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+}
+
+.bullets {
+ padding-top: 36px;
+ text-align: center;
+
+ ::ng-deep .swiper-pagination-bullet {
+ width: 16px;
+ height: 16px;
+ margin: 0 6px;
+ background-color: #C4C4C4;
+ }
+
+ ::ng-deep .swiper-pagination-bullet-active {
+ background-color: #FFB700;
+ }
+}
+
+
+.fullwidth {
+ padding: 100px 80px;
+ background: #86898E url("~src/assets/images/portfolio_bg.png") no-repeat 0 100%;
+
+ .row {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ justify-content: space-between;
+ flex-wrap: wrap;
+ gap: 32px;
+
+ .left {
+ flex-grow: 1;
+
+ h2 {
+ margin: 0 0 32px;
+ font-size: 60px;
+ font-weight: 800;
+ color: #ffffff;
+ }
+ }
+
+ .right {
+ .holder {
+ width: 520px;
+ height: 350px;
+ background-color: #f7f7f7;
+ box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.25);
+ }
+ }
+ }
+}
+
+@media screen and (max-width: 768px) {
+ .fullwidth {
+ padding: 40px 0 80px;
+ .limiter {
+ .row {
+ width: 100%;
+ .left {
+ h2 {
+ font-size: 48px;
+ line-height: 100%;
+ }
+ }
+ .right {
+ width: 100%;
+ .holder {
+ width: 100%;
+ }
+ }
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.ts b/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.ts
new file mode 100644
index 0000000..8203f34
--- /dev/null
+++ b/src/app/_modules/pages/home/portfolio/homepage-portfolio.component.ts
@@ -0,0 +1,35 @@
+import {Component} from '@angular/core';
+import SwiperCore, {Pagination, Autoplay, SwiperOptions} from 'swiper';
+SwiperCore.use([Pagination, Autoplay]);
+import {PublicationsService} from "@app/_services/publications.service";
+
+@Component({
+ selector: 'homepage-portfolio',
+ templateUrl: 'homepage-portfolio.component.html',
+ styleUrls: ['homepage-portfolio.component.scss'],
+})
+export class HomepagePortfolioComponent {
+ public config: SwiperOptions = {
+ lazy: true,
+ slidesPerView: 1,
+ spaceBetween: 0,
+ pagination: {el: 'homepage-portfolio .bullets', clickable: true},
+ };
+
+ public items: any[] = [];
+
+ constructor(
+ private publicationsService: PublicationsService,
+ ) {
+ }
+
+ ngOnInit() {
+ this.fetch();
+ }
+
+ fetch() {
+ this.publicationsService.list({type: 'portfolio', limit: 5}).subscribe(result => {
+ this.items = result.data;
+ });
+ }
+}
diff --git a/src/app/_modules/pages/list/item/pages-list-item.component.html b/src/app/_modules/pages/list/item/pages-list-item.component.html
new file mode 100644
index 0000000..7a8c582
--- /dev/null
+++ b/src/app/_modules/pages/list/item/pages-list-item.component.html
@@ -0,0 +1 @@
+{{page.name}}
diff --git a/src/app/_modules/pages/list/item/pages-list-item.component.scss b/src/app/_modules/pages/list/item/pages-list-item.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/pages/list/item/pages-list-item.component.ts b/src/app/_modules/pages/list/item/pages-list-item.component.ts
new file mode 100644
index 0000000..2de5dba
--- /dev/null
+++ b/src/app/_modules/pages/list/item/pages-list-item.component.ts
@@ -0,0 +1,17 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'pages-list-item',
+ templateUrl: 'pages-list-item.component.html',
+ styleUrls: ['pages-list-item.component.scss']
+})
+export class PagesListItemComponent {
+ @Input() page: any;
+
+ constructor(
+ ) {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/pages/list/pages-list.component.html b/src/app/_modules/pages/list/pages-list.component.html
new file mode 100644
index 0000000..95e02b4
--- /dev/null
+++ b/src/app/_modules/pages/list/pages-list.component.html
@@ -0,0 +1,6 @@
+
+
+
+
diff --git a/src/app/_modules/pages/list/pages-list.component.scss b/src/app/_modules/pages/list/pages-list.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/pages/list/pages-list.component.ts b/src/app/_modules/pages/list/pages-list.component.ts
new file mode 100644
index 0000000..0e81330
--- /dev/null
+++ b/src/app/_modules/pages/list/pages-list.component.ts
@@ -0,0 +1,46 @@
+import {Component} from '@angular/core';
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+import {PagesService} from "@app/_services/pages.service";
+
+@Component({
+ selector: 'pages-list',
+ templateUrl: 'pages-list.component.html',
+ styleUrls: ['pages-list.component.scss']
+})
+export class PagesListComponent {
+ controlsSubscription?: Subscription;
+ resultsSubscription?: Subscription;
+
+ public pages: any;
+
+ constructor(private pagesService: PagesService, private listsService: ListsService) {
+ }
+
+ get listId() {
+ return 'pages-list';
+ }
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls(this.listId).subscribe(controls => {
+ this.fetch(controls);
+ });
+ this.resultsSubscription = this.listsService.result(this.listId).subscribe(val => {
+ this.pages = val.data;
+ });
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ this.resultsSubscription?.unsubscribe();
+ }
+
+
+
+ fetch(controls) {
+ let params = {page: controls.page || 0, filters: JSON.stringify(controls.filters)};
+ this.pagesService.list(params).subscribe(result => {
+ this.listsService.result(this.listId).next(result);
+ })
+ }
+}
diff --git a/src/app/_modules/pages/menu/item/pages-menu-item.component.html b/src/app/_modules/pages/menu/item/pages-menu-item.component.html
new file mode 100644
index 0000000..9d6ea55
--- /dev/null
+++ b/src/app/_modules/pages/menu/item/pages-menu-item.component.html
@@ -0,0 +1,7 @@
+
+
+{{item.name}}
+
+
diff --git a/src/app/_modules/pages/menu/item/pages-menu-item.component.scss b/src/app/_modules/pages/menu/item/pages-menu-item.component.scss
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/src/app/_modules/pages/menu/item/pages-menu-item.component.scss
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/pages/menu/item/pages-menu-item.component.ts b/src/app/_modules/pages/menu/item/pages-menu-item.component.ts
new file mode 100644
index 0000000..07b146d
--- /dev/null
+++ b/src/app/_modules/pages/menu/item/pages-menu-item.component.ts
@@ -0,0 +1,36 @@
+import {Component, EventEmitter, Input, Output} from '@angular/core';
+import { Router} from '@angular/router';
+import {Subscription} from 'rxjs';
+
+@Component({
+ selector: 'pages-menu-item',
+ templateUrl: 'pages-menu-item.component.html',
+ styleUrls: ['pages-menu-item.component.scss', '../pages-menu.component.scss']
+})
+export class PagesMenuItemComponent {
+ @Input() item: any;
+ @Output() onSelected = new EventEmitter();
+ showChildren = false;
+
+ currentURL:string;
+ constructor(private router: Router) {
+ router.events.subscribe((event:any)=>{
+ if(event.url)this.currentURL = event.url
+ })
+ this.currentURL = router.url
+ }
+
+
+ get children() {
+ return this.item?.children?.data;
+ }
+
+ ngOnInit() {
+
+ }
+
+ select(item:any){
+ this.onSelected.emit(item);
+ }
+
+}
diff --git a/src/app/_modules/pages/menu/pages-menu.component.html b/src/app/_modules/pages/menu/pages-menu.component.html
new file mode 100644
index 0000000..c63bd18
--- /dev/null
+++ b/src/app/_modules/pages/menu/pages-menu.component.html
@@ -0,0 +1,2 @@
+
diff --git a/src/app/_modules/pages/menu/pages-menu.component.scss b/src/app/_modules/pages/menu/pages-menu.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/pages/menu/pages-menu.component.ts b/src/app/_modules/pages/menu/pages-menu.component.ts
new file mode 100644
index 0000000..4300487
--- /dev/null
+++ b/src/app/_modules/pages/menu/pages-menu.component.ts
@@ -0,0 +1,33 @@
+import {Component, EventEmitter, Input, Output} from '@angular/core';
+
+@Component({
+ selector: 'pages-menu',
+ templateUrl: 'pages-menu.component.html',
+ styleUrls: ['pages-menu.component.scss']
+})
+export class PagesMenuComponent {
+ @Input() items = [];
+ @Output() onSelected = new EventEmitter();
+ public hidden = false;
+
+ private hiddenPages = ['/o-tsentre/protivodeistvie-korruptsii', '/o-tsentre/zashchita-personalnykh-dannykh', '/o-tsentre/okhrana-truda'];
+
+
+
+ get visibleItems() {
+ return this.items.filter(item => {
+ return this.hiddenPages.indexOf(item.link) === -1;
+ });
+ }
+
+
+ close() {
+ this.hidden = true;
+ setTimeout(() => {this.hidden = false;}, 1);
+ }
+
+ itemSelect(event:any){
+ this.onSelected.emit(event);
+ }
+
+}
diff --git a/src/app/_modules/pages/not-found/page-not-found.component.html b/src/app/_modules/pages/not-found/page-not-found.component.html
new file mode 100644
index 0000000..a617c32
--- /dev/null
+++ b/src/app/_modules/pages/not-found/page-not-found.component.html
@@ -0,0 +1 @@
+page not found
diff --git a/src/app/_modules/pages/not-found/page-not-found.component.scss b/src/app/_modules/pages/not-found/page-not-found.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/pages/not-found/page-not-found.component.ts b/src/app/_modules/pages/not-found/page-not-found.component.ts
new file mode 100644
index 0000000..bca6604
--- /dev/null
+++ b/src/app/_modules/pages/not-found/page-not-found.component.ts
@@ -0,0 +1,16 @@
+import {Component} from '@angular/core';
+
+@Component({
+ selector: 'page-not-found',
+ templateUrl: 'page-not-found.component.html',
+ styleUrls: ['page-not-found.component.scss']
+})
+export class PageNotFoundComponent {
+ constructor() {
+ }
+
+ ngOnInit() {
+
+ }
+
+}
diff --git a/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.html b/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.html
new file mode 100644
index 0000000..ce4a5f6
--- /dev/null
+++ b/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.scss b/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.scss
new file mode 100644
index 0000000..44d968d
--- /dev/null
+++ b/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.scss
@@ -0,0 +1,38 @@
+.breadcrumbs {
+ padding: 12px 0;
+ display: flex;
+ flex-wrap: wrap;
+ row-gap: 12px;
+
+ li {
+ padding: 0;
+ display: inline;
+ list-style-type: none;
+ margin-right: 22px;
+ position: relative;
+ color: #86898E;
+ font-weight: 400;
+ font-size: 0.875rem;
+ line-height: 18px;
+ text-wrap: none;
+
+ &::before {
+ display: block;
+ content: "";
+ position: absolute;
+ width: 20px;
+ height: 20px;
+ right: -22px;
+ top: 0;
+ background: url("~src/assets/images/icons/chevron_right_20dp.svg") no-repeat center;
+ }
+ &:last-child {
+ &::before {
+ background: none;
+ }
+ }
+ a {
+ color: var(--grey-7);
+ }
+ }
+}
diff --git a/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.ts b/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.ts
new file mode 100644
index 0000000..caae6c9
--- /dev/null
+++ b/src/app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component.ts
@@ -0,0 +1,22 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'page-breadcrumbs',
+ templateUrl: 'page-breadcrumbs.component.html',
+ styleUrls: ['page-breadcrumbs.component.scss']
+})
+export class pageBreadcrumbsComponent {
+ @Input() page: any;
+
+ constructor() {
+ }
+
+ get parents() {
+ return this.page?.parents?.data;
+ }
+
+ ngOnInit() {
+
+ }
+
+}
diff --git a/src/app/_modules/pages/page/page.component.html b/src/app/_modules/pages/page/page.component.html
new file mode 100644
index 0000000..85a8b33
--- /dev/null
+++ b/src/app/_modules/pages/page/page.component.html
@@ -0,0 +1,21 @@
+
+
+
{{page?.name}}
+
+
+
+
+
+
+
Page type {{page?.type?.name}} is undefined
+
+
+
+
diff --git a/src/app/_modules/pages/page/page.component.scss b/src/app/_modules/pages/page/page.component.scss
new file mode 100644
index 0000000..f0581b3
--- /dev/null
+++ b/src/app/_modules/pages/page/page.component.scss
@@ -0,0 +1,77 @@
+.content {
+ .row {
+ display: flex;
+ flex-direction: row;
+ width: 100%;
+ .left {
+ flex-grow: 1;
+ }
+ .right {
+ margin-left: 32px;
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ flex-shrink: 0;
+ cursor: pointer;
+ .label {
+ margin-right: 8px;
+ font-size: 14px;
+ color: #86898E;
+ }
+ }
+ }
+
+ h1 {
+ font-weight: 700;
+ font-size: 2rem;
+ line-height: 2.5rem;
+ color: var(--grey-7);
+ }
+
+ .holder {
+ margin-bottom: 32px;
+ }
+}
+
+.dual-cols {
+ display: flex;
+ flex-direction: row;
+ width: 100%;
+
+ .col {
+ &.left {
+ flex-grow: 1;
+ }
+
+ &.right {
+ flex-shrink: 0;
+ width: 400px;
+ margin-left: 40px;
+ }
+ }
+}
+
+@media screen and (max-width: 768px) {
+ .content {
+ h1 {
+ font-size: 1.5rem;
+ line-height: 2rem;
+ }
+ .row {
+ flex-direction: column-reverse;
+ //padding-top: 24px;
+ .right {
+ visibility: hidden;
+ }
+ }
+ }
+ .dual-cols {
+ flex-direction: column;
+ .col {
+ &.right {
+ width: 100%;
+ margin-left: 0 !important;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/pages/page/page.component.ts b/src/app/_modules/pages/page/page.component.ts
new file mode 100644
index 0000000..0abbcf1
--- /dev/null
+++ b/src/app/_modules/pages/page/page.component.ts
@@ -0,0 +1,73 @@
+import {Component} from '@angular/core';
+import {NavigationEnd, Router} from "@angular/router";
+import {Subscription} from "rxjs";
+import {PagesService} from "@app/_services/pages.service";
+import {ListsService} from "@app/_services";
+
+@Component({
+ templateUrl: 'page.component.html',
+ styleUrls: ['page.component.scss']
+})
+export class PageComponent {
+ public page: any;
+ public editMode = false;
+ public loading = false;
+ private url: string;
+ private inited = false;
+ routeSubscription?: Subscription;
+
+ constructor(private router: Router, private pagesService: PagesService, private listsService: ListsService) {
+ this.routeSubscription = this.router.events.subscribe(event => {
+ if (event instanceof NavigationEnd) this.onNavigationEnd(event);
+ });
+ }
+
+
+ get permissions() {
+ return this.page?.permissions;
+ }
+ get isEditable() {
+ return this.permissions?.edit || this.permissions?.anything;
+ }
+
+
+
+ ngOnInit() {
+ this.listsService.controls().subscribe(res => {
+ this.inited ? this.fetch() : this.inited = true;
+ });
+ }
+
+ ngOnDestroy() {
+ this.routeSubscription?.unsubscribe();
+ }
+
+
+ onNavigationEnd(event: NavigationEnd) {
+ let url = event.url.split('(')[0];
+ url = url.split('?')[0];
+ if (url !== this.url) {
+ this.url = url;
+ this.fetch();
+ this.editMode = false;
+ }
+ }
+
+ fetch() {
+ this.loading = true;
+ let include = ['parents', 'sections.type', 'sections.groups.fields.value', 'sidebars.groups.fields.value', 'sidebars.type', 'permissions'];
+ this.pagesService.find(this.url, {include: include.join(',')}).subscribe(res => {
+ this.page = res?.data;
+ this.loading = false;
+ }, error => {
+ console.log(error);
+ this.loading = false;
+ });
+ }
+
+
+ toggleEditMode() {
+ this.editMode = !this.editMode;
+ }
+
+}
diff --git a/src/app/_modules/pages/page/types/content/content-page.component.html b/src/app/_modules/pages/page/types/content/content-page.component.html
new file mode 100644
index 0000000..1fe6646
--- /dev/null
+++ b/src/app/_modules/pages/page/types/content/content-page.component.html
@@ -0,0 +1,8 @@
+
+
+
0 || editMode" class="col right">
+
+
+
diff --git a/src/app/_modules/pages/page/types/content/content-page.component.scss b/src/app/_modules/pages/page/types/content/content-page.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/pages/page/types/content/content-page.component.ts b/src/app/_modules/pages/page/types/content/content-page.component.ts
new file mode 100644
index 0000000..4748538
--- /dev/null
+++ b/src/app/_modules/pages/page/types/content/content-page.component.ts
@@ -0,0 +1,28 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'content-page',
+ templateUrl: 'content-page.component.html',
+ styleUrls: ['../../page.component.scss', 'content-page.component.scss']
+})
+export class ContentPageComponent {
+ @Input() page: any;
+ @Input() editMode = false;
+
+ constructor() {
+ }
+
+ get sections() {
+ return this.page?.sections?.data;
+ }
+
+ get sidebars() {
+ return this.page?.sidebars?.data;
+ }
+
+
+ ngOnInit() {
+ }
+
+
+}
diff --git a/src/app/_modules/pages/page/types/publications/publications-page.component.html b/src/app/_modules/pages/page/types/publications/publications-page.component.html
new file mode 100644
index 0000000..1dae2d0
--- /dev/null
+++ b/src/app/_modules/pages/page/types/publications/publications-page.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/pages/page/types/publications/publications-page.component.scss b/src/app/_modules/pages/page/types/publications/publications-page.component.scss
new file mode 100644
index 0000000..faa452c
--- /dev/null
+++ b/src/app/_modules/pages/page/types/publications/publications-page.component.scss
@@ -0,0 +1,54 @@
+.pagination {
+ display: flex;
+ justify-content: space-between;
+ .left {
+ display: flex;
+ column-gap: 16px;
+ .nav {
+ min-width: 20px;
+ min-height: 20px;
+ border-radius: 10px;
+ font-weight: 700;
+ font-size: 0.875rem;
+ line-height: 18px;
+ border: 1px solid #F9B417;
+ color: #F9B417;
+ text-align: center;
+ padding: 1px 6px;
+ &.active {
+ background: #F9B417;
+ color: #ffffff;
+ }
+ }
+ .points {
+ width: 20px;
+ height: 20px;
+ background: url("~src/assets/images/icons/more_horiz_20dp.svg") center no-repeat;
+ }
+ .next {
+ color: #F9B417;
+ display: inline;
+ list-style-type: none;
+ margin-right: 22px;
+ position: relative;
+ font-weight: 400;
+ font-size: 0.875rem;
+ line-height: 18px;
+ &:before {
+ content: "";
+ position: absolute;
+ width: 20px;
+ height: 20px;
+ right: -22px;
+ top: 0;
+ background: url("~src/assets/images/icons/chevron_right_orange_20dp.svg") no-repeat center;
+ }
+ }
+ }
+ .right {
+ font-weight: 400;
+ font-size: 0.875rem;
+ line-height: 18px;
+ color: var(--grey-7);
+ }
+}
diff --git a/src/app/_modules/pages/page/types/publications/publications-page.component.ts b/src/app/_modules/pages/page/types/publications/publications-page.component.ts
new file mode 100644
index 0000000..645a188
--- /dev/null
+++ b/src/app/_modules/pages/page/types/publications/publications-page.component.ts
@@ -0,0 +1,17 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'publications-page',
+ templateUrl: 'publications-page.component.html',
+ styleUrls: ['publications-page.component.scss'],
+})
+export class PublicationsPageComponent {
+ @Input() page: any;
+ @Input() editMode = false;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/pages/page/types/registry/registry-page.component.html b/src/app/_modules/pages/page/types/registry/registry-page.component.html
new file mode 100644
index 0000000..4a04b7a
--- /dev/null
+++ b/src/app/_modules/pages/page/types/registry/registry-page.component.html
@@ -0,0 +1,2 @@
+
+
diff --git a/src/app/_modules/pages/page/types/registry/registry-page.component.scss b/src/app/_modules/pages/page/types/registry/registry-page.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/pages/page/types/registry/registry-page.component.ts b/src/app/_modules/pages/page/types/registry/registry-page.component.ts
new file mode 100644
index 0000000..ab25765
--- /dev/null
+++ b/src/app/_modules/pages/page/types/registry/registry-page.component.ts
@@ -0,0 +1,38 @@
+import {Component, Input} from '@angular/core';
+import {PagesService} from "@app/_services/pages.service";
+
+@Component({
+ selector: 'registry-page',
+ templateUrl: 'registry-page.component.html',
+ styleUrls: ['../../page.component.scss', 'registry-page.component.scss']
+})
+export class RegistryPageComponent {
+ @Input() page: any;
+ @Input() editMode = false;
+
+ constructor(private pagesService: PagesService) {
+ }
+
+
+ get registry() {
+ return this.page?.registry?.data;
+ }
+
+
+ ngOnInit() {
+
+ }
+
+ ngOnChanges() {
+ this.fetch();
+ }
+
+ fetch() {
+ let include = ['sections.type', 'sections.groups.fields.value', 'registry'];
+ this.pagesService.show(this.page.id, {include: include.join(',')}).subscribe(res => {
+ this.page = res.data;
+ });
+ }
+
+
+}
diff --git a/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.html b/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.html
new file mode 100644
index 0000000..42f1875
--- /dev/null
+++ b/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.html
@@ -0,0 +1,27 @@
+
+Секретариат на базе ФАУ «ФЦС» Направления стандартизации
+
+
+
{{group.title}}
+
+
+
+
+
{{advisory.caption}}
+
+
+
Руководитель: {{advisory.directorName}}
+
Секретарь: {{advisory.secretaryName}}
+
{{advisory.phone}}
+
{{advisory.email}}
+
+ Списочный состав
+
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.scss b/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.scss
new file mode 100644
index 0000000..9d47b97
--- /dev/null
+++ b/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.scss
@@ -0,0 +1,150 @@
+.buttons {
+ margin-bottom: 32px;
+}
+.card {
+ padding: 16px;
+ border: #86898E solid 1px;
+ background-color: #F5F4F4;
+ border-radius: 8px;
+}
+
+.title {
+ position: relative;
+ margin-bottom: 42px;
+ text-align: center;
+ font-size: 1.5rem;
+
+ &:before, &:after, .label {position: absolute; background-color: #86898E; content: '';}
+ &:before {top: 100%; left: 50%; width: 1px; height: 42px;}
+ &:after {bottom: -45px; left: calc(50% - 3px); width: 7px; height: 7px; border-radius: 20px;}
+ .label {bottom: - 32px; left: 0; width: 100%; text-align: center; font-size: 0.875rem; background-color: #ffffff;}
+}
+
+.columns {
+ display: flex;
+ flex-direction: row;
+ gap: 8px;
+ padding-top: 27px;
+ .column {
+ position: relative;
+ width: 25%;
+ flex-shrink: 1;
+ .head {
+ display: flex;
+ height: 112px;
+ justify-content: center;
+ align-items: center;
+ font-weight: 700;
+ }
+
+ &:before, &:after, .head:before, .head:after {
+ position: absolute;
+ background-color: #86898E;
+ content: '';
+ }
+
+ &:before {bottom: 100%; left: 50%; width: 1px; height: 32px;}
+ &:after {top: -32px; left: calc(50% - 3px); width: 7px; height: 7px; border-radius: 20px;}
+ .head:before {top: -29px; left: -5px; right: 50%; height: 1px;}
+ .head:after {top: -29px; left: 50%; right: -5px; height: 1px;}
+
+ &:first-child .head:before {content: none;}
+ &:last-child .head:after {content: none;}
+ }
+
+}
+
+
+.cells {
+ .cell {
+ position: relative;
+ margin: 24px 0 0 32px;
+
+ &:before, &:after, .card:before, .card:after {position: absolute; background-color: #86898E; content: '';}
+ &:before {top: 20px; left: -20px; width: 20px; height: 1px;}
+ &:after {top: 17px; left: -23px; width: 7px; height: 7px; border-radius: 20px;}
+
+ .card {
+ &:before {top: -24px; left: -20px; width: 1px; height: 44px;}
+ &:after {top: 20px; bottom: 0; left: -20px; width: 1px;}
+ }
+
+ &:last-child .card:after {
+ content: none;
+ }
+
+
+ .advisory {
+ margin-bottom: 32px;
+ &:last-child {
+ margin-bottom: 0;
+ }
+ .caption {
+ cursor: pointer;
+ }
+ .info {
+ max-height: 0;
+ margin: 8px -8px -8px;
+ overflow: hidden;
+ transition: max-height 0.3s;
+ .in {
+ padding: 8px;
+ border: #CFD1D4 solid 1px;
+ border-radius: 4px;
+ background-color: #ffffff;
+ font-size: 0.875rem;
+ }
+ p {
+ margin: 0 0 8px;
+ &:last-child {
+ margin: 0;
+ }
+ &.icon {
+ padding-left: 28px;
+ background: transparent none 0 0 no-repeat;
+ line-height: 20px;
+ &.phone {background-image: url('~src/assets/images/icons/phone_20.svg');}
+ &.email {background-image: url('~src/assets/images/icons/email_20.svg');}
+ }
+ }
+ }
+
+ &.active {
+ .info {
+ max-height: 500px;
+ }
+ }
+ }
+ }
+}
+@media screen and (max-width: 960px) {
+ .title {
+ span {
+ font-size: 1rem !important;
+ }
+ &:after, &:before {
+ background: none;
+ }
+ }
+ .columns {
+ display: block;
+ padding-top: 0;
+ .column {
+ margin-bottom: 24px;
+ width: 100%;
+ &:after {
+ visibility: hidden;
+ }
+ &:before {
+ display: none;
+ background: none;
+ }
+ .head {
+ height: auto;
+ &:after, &:before {
+ height: 0;
+ }
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.ts b/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.ts
new file mode 100644
index 0000000..6ad1449
--- /dev/null
+++ b/src/app/_modules/pages/page/types/tk-structure/tk-structure-page.component.ts
@@ -0,0 +1,60 @@
+import {Component, Input} from '@angular/core';
+import {AdvisoriesService} from "@app/_services/advisories.service";
+
+@Component({
+ selector: 'tk-structure-page',
+ templateUrl: 'tk-structure-page.component.html',
+ styleUrls: ['../../page.component.scss', 'tk-structure-page.component.scss']
+})
+export class TkStructurePageComponent {
+ @Input() page: any;
+ @Input() editMode = false;
+
+ public mainCommittee: any;
+ public activeAdvisories = {};
+
+ constructor(private advisoriesService: AdvisoriesService) {
+ }
+
+ get groups() {
+ return this.mainCommittee?.children?.data;
+ }
+
+
+ ngOnInit() {
+
+ }
+
+ ngOnChanges() {
+ this.fetch();
+ }
+
+ fetch() {
+ let include = ['children.children.document', 'children.children.children.document'];
+ this.advisoriesService.show('main', {include: include.join(',')}).subscribe(res => {
+ this.mainCommittee = res.data;
+ });
+ }
+
+
+ toggleActivity(advisory: any) {
+ this.activeAdvisories[advisory.id] = !this.activeAdvisories[advisory.id];
+ }
+
+ isActive(advisory: any) {
+ return this.activeAdvisories[advisory.id];
+ }
+
+
+ getChildren(advisory: any) {
+ return advisory?.children?.data;
+ }
+ getAdvisoryWithChildren(advisory: any) {
+ let result = [advisory];
+ this.getChildren(advisory).forEach(item => {
+ result.push(item);
+ });
+ return result;
+ }
+
+}
diff --git a/src/app/_modules/pages/pages-routing.module.ts b/src/app/_modules/pages/pages-routing.module.ts
new file mode 100644
index 0000000..3981825
--- /dev/null
+++ b/src/app/_modules/pages/pages-routing.module.ts
@@ -0,0 +1,46 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {RouterModule, Routes} from "@angular/router";
+import {PageNotFoundComponent} from "@app/_modules/pages/not-found/page-not-found.component";
+import {HomepageComponent} from "@app/_modules/pages/home/homepage.component";
+import {PageComponent} from "@app/_modules/pages/page/page.component";
+import {pageBreadcrumbsComponent} from "@app/_modules/pages/page/breadcrumbs/page-breadcrumbs.component";
+import {PageSectionsModule} from "@app/_modules/pages/sections/page-sections.module";
+import {PageSidebarsModule} from "@app/_modules/pages/sidebars/page-sidebars.module";
+import {ContentPageComponent} from "@app/_modules/pages/page/types/content/content-page.component";
+import {PublicationsPageComponent} from "@app/_modules/pages/page/types/publications/publications-page.component";
+import {RegistryPageComponent} from "@app/_modules/pages/page/types/registry/registry-page.component";
+import {RegistriesModule} from "@app/_modules/registries/registries.module";
+import {PublicationsModule} from "@app/_modules/publications/publications.module";
+import {TkStructurePageComponent} from "@app/_modules/pages/page/types/tk-structure/tk-structure-page.component";
+import {HomepageModule} from "@app/_modules/pages/home/homepage.module";
+
+const routes: Routes = [
+ {path: '', component: HomepageComponent},
+ {path: '**', component: PageComponent}
+];
+
+@NgModule({
+ imports: [
+ CommonModule,
+ RouterModule.forRoot(routes),
+ HomepageModule,
+ PageSectionsModule,
+ PageSidebarsModule,
+ RegistriesModule,
+ PublicationsModule
+ ],
+ declarations: [
+ PageComponent,
+ PageNotFoundComponent,
+ pageBreadcrumbsComponent,
+ ContentPageComponent,
+ PublicationsPageComponent,
+ RegistryPageComponent,
+ TkStructurePageComponent
+ ],
+ exports: [
+ RouterModule
+ ]
+})
+export class PagesRoutingModule {}
diff --git a/src/app/_modules/pages/pages.module.ts b/src/app/_modules/pages/pages.module.ts
new file mode 100644
index 0000000..b7797df
--- /dev/null
+++ b/src/app/_modules/pages/pages.module.ts
@@ -0,0 +1,42 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {PageSectionsModule} from "@app/_modules/pages/sections/page-sections.module";
+import {PageSidebarsModule} from "@app/_modules/pages/sidebars/page-sidebars.module";
+import {RegistriesModule} from "@app/_modules/registries/registries.module";
+import {PublicationsModule} from "@app/_modules/publications/publications.module";
+import {PagesListComponent} from "@app/_modules/pages/list/pages-list.component";
+import {PagesListItemComponent} from "@app/_modules/pages/list/item/pages-list-item.component";
+import {PagesMenuComponent} from "@app/_modules/pages/menu/pages-menu.component";
+import {PagesMenuItemComponent} from "@app/_modules/pages/menu/item/pages-menu-item.component";
+import {RouterModule} from "@angular/router";
+import {PaginationModule} from "@app/_modules/pagination/pagination.module";
+import {SearchSectionsComponent} from "@app/_modules/pages/sections/search/search-sections.component";
+import {SearchSectionsItemComponent} from "@app/_modules/pages/sections/search/item/search-sections-item.component";
+import {SwiperModule} from "swiper/angular";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ RouterModule,
+ PageSectionsModule,
+ PageSidebarsModule,
+ RegistriesModule,
+ PublicationsModule,
+ PaginationModule,
+ SwiperModule
+ ],
+ declarations: [
+ PagesMenuComponent,
+ PagesMenuItemComponent,
+ PagesListComponent,
+ PagesListItemComponent,
+ SearchSectionsComponent,
+ SearchSectionsItemComponent
+ ],
+ exports: [
+ PagesMenuComponent,
+ PagesListComponent,
+ SearchSectionsComponent
+ ]
+})
+export class PagesModule {}
diff --git a/src/app/_modules/pages/sections/add/add-section.component.html b/src/app/_modules/pages/sections/add/add-section.component.html
new file mode 100644
index 0000000..f293d57
--- /dev/null
+++ b/src/app/_modules/pages/sections/add/add-section.component.html
@@ -0,0 +1,19 @@
+
diff --git a/src/app/_modules/pages/sections/add/add-section.component.scss b/src/app/_modules/pages/sections/add/add-section.component.scss
new file mode 100644
index 0000000..a88aee5
--- /dev/null
+++ b/src/app/_modules/pages/sections/add/add-section.component.scss
@@ -0,0 +1,92 @@
+.add {
+ position: relative;
+ height: 24px;
+ margin-bottom: 24px;
+ &:before {
+ position: absolute;
+ left: 0;
+ top: 11px;
+ width: 100%;
+ height: 2px;
+ background-color: #CFD1D4;
+ content: '';
+ z-index: 0;
+ }
+
+ .toggle {
+ position: relative;
+ width: 24px;
+ height: 24px;
+ margin: 0 auto;
+ background: var(--white) url("~src/assets/images/icons/add_24dp.svg") no-repeat center;
+ cursor: pointer;
+ z-index: 1;
+ }
+
+ .dropdown {
+ display: none;
+ width: 250px;
+ left: calc(50% - 126px);
+ top: calc(100% + 8px);
+ z-index: 10;
+ &.active {
+ display: block;
+ }
+
+ &:before {
+ width: 250px;
+ height: 24px;
+ position: absolute;
+ left: 0;
+ top: -20px;
+ background: url("~src/assets/images/triangle.png") no-repeat center;
+ content: '';
+ }
+
+ .menu {
+ display: flex;
+ flex-direction: column;
+ margin: 0;
+ padding: 0;
+ border-radius: 8px;
+ position: relative;
+ z-index: 30;
+ .type {
+ display: flex;
+ flex-direction: column;
+ .row {
+ display: flex;
+ flex-direction: row;
+ justify-content: space-between;
+ padding: 12px 16px;
+ border-bottom: #E0E0E0 solid 1px;
+ column-gap: 12px;
+ cursor: pointer;
+ &:first-child {
+ border-radius: 8px 8px 0 0;
+ }
+ &:last-child {
+ border-radius: 0 0 8px 8px;
+ a, span {
+ border-bottom: none;
+ }
+ }
+ &:hover {
+ background-color: #f7f7f7;
+ }
+ }
+
+ .sub-row {
+ padding: 12px 16px 12px 32px;
+ border-bottom: #E0E0E0 solid 1px;
+ color: var(--grey-4);
+ cursor: pointer;
+ &:hover {
+ background-color: #f7f7f7;
+ }
+ }
+ }
+ }
+ }
+
+}
diff --git a/src/app/_modules/pages/sections/add/add-section.component.ts b/src/app/_modules/pages/sections/add/add-section.component.ts
new file mode 100644
index 0000000..b339545
--- /dev/null
+++ b/src/app/_modules/pages/sections/add/add-section.component.ts
@@ -0,0 +1,60 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'add-section',
+ templateUrl: 'add-section.component.html',
+ styleUrls: ['add-section.component.scss']
+})
+export class AddSectionComponent {
+ @Input() page: any;
+ @Input() ord: number;
+ @Input() modelType: string;
+ public types = [];
+ public ddVisible = false;
+
+ constructor(private formsService: FormsService, private objectsService: ObjectsService) {
+ }
+
+ ngOnInit() {
+ this.fetchTypes();
+ }
+
+
+ fetchTypes() {
+ this.objectsService.fetchType('page-section', {include: 'children.children'}).subscribe(res => {
+ this.types = res.data?.children?.data;
+ this.types = this.types.map(item => {
+ item.parent = item?.children?.data?.length > 0;
+ item.showChilren = false;
+ return item;
+ });
+ });
+ }
+ add(type: string) {
+ this.types = this.types.map(item => {
+ item.showChilren = false;
+ return item;
+ });
+ let attach = {modelType: this.modelType, modelId: this.page.id, group: 'sections', ord: this.ord};
+ this.formsService.createObject(type, {extraProps: {attach: attach}});
+ this.hideDD();
+ }
+
+ submenu(type: any) {
+ this.types = this.types.map(item => {
+ item.showChilren = item.showChilren ? false : item.id === type.id;
+ return item;
+ });
+ }
+
+ toggleDD() {
+ this.ddVisible = !this.ddVisible;
+ }
+ showDD() {
+ this.ddVisible = true;
+ }
+ hideDD() {
+ this.ddVisible = false;
+ }
+}
diff --git a/src/app/_modules/pages/sections/item/page-section.component.html b/src/app/_modules/pages/sections/item/page-section.component.html
new file mode 100644
index 0000000..40f81e8
--- /dev/null
+++ b/src/app/_modules/pages/sections/item/page-section.component.html
@@ -0,0 +1,26 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
section {{type?.name}} is undefined
+
+
diff --git a/src/app/_modules/pages/sections/item/page-section.component.scss b/src/app/_modules/pages/sections/item/page-section.component.scss
new file mode 100644
index 0000000..344632a
--- /dev/null
+++ b/src/app/_modules/pages/sections/item/page-section.component.scss
@@ -0,0 +1,13 @@
+.add {
+ margin-bottom: 12px;
+}
+
+@media screen and (max-width: 768px) {
+ .section {
+ .content {
+ images-section {
+ width: 100%;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/pages/sections/item/page-section.component.ts b/src/app/_modules/pages/sections/item/page-section.component.ts
new file mode 100644
index 0000000..0c3622c
--- /dev/null
+++ b/src/app/_modules/pages/sections/item/page-section.component.ts
@@ -0,0 +1,63 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService, ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'page-section',
+ templateUrl: 'page-section.component.html',
+ styleUrls: ['page-section.component.scss']
+})
+export class PageSectionComponent {
+ @Input() page: any;
+ @Input() section: any;
+ @Input() index: number;
+ @Input() editMode = false;
+ @Input() modelType: string;
+
+ constructor(private formsService: FormsService, private objectsService: ObjectsService, private listsService: ListsService) {
+ }
+
+
+ get type() {
+ return this.section?.type?.data;
+ }
+
+ get ord() {
+ return this.section?.pivot?.ord;
+ }
+
+ get total() {
+ return this.page?.sections?.data?.length;
+ }
+
+ get isFirst() {
+ return this.index === 0;
+ }
+
+ get isLast() {
+ return (this.index + 1) === this.total;
+ }
+
+
+ ngOnInit() {
+
+ }
+
+
+ edit() {
+ this.formsService.editObject(this.section.id);
+ }
+
+ move(ord) {
+ this.objectsService.move(this.section.id, {modelType: this.modelType, modelId: this.page.id, ord: ord}).subscribe(res => {
+ this.listsService.refresh();
+ });
+ }
+
+ delete() {
+ //r u sure?
+ if (confirm('Удалить этот блок?')) this.objectsService.destroy(this.section.id).subscribe(res => {
+ this.listsService.refresh();
+ });
+ }
+
+}
diff --git a/src/app/_modules/pages/sections/list/page-sections.component.html b/src/app/_modules/pages/sections/list/page-sections.component.html
new file mode 100644
index 0000000..3e92b41
--- /dev/null
+++ b/src/app/_modules/pages/sections/list/page-sections.component.html
@@ -0,0 +1,2 @@
+
+
diff --git a/src/app/_modules/pages/sections/list/page-sections.component.scss b/src/app/_modules/pages/sections/list/page-sections.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/pages/sections/list/page-sections.component.ts b/src/app/_modules/pages/sections/list/page-sections.component.ts
new file mode 100644
index 0000000..9b5c9de
--- /dev/null
+++ b/src/app/_modules/pages/sections/list/page-sections.component.ts
@@ -0,0 +1,24 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'page-sections',
+ templateUrl: 'page-sections.component.html',
+ styleUrls: ['page-sections.component.scss']
+})
+export class PageSectionsComponent {
+ @Input() page: any;
+ @Input() editMode = false;
+ @Input() modelType: string = 'page';
+
+ constructor() {
+ }
+
+ get sections() {
+ return this.page?.sections?.data;
+ }
+
+ ngOnInit() {
+
+ }
+
+}
diff --git a/src/app/_modules/pages/sections/page-sections.module.ts b/src/app/_modules/pages/sections/page-sections.module.ts
new file mode 100644
index 0000000..7a3f88b
--- /dev/null
+++ b/src/app/_modules/pages/sections/page-sections.module.ts
@@ -0,0 +1,54 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {FormsModule, ReactiveFormsModule} from "@angular/forms";
+import {SwiperModule} from "swiper/angular";
+
+import {ObjectsModule} from "@app/_modules/objects/objects.module";
+
+import {PageSectionsComponent} from "@app/_modules/pages/sections/list/page-sections.component";
+import {PageSectionComponent} from "@app/_modules/pages/sections/item/page-section.component";
+import {HeaderSectionComponent} from "@app/_modules/pages/sections/types/basic/header/header-section.component";
+import {TextSectionComponent} from "@app/_modules/pages/sections/types/basic/text/text-section.component";
+import {AddSectionComponent} from "@app/_modules/pages/sections/add/add-section.component";
+import {ImagesSectionComponent} from "@app/_modules/pages/sections/types/basic/images/images-section.component";
+import {DocumentsSectionComponent} from "@app/_modules/pages/sections/types/basic/documents/documents-section.component";
+import {ListSectionComponent} from "@app/_modules/pages/sections/types/basic/list/list-section.component";
+import {HtmlSectionComponent} from "@app/_modules/pages/sections/types/basic/html/html-section.component";
+import {VideoSectionComponent} from "@app/_modules/pages/sections/types/basic/video/video-section.component";
+import {ButtonSectionComponent} from "@app/_modules/pages/sections/types/basic/button/button-section.component";
+import {IframeSectionComponent} from "@app/_modules/pages/sections/types/basic/iframe/iframe-section.component";
+import {FeedbackSectionComponent} from "@app/_modules/pages/sections/types/basic/feedback/feedback-section.component";
+import {ContactSectionComponent} from "@app/_modules/pages/sections/types/basic/contact/contact-section.component";
+import {MapsSectionComponent} from "@app/_modules/pages/sections/types/basic/maps/maps-section.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ FormsModule,
+ ReactiveFormsModule,
+ ObjectsModule,
+ SwiperModule,
+ ],
+ declarations: [
+ PageSectionsComponent,
+ PageSectionComponent,
+ HeaderSectionComponent,
+ TextSectionComponent,
+ AddSectionComponent,
+ ImagesSectionComponent,
+ DocumentsSectionComponent,
+ ListSectionComponent,
+ HtmlSectionComponent,
+ VideoSectionComponent,
+ ButtonSectionComponent,
+ IframeSectionComponent,
+ FeedbackSectionComponent,
+ ContactSectionComponent,
+ MapsSectionComponent,
+ ],
+ exports: [
+ PageSectionsComponent,
+ ]
+})
+export class PageSectionsModule {
+}
diff --git a/src/app/_modules/pages/sections/search/item/search-sections-item.component.html b/src/app/_modules/pages/sections/search/item/search-sections-item.component.html
new file mode 100644
index 0000000..135de7d
--- /dev/null
+++ b/src/app/_modules/pages/sections/search/item/search-sections-item.component.html
@@ -0,0 +1,2 @@
+
+{{content}}
diff --git a/src/app/_modules/pages/sections/search/item/search-sections-item.component.scss b/src/app/_modules/pages/sections/search/item/search-sections-item.component.scss
new file mode 100644
index 0000000..293c9f7
--- /dev/null
+++ b/src/app/_modules/pages/sections/search/item/search-sections-item.component.scss
@@ -0,0 +1,3 @@
+.page {
+ margin-bottom: 8px;
+}
diff --git a/src/app/_modules/pages/sections/search/item/search-sections-item.component.ts b/src/app/_modules/pages/sections/search/item/search-sections-item.component.ts
new file mode 100644
index 0000000..02a0522
--- /dev/null
+++ b/src/app/_modules/pages/sections/search/item/search-sections-item.component.ts
@@ -0,0 +1,25 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'search-sections-item',
+ templateUrl: 'search-sections-item.component.html',
+ styleUrls: ['search-sections-item.component.scss']
+})
+export class SearchSectionsItemComponent {
+ @Input() section: any;
+
+ constructor(private objectsService: ObjectsService) {
+ }
+
+ get page() {
+ return this.section.pages?.data[0];
+ }
+ get content() {
+ let result = (this.objectsService.getValue(this.section, 'header-required') || this.objectsService.getValue(this.section, 'html-required')).replace(/<[^>]+>/g, '').replace(' ', ' ');
+ return (result.length > 200) ? result.substring(0, 200) + '...' : result;
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/pages/sections/search/search-sections.component.html b/src/app/_modules/pages/sections/search/search-sections.component.html
new file mode 100644
index 0000000..38a8e5b
--- /dev/null
+++ b/src/app/_modules/pages/sections/search/search-sections.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/pages/sections/search/search-sections.component.scss b/src/app/_modules/pages/sections/search/search-sections.component.scss
new file mode 100644
index 0000000..c78ac05
--- /dev/null
+++ b/src/app/_modules/pages/sections/search/search-sections.component.scss
@@ -0,0 +1,8 @@
+search-sections-item {
+ display: block;
+ padding: 16px 24px;
+ border-bottom: #E8E8E8 solid 1px;
+ &:first-child {
+ border-top: #E8E8E8 solid 1px;
+ }
+}
diff --git a/src/app/_modules/pages/sections/search/search-sections.component.ts b/src/app/_modules/pages/sections/search/search-sections.component.ts
new file mode 100644
index 0000000..bccdf1b
--- /dev/null
+++ b/src/app/_modules/pages/sections/search/search-sections.component.ts
@@ -0,0 +1,47 @@
+import {Component} from '@angular/core';
+import {Subscription} from "rxjs";
+import {ListsService, ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'search-sections',
+ templateUrl: 'search-sections.component.html',
+ styleUrls: ['search-sections.component.scss']
+})
+export class SearchSectionsComponent {
+ controlsSubscription?: Subscription;
+ resultsSubscription?: Subscription;
+
+ public items: any;
+
+ constructor(private objectsService: ObjectsService, private listsService: ListsService) {
+ }
+
+ get listId() {
+ return 'sections-list';
+ }
+
+ ngOnInit() {
+ this.listsService.addFilters({types: ['page-section-header', 'page-section-html']}, this.listId);
+ this.controlsSubscription = this.listsService.controls(this.listId).subscribe(controls => {
+ this.fetch(controls);
+ });
+ this.resultsSubscription = this.listsService.result(this.listId).subscribe(val => {
+ this.items = val?.data || [];
+ });
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ this.resultsSubscription?.unsubscribe();
+ }
+
+
+
+ fetch(controls) {
+ let include = ['groups.fields.value', 'pages'];
+ let params = {page: controls.page || 0, filters: JSON.stringify(controls.filters), include: include.join(',')};
+ this.objectsService.listObjects(params).subscribe(result => {
+ this.listsService.result(this.listId).next(result);
+ });
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/button/button-section.component.html b/src/app/_modules/pages/sections/types/basic/button/button-section.component.html
new file mode 100644
index 0000000..f7c19ef
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/button/button-section.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/button/button-section.component.scss b/src/app/_modules/pages/sections/types/basic/button/button-section.component.scss
new file mode 100644
index 0000000..b941511
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/button/button-section.component.scss
@@ -0,0 +1,8 @@
+a {
+ display: inline-block;
+ margin: 0 16px 16px 0;
+ padding: 11px 24px;
+ background-color: #F9B417;
+ border-radius: 20px;
+ color: #ffffff;
+}
diff --git a/src/app/_modules/pages/sections/types/basic/button/button-section.component.ts b/src/app/_modules/pages/sections/types/basic/button/button-section.component.ts
new file mode 100644
index 0000000..db04128
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/button/button-section.component.ts
@@ -0,0 +1,30 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'button-section',
+ templateUrl: 'button-section.component.html',
+ styleUrls: ['button-section.component.scss']
+})
+export class ButtonSectionComponent {
+ @Input() section: any;
+
+ constructor(
+ private objectsService: ObjectsService
+ ) {
+ }
+
+
+ get url() {
+ return this.objectsService.getValue(this.section, 'button-url');
+ }
+ get title() {
+ return this.objectsService.getValue(this.section, 'button-title');
+ }
+ get targetBlank() {
+ return this.objectsService.getValue(this.section, 'target-blank');
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.html b/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.html
new file mode 100644
index 0000000..232c32b
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.html
@@ -0,0 +1,8 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.scss b/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.scss
new file mode 100644
index 0000000..c66a983
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.scss
@@ -0,0 +1,36 @@
+.contact {
+ margin-bottom: 40px;
+
+ h2 {
+ color: var(--grey-7);
+ font-size: 1.5rem;
+ line-height: 30px;
+ font-weight: 400;
+ }
+
+ p {
+ display: flex;
+ &:before {
+ content: '';
+ width: 24px;
+ height: 24px;
+ display: block;
+ margin-right: 8px;
+ background-repeat: no-repeat;
+ background-position: center;
+ }
+
+ &.legal-address:before {
+ background-image: url("~src/assets/images/icons/location_orange_24dp.svg");
+ }
+ &.local-address:before {
+ background-image: url("~src/assets/images/icons/mail_orange_24dp.svg");
+ }
+ &.email:before {
+ background-image: url("~src/assets/images/icons/email_orange_24dp.svg");
+ }
+ &.phone:before {
+ background-image: url("~src/assets/images/icons/phone_orange_24dp.svg");
+ }
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.ts b/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.ts
new file mode 100644
index 0000000..b916d85
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/contact/contact-section.component.ts
@@ -0,0 +1,39 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'contact-section',
+ templateUrl: 'contact-section.component.html',
+ styleUrls: ['contact-section.component.scss']
+})
+export class ContactSectionComponent {
+ @Input() section: any;
+
+ constructor(
+ private objectsService: ObjectsService
+ ) {
+ }
+
+ ngOnInit() {
+ }
+
+
+ get name() {
+ return this.objectsService.getValue(this.section, 'contact-name');
+ }
+ get legalAddress() {
+ return this.objectsService.getValue(this.section, 'contact-legal-address');
+ }
+ get locationAddress() {
+ return this.objectsService.getValue(this.section, 'contact-location-address');
+ }
+ get email() {
+ return this.objectsService.getValue(this.section, 'contact-email');
+ }
+ get phone() {
+ return this.objectsService.getValue(this.section, 'contact-phone');
+ }
+ get description() {
+ return this.objectsService.getValue(this.section, 'contact-description');
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.html b/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.html
new file mode 100644
index 0000000..254247e
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.scss b/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.scss
new file mode 100644
index 0000000..a8526c3
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.scss
@@ -0,0 +1,6 @@
+.documents {
+ margin-bottom: 24px;
+ a {
+ color: var(--black);
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.ts b/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.ts
new file mode 100644
index 0000000..13f2972
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/documents/documents-section.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'documents-section',
+ templateUrl: 'documents-section.component.html',
+ styleUrls: ['documents-section.component.scss']
+})
+export class DocumentsSectionComponent {
+ @Input() section: any;
+
+ constructor(private objectsService: ObjectsService) {
+ }
+
+
+ get items() {
+ return this.objectsService.getValue(this.section, 'documents-required');
+ }
+
+ ngOnInit() {
+
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.html b/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.html
new file mode 100644
index 0000000..dd33fb2
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.html
@@ -0,0 +1,16 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.scss b/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.scss
new file mode 100644
index 0000000..295a0d9
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.scss
@@ -0,0 +1,27 @@
+.feedback-form {
+ form {
+ display: flex;
+ flex-direction: column;
+ row-gap: 16px;
+ margin-bottom: 40px;
+ max-width: 720px;
+
+ .title {
+ color: var(--grey-7);
+ margin-bottom: 16px;
+
+ span {
+ color: var(--grey-4);
+ }
+ }
+
+ .row {
+ button {
+ padding: 11px 24px;
+ background-color: var(--orange-2);
+ border-radius: var(--radius-2);
+ color: var(--white);
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.ts b/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.ts
new file mode 100644
index 0000000..1c142a4
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/feedback/feedback-section.component.ts
@@ -0,0 +1,39 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ObjectsService} from "@app/_services";
+import {FormGroup, FormControl} from "@angular/forms";
+
+@Component({
+ selector: 'feedback-section',
+ templateUrl: 'feedback-section.component.html',
+ styleUrls: ['feedback-section.component.scss']
+})
+export class FeedbackSectionComponent {
+ @Input() section: any;
+
+ public formGroup: FormGroup;
+ public loading = false;
+ public sent = false;
+
+ constructor(private formsService: FormsService, private objectsService: ObjectsService) {
+ }
+
+ get objectType(): any {
+ return this.objectsService.getValue(this.section, 'feedback-form-type');
+ }
+ get email(): string {
+ return this.objectsService.getValue(this.section, 'feedback-support-email');
+ }
+
+
+ ngOnInit() {
+ this.formGroup = new FormGroup({mailto: new FormControl(this.email)});
+ }
+
+ onSubmit() {
+ this.formsService.save('model', this.objectType.name, null, this.formGroup.value).subscribe(res => {
+ this.sent = true;
+ }, error => {
+ console.log(error);
+ });
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/header/header-section.component.html b/src/app/_modules/pages/sections/types/basic/header/header-section.component.html
new file mode 100644
index 0000000..ae176c2
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/header/header-section.component.html
@@ -0,0 +1,5 @@
+
+
+
+
+
diff --git a/src/app/_modules/pages/sections/types/basic/header/header-section.component.scss b/src/app/_modules/pages/sections/types/basic/header/header-section.component.scss
new file mode 100644
index 0000000..8e09d57
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/header/header-section.component.scss
@@ -0,0 +1,21 @@
+h2 {
+ color: var(--grey-7);
+ font-size: 1.75rem;
+ line-height: 32px;
+ font-weight: 700;
+ margin: 32px 0 16px;
+}
+h3 {
+ color: var(--grey-7);
+ font-size: 1.5rem;
+ line-height: 30px;
+ font-weight: 400;
+ margin: 24px 0 16px;
+}
+h4 {
+ color: var(--grey-7);
+ font-size: 1.25rem;
+ line-height: 24px;
+ font-weight: 200;
+ margin: 20px 0 16px;
+}
diff --git a/src/app/_modules/pages/sections/types/basic/header/header-section.component.ts b/src/app/_modules/pages/sections/types/basic/header/header-section.component.ts
new file mode 100644
index 0000000..169d049
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/header/header-section.component.ts
@@ -0,0 +1,24 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'header-section',
+ templateUrl: 'header-section.component.html',
+ styleUrls: ['header-section.component.scss']
+})
+export class HeaderSectionComponent {
+ @Input() section: any;
+
+ constructor(private objectsService: ObjectsService) {
+ }
+ ngOnInit() {
+ }
+
+
+ get content() {
+ return this.objectsService.getValue(this.section, 'header-required');
+ }
+ get type() {
+ return this.objectsService.getValue(this.section, 'header-type');
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/html/html-section.component.html b/src/app/_modules/pages/sections/types/basic/html/html-section.component.html
new file mode 100644
index 0000000..11e5adb
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/html/html-section.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/html/html-section.component.scss b/src/app/_modules/pages/sections/types/basic/html/html-section.component.scss
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/html/html-section.component.scss
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/html/html-section.component.ts b/src/app/_modules/pages/sections/types/basic/html/html-section.component.ts
new file mode 100644
index 0000000..876e663
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/html/html-section.component.ts
@@ -0,0 +1,25 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+import {DomSanitizer} from "@angular/platform-browser";
+
+@Component({
+ selector: 'html-section',
+ templateUrl: 'html-section.component.html',
+ styleUrls: ['html-section.component.scss']
+})
+export class HtmlSectionComponent {
+ @Input() section: any;
+
+ constructor(private objectsService: ObjectsService, private sanitized: DomSanitizer) {
+ }
+
+ get content() {
+ let res = this.objectsService.getValue(this.section, 'html-required');
+ res = res.replace(/
/g,"
").replace(/
/g,"
");
+ return this.sanitized.bypassSecurityTrustHtml(res);
+ }
+
+ ngOnInit() {
+
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.html b/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.html
new file mode 100644
index 0000000..ab7cfac
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.scss b/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.scss
new file mode 100644
index 0000000..64f36b2
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.scss
@@ -0,0 +1,5 @@
+iframe {
+ width: 100%;
+ height: 400px;
+ margin-bottom: 40px;
+}
diff --git a/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.ts b/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.ts
new file mode 100644
index 0000000..df67f9c
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/iframe/iframe-section.component.ts
@@ -0,0 +1,26 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+import {DomSanitizer} from "@angular/platform-browser";
+
+@Component({
+ selector: 'iframe-section',
+ templateUrl: 'iframe-section.component.html',
+ styleUrls: ['iframe-section.component.scss']
+})
+export class IframeSectionComponent {
+ @Input() section: any;
+
+ constructor(
+ private objectsService: ObjectsService,
+ private sanitized: DomSanitizer
+ ) {
+ }
+
+
+ get url() {
+ return this.sanitized.bypassSecurityTrustResourceUrl(this.objectsService.getValue(this.section, 'iframe-url'));
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/images/images-section.component.html b/src/app/_modules/pages/sections/types/basic/images/images-section.component.html
new file mode 100644
index 0000000..60f0160
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/images/images-section.component.html
@@ -0,0 +1,39 @@
+
+
+
![]()
+
+
+
+
+
+

+
+
+
+
+
+
+
![]()
+
+
+
+
+
+
+

+
+
+
+
+
1" class="left" (click)="go('decrement')">
+

+
+
+
1" class="right" (click)="go('increment')">
+

+
+
+
+
diff --git a/src/app/_modules/pages/sections/types/basic/images/images-section.component.scss b/src/app/_modules/pages/sections/types/basic/images/images-section.component.scss
new file mode 100644
index 0000000..a2d7404
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/images/images-section.component.scss
@@ -0,0 +1,112 @@
+.items {
+ display: flex;
+ flex-direction: row;
+ flex-wrap: wrap;
+ width: 100%;
+ gap: 20px;
+ margin-bottom: 20px;
+
+ .item {
+ position: relative;
+
+ img {
+ width: 128px;
+ height: 128px;
+ object-fit: cover;
+ cursor: pointer;
+ }
+
+ &:last-child {
+ margin-bottom: 0;
+ }
+
+ &.full-width {
+ display: flex;
+ flex-direction: column;
+ img {
+ width: 100%;
+ height: auto;
+ }
+ }
+ &.tiles {
+
+ }
+ }
+}
+
+.carousel {
+ display: flex;
+ flex-direction: row;
+ justify-content: center;
+ column-gap: 42px;
+ margin-bottom: 20px;
+ align-items: center;
+ width: 100%;
+ .prev, .next {
+ cursor: pointer;
+ }
+ .center {
+ display: flex;
+ overflow: hidden;
+ max-width: 548px;
+ width: 100%;
+ }
+}
+
+.slide {
+ width: 100%;
+ height: 100%;
+ display: flex;
+ justify-content: center;
+ align-items: center;
+
+ img {
+ display: block;
+ width: 100%;
+ height: 300px;
+ object-fit: cover;
+ }
+}
+
+.fullscreen {
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ z-index: 2;
+ display: flex;
+ position: fixed;
+ align-items: center;
+ justify-content: center;
+ background-color: rgba(37, 46, 52, 60%);
+ .left {
+ width: 72px;
+ flex-grow: 0;
+ display: flex;
+ cursor: pointer;
+ align-items: center;
+ justify-content: center;
+ }
+ .center {
+ flex-grow: 1;
+ display: flex;
+ justify-content: center;
+ width: 100%;
+ max-width: calc(100% - 144px);
+ img {
+ max-width: 100%;
+ width: auto;
+ height: 100%;
+ max-height: calc(100vh - 2 * 24px);
+ }
+ }
+ .right {
+ width: 72px;
+ flex-grow: 0;
+ display: flex;
+ cursor: pointer;
+ align-items: center;
+ justify-content: center;
+ }
+}
+
diff --git a/src/app/_modules/pages/sections/types/basic/images/images-section.component.ts b/src/app/_modules/pages/sections/types/basic/images/images-section.component.ts
new file mode 100644
index 0000000..0c0ed10
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/images/images-section.component.ts
@@ -0,0 +1,111 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+import SwiperCore, {Navigation, Pagination, SwiperOptions} from 'swiper';
+SwiperCore.use([Navigation, Pagination]);
+
+@Component({
+ selector: 'images-section',
+ templateUrl: 'images-section.component.html',
+ styleUrls: ['images-section.component.scss']
+})
+export class ImagesSectionComponent {
+ @Input() section: any;
+
+ public config: SwiperOptions;
+
+ public parsedPhotos: any[] = []
+ public activePhoto: string = ''
+ public nextId:string;
+ public backId:string;
+ public showId: string = ''
+ public showFullscreen = false;
+ public activeIndex: number = 0
+ public tmpNumber: number = 0
+
+ constructor(private objectsService: ObjectsService) {
+ }
+
+
+ ngOnInit() {
+ this.config = {
+ slidesPerView: 1,
+ spaceBetween: 40,
+ navigation: {prevEl: `#section-${this.section?.id} .prev`, nextEl: `#section-${this.section?.id} .next`}
+ }
+
+ setTimeout(()=>{
+ this.parsed();
+ }, 300)
+ }
+
+
+ get items() {
+ return this.objectsService.getValue(this.section, 'images-required');
+ }
+ get imageType() {
+ let type = this.objectsService.getValue(this.section, 'image-type');
+ return type.name;
+ }
+ set photo(activePhoto: string) {
+ this.activePhoto = activePhoto
+ }
+ get photo(): string {
+ return this.activePhoto
+ }
+
+
+ parsed(): void {
+ this.tmpNumber = 0
+ this.parsedPhotos = this.items || []
+ this.parsedPhotos.map((photo: any) => {
+ if (this.tmpNumber===0) {
+ photo.active = true
+ this.photo = photo.links.full
+ this.showId = photo.id
+ } else {
+ photo.active = false
+ if (this.tmpNumber===1) {
+ this.nextId = photo.id
+ }
+ }
+ this.tmpNumber++
+ if (this.items.length > 1 && this.items.length == this.tmpNumber) {
+ this.backId = photo.id
+ }
+ return photo
+ })
+ }
+
+ show(id: string): void {
+ this.parsedPhotos?.forEach((photo: any) => {
+ if (photo.id === id) {
+ this.photo = photo.links.full
+ this.showFullscreen = true
+ }
+ })
+ }
+
+ go(how: string) {
+ this.show(this.showId)
+ switch(how) {
+ case 'decrement':
+ this.activeIndex--
+ if (this.activeIndex < 0) this.activeIndex = this.parsedPhotos.length - 1
+ break
+ case 'increment':
+ this.activeIndex++
+ if (this.activeIndex == this.parsedPhotos.length) this.activeIndex = 0
+ break
+ }
+ this.parsedPhotos = this.parsedPhotos.map((item: any, index: number) => {
+ if (index === this.activeIndex) {
+ item.active = true
+ this.photo = item.links.full
+ this.showId = item.id
+ } else {
+ item.active = false
+ }
+ return item
+ })
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/list/list-section.component.html b/src/app/_modules/pages/sections/types/basic/list/list-section.component.html
new file mode 100644
index 0000000..ac2bb88
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/list/list-section.component.html
@@ -0,0 +1,6 @@
+
+
+ - {{item}}
+
diff --git a/src/app/_modules/pages/sections/types/basic/list/list-section.component.scss b/src/app/_modules/pages/sections/types/basic/list/list-section.component.scss
new file mode 100644
index 0000000..202c88a
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/list/list-section.component.scss
@@ -0,0 +1,3 @@
+li {
+ white-space: pre-line;
+}
diff --git a/src/app/_modules/pages/sections/types/basic/list/list-section.component.ts b/src/app/_modules/pages/sections/types/basic/list/list-section.component.ts
new file mode 100644
index 0000000..d06d6c1
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/list/list-section.component.ts
@@ -0,0 +1,25 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'list-section',
+ templateUrl: 'list-section.component.html',
+ styleUrls: ['list-section.component.scss']
+})
+export class ListSectionComponent {
+ @Input() section: any;
+
+ constructor(private objectsService: ObjectsService) {
+ }
+
+ get type() {
+ return this.objectsService.getValue(this.section, 'list-type');
+ }
+ get items() {
+ return this.objectsService.getValue(this.section, 'list-items');
+ }
+
+ ngOnInit() {
+
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.html b/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.html
new file mode 100644
index 0000000..f306852
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.scss b/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.scss
new file mode 100644
index 0000000..64f36b2
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.scss
@@ -0,0 +1,5 @@
+iframe {
+ width: 100%;
+ height: 400px;
+ margin-bottom: 40px;
+}
diff --git a/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.ts b/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.ts
new file mode 100644
index 0000000..835b42f
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/maps/maps-section.component.ts
@@ -0,0 +1,35 @@
+import {Component, Input} from '@angular/core';
+import {DomSanitizer} from "@angular/platform-browser";
+import {ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'maps-section',
+ templateUrl: 'maps-section.component.html',
+ styleUrls: ['maps-section.component.scss']
+})
+export class MapsSectionComponent {
+ @Input() section: any;
+ public mapUrl: any = '';
+
+ constructor(
+ private sanitized: DomSanitizer,
+ private objectsService: ObjectsService,
+ ) {
+ }
+
+ ngOnInit() {
+ this.setMapUrl();
+ }
+
+ setMapUrl() {
+ const url = this.objectsService.getValue(this.section, 'maps-url');
+ const arUrl = url.split('?');
+ const getUrl = arUrl.length==2 ? arUrl[1] : '';
+ const arOid = arUrl[0].split('/').filter(value => value);
+ let newUrl = 'https://yandex.ru/map-widget/v1/?' + getUrl;
+ if (arOid.length === 6) {
+ newUrl += '&ol=biz&mode=search&oid=' + arOid[5];
+ }
+ this.mapUrl = this.sanitized.bypassSecurityTrustResourceUrl(newUrl);
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/text/text-section.component.html b/src/app/_modules/pages/sections/types/basic/text/text-section.component.html
new file mode 100644
index 0000000..d748ca3
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/text/text-section.component.html
@@ -0,0 +1 @@
+{{content}}
diff --git a/src/app/_modules/pages/sections/types/basic/text/text-section.component.scss b/src/app/_modules/pages/sections/types/basic/text/text-section.component.scss
new file mode 100644
index 0000000..d04f5c6
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/text/text-section.component.scss
@@ -0,0 +1,3 @@
+p {
+ white-space: pre-line;
+}
diff --git a/src/app/_modules/pages/sections/types/basic/text/text-section.component.ts b/src/app/_modules/pages/sections/types/basic/text/text-section.component.ts
new file mode 100644
index 0000000..17bc61c
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/text/text-section.component.ts
@@ -0,0 +1,22 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'text-section',
+ templateUrl: 'text-section.component.html',
+ styleUrls: ['text-section.component.scss']
+})
+export class TextSectionComponent {
+ @Input() section: any;
+
+ constructor(private objectsService: ObjectsService) {
+ }
+
+ get content() {
+ return this.objectsService.getValue(this.section, 'text-required');
+ }
+
+ ngOnInit() {
+
+ }
+}
diff --git a/src/app/_modules/pages/sections/types/basic/video/video-section.component.html b/src/app/_modules/pages/sections/types/basic/video/video-section.component.html
new file mode 100644
index 0000000..fc24ac4
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/video/video-section.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/pages/sections/types/basic/video/video-section.component.scss b/src/app/_modules/pages/sections/types/basic/video/video-section.component.scss
new file mode 100644
index 0000000..1f606d7
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/video/video-section.component.scss
@@ -0,0 +1,7 @@
+iframe {
+ width: 100%;
+ max-width: 720px;
+ min-height: 400px;
+ height: 100%;
+ margin-bottom: 24px;
+}
diff --git a/src/app/_modules/pages/sections/types/basic/video/video-section.component.ts b/src/app/_modules/pages/sections/types/basic/video/video-section.component.ts
new file mode 100644
index 0000000..d64b99b
--- /dev/null
+++ b/src/app/_modules/pages/sections/types/basic/video/video-section.component.ts
@@ -0,0 +1,43 @@
+import {Component, Input} from '@angular/core';
+import {ObjectsService} from "@app/_services";
+import {DomSanitizer} from "@angular/platform-browser";
+
+@Component({
+ selector: 'video-section',
+ templateUrl: 'video-section.component.html',
+ styleUrls: ['video-section.component.scss']
+})
+export class VideoSectionComponent {
+ @Input() section: any;
+
+ constructor(
+ private objectsService: ObjectsService,
+ private sanitizer: DomSanitizer
+ ) {
+ }
+
+ public url:any = '';
+
+ ngOnInit() {
+ const url = this.parsedUrl(this.objectsService.getValue(this.section, 'video-url'));
+ this.url = this.sanitizer.bypassSecurityTrustResourceUrl(url);
+ }
+
+ parsedUrl(url: any) {
+ let res = '';
+ let videoId = '';
+ if (/https:\/\/youtu.be\//.test(url)) {
+ videoId = url.replace('https://youtu.be/','');
+ res = 'https://www.youtube.com/embed/' + videoId;
+ } else if (/https:\/\/www\.youtube\.com\/watch\?v\=/.test(url)) {
+ videoId = url.replace('https://www.youtube.com/watch?v=','');
+ res = 'https://www.youtube.com/embed/' + videoId;
+ } else if (/https:\/\/rutube.ru\/video\//.test(url)) {
+ videoId = url.replace('https://rutube.ru/video/','');
+ res = 'https://rutube.ru/play/embed/' + videoId;
+ } else {
+ res = url;
+ }
+ return res;
+ }
+}
diff --git a/src/app/_modules/pages/sidebars/add/add-sidebar.component.html b/src/app/_modules/pages/sidebars/add/add-sidebar.component.html
new file mode 100644
index 0000000..b77cd5b
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/add/add-sidebar.component.html
@@ -0,0 +1,11 @@
+
diff --git a/src/app/_modules/pages/sidebars/add/add-sidebar.component.scss b/src/app/_modules/pages/sidebars/add/add-sidebar.component.scss
new file mode 100644
index 0000000..7b921e8
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/add/add-sidebar.component.scss
@@ -0,0 +1,21 @@
+.add {
+ margin: 10px 0 24px;
+ width: 100%;
+ height: 24px;
+ .toggle {
+ height: 2px;
+ background-color: #CFD1D4;
+ width: 100%;
+ position: relative;
+ margin-bottom: 24px;
+ .button {
+ top: -11px;
+ left: calc(50% - 12px);
+ position: absolute;
+ width: 24px;
+ height: 24px;
+ background: url("~src/assets/images/icons/add_24dp.svg") no-repeat center #ffffff;
+ cursor: pointer;
+ }
+ }
+}
diff --git a/src/app/_modules/pages/sidebars/add/add-sidebar.component.ts b/src/app/_modules/pages/sidebars/add/add-sidebar.component.ts
new file mode 100644
index 0000000..d679f4b
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/add/add-sidebar.component.ts
@@ -0,0 +1,39 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'add-sidebar',
+ templateUrl: 'add-sidebar.component.html',
+ styleUrls: ['add-sidebar.component.scss']
+})
+export class AddSidebarComponent {
+ @Input() page: any;
+ @Input() ord: number;
+ public ddVisible = false;
+ public types = [];
+
+ constructor(private formsService: FormsService, private objectsService: ObjectsService) {
+ }
+
+ ngOnInit() {
+ }
+
+
+ fetchTypes() {
+ this.objectsService.fetchType('page-sidebar', {include: 'children'}).subscribe(res => {
+ this.types = res.data?.children?.data;
+ });
+ }
+
+ add(type: string) {
+ let attach = {modelType: 'page', modelId: this.page.id, group: 'sidebars', ord: this.ord};
+ this.formsService.createObject(type, {extraProps: {attach: attach}});
+ this.ddVisible = false;
+ }
+
+ toggle() {
+ if (!this.types?.length) this.fetchTypes();
+ this.ddVisible = !this.ddVisible;
+ }
+
+}
diff --git a/src/app/_modules/pages/sidebars/item/page-sidebar.component.html b/src/app/_modules/pages/sidebars/item/page-sidebar.component.html
new file mode 100644
index 0000000..751d859
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/item/page-sidebar.component.html
@@ -0,0 +1,18 @@
+
+
diff --git a/src/app/_modules/pages/sidebars/item/page-sidebar.component.scss b/src/app/_modules/pages/sidebars/item/page-sidebar.component.scss
new file mode 100644
index 0000000..da8a492
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/item/page-sidebar.component.scss
@@ -0,0 +1,74 @@
+.sidebar {
+ padding: 24px;
+ margin-bottom: 24px;
+ border: #dedede solid 1px;
+ background-color: #F7F8FA;
+ .header {
+ margin-bottom: 20px;
+ font-size: 1.5rem;
+ font-style: normal;
+ font-weight: 400;
+ line-height: 30px;
+ color: var(--grey-7);
+ }
+ .text {
+ margin-bottom: 12px;
+ font-weight: 400;
+ font-size: 1rem;
+ line-height: 24px;
+ color: var(--grey-7);
+ }
+ .documents {
+ margin-bottom: 12px;
+ .items {
+ .item {
+ display: flex;
+ flex-direction: row;
+ margin-top: 10px;
+ a {
+ color: var(--black);
+ }
+ &:before {
+ width: 20px;
+ height: 20px;
+ margin-right: 8px;
+ flex-shrink: 0;
+ background: transparent url("~src/assets/images/icons/document_20dp.svg") center no-repeat;
+ content: '';
+ }
+ }
+ }
+ }
+ .menu {
+ display: flex;
+ .block {
+ margin: 12px 0;
+ background: var(--white);
+ border: 1px solid #CFD1D4;
+ border-radius: 4px;
+ padding: 12px 24px;
+ display: flex;
+ column-gap: 20px;
+ button {
+ &.up, &.down, &.edit, &.delete {
+ width: 24px;
+ height: 24px;
+ background-position: center;
+ background-repeat: no-repeat;
+ }
+ &.up {
+ background: url("~src/assets/images/icons/arrow_upward_24dp.svg");
+ }
+ &.down {
+ background: url("~src/assets/images/icons/arrow_downward_24dp.svg");
+ }
+ &.edit {
+ background: url("~src/assets/images/icons/edit_24dp.svg");
+ }
+ &.delete {
+ background: url("~src/assets/images/icons/trash_24dp.svg");
+ }
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/pages/sidebars/item/page-sidebar.component.ts b/src/app/_modules/pages/sidebars/item/page-sidebar.component.ts
new file mode 100644
index 0000000..d89a95c
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/item/page-sidebar.component.ts
@@ -0,0 +1,64 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService, ObjectsService} from "@app/_services";
+
+@Component({
+ selector: 'page-sidebar',
+ templateUrl: 'page-sidebar.component.html',
+ styleUrls: ['page-sidebar.component.scss']
+})
+export class PageSidebarComponent {
+ @Input() page: any;
+ @Input() sidebar: any;
+ @Input() index: number;
+ @Input() editMode = false;
+
+ constructor(private objectsService: ObjectsService, private formsService: FormsService, private listsService: ListsService) {
+ }
+
+ get ord() {
+ return this.sidebar?.pivot?.ord;
+ }
+ get total() {
+ return this.page?.sidebars?.data?.length;
+ }
+ get isFirst() {
+ return this.index === 0;
+ }
+ get isLast() {
+ return (this.index + 1) === this.total;
+ }
+
+ get header() {
+ return this.objectsService.getValue(this.sidebar, 'header');
+ }
+ get html() {
+ return this.objectsService.getValue(this.sidebar, 'html');
+ }
+ get documents() {
+ return this.objectsService.getValue(this.sidebar, 'documents');
+ }
+
+
+ ngOnInit() {
+
+ }
+
+
+ edit() {
+ this.formsService.editObject(this.sidebar.id);
+ }
+
+ move(ord) {
+ this.objectsService.move(this.sidebar.id, {modelType: 'page', modelId: this.page.id, ord: ord}).subscribe(res => {
+ this.listsService.refresh();
+ });
+ }
+
+ delete() {
+ if (confirm('Вы точно хотите удалить блок?')) this.objectsService.destroy(this.sidebar.id).subscribe(res => {
+ this.listsService.refresh();
+ });
+ }
+
+
+}
diff --git a/src/app/_modules/pages/sidebars/list/page-sidebars.component.html b/src/app/_modules/pages/sidebars/list/page-sidebars.component.html
new file mode 100644
index 0000000..d6dd196
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/list/page-sidebars.component.html
@@ -0,0 +1,2 @@
+
+
diff --git a/src/app/_modules/pages/sidebars/list/page-sidebars.component.scss b/src/app/_modules/pages/sidebars/list/page-sidebars.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/pages/sidebars/list/page-sidebars.component.ts b/src/app/_modules/pages/sidebars/list/page-sidebars.component.ts
new file mode 100644
index 0000000..78e61d9
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/list/page-sidebars.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'page-sidebars',
+ templateUrl: 'page-sidebars.component.html',
+ styleUrls: ['page-sidebars.component.scss']
+})
+export class PageSidebarsComponent {
+ @Input() page: any;
+ @Input() editMode = false;
+
+ constructor() {
+ }
+
+ get sidebars() {
+ return this.page?.sidebars?.data;
+ }
+
+ ngOnInit() {
+
+ }
+
+}
diff --git a/src/app/_modules/pages/sidebars/page-sidebars.module.ts b/src/app/_modules/pages/sidebars/page-sidebars.module.ts
new file mode 100644
index 0000000..ce5750e
--- /dev/null
+++ b/src/app/_modules/pages/sidebars/page-sidebars.module.ts
@@ -0,0 +1,21 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {PageSidebarsComponent} from "@app/_modules/pages/sidebars/list/page-sidebars.component";
+import {PageSidebarComponent} from "@app/_modules/pages/sidebars/item/page-sidebar.component";
+import {AddSidebarComponent} from "@app/_modules/pages/sidebars/add/add-sidebar.component";
+
+@NgModule({
+ imports: [
+ CommonModule
+ ],
+ declarations: [
+ PageSidebarsComponent,
+ PageSidebarComponent,
+ AddSidebarComponent
+ ],
+ exports: [
+ PageSidebarsComponent,
+ AddSidebarComponent
+ ]
+})
+export class PageSidebarsModule {}
diff --git a/src/app/_modules/pagination/pagination.component.html b/src/app/_modules/pagination/pagination.component.html
new file mode 100644
index 0000000..7cc4a1a
--- /dev/null
+++ b/src/app/_modules/pagination/pagination.component.html
@@ -0,0 +1,9 @@
+
diff --git a/src/app/_modules/pagination/pagination.component.scss b/src/app/_modules/pagination/pagination.component.scss
new file mode 100644
index 0000000..923abcd
--- /dev/null
+++ b/src/app/_modules/pagination/pagination.component.scss
@@ -0,0 +1,59 @@
+.pagination {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ flex-wrap: wrap;
+ gap: 16px;
+ button {
+ background-color: transparent;
+ min-width: 20px;
+ min-height: 20px;
+ border-radius: 10px;
+ font-weight: 700;
+ font-size: 0.875rem;
+ line-height: 18px;
+ border: 1px solid var(--orange-2);
+ color: var(--orange-2);
+ text-align: center;
+ padding: 1px 6px;
+
+ &.active {
+ background: var(--orange-2);
+ color: var(--white);
+ border-color: var(--orange-2);
+ }
+ &.next {
+ margin-right: 20px;
+ border-color: transparent;
+ color: var(--grey-4);
+ font-size: 0.875rem;
+ font-style: normal;
+ font-weight: 400;
+ line-height: 18px;
+ }
+ }
+ .dots {
+ width: 24px;
+ height: 24px;
+ background: transparent url("~src/assets/images/icons/more_horiz_20dp.svg") no-repeat center;
+ }
+ .count {
+ display: flex;
+ justify-content: right;
+ flex-grow: 1;
+ color: var(--black);
+ font-size: 0.875rem;
+ }
+}
+
+
+@media screen and (max-width: 767px) {
+ .pagination {
+ .next {
+ display: none;
+ }
+ .count {
+ display: none;
+ }
+ }
+}
diff --git a/src/app/_modules/pagination/pagination.component.ts b/src/app/_modules/pagination/pagination.component.ts
new file mode 100644
index 0000000..d0452a8
--- /dev/null
+++ b/src/app/_modules/pagination/pagination.component.ts
@@ -0,0 +1,75 @@
+import {Component, Input} from '@angular/core';
+import {Subscription} from "rxjs";
+
+import {ListsService} from "@app/_services/lists.service";
+
+@Component({
+ selector: 'pagination',
+ templateUrl: 'pagination.component.html',
+ styleUrls: ['pagination.component.scss']
+})
+export class PaginationComponent {
+ @Input() listId?;
+ public data: any;
+ public pages = [];
+ resultSubscription?: Subscription;
+
+ public maxPages = 2;
+
+ constructor(private listsService: ListsService) {
+ }
+
+ ngOnInit() {
+ this.resultSubscription = this.listsService.result(this.listId).subscribe(data => {
+ this.data = data?.meta?.pagination;
+ this.makePages();
+ });
+ }
+ ngOnDestroy() {
+ this.resultSubscription?.unsubscribe();
+ }
+
+
+ get shownFrom() {
+ return (this.data?.currentPage - 1) * this.data?.perPage + 1;
+ }
+ get shownTo() {
+ let val = this.data?.currentPage * this.data?.perPage;
+ return (val < this.data?.total) ? val : this.data?.total;
+ }
+ get currentPage() {
+ return this.listsService.result(this.listId).value.meta?.pagination?.currentPage;
+ }
+ get total() {
+ return this.data?.totalPages || 1;
+ }
+ get page() {
+ return this.data?.currentPage || 1;
+ }
+ get from() {
+ let res = this.page - this.maxPages;
+ if (this.page > (this.total - this.maxPages)) res -= (this.page + this.maxPages - this.total);
+ return (res > 1) ? res : 1;
+ }
+ get to() {
+ let res = this.page + this.maxPages;
+ if (this.page < this.maxPages) res += this.maxPages - this.page;
+ return (res < this.total) ? res : this.total;
+ }
+
+
+ makePages() {
+ this.pages = [];
+ if (this.total > 1) {
+ for (let i = this.from; i <= this.to; i++) {
+ this.pages.push(i);
+ }
+ }
+ }
+ setPage(page: number) {
+ this.listsService.setPage(page, this.listId);
+ }
+ nextPage() {
+ this.listsService.setPage(this.currentPage + 1, this.listId);
+ }
+}
diff --git a/src/app/_modules/pagination/pagination.module.ts b/src/app/_modules/pagination/pagination.module.ts
new file mode 100644
index 0000000..7baa8b3
--- /dev/null
+++ b/src/app/_modules/pagination/pagination.module.ts
@@ -0,0 +1,17 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {PaginationComponent} from "@app/_modules/pagination/pagination.component";
+
+
+@NgModule({
+ imports: [
+ CommonModule
+ ],
+ declarations: [
+ PaginationComponent
+ ],
+ exports: [
+ PaginationComponent
+ ]
+})
+export class PaginationModule {}
diff --git a/src/app/_modules/phonebook/list/item/phonebook-list-item.component.html b/src/app/_modules/phonebook/list/item/phonebook-list-item.component.html
new file mode 100644
index 0000000..02c0ac7
--- /dev/null
+++ b/src/app/_modules/phonebook/list/item/phonebook-list-item.component.html
@@ -0,0 +1,7 @@
+{{user?.name}}
+
+ | Отдел | {{department?.title || '—'}} |
+ | Должность | {{member.position || '—'}} |
+ | Внутренний телефон | {{member.intercom || '—'}} |
+ | Кабинет | {{member.room || '—'}} |
+
diff --git a/src/app/_modules/phonebook/list/item/phonebook-list-item.component.scss b/src/app/_modules/phonebook/list/item/phonebook-list-item.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/phonebook/list/item/phonebook-list-item.component.ts b/src/app/_modules/phonebook/list/item/phonebook-list-item.component.ts
new file mode 100644
index 0000000..81db606
--- /dev/null
+++ b/src/app/_modules/phonebook/list/item/phonebook-list-item.component.ts
@@ -0,0 +1,24 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'phonebook-list-item',
+ templateUrl: 'phonebook-list-item.component.html',
+ styleUrls: ['phonebook-list-item.component.scss']
+})
+export class PhonebookListItemComponent {
+ @Input() member: any;
+
+ constructor() {
+ }
+
+ get user() {
+ return this.member?.user?.data;
+ }
+ get department() {
+ return this.member?.department?.data;
+ }
+
+ ngOnInit() {
+ }
+
+}
diff --git a/src/app/_modules/phonebook/list/phonebook-list.component.html b/src/app/_modules/phonebook/list/phonebook-list.component.html
new file mode 100644
index 0000000..60c7f98
--- /dev/null
+++ b/src/app/_modules/phonebook/list/phonebook-list.component.html
@@ -0,0 +1,5 @@
+
+
+
diff --git a/src/app/_modules/phonebook/list/phonebook-list.component.scss b/src/app/_modules/phonebook/list/phonebook-list.component.scss
new file mode 100644
index 0000000..419df0b
--- /dev/null
+++ b/src/app/_modules/phonebook/list/phonebook-list.component.scss
@@ -0,0 +1,11 @@
+.items {
+ margin: 24px 0;
+}
+phonebook-list-item {
+ display: block;
+ padding: 16px 24px;
+ border-bottom: #E8E8E8 solid 1px;
+ &:first-child {
+ border-top: #E8E8E8 solid 1px;
+ }
+}
diff --git a/src/app/_modules/phonebook/list/phonebook-list.component.ts b/src/app/_modules/phonebook/list/phonebook-list.component.ts
new file mode 100644
index 0000000..86d9dbf
--- /dev/null
+++ b/src/app/_modules/phonebook/list/phonebook-list.component.ts
@@ -0,0 +1,47 @@
+import {Component, Input} from '@angular/core';
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+import {CompanyMembersService} from "@app/_services/company-members.service";
+
+@Component({
+ selector: 'phonebook-list',
+ templateUrl: 'phonebook-list.component.html',
+ styleUrls: ['phonebook-list.component.scss']
+})
+export class PhonebookListComponent {
+ @Input() companyId: string;
+ public items = [];
+
+ private controlsSubscription: Subscription;
+ private resultSubscription: Subscription;
+
+ constructor(private membersService: CompanyMembersService, private listsService: ListsService) {
+ }
+
+ get listId() {
+ return 'phonebook-list';
+ }
+
+ ngOnInit() {
+ this.listsService.setFilters({company: this.companyId}, this.listId);
+ this.controlsSubscription = this.listsService.controls(this.listId).subscribe(controls => {
+ this.fetch(controls);
+ });
+ this.resultSubscription = this.listsService.result(this.listId).subscribe(res => {
+ this.items = res?.data || [];
+ });
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ this.resultSubscription?.unsubscribe();
+ }
+
+ fetch(controls: any) {
+ let include = ['user', 'department'];
+ this.membersService.list({page: controls.page || 0, filters: JSON.stringify(controls.filters), include: include.join(',')}).subscribe(res => {
+ this.listsService.result(this.listId).next(res);
+ });
+ }
+
+}
diff --git a/src/app/_modules/phonebook/page/phonebook-page.component.html b/src/app/_modules/phonebook/page/phonebook-page.component.html
new file mode 100644
index 0000000..e9f294a
--- /dev/null
+++ b/src/app/_modules/phonebook/page/phonebook-page.component.html
@@ -0,0 +1,12 @@
+
+
Телефонный справочник
+
+
+
diff --git a/src/app/_modules/phonebook/page/phonebook-page.component.scss b/src/app/_modules/phonebook/page/phonebook-page.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/phonebook/page/phonebook-page.component.ts b/src/app/_modules/phonebook/page/phonebook-page.component.ts
new file mode 100644
index 0000000..414c0d1
--- /dev/null
+++ b/src/app/_modules/phonebook/page/phonebook-page.component.ts
@@ -0,0 +1,31 @@
+import {Component} from '@angular/core';
+import {FormGroup, FormControl} from "@angular/forms";
+import {debounceTime} from "rxjs/operators";
+import {ListsService} from "@app/_services";
+
+@Component({
+ templateUrl: 'phonebook-page.component.html',
+ styleUrls: ['phonebook-page.component.scss']
+})
+export class PhonebookPageComponent {
+ public filters: FormGroup;
+
+ constructor(private listsService: ListsService) {
+ }
+
+ get listId() {
+ return 'phonebook-list';
+ }
+
+ ngOnInit() {
+ this.filters = new FormGroup({search: new FormControl('')});
+ this.filters.valueChanges.pipe(debounceTime(200)).subscribe(val => {
+ this.listsService.addFilters(val, this.listId);
+ });
+ }
+
+ ngOnDestroy() {
+ }
+
+
+}
diff --git a/src/app/_modules/phonebook/phonebook.module.ts b/src/app/_modules/phonebook/phonebook.module.ts
new file mode 100644
index 0000000..ea7058e
--- /dev/null
+++ b/src/app/_modules/phonebook/phonebook.module.ts
@@ -0,0 +1,33 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {RouterModule} from "@angular/router";
+import {AuthGuard} from "@app/_helpers";
+import {BrowserModule} from "@angular/platform-browser";
+import {PhonebookPageComponent} from "@app/_modules/phonebook/page/phonebook-page.component";
+import {ReactiveFormsModule} from "@angular/forms";
+import {PhonebookListComponent} from "@app/_modules/phonebook/list/phonebook-list.component";
+import {PaginationModule} from "@app/_modules/pagination/pagination.module";
+import {PhonebookListItemComponent} from "@app/_modules/phonebook/list/item/phonebook-list-item.component";
+
+const routes = [
+ {path: 'phonebook', component: PhonebookPageComponent, canActivate: [AuthGuard]}
+];
+
+@NgModule({
+ imports: [
+ BrowserModule,
+ CommonModule,
+ ReactiveFormsModule,
+ RouterModule.forRoot(routes),
+ PaginationModule,
+ ],
+ declarations: [
+ PhonebookPageComponent,
+ PhonebookListComponent,
+ PhonebookListItemComponent
+ ],
+ exports: [
+ RouterModule
+ ]
+})
+export class PhonebookModule {}
diff --git a/src/app/_modules/publications/list/item/item.component.html b/src/app/_modules/publications/list/item/item.component.html
new file mode 100644
index 0000000..ebfbd28
--- /dev/null
+++ b/src/app/_modules/publications/list/item/item.component.html
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+ publication type {{item.subtype.name}} is undefined
+
diff --git a/src/app/_modules/publications/list/item/item.component.scss b/src/app/_modules/publications/list/item/item.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/publications/list/item/item.component.ts b/src/app/_modules/publications/list/item/item.component.ts
new file mode 100644
index 0000000..089bcbf
--- /dev/null
+++ b/src/app/_modules/publications/list/item/item.component.ts
@@ -0,0 +1,18 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'publications-list-item',
+ templateUrl: 'item.component.html',
+ styleUrls: ['item.component.scss']
+})
+export class PublicationsListItemComponent {
+ @Input() item: any;
+ @Input() editMode = false;
+
+ constructor(
+ ) {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/publications/list/item/menu/menu.component.html b/src/app/_modules/publications/list/item/menu/menu.component.html
new file mode 100644
index 0000000..d16b598
--- /dev/null
+++ b/src/app/_modules/publications/list/item/menu/menu.component.html
@@ -0,0 +1,7 @@
+
diff --git a/src/app/_modules/publications/list/item/menu/menu.component.scss b/src/app/_modules/publications/list/item/menu/menu.component.scss
new file mode 100644
index 0000000..aafbce6
--- /dev/null
+++ b/src/app/_modules/publications/list/item/menu/menu.component.scss
@@ -0,0 +1,32 @@
+.menu_ {
+ display: flex;
+ .block {
+ margin: 12px 0;
+ background: #F7F8FA;
+ border: 1px solid #CFD1D4;
+ border-radius: 4px;
+ padding: 12px 24px;
+ display: flex;
+ column-gap: 20px;
+ button {
+ &.edit, &.publish, &.unpublish, &.delete {
+ width: 24px;
+ height: 24px;
+ background-position: center;
+ background-repeat: no-repeat;
+ }
+ &.edit {
+ background: url("~src/assets/images/icons/edit_24dp.svg");
+ }
+ &.publish {
+ background: url("~src/assets/images/icons/visibility_on_24dp.svg");
+ }
+ &.unpublish {
+ background: url("~src/assets/images/icons/visibility_off_24dp.svg");
+ }
+ &.delete {
+ background: url("~src/assets/images/icons/trash_24dp.svg");
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/publications/list/item/menu/menu.component.ts b/src/app/_modules/publications/list/item/menu/menu.component.ts
new file mode 100644
index 0000000..6338bd9
--- /dev/null
+++ b/src/app/_modules/publications/list/item/menu/menu.component.ts
@@ -0,0 +1,54 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService} from "@app/_services";
+import {PublicationsService} from "@app/_services/publications.service";
+
+@Component({
+ selector: 'publications-list-item-menu',
+ templateUrl: 'menu.component.html',
+ styleUrls: ['menu.component.scss']
+})
+export class PublicationsListItemMenuComponent {
+ @Input() data: any;
+ @Input() editMode = false;
+
+ constructor(
+ private formsService: FormsService,
+ private publicationsService: PublicationsService,
+ private listsService: ListsService,
+ ) {
+ }
+
+ get listId() {
+ return 'publications-list';
+ }
+
+ ngOnInit() {
+ //console.log(this.data);
+ }
+
+ edit(id: string) {
+ this.formsService.editModel(this.type, id, null, this.listId);
+ }
+
+ get type() {
+ let type = this.data.type;
+ if (this.data?.subtype?.name) type += '-' + this.data.subtype.name;
+ return type;
+ }
+
+ show(id: string, published: boolean) {
+ if (confirm(published?'Опубликовать?':'Снять с публикации?')) {
+ this.publicationsService.published(id, published).subscribe(res => {
+ this.listsService.refresh(this.listId, true);
+ });
+ }
+ }
+
+ delete(id: string) {
+ if (confirm('Вы деествительно хотите удалить эту запись?')) {
+ this.publicationsService.delete(id).subscribe(res => {
+ this.listsService.refresh(this.listId, true);
+ });
+ }
+ }
+}
diff --git a/src/app/_modules/publications/list/item/news/news.component.html b/src/app/_modules/publications/list/item/news/news.component.html
new file mode 100644
index 0000000..b8dfc4a
--- /dev/null
+++ b/src/app/_modules/publications/list/item/news/news.component.html
@@ -0,0 +1,13 @@
+
+
+
+
+
![]()
+
+
+
+
diff --git a/src/app/_modules/publications/list/item/news/news.component.scss b/src/app/_modules/publications/list/item/news/news.component.scss
new file mode 100644
index 0000000..cc1e5da
--- /dev/null
+++ b/src/app/_modules/publications/list/item/news/news.component.scss
@@ -0,0 +1,80 @@
+.item {
+ border-top: 1px solid #E8E8E8;
+ margin-top: 24px;
+ padding-top: 24px;
+ display: flex;
+ flex-direction: column;
+
+ .block {
+ display: flex;
+ column-gap: 24px;
+
+ &.nopublish {
+ opacity: 50%;
+ }
+
+ .photo {
+ img {
+ max-width: 320px;
+ width: 100%;
+ height: auto;
+ }
+ }
+
+ .information {
+ width: 720px;
+ display: flex;
+ flex-direction: column;
+ row-gap: 16px;
+
+ .date {
+ font-weight: 700;
+ font-size: 0.875rem;
+ line-height: 18px;
+ color: #86898E;
+ }
+
+ .title {
+ a {
+ font-weight: 400;
+ font-size: 1.5rem;
+ line-height: 30px;
+ color: var(--grey-7);
+ }
+ }
+
+ .description {
+ font-weight: 400;
+ font-size: 1rem;
+ line-height: 24px;
+ color: var(--grey-7);
+
+ a {
+ color: #86898E;
+ }
+ }
+ }
+ }
+}
+@media screen and (max-width: 768px) {
+ .item {
+ .block {
+ flex-direction: column;
+ row-gap: 12px;
+ .photo {
+ width: 100%;
+ img {
+ width: 100%;
+ }
+ }
+ .information {
+ width: 100%;
+ .title {
+ a {
+ font-size: 18px;
+ }
+ }
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/publications/list/item/news/news.component.ts b/src/app/_modules/publications/list/item/news/news.component.ts
new file mode 100644
index 0000000..7e30c9f
--- /dev/null
+++ b/src/app/_modules/publications/list/item/news/news.component.ts
@@ -0,0 +1,17 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'publications-list-item-news',
+ templateUrl: 'news.component.html',
+ styleUrls: ['news.component.scss']
+})
+export class PublicationsListItemNewsComponent {
+ @Input() item: any;
+ @Input() editMode = false;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/publications/list/item/photos/photos.component.html b/src/app/_modules/publications/list/item/photos/photos.component.html
new file mode 100644
index 0000000..e4ad4a7
--- /dev/null
+++ b/src/app/_modules/publications/list/item/photos/photos.component.html
@@ -0,0 +1,31 @@
+
+
+
+
+
+
+
+
+
![]()
+
+
+
+
Показать все {{item?.assets?.data?.length}} фото
+
+
+
+
+
+
+
+
{{item.name}}. {{activeIndex + 1}} из {{items.length}}
+
![]()
+
+
+
+
+
diff --git a/src/app/_modules/publications/list/item/photos/photos.component.scss b/src/app/_modules/publications/list/item/photos/photos.component.scss
new file mode 100644
index 0000000..77a23bc
--- /dev/null
+++ b/src/app/_modules/publications/list/item/photos/photos.component.scss
@@ -0,0 +1,145 @@
+.item {
+ border-top: 1px solid #E8E8E8;
+ margin-top: 24px;
+ padding-top: 24px;
+ display: flex;
+ flex-direction: column;
+
+ .block {
+ display: flex;
+ flex-direction: column;
+ row-gap: 16px;
+
+ &.nopublish {
+ opacity: 50%;
+ }
+
+ .date {
+ font-weight: 700;
+ font-size: 0.875rem;
+ line-height: 18px;
+ color: #86898E;
+ }
+
+ .title {
+ font-weight: 400;
+ font-size: 1.5rem;
+ line-height: 30px;
+ color: var(--grey-7);
+ }
+
+ .photos {
+ display: flex;
+ gap: 10px;
+ align-items: center;
+ flex-direction: row;
+ flex-wrap: wrap;
+ .photo {
+ width: 128px;
+ height: 128px;
+ overflow: hidden;
+ img {
+ display: block;
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ cursor: pointer;
+ }
+ }
+ }
+
+ .more {
+ font-weight: 400;
+ font-size: 1rem;
+ line-height: 24px;
+ color: #86898E;
+ cursor: pointer;
+ }
+ }
+}
+.fullscreen {
+ top: 0;
+ left: 0;
+ right: 0;
+ bottom: 0;
+ z-index: 2;
+ display: flex;
+ position: fixed;
+ align-items: center;
+ justify-content: center;
+ background-color: rgba(37, 46, 52, 60%);
+ .left, .right {
+ width: 72px;
+ flex-grow: 0;
+ display: flex;
+ cursor: pointer;
+ align-items: center;
+ justify-content: center;
+ .circle {
+ width: 48px;
+ height: 48px;
+ border-radius: 100%;
+ background-position: center;
+ background-repeat: no-repeat;
+ &:hover {
+ background-color: #3e3d40;
+ }
+ }
+ }
+ .left {
+ .circle {
+ background-image: url('/assets/images/icons/chevron_left_white_48dp.svg');
+ }
+ }
+ .right {
+ .circle {
+ background-image: url('/assets/images/icons/chevron_right_white_48dp.svg');
+ }
+ }
+ .circle {
+ align-content: center;
+ justify-content: center;
+ }
+ .center {
+ flex-grow: 1;
+ display: flex;
+ justify-items: center;
+ justify-content: center;
+ text-align: center;
+ width: calc(100% - 144px);
+ .title {
+ color: var(--white);
+ text-align: center;
+ font-size: 1.125rem;
+ font-style: normal;
+ font-weight: 700;
+ line-height: 22px;
+ }
+ img {
+ max-width: 100%;
+ width: auto;
+ height: 100%;
+ max-height: calc(100vh - 2 * 24px);
+ cursor: pointer;
+ }
+ }
+ .close {
+ top: 24px;
+ right: 24px;
+ width: 24px;
+ height: 24px;
+ cursor: pointer;
+ position: absolute;
+ background: url("~src/assets/images/icons/close_white_24dp.svg") no-repeat center;
+ }
+}
+@media screen and (max-width: 768px) {
+ .item {
+ .block {
+ flex-direction: column;
+ .photo {
+
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/publications/list/item/photos/photos.component.ts b/src/app/_modules/publications/list/item/photos/photos.component.ts
new file mode 100644
index 0000000..b1371a6
--- /dev/null
+++ b/src/app/_modules/publications/list/item/photos/photos.component.ts
@@ -0,0 +1,112 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'publications-list-item-photos',
+ templateUrl: 'photos.component.html',
+ styleUrls: ['photos.component.scss']
+})
+export class PublicationsListItemPhotosComponent {
+ @Input() item: any;
+ @Input() editMode = false;
+
+ public parsedPhotos: any[] = [];
+ public activePhoto: string = '';
+ public showFullscreen = false;
+ public showId: string = '';
+ public activeIndex: number = 0;
+ public tmpNumber: number = 0;
+ public nextId:string;
+ public backId:string;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ this.parsed();
+ }
+
+
+
+
+ set photo(activePhoto: string) {
+ this.activePhoto = activePhoto
+ }
+ get photo(): string {
+ return this.activePhoto
+ }
+
+ get items(): any {
+ return this.item.assets.data || [];
+ }
+
+ parsed(): void {
+ this.tmpNumber = 0;
+ this.parsedPhotos = this.items;
+ this.parsedPhotos.map((photo: any) => {
+ if (this.tmpNumber===0) {
+ photo.active = true
+ this.photo = photo.links.full
+ this.showId = photo.id
+ } else {
+ photo.active = false
+ if (this.tmpNumber===1) {
+ this.nextId = photo.id
+ }
+ }
+ this.tmpNumber++
+ if (this.items.length > 1 && this.items.length == this.tmpNumber) {
+ this.backId = photo.id
+ }
+ return photo
+ })
+ }
+
+ show(id: string): void {
+ this.parsedPhotos?.forEach((photo: any) => {
+ if (photo.id === id) {
+ this.photo = photo.links.full
+ this.showFullscreen = true
+ }
+ })
+ }
+
+ showAll() {
+ this.show(this.showId);
+ }
+
+ go(how: string) {
+ this.show(this.showId)
+ switch(how) {
+ case 'decrement':
+ this.activeIndex--
+ if (this.activeIndex < 0) {
+ this.activeIndex = this.parsedPhotos.length - 1
+ }
+ break
+ case 'increment':
+ this.activeIndex++
+ if (this.activeIndex == this.parsedPhotos.length) {
+ this.activeIndex = 0
+ }
+ break
+ }
+
+ this.parsedPhotos = this.parsedPhotos.map((item: any, index: number) => {
+ if (index === this.activeIndex) {
+ item.active = true
+ this.photo = item.links.full
+ this.showId = item.id
+ } else {
+ item.active = false
+ }
+ return item
+ })
+ }
+
+ back(): void {
+ this.go('decrement')
+ }
+ next(): void {
+ this.go('increment')
+ }
+}
diff --git a/src/app/_modules/publications/list/item/portfolio/portfolio.component.html b/src/app/_modules/publications/list/item/portfolio/portfolio.component.html
new file mode 100644
index 0000000..a7e552b
--- /dev/null
+++ b/src/app/_modules/publications/list/item/portfolio/portfolio.component.html
@@ -0,0 +1,15 @@
+
diff --git a/src/app/_modules/publications/list/item/portfolio/portfolio.component.scss b/src/app/_modules/publications/list/item/portfolio/portfolio.component.scss
new file mode 100644
index 0000000..60b5810
--- /dev/null
+++ b/src/app/_modules/publications/list/item/portfolio/portfolio.component.scss
@@ -0,0 +1,65 @@
+.item {
+ border-top: 1px solid #E8E8E8;
+ margin-top: 24px;
+ padding-top: 24px;
+ display: flex;
+ flex-direction: column;
+ .block {
+ display: flex;
+ column-gap: 24px;
+ &.nopublish {
+ opacity: 50%;
+ }
+ .photo {
+ img {
+ width: 320px;
+ height: auto;
+ }
+ }
+ .information {
+ width: 100%;
+ max-width: 720px;
+ display: flex;
+ flex-direction: column;
+ .excerpt {
+ margin-bottom: 24px;
+ }
+ .title, .excerpt {
+ a {
+ color: var(--grey-7);
+ font-size: 1.25rem;
+ font-style: normal;
+ font-weight: 700;
+ line-height: 1.75rem;
+ text-decoration: none;
+ text-wrap: none !important;
+ }
+ }
+ .description {
+ a {
+ color: var(--grey-7);
+ font-size: 1.25rem;
+ font-style: normal;
+ font-weight: 400;
+ line-height: 1.75rem;
+ text-decoration: none;
+ }
+ }
+ }
+ }
+}
+
+@media screen and (max-width: 768px) {
+ .item {
+ .block {
+ flex-direction: column;
+ .photo {
+ img {
+ width: 100%;
+ }
+
+ }
+ }
+ }
+}
+
diff --git a/src/app/_modules/publications/list/item/portfolio/portfolio.component.ts b/src/app/_modules/publications/list/item/portfolio/portfolio.component.ts
new file mode 100644
index 0000000..7a4ecdb
--- /dev/null
+++ b/src/app/_modules/publications/list/item/portfolio/portfolio.component.ts
@@ -0,0 +1,17 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'publications-list-item-portfolio',
+ templateUrl: 'portfolio.component.html',
+ styleUrls: ['portfolio.component.scss']
+})
+export class PublicationsListItemPortfolioComponent {
+ @Input() item: any;
+ @Input() editMode = false;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/publications/list/item/smi/smi.component.html b/src/app/_modules/publications/list/item/smi/smi.component.html
new file mode 100644
index 0000000..7066f18
--- /dev/null
+++ b/src/app/_modules/publications/list/item/smi/smi.component.html
@@ -0,0 +1,14 @@
+
+
+
+
+
![]()
+
+
+
+
diff --git a/src/app/_modules/publications/list/item/smi/smi.component.scss b/src/app/_modules/publications/list/item/smi/smi.component.scss
new file mode 100644
index 0000000..6ee5083
--- /dev/null
+++ b/src/app/_modules/publications/list/item/smi/smi.component.scss
@@ -0,0 +1,58 @@
+.item {
+ border-top: 1px solid #E8E8E8;
+ margin-top: 24px;
+ padding-top: 24px;
+ display: flex;
+ flex-direction: column;
+
+ .block {
+ display: flex;
+ column-gap: 24px;
+
+ &.nopublish {
+ opacity: 50%;
+ }
+
+ .photo {
+ img {
+ width: 320px;
+ height: auto;
+ }
+ }
+
+ .information {
+ width: 720px;
+ display: flex;
+ flex-direction: column;
+ row-gap: 16px;
+
+ .date {
+ font-weight: 700;
+ font-size: 0.875rem;
+ line-height: 18px;
+ color: #86898E;
+ }
+
+ .title {
+ a {
+ font-weight: 400;
+ font-size: 1.5rem;
+ line-height: 30px;
+ color: var(--grey-7);
+ }
+ }
+
+ .description {
+ font-weight: 400;
+ font-size: 1rem;
+ line-height: 24px;
+ color: var(--grey-7)4;
+
+ a {
+ color: #86898E;
+ }
+ }
+ }
+ }
+}
+
diff --git a/src/app/_modules/publications/list/item/smi/smi.component.ts b/src/app/_modules/publications/list/item/smi/smi.component.ts
new file mode 100644
index 0000000..6980b56
--- /dev/null
+++ b/src/app/_modules/publications/list/item/smi/smi.component.ts
@@ -0,0 +1,17 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'publications-list-item-smi',
+ templateUrl: 'smi.component.html',
+ styleUrls: ['smi.component.scss']
+})
+export class PublicationsListItemSmiComponent {
+ @Input() item: any;
+ @Input() editMode = false;
+
+ constructor() {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/publications/list/item/video/video.component.html b/src/app/_modules/publications/list/item/video/video.component.html
new file mode 100644
index 0000000..de1b98e
--- /dev/null
+++ b/src/app/_modules/publications/list/item/video/video.component.html
@@ -0,0 +1,13 @@
+
diff --git a/src/app/_modules/publications/list/item/video/video.component.scss b/src/app/_modules/publications/list/item/video/video.component.scss
new file mode 100644
index 0000000..45dda4a
--- /dev/null
+++ b/src/app/_modules/publications/list/item/video/video.component.scss
@@ -0,0 +1,71 @@
+.item {
+ border-top: 1px solid #E8E8E8;
+ margin-top: 24px;
+ padding-top: 24px;
+ display: flex;
+ flex-direction: column;
+
+ .block {
+ display: flex;
+ flex-direction: row;
+ column-gap: 24px;
+
+ &.nopublish {
+ opacity: 50%;
+ }
+
+ .video {
+ width: calc(50% - 12px);
+ position: relative;
+ &:before {
+ display: block;
+ padding-bottom: 56.25%;
+ content: '';
+ }
+ iframe {
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+ }
+
+ .information {
+ width: calc(50% - 12px);
+ display: flex;
+ flex-direction: column;
+ row-gap: 16px;
+
+ .date {
+ font-weight: 700;
+ font-size: 0.875rem;
+ line-height: 18px;
+ color: #86898E;
+ }
+
+ .description {
+ font-weight: 400;
+ color: var(--grey-7);
+ font-size: 1.5rem;
+ line-height: 30px;
+ }
+ }
+ }
+}
+
+@media screen and (max-width: 768px) {
+ .item {
+ .block {
+ flex-direction: column;
+ row-gap: 12px;
+ .video {
+ width: 100%;
+ }
+ .information {
+ width: 100%;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/publications/list/item/video/video.component.ts b/src/app/_modules/publications/list/item/video/video.component.ts
new file mode 100644
index 0000000..4735847
--- /dev/null
+++ b/src/app/_modules/publications/list/item/video/video.component.ts
@@ -0,0 +1,23 @@
+import {Component, Input} from '@angular/core';
+import {DomSanitizer} from "@angular/platform-browser";
+
+@Component({
+ selector: 'publications-list-item-video',
+ templateUrl: 'video.component.html',
+ styleUrls: ['video.component.scss']
+})
+export class PublicationsListItemVideoComponent {
+ @Input() item: any;
+ @Input() editMode = false;
+
+ constructor(
+ private sanitized: DomSanitizer
+ ) {
+ }
+
+ public url: any = '';
+
+ ngOnInit(): void {
+ this.url = this.sanitized.bypassSecurityTrustResourceUrl(this.item.params.url);
+ }
+}
diff --git a/src/app/_modules/publications/list/list.component.html b/src/app/_modules/publications/list/list.component.html
new file mode 100644
index 0000000..662e729
--- /dev/null
+++ b/src/app/_modules/publications/list/list.component.html
@@ -0,0 +1,8 @@
+
+
diff --git a/src/app/_modules/publications/list/list.component.scss b/src/app/_modules/publications/list/list.component.scss
new file mode 100644
index 0000000..e5a8b34
--- /dev/null
+++ b/src/app/_modules/publications/list/list.component.scss
@@ -0,0 +1,25 @@
+.items {
+ border-bottom: 1px solid #E8E8E8;
+ padding-bottom: 24px;
+ margin-bottom: 24px;
+ .add {
+ margin: 24px 0;
+ width: 100%;
+ .toggle {
+ height: 2px;
+ background-color: #CFD1D4;
+ width: 100%;
+ position: relative;
+ margin-bottom: 24px;
+ .button {
+ top: -11px;
+ left: calc(50% - 12px);
+ position: absolute;
+ width: 24px;
+ height: 24px;
+ background: url("~src/assets/images/icons/add_24dp.svg") no-repeat center #ffffff;
+ cursor: pointer;
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/publications/list/list.component.ts b/src/app/_modules/publications/list/list.component.ts
new file mode 100644
index 0000000..fc767d4
--- /dev/null
+++ b/src/app/_modules/publications/list/list.component.ts
@@ -0,0 +1,62 @@
+import {Component, Input} from '@angular/core';
+import {Subscription} from "rxjs";
+import {FormsService, ListsService} from "@app/_services";
+import {PublicationsService} from "@app/_services/publications.service";
+
+@Component({
+ selector: 'publications-list',
+ templateUrl: 'list.component.html',
+ styleUrls: ['list.component.scss']
+})
+export class PublicationsListComponent {
+ @Input() page: any;
+ @Input() editMode = false;
+
+ controlsSubscription?: Subscription;
+ resultsSubscription?: Subscription;
+
+ public result: any;
+
+ constructor(private publicationsService: PublicationsService, private listsService: ListsService, private formsService: FormsService) {
+ }
+
+ get listId() {
+ return 'publications-list';
+ }
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls(this.listId).subscribe(controls => {
+ this.fetch(controls);
+ });
+ this.resultsSubscription = this.listsService.result(this.listId).subscribe(val => {
+ this.result = val;
+ });
+ }
+
+ ngOnChanges() {
+ this.listsService.result(this.listId).next(null);
+ this.listsService.setFilters({page: this.page?.id}, this.listId);
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ this.resultsSubscription?.unsubscribe();
+ }
+
+
+ get items() {
+ return this.result?.data;
+ }
+
+
+ add() {
+ this.formsService.createModel(this.page.subType, {extraProps: {attach: {pageId: this.page.id}}}, this.listId);
+ }
+
+ fetch(controls) {
+ let params = {page: controls.page || 0, filters: JSON.stringify(controls.filters), pageId: this.page?.id || null};
+ this.publicationsService.list(params).subscribe(result => {
+ this.listsService.result(this.listId).next(result);
+ })
+ }
+}
diff --git a/src/app/_modules/publications/publication/publication.component.html b/src/app/_modules/publications/publication/publication.component.html
new file mode 100644
index 0000000..4eb7303
--- /dev/null
+++ b/src/app/_modules/publications/publication/publication.component.html
@@ -0,0 +1,5 @@
+
diff --git a/src/app/_modules/publications/publication/publication.component.scss b/src/app/_modules/publications/publication/publication.component.scss
new file mode 100644
index 0000000..37df446
--- /dev/null
+++ b/src/app/_modules/publications/publication/publication.component.scss
@@ -0,0 +1,14 @@
+.dual-cols {
+ display: flex;
+ flex-direction: row;
+ width: 100%;
+
+ .col {
+ flex-grow: 1;
+ }
+}
+@media screen and (max-width: 768px) {
+ .dual-cols {
+ flex-direction: column;
+ }
+}
diff --git a/src/app/_modules/publications/publication/publication.component.ts b/src/app/_modules/publications/publication/publication.component.ts
new file mode 100644
index 0000000..9bc0927
--- /dev/null
+++ b/src/app/_modules/publications/publication/publication.component.ts
@@ -0,0 +1,18 @@
+import {Component, Input} from '@angular/core';
+
+@Component({
+ selector: 'publication-page',
+ templateUrl: 'publication.component.html',
+ styleUrls: ['publication.component.scss']
+})
+export class PublicationsPublicationComponent {
+ @Input() page: any;
+ @Input() editMode = false;
+
+ constructor(
+ ) {
+ }
+
+ ngOnInit() {
+ }
+}
diff --git a/src/app/_modules/publications/publications.module.ts b/src/app/_modules/publications/publications.module.ts
new file mode 100644
index 0000000..bdf779c
--- /dev/null
+++ b/src/app/_modules/publications/publications.module.ts
@@ -0,0 +1,39 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+
+import {PublicationsListComponent} from "@app/_modules/publications/list/list.component";
+import {PublicationsListItemComponent} from "@app/_modules/publications/list/item/item.component";
+import {PublicationsListItemMenuComponent} from "@app/_modules/publications/list/item/menu/menu.component";
+import {PublicationsListItemNewsComponent} from "@app/_modules/publications/list/item/news/news.component";
+import {PublicationsListItemPhotosComponent} from "@app/_modules/publications/list/item/photos/photos.component";
+import {PublicationsListItemVideoComponent} from "@app/_modules/publications/list/item/video/video.component";
+import {PublicationsListItemSmiComponent} from "@app/_modules/publications/list/item/smi/smi.component";
+import {PaginationModule} from "@app/_modules/pagination/pagination.module";
+import {PublicationsPublicationComponent} from "@app/_modules/publications/publication/publication.component";
+import {PageSectionsModule} from "@app/_modules/pages/sections/page-sections.module";
+import {PublicationsListItemPortfolioComponent} from "@app/_modules/publications/list/item/portfolio/portfolio.component";
+
+@NgModule({
+ imports: [
+ CommonModule,
+ PaginationModule,
+ PageSectionsModule
+ ],
+ declarations: [
+ PublicationsListComponent,
+ PublicationsListItemComponent,
+ PublicationsListItemMenuComponent,
+ PublicationsListItemNewsComponent,
+ PublicationsListItemPhotosComponent,
+ PublicationsListItemVideoComponent,
+ PublicationsListItemSmiComponent,
+ PublicationsListComponent,
+ PublicationsPublicationComponent,
+ PublicationsListItemPortfolioComponent,
+ ],
+ exports: [
+ PublicationsListComponent,
+ PublicationsPublicationComponent,
+ ]
+})
+export class PublicationsModule {}
diff --git a/src/app/_modules/registries/registries.module.ts b/src/app/_modules/registries/registries.module.ts
new file mode 100644
index 0000000..c9cfeb4
--- /dev/null
+++ b/src/app/_modules/registries/registries.module.ts
@@ -0,0 +1,42 @@
+import {NgModule} from '@angular/core';
+import {BrowserModule} from "@angular/platform-browser";
+import {RouterModule} from "@angular/router";
+import {RegistryComponent} from "@app/_modules/registries/registry/registry.component";
+import {RegistryCategoriesComponent} from "@app/_modules/registries/registry/categories/registry-categories.component";
+import {RegistryEntriesComponent} from "@app/_modules/registries/registry/entries/registry-entries.component";
+import {RegistryEntryComponent} from "@app/_modules/registries/registry/entries/entry/registry-entry.component";
+import {EntryOperationsComponent} from "@app/_modules/registries/registry/operations/entry-operations.component";
+import {RegistryCategoryComponent} from "@app/_modules/registries/registry/categories/category/registry-category.component";
+import {EntryOperationComponent} from "@app/_modules/registries/registry/operations/operation/entry-operation.component";
+import {RegistryFiltersComponent} from "@app/_modules/registries/registry/filters/registry-filters.component";
+import {PaginationModule} from "@app/_modules/pagination/pagination.module";
+import {SortablejsModule} from "ngx-sortablejs";
+import {ReactiveFormsModule} from "@angular/forms";
+import {EntryPropertiesComponent} from "@app/_modules/registries/registry/entries/entry/properties/entry-properties.component";
+
+@NgModule({
+ imports: [
+ BrowserModule,
+ RouterModule,
+ ReactiveFormsModule,
+ PaginationModule,
+ SortablejsModule
+ ],
+ declarations: [
+ RegistryComponent,
+ RegistryCategoriesComponent,
+ RegistryEntriesComponent,
+ RegistryEntryComponent,
+ EntryOperationsComponent,
+ RegistryCategoryComponent,
+ EntryOperationComponent,
+ RegistryFiltersComponent,
+ EntryPropertiesComponent
+ ],
+ exports: [
+ RegistryComponent,
+ RegistryEntriesComponent
+ ]
+})
+export class RegistriesModule {
+}
diff --git a/src/app/_modules/registries/registry/categories/category/registry-category.component.html b/src/app/_modules/registries/registry/categories/category/registry-category.component.html
new file mode 100644
index 0000000..ffba81d
--- /dev/null
+++ b/src/app/_modules/registries/registry/categories/category/registry-category.component.html
@@ -0,0 +1,15 @@
+
+
{{category.name}}
+
+
+
+
+
+
+
diff --git a/src/app/_modules/registries/registry/categories/category/registry-category.component.scss b/src/app/_modules/registries/registry/categories/category/registry-category.component.scss
new file mode 100644
index 0000000..3062284
--- /dev/null
+++ b/src/app/_modules/registries/registry/categories/category/registry-category.component.scss
@@ -0,0 +1,3 @@
+.bar {
+ cursor: pointer;
+}
diff --git a/src/app/_modules/registries/registry/categories/category/registry-category.component.ts b/src/app/_modules/registries/registry/categories/category/registry-category.component.ts
new file mode 100644
index 0000000..07626c7
--- /dev/null
+++ b/src/app/_modules/registries/registry/categories/category/registry-category.component.ts
@@ -0,0 +1,61 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService} from "@app/_services";
+import {RegistryCategoriesService} from "@app/_services/registry-categories.service";
+
+@Component({
+ selector: 'registry-category',
+ templateUrl: 'registry-category.component.html',
+ styleUrls: ['../../registry.component.scss', 'registry-category.component.scss']
+})
+export class RegistryCategoryComponent {
+ @Input() registry: any;
+ @Input() parent: any;
+ @Input() category: any;
+ @Input() editMode = false;
+ public isExpanded = false;
+
+ constructor(private categoriesService: RegistryCategoriesService, private formsService: FormsService, private listsService: ListsService) {
+ }
+
+ get parentListId() {
+ return (this.parent?.id || this.registry?.id) + '-categories';
+ }
+ get categoriesListId() {
+ return this.category.id + '-categories';
+ }
+ get entriesListId() {
+ return this.category.id + '-entries';
+ }
+
+
+ ngOnInit() {
+
+ }
+
+
+ edit() {
+ this.formsService.editModel('registryCategory', this.category.id, null, this.parentListId);
+ }
+
+ addCategory() {
+ this.isExpanded = true;
+ this.formsService.createModel('registryCategory', {extraProps: {registry: this.registry.id, parent: this.category.id}}, this.categoriesListId);
+ }
+
+ addEntry() {
+ this.isExpanded = true;
+ this.formsService.createModel('registryEntry', {extraProps: {registry: this.registry.id, category: this.category.id}}, this.entriesListId);
+ }
+
+ delete() {
+ if (confirm('Удалить категорию?')) this.categoriesService.delete(this.category.id).subscribe(res => {
+ this.listsService.refresh(this.parentListId, true);
+ });
+ }
+
+
+ toggle() {
+ this.isExpanded = !this.isExpanded;
+ }
+
+}
diff --git a/src/app/_modules/registries/registry/categories/registry-categories.component.html b/src/app/_modules/registries/registry/categories/registry-categories.component.html
new file mode 100644
index 0000000..63249d9
--- /dev/null
+++ b/src/app/_modules/registries/registry/categories/registry-categories.component.html
@@ -0,0 +1,3 @@
+
+
+
diff --git a/src/app/_modules/registries/registry/categories/registry-categories.component.scss b/src/app/_modules/registries/registry/categories/registry-categories.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/registries/registry/categories/registry-categories.component.ts b/src/app/_modules/registries/registry/categories/registry-categories.component.ts
new file mode 100644
index 0000000..65977d3
--- /dev/null
+++ b/src/app/_modules/registries/registry/categories/registry-categories.component.ts
@@ -0,0 +1,61 @@
+import {Component, Input} from '@angular/core';
+import {RegistryCategoriesService} from "@app/_services/registry-categories.service";
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+import {SortableOptions} from "sortablejs";
+
+@Component({
+ selector: 'registry-categories',
+ templateUrl: 'registry-categories.component.html',
+ styleUrls: ['registry-categories.component.scss']
+})
+export class RegistryCategoriesComponent {
+ @Input() registry: any;
+ @Input() parent: any;
+ @Input() editMode = false;
+ public categories = [];
+
+ public options: SortableOptions = {
+ group: 'registry-categories',
+ handle: '.move',
+ onUpdate: (event: any) => {
+ this.move(event);
+ },
+ onAdd: (event: any) => {
+ this.move(event);
+ }
+ };
+
+ subscription: Subscription;
+
+ constructor(private categoriesService: RegistryCategoriesService, private listsService: ListsService) {
+ }
+
+ get listId() {
+ return (this.parent?.id || this.registry?.id) + '-categories';
+ }
+
+ ngOnInit() {
+ this.subscription = this.listsService.controls(this.listId).subscribe(controls => {
+ this.fetch();
+ });
+ }
+
+ ngOnDestroy() {
+ this.subscription?.unsubscribe();
+ }
+
+ fetch() {
+ this.categoriesService.list({registry: this.registry.id, parent: this.parent?.id}).subscribe(res => {
+ this.categories = res.data;
+ });
+ }
+
+
+ move(event: any) {
+ this.categoriesService.move(event.item.id, {registry: this.registry.id, category: this.parent?.id, ord: event.newIndex}).subscribe(res => {
+ //this.listsService.refresh((this.parent?.id || this.registry?.id) + '-categories');
+ });
+ }
+
+}
diff --git a/src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.html b/src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.html
new file mode 100644
index 0000000..a2ee593
--- /dev/null
+++ b/src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.html
@@ -0,0 +1,13 @@
+
+
+ | {{field.title}} |
+
+
+ |
+ {{getValue(field)}} |
+
+
diff --git a/src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.scss b/src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.ts b/src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.ts
new file mode 100644
index 0000000..cc82783
--- /dev/null
+++ b/src/app/_modules/registries/registry/entries/entry/properties/entry-properties.component.ts
@@ -0,0 +1,41 @@
+import {Component, Input} from '@angular/core';
+import {RegistryEntriesService} from "@app/_services/registry-entries.service";
+import {ObjectsService} from "@app/_services";
+import {DatePipe} from "@angular/common";
+
+@Component({
+ selector: 'entry-properties',
+ templateUrl: 'entry-properties.component.html',
+ styleUrls: ['entry-properties.component.scss']
+})
+export class EntryPropertiesComponent {
+ @Input() entry: any;
+
+ constructor(private entriesService: RegistryEntriesService, private objectsService: ObjectsService, private datePipe: DatePipe) {
+ }
+
+ get fields() {
+ return this.objectsService.parsedFields(this.entry.properties?.data).filter(field => {return field.value?.length || field.value?.id});
+ }
+
+ ngOnInit() {
+ this.fetch();
+ }
+
+ fetch() {
+ let include = ['properties.groups.fields.value'];
+ this.entriesService.show(this.entry.id, {include: include.join(',')}).subscribe(res => {
+ this.entry = res.data;
+ });
+ }
+
+
+ getValue(field: any) {
+ let value = Array.isArray(field.value) ? field.value : [field.value];
+ return value.filter(val => {return val?.length || val?.id;}).map(val => {
+ if (field.type === 'date') return this.datePipe.transform(val, 'dd.MM.yyyy');
+ else return val?.caption || val?.title || val;
+ }).join('; ');
+ }
+
+}
diff --git a/src/app/_modules/registries/registry/entries/entry/registry-entry.component.html b/src/app/_modules/registries/registry/entries/entry/registry-entry.component.html
new file mode 100644
index 0000000..a57d001
--- /dev/null
+++ b/src/app/_modules/registries/registry/entries/entry/registry-entry.component.html
@@ -0,0 +1,34 @@
+
+
+
+
{{entry.state?.title}}
+
+
+ | Дата выдачи | {{activeSince || '—'}} |
+ | Срок действия | {{activeTill || '—'}} |
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/registries/registry/entries/entry/registry-entry.component.scss b/src/app/_modules/registries/registry/entries/entry/registry-entry.component.scss
new file mode 100644
index 0000000..8dbf07f
--- /dev/null
+++ b/src/app/_modules/registries/registry/entries/entry/registry-entry.component.scss
@@ -0,0 +1,45 @@
+.main {
+ .name {
+ margin-right: 24px;
+ }
+ .toggle {
+ margin-left: auto;
+ button {
+ display: block;
+ width: 20px;
+ height: 20px;
+ padding: 0;
+ background: transparent url('~src/assets/images/icons/expand_less_20.svg') 50% 50% no-repeat;
+ transform: rotateZ(180deg);
+ transition: transform 0.3s;
+ &.less {
+ transform: rotateZ(0);
+ }
+ }
+ }
+ .state {
+ display: inline-block;
+ padding: 0 8px;
+ border-radius: 10px;
+ background-color: #777777;
+ color: #ffffff;
+ font-size: 0.875rem;
+ font-weight: 700;
+ &.active {background-color: #28A814;}
+ &.suspended,&.cancelled {background-color: #D9235F;}
+ }
+}
+
+.details {
+ padding: 16px 0 0;
+}
+
+.block {
+ margin-bottom: 16px;
+ &:last-child {margin-bottom: 0}
+ &.row {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ }
+}
diff --git a/src/app/_modules/registries/registry/entries/entry/registry-entry.component.ts b/src/app/_modules/registries/registry/entries/entry/registry-entry.component.ts
new file mode 100644
index 0000000..fbfa625
--- /dev/null
+++ b/src/app/_modules/registries/registry/entries/entry/registry-entry.component.ts
@@ -0,0 +1,82 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService} from "@app/_services";
+import {RegistryEntriesService} from "@app/_services/registry-entries.service";
+import {DatePipe} from "@angular/common";
+
+@Component({
+ selector: 'registry-entry',
+ templateUrl: 'registry-entry.component.html',
+ styleUrls: ['registry-entry.component.scss']
+})
+export class RegistryEntryComponent {
+ @Input() registry: any;
+ @Input() category: any;
+ @Input() entry: any;
+ @Input() editMode = false;
+
+ public isExpanded = false;
+
+ constructor(private entriesService: RegistryEntriesService, private formsService: FormsService, private listsService: ListsService, private datePipe: DatePipe) {
+ }
+
+
+ get operationsListId() {
+ return this.entry.id;
+ }
+ get parentListId() {
+ return (this.category?.id || this.registry?.id) + '-entries';
+ }
+
+ get isExpandable() {
+ return this.registryOptions?.properties || this.registryOptions?.operations
+ }
+
+ get title() {
+ return this.entry.number ? `${this.entry.number} «${this.entry.name}»` : this.entry.name;
+ }
+ get activeSince() {
+ return this.entry.activeSince ? this.datePipe.transform(this.entry.activeSince, 'dd.MM.yyyy') : null;
+ }
+ get activeTill() {
+ return this.entry.activeTill ? this.datePipe.transform(this.entry.activeTill, 'dd.MM.yyyy') : null;
+ }
+ get asset() {
+ return this.entry.asset?.data;
+ }
+ get link() {
+ return this.asset?.links?.open || this.entry.link;
+ }
+
+ get registryOptions() {
+ return this.registry?.type?.options || this.entry?.registry?.data.type?.options;
+ }
+
+
+ ngOnInit() {
+
+ }
+
+
+ add() {
+ if (this.isExpandable) this.isExpanded = true;
+ this.formsService.createModel('entryOperation', {extraProps: {entry: this.entry.id}}, this.operationsListId);
+ }
+
+ edit() {
+ this.formsService.editModel('registryEntry', this.entry.id, {extraProps: {registry: this.registry?.id}}, this.parentListId);
+ }
+
+ delete() {
+ if (confirm('r u sure?')) {
+ this.entriesService.delete(this.entry.id).subscribe(res => {
+ this.listsService.refresh(this.parentListId);
+ });
+ }
+ }
+
+
+ toggle() {
+ this.isExpanded = !this.isExpanded;
+ }
+
+}
diff --git a/src/app/_modules/registries/registry/entries/registry-entries.component.html b/src/app/_modules/registries/registry/entries/registry-entries.component.html
new file mode 100644
index 0000000..c3a55ed
--- /dev/null
+++ b/src/app/_modules/registries/registry/entries/registry-entries.component.html
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/registries/registry/entries/registry-entries.component.scss b/src/app/_modules/registries/registry/entries/registry-entries.component.scss
new file mode 100644
index 0000000..b4cf463
--- /dev/null
+++ b/src/app/_modules/registries/registry/entries/registry-entries.component.scss
@@ -0,0 +1,29 @@
+.items {
+ min-height: 20px;
+}
+
+registry-entry {
+ display: block;
+ padding: 16px 24px;
+ border-bottom: #E8E8E8 solid 1px;
+ &:first-child {
+ border-top: #E8E8E8 solid 1px;
+ }
+}
+
+pagination {
+ display: block;
+ padding: 0 24px;
+ &:first-child {
+ margin-bottom: 12px;
+ }
+ &:last-child {
+ margin-top: 12px;
+ }
+}
+
+@media screen and (max-width: 960px) {
+ registry-entry {
+ padding: 16px 0;
+ }
+}
diff --git a/src/app/_modules/registries/registry/entries/registry-entries.component.ts b/src/app/_modules/registries/registry/entries/registry-entries.component.ts
new file mode 100644
index 0000000..57a50f7
--- /dev/null
+++ b/src/app/_modules/registries/registry/entries/registry-entries.component.ts
@@ -0,0 +1,67 @@
+import {Component, Input} from '@angular/core';
+import {Subscription} from "rxjs";
+import {RegistryEntriesService} from "@app/_services/registry-entries.service";
+import {ListsService} from "@app/_services";
+import {SortableOptions} from "sortablejs";
+
+@Component({
+ selector: 'registry-entries',
+ templateUrl: 'registry-entries.component.html',
+ styleUrls: ['registry-entries.component.scss']
+})
+export class RegistryEntriesComponent {
+ @Input() registry: any;
+ @Input() category: any;
+ @Input() editMode = false;
+ public entries = [];
+
+ public options: SortableOptions = {
+ group: 'registry-entries',
+ handle: '.move',
+ sort: false,
+ onAdd: (event: any) => {
+ this.move(event);
+ }
+ };
+
+ private controlsSubscription: Subscription;
+ private resultSubscription: Subscription;
+
+ constructor(private entriesService: RegistryEntriesService, private listsService: ListsService) {
+ }
+
+ get listId() {
+ return (this.category?.id || this.registry?.id || 'common') + '-entries';
+ }
+
+ ngOnInit() {
+ this.listsService.addFilters({registry: this.registry?.id, category: this.category?.id}, this.listId);
+ this.controlsSubscription = this.listsService.controls(this.listId).subscribe(controls => {
+ this.fetch(controls);
+ });
+ this.resultSubscription = this.listsService.result(this.listId).subscribe(res => {
+ this.entries = res?.data || [];
+ });
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ this.resultSubscription?.unsubscribe();
+ }
+
+ fetch(controls: any) {
+ let include = ['asset'];
+ if (!this.registry) include.push('registry');
+ this.entriesService.list({page: controls.page || 0, filters: JSON.stringify(controls.filters), include: include.join(',')}).subscribe(res => {
+ this.listsService.result(this.listId).next(res);
+ });
+ }
+
+
+ move(event: any) {
+ this.entriesService.move(event.item.id, {category: this.category?.id}).subscribe(res => {
+ });
+ }
+
+
+}
diff --git a/src/app/_modules/registries/registry/filters/registry-filters.component.html b/src/app/_modules/registries/registry/filters/registry-filters.component.html
new file mode 100644
index 0000000..4769176
--- /dev/null
+++ b/src/app/_modules/registries/registry/filters/registry-filters.component.html
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/registries/registry/filters/registry-filters.component.scss b/src/app/_modules/registries/registry/filters/registry-filters.component.scss
new file mode 100644
index 0000000..b70f6f8
--- /dev/null
+++ b/src/app/_modules/registries/registry/filters/registry-filters.component.scss
@@ -0,0 +1,5 @@
+@media screen and (max-width: 500px) {
+ button span {
+ display: none;
+ }
+}
diff --git a/src/app/_modules/registries/registry/filters/registry-filters.component.ts b/src/app/_modules/registries/registry/filters/registry-filters.component.ts
new file mode 100644
index 0000000..70a1eee
--- /dev/null
+++ b/src/app/_modules/registries/registry/filters/registry-filters.component.ts
@@ -0,0 +1,27 @@
+import {Component, Input} from '@angular/core';
+import {FormGroup} from "@angular/forms";
+import {FiltersService} from "@app/_services";
+
+@Component({
+ selector: 'registry-filters',
+ templateUrl: 'registry-filters.component.html',
+ styleUrls: ['registry-filters.component.scss']
+})
+export class RegistryFiltersComponent {
+ @Input() registry: any;
+ @Input() filters: FormGroup;
+ @Input() hasCustomFilters: boolean;
+ @Input() isFiltersApplied: boolean;
+ @Input() listId: string;
+
+ constructor(private filtersService: FiltersService) {
+ }
+
+ ngOnInit() {
+ }
+
+ showFilters() {
+ this.filtersService.slider('model', 'registryEntries', {extraProps: {registry: this.registry.id}}, this.listId);
+ }
+
+}
diff --git a/src/app/_modules/registries/registry/operations/entry-operations.component.html b/src/app/_modules/registries/registry/operations/entry-operations.component.html
new file mode 100644
index 0000000..d95560c
--- /dev/null
+++ b/src/app/_modules/registries/registry/operations/entry-operations.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/_modules/registries/registry/operations/entry-operations.component.scss b/src/app/_modules/registries/registry/operations/entry-operations.component.scss
new file mode 100644
index 0000000..6c154d6
--- /dev/null
+++ b/src/app/_modules/registries/registry/operations/entry-operations.component.scss
@@ -0,0 +1,7 @@
+entry-operation {
+ display: block;
+ margin-bottom: 24px;
+ &:last-child {
+ margin-bottom: 0;
+ }
+}
diff --git a/src/app/_modules/registries/registry/operations/entry-operations.component.ts b/src/app/_modules/registries/registry/operations/entry-operations.component.ts
new file mode 100644
index 0000000..0258014
--- /dev/null
+++ b/src/app/_modules/registries/registry/operations/entry-operations.component.ts
@@ -0,0 +1,46 @@
+import {Component, Input} from '@angular/core';
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+import {RegistryEntriesService} from "@app/_services/registry-entries.service";
+
+@Component({
+ selector: 'entry-operations',
+ templateUrl: 'entry-operations.component.html',
+ styleUrls: ['entry-operations.component.scss']
+})
+export class EntryOperationsComponent {
+ @Input() entry: any;
+ @Input() editMode = false;
+
+ subscription: Subscription;
+
+ constructor(private entriesService: RegistryEntriesService, private listsService: ListsService) {
+ }
+
+ get listId() {
+ return this.entry.id;
+ }
+
+ get operations() {
+ return this.entry.operations?.data;
+ }
+
+ ngOnInit() {
+ this.subscription = this.listsService.controls(this.listId).subscribe(res => {
+ this.fetch();
+ });
+ }
+
+ ngOnDestroy() {
+ this.subscription?.unsubscribe();
+ }
+
+ fetch() {
+ let include = ['operations.groups.fields.value'];
+ this.entriesService.show(this.entry.id, {include: include.join(',')}).subscribe(res => {
+ this.entry = res.data;
+ });
+ }
+
+
+}
diff --git a/src/app/_modules/registries/registry/operations/operation/entry-operation.component.html b/src/app/_modules/registries/registry/operations/operation/entry-operation.component.html
new file mode 100644
index 0000000..44c2c94
--- /dev/null
+++ b/src/app/_modules/registries/registry/operations/operation/entry-operation.component.html
@@ -0,0 +1,22 @@
+{{type?.title || 'Вид не указан'}}
+
+
+ | Приказ |
+
+ {{orderName}} от {{orderDate}}
+ {{orderName}} от {{orderDate}}
+ |
+
+
+ | Вхождение в перечень ПП |
+ {{listing.title}} |
+ — |
+
+ | Действует с | {{activeSince || '—'}} |
+ | Действует по | {{activeTill || '—'}} |
+ | Разработчик | {{developer || '—'}} |
+
+
diff --git a/src/app/_modules/registries/registry/operations/operation/entry-operation.component.scss b/src/app/_modules/registries/registry/operations/operation/entry-operation.component.scss
new file mode 100644
index 0000000..2bda579
--- /dev/null
+++ b/src/app/_modules/registries/registry/operations/operation/entry-operation.component.scss
@@ -0,0 +1,11 @@
+.title {
+ margin-bottom: 6px;
+ font-weight: 700;
+}
+.document {
+ display: flex;
+ margin-bottom: 8px;
+ &:last-child {
+ margin-bottom: 0;
+ }
+}
diff --git a/src/app/_modules/registries/registry/operations/operation/entry-operation.component.ts b/src/app/_modules/registries/registry/operations/operation/entry-operation.component.ts
new file mode 100644
index 0000000..6a9af79
--- /dev/null
+++ b/src/app/_modules/registries/registry/operations/operation/entry-operation.component.ts
@@ -0,0 +1,66 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService, ObjectsService} from "@app/_services";
+import {DatePipe} from "@angular/common";
+
+@Component({
+ selector: 'entry-operation',
+ templateUrl: 'entry-operation.component.html',
+ styleUrls: ['entry-operation.component.scss']
+})
+export class EntryOperationComponent {
+ @Input() entry: any;
+ @Input() operation: any;
+ @Input() editMode = false;
+
+ constructor(private formsService: FormsService, private listsService: ListsService,
+ private objectsService: ObjectsService, private datePipe: DatePipe) {
+ }
+
+ get type() {
+ return this.getValue('operation-type');
+ }
+ get orderName() {
+ return this.getValue('order-name');
+ }
+ get orderDate() {
+ let v = this.getValue('order-date');
+ return v ? this.datePipe.transform(v, 'dd.MM.yyyy') : null;
+ }
+ get activeSince() {
+ let v = this.getValue('active-since');
+ return v ? this.datePipe.transform(v, 'dd.MM.yyyy') : null;
+ }
+ get activeTill() {
+ let v = this.getValue('active-till');
+ return v ? this.datePipe.transform(v, 'dd.MM.yyyy') : null;
+ }
+ get developer() {
+ return this.getValue('developer');
+ }
+ get orderDocument() {
+ return this.getValue('order-document');
+ }
+ get listings() {
+ return this.getValue('listings');
+ }
+
+ ngOnInit() {
+
+ }
+
+ getValue(name) {
+ return this.objectsService.getValue(this.operation, name);
+ }
+
+
+ edit() {
+ this.formsService.editModel('entryOperation', this.operation.id, {extraProps: {entry: this.entry.id}}, this.entry.id);
+ }
+
+ delete() {
+ if (confirm('r u sure?')) this.objectsService.destroy(this.operation.id).subscribe(res => {
+ this.listsService.refresh(this.entry.id);
+ });
+ }
+
+}
diff --git a/src/app/_modules/registries/registry/registry.component.html b/src/app/_modules/registries/registry/registry.component.html
new file mode 100644
index 0000000..0d34b77
--- /dev/null
+++ b/src/app/_modules/registries/registry/registry.component.html
@@ -0,0 +1,14 @@
+
diff --git a/src/app/_modules/registries/registry/registry.component.scss b/src/app/_modules/registries/registry/registry.component.scss
new file mode 100644
index 0000000..793da2c
--- /dev/null
+++ b/src/app/_modules/registries/registry/registry.component.scss
@@ -0,0 +1,37 @@
+registry-entries {
+ display: block;
+ padding-bottom: 24px;
+}
+
+.bar {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 24px;
+ margin-bottom: 24px;
+ border-radius: 20px;
+ .name {
+ margin-right: auto;
+ font-size: 1.125rem;
+ font-weight: 700;
+ }
+ .menu {
+ display: flex;
+ flex-direction: row;
+ gap: 24px;
+ button {
+ width: 24px;
+ height: 24px;
+ }
+ }
+ .expand {
+ margin-left: 48px;
+ button {
+ width: 24px;
+ height: 24px;
+ transform: rotateZ(180deg);
+ transition: transform 0.3s;
+ &.less {transform: rotateZ(0);}
+ }
+ }
+}
diff --git a/src/app/_modules/registries/registry/registry.component.ts b/src/app/_modules/registries/registry/registry.component.ts
new file mode 100644
index 0000000..1e42538
--- /dev/null
+++ b/src/app/_modules/registries/registry/registry.component.ts
@@ -0,0 +1,77 @@
+import {Component, Input} from '@angular/core';
+import {FormsService, ListsService} from "@app/_services";
+import {Subscription} from "rxjs";
+import {FormGroup, FormControl} from "@angular/forms";
+import {debounceTime} from "rxjs/operators";
+
+@Component({
+ selector: 'registry',
+ templateUrl: 'registry.component.html',
+ styleUrls: ['registry.component.scss']
+})
+export class RegistryComponent {
+ @Input() registry: any;
+ @Input() editMode = false;
+
+ public filters: FormGroup;
+ public isFiltersApplied = false;
+
+ controlsSubscription: Subscription;
+
+ constructor(private formsService: FormsService, private listsService: ListsService) {
+ }
+
+ get listId() {
+ return this.registry.id;
+ }
+ get categoriesListId() {
+ return this.listId + '-categories';
+ }
+ get entriesListId() {
+ return this.listId + '-entries';
+ }
+
+ get options() {
+ return this.registry.type?.options;
+ }
+ get hasCategories() {
+ return !!this.options?.categories;
+ }
+ get hasCustomFilters() {
+ return !!(this.options?.states || this.options?.operations || this.options?.properties);
+ }
+
+
+
+ ngOnInit() {
+ this.filters = new FormGroup({search: new FormControl(), 'registry': new FormControl(this.registry.id)});
+ this.filters.valueChanges.pipe(debounceTime(200)).subscribe(val => {
+ this.listsService.addFilters(val, this.entriesListId);
+ });
+ this.controlsSubscription = this.listsService.controls(this.entriesListId).subscribe(controls => {
+ this.detectFilters(controls.filters);
+ });
+ }
+
+ ngOnDestroy() {
+ this.controlsSubscription?.unsubscribe();
+ }
+
+
+ detectFilters(filters: any) {
+ this.isFiltersApplied = false;
+ for (let prop in filters) {
+ if (filters.hasOwnProperty(prop) && (filters[prop]?.length || filters[prop]?.gt || filters[prop]?.lt) && (['registry', 'category', 'types'].indexOf(prop) === -1)) this.isFiltersApplied = true;
+ }
+ }
+
+
+ addCategory() {
+ this.formsService.createModel('registryCategory', {extraProps: {registry: this.registry.id}}, this.categoriesListId);
+ }
+
+ addEntry() {
+ this.formsService.createModel('registryEntry', {extraProps: {registry: this.registry.id}}, this.entriesListId);
+ }
+
+}
diff --git a/src/app/_modules/search/page/search-page.component.html b/src/app/_modules/search/page/search-page.component.html
new file mode 100644
index 0000000..9c19859
--- /dev/null
+++ b/src/app/_modules/search/page/search-page.component.html
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+
+По запросу "{{searchString}}" результатов не найдено. Попробуйте задать менее строгий запрос
diff --git a/src/app/_modules/search/page/search-page.component.scss b/src/app/_modules/search/page/search-page.component.scss
new file mode 100644
index 0000000..01041d7
--- /dev/null
+++ b/src/app/_modules/search/page/search-page.component.scss
@@ -0,0 +1,14 @@
+.results {
+ margin: 0 auto;
+ max-width: 1240px;
+ .result {
+ .hidden {
+ display: none;
+ }
+ }
+}
+.empty {
+ margin: 0 auto;
+ max-width: 1240px;
+ padding: 0 40px;
+}
diff --git a/src/app/_modules/search/page/search-page.component.ts b/src/app/_modules/search/page/search-page.component.ts
new file mode 100644
index 0000000..8f13ca7
--- /dev/null
+++ b/src/app/_modules/search/page/search-page.component.ts
@@ -0,0 +1,107 @@
+import {Component} from '@angular/core';
+import {FormControl, FormGroup} from "@angular/forms";
+import {debounceTime} from "rxjs/operators";
+import {Subscription} from "rxjs";
+import {ListsService} from "@app/_services";
+
+@Component({
+ templateUrl: 'search-page.component.html',
+ styleUrls: ['search-page.component.scss']
+})
+export class SearchPageComponent {
+ public filters: FormGroup;
+ public tabs: any = [
+ {name: 'pages', title: 'Страницы сайта', active: true},
+ {name: 'publications', title: 'Публикации'},
+ {name: 'entries', title: 'Записи реестров'}
+ ];
+ public total = 0;
+ public searchString = '';
+ public loading: any = {pages: true, publications: true, entries: true};
+
+ pagesSubscription: Subscription;
+ publicationsSubscription: Subscription;
+ entriesSubscription: Subscription;
+
+ constructor(private listsService: ListsService) {
+ this.pagesSubscription = this.listsService.result('sections-list').subscribe(res => {
+ this.setCount('pages', res?.meta?.pagination?.total);
+ });
+ this.publicationsSubscription = this.listsService.result('publications-list').subscribe(res => {
+ this.setCount('publications', res?.meta?.pagination?.total);
+ });
+ this.entriesSubscription = this.listsService.result('common-entries').subscribe(res => {
+ this.setCount('entries', res?.meta?.pagination?.total);
+ });
+ }
+
+ get activeTab() {
+ return this.tabs.filter(item => {return item.active})[0];
+ }
+ get enabledTabs() {
+ return this.tabs.filter(item => {return !item.disabled});
+ }
+
+ get isLoaded() {
+ return !this.loading?.pages && !this.loading?.publications && !this.loading?.entries;
+ }
+
+ ngOnInit() {
+ this.filters = new FormGroup({search: new FormControl()});
+ this.filters.valueChanges.pipe(debounceTime(300)).subscribe(val => {
+ this.loading = {pages: true, publications: true, entries: true};
+ if (val.search) {
+ this.listsService.addFilters(val, 'sections-list');
+ this.listsService.addFilters(val, 'publications-list');
+ this.listsService.addFilters(val, 'common-entries');
+ } else this.resetResults();
+ this.searchString = val.search;
+ });
+ }
+
+ ngOnDestroy() {
+ this.pagesSubscription?.unsubscribe();
+ this.publicationsSubscription?.unsubscribe();
+ this.entriesSubscription?.unsubscribe();
+ }
+
+
+ toggleTab(tab: any) {
+ if (!tab.disabled) {
+ this.tabs = this.tabs.map(item => {
+ item.active = item.name === tab.name;
+ return item;
+ });
+ }
+ }
+
+ setCount(tabName, value) {
+ this.total = 0;
+ this.tabs = this.tabs.map(item => {
+ if (item.name === tabName) {
+ item.count = value || 0;
+ item.disabled = item.count < 1;
+ }
+ this.total += (item.count || 0);
+ return item;
+ });
+ this.loading[tabName] = false;
+ if (this.isLoaded) this.checkActiveTab();
+ }
+
+ checkActiveTab() {
+ let active = this.activeTab;
+ let enabled = this.enabledTabs;
+ if ((!active || active.disabled) && enabled.length) {
+ this.toggleTab(enabled[0]);
+ }
+ }
+
+ resetResults() {
+ this.listsService.result('sections-list').next(null);
+ this.listsService.result('publications-list').next(null);
+ this.listsService.result('common-entries').next(null);
+
+ }
+
+}
diff --git a/src/app/_modules/search/search.module.ts b/src/app/_modules/search/search.module.ts
new file mode 100644
index 0000000..32148ce
--- /dev/null
+++ b/src/app/_modules/search/search.module.ts
@@ -0,0 +1,30 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {RouterModule} from "@angular/router";
+import {SearchPageComponent} from "@app/_modules/search/page/search-page.component";
+import {PublicationsModule} from "@app/_modules/publications/publications.module";
+import {RegistriesModule} from "@app/_modules/registries/registries.module";
+import {ReactiveFormsModule} from "@angular/forms";
+import {PagesModule} from "@app/_modules/pages/pages.module";
+
+const routes = [
+ {path: 'search', component: SearchPageComponent}
+];
+
+@NgModule({
+ imports: [
+ CommonModule,
+ RouterModule.forRoot(routes),
+ ReactiveFormsModule,
+ PublicationsModule,
+ RegistriesModule,
+ PagesModule
+ ],
+ declarations: [
+ SearchPageComponent
+ ],
+ exports: [
+ RouterModule
+ ]
+})
+export class SearchModule {}
diff --git a/src/app/_modules/sorting/sorting.component.html b/src/app/_modules/sorting/sorting.component.html
new file mode 100644
index 0000000..c67f46f
--- /dev/null
+++ b/src/app/_modules/sorting/sorting.component.html
@@ -0,0 +1,9 @@
+
+
+
+
+
+
+
diff --git a/src/app/_modules/sorting/sorting.component.scss b/src/app/_modules/sorting/sorting.component.scss
new file mode 100644
index 0000000..679249c
--- /dev/null
+++ b/src/app/_modules/sorting/sorting.component.scss
@@ -0,0 +1,12 @@
+.order {
+ .dropdown {
+ top: 100%;
+ width: auto;
+ }
+}
+
+@media screen and (max-width: 767px) {
+ .order {
+ display: none;
+ }
+}
diff --git a/src/app/_modules/sorting/sorting.component.ts b/src/app/_modules/sorting/sorting.component.ts
new file mode 100644
index 0000000..f8a68e7
--- /dev/null
+++ b/src/app/_modules/sorting/sorting.component.ts
@@ -0,0 +1,41 @@
+import {Component} from '@angular/core';
+import {ListsService} from "@app/_services/lists.service";
+
+@Component({
+ selector: 'sorting',
+ templateUrl: 'sorting.component.html',
+ styleUrls: ['sorting.component.scss']
+})
+export class SortingComponent {
+ public orders = [
+ {title: 'По убыванию дат', value: {by: 'dates', dir: 'desc'}, selected: true},
+ {title: 'По возрастанию дат', value: {by: 'dates', dir: 'asc'}}
+ //{title: 'По алфавиту', value: {by: 'names', dir: 'asc'}}
+ ];
+ public visible = false;
+
+ constructor(private listsService: ListsService) {
+ }
+
+ ngOnInit() {
+
+ }
+
+ get selected() {
+ return this.orders.filter(item => {return item.selected})[0];
+ }
+
+
+ set(order: any) {
+ this.orders = this.orders.map(item => {
+ item.selected = item.value === order.value;
+ return item;
+ });
+ this.listsService.setOrder(order.value);
+ this.visible = false;
+ }
+
+ order() {
+ //this.listsService.setOrder({date: 'desc'});
+ }
+}
diff --git a/src/app/_modules/sorting/sorting.module.ts b/src/app/_modules/sorting/sorting.module.ts
new file mode 100644
index 0000000..0e8ec71
--- /dev/null
+++ b/src/app/_modules/sorting/sorting.module.ts
@@ -0,0 +1,16 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {SortingComponent} from "@app/_modules/sorting/sorting.component";
+
+@NgModule({
+ imports: [
+ CommonModule
+ ],
+ declarations: [
+ SortingComponent
+ ],
+ exports: [
+ SortingComponent
+ ]
+})
+export class SortingModule {}
diff --git a/src/app/_modules/users/profile/user-profile.component.html b/src/app/_modules/users/profile/user-profile.component.html
new file mode 100644
index 0000000..7fa3089
--- /dev/null
+++ b/src/app/_modules/users/profile/user-profile.component.html
@@ -0,0 +1,22 @@
+
+
Личный кабинет
+
+
+
+
+
+
![]()
+
{{user.initials}}
+
+
+
{{user.name}}
+
{{user.email}}
+
{{user.phone}}
+
+
+
+
+
+
+
+
diff --git a/src/app/_modules/users/profile/user-profile.component.scss b/src/app/_modules/users/profile/user-profile.component.scss
new file mode 100644
index 0000000..69e7ab1
--- /dev/null
+++ b/src/app/_modules/users/profile/user-profile.component.scss
@@ -0,0 +1,85 @@
+.profile {
+ padding: 24px;
+ border-top: #E8E8E8 solid 1px;
+ border-bottom: #E8E8E8 solid 1px;
+ .row {
+ display: flex;
+ flex-direction: row;
+ gap: 24px;
+ .left {
+ flex-grow: 1;
+ }
+ .right {
+ flex-shrink: 0;
+ }
+ }
+
+ .sub {
+ margin-top: 24px;
+ }
+
+ .user {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ gap: 24px;
+
+ .avatar {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ flex-shrink: 0;
+ width: 120px;
+ height: 120px;
+ border: #86898E solid 1px;
+ border-radius: 100%;
+ overflow: hidden;
+
+ img {
+ display: block;
+ width: 100%;
+ height: 100%;
+ object-fit: cover;
+ }
+ .initials {
+ font-size: 48px;
+ color: #86898E;
+ }
+ }
+
+ .data {
+ .name {
+ font-size: 24px;
+ }
+ .email {
+ font-size: 18px;
+ color: #86898E;
+ }
+ }
+ }
+}
+@media screen and (max-width: 960px) {
+ .profile {
+ padding: 24px 0;
+ .user {
+ .avatar {
+ width: 64px;
+ height: 64px;
+ .initials {
+ font-size: 24px;
+ }
+ }
+ .data {
+ .name {
+ font-size: 18px;
+ }
+ .email {
+ font-size: 14px;
+ }
+ .phone {
+ font-size: 14px;
+ }
+ }
+ }
+ }
+}
diff --git a/src/app/_modules/users/profile/user-profile.component.ts b/src/app/_modules/users/profile/user-profile.component.ts
new file mode 100644
index 0000000..a0fd108
--- /dev/null
+++ b/src/app/_modules/users/profile/user-profile.component.ts
@@ -0,0 +1,46 @@
+import {Component} from '@angular/core';
+import {AuthenticationService, FormsService, ListsService} from "@app/_services";
+import {Subscription} from "rxjs";
+
+@Component({
+ templateUrl: 'user-profile.component.html',
+ styleUrls: ['user-profile.component.scss']
+})
+export class UserProfileComponent {
+ public user: any;
+ inited = false;
+ userSubscription: Subscription;
+ controlsSubscription: Subscription;
+
+ constructor(private listsService: ListsService, private formsService: FormsService, private authService: AuthenticationService) {
+ this.userSubscription = this.authService.user.subscribe(user => {
+ this.user = user;
+ });
+ }
+
+ get avatar() {
+ return this.user?.avatar?.data;
+ }
+
+ ngOnInit() {
+ this.controlsSubscription = this.listsService.controls().subscribe(res => {
+ this.inited ? this.authService.checkUser() : this.inited = true;
+ });
+ }
+
+ ngOnDestroy() {
+ this.userSubscription?.unsubscribe();
+ this.controlsSubscription?.unsubscribe();
+ }
+
+
+
+ editProfile() {
+ this.formsService.editModel('userProfile', this.user.id);
+ }
+
+ changePassword() {
+ this.formsService.editModel('userPassword', this.user.id);
+ }
+
+}
diff --git a/src/app/_modules/users/users.module.ts b/src/app/_modules/users/users.module.ts
new file mode 100644
index 0000000..7416160
--- /dev/null
+++ b/src/app/_modules/users/users.module.ts
@@ -0,0 +1,23 @@
+import {NgModule} from '@angular/core';
+import {CommonModule} from '@angular/common';
+import {RouterModule} from "@angular/router";
+import {AuthGuard} from "@app/_helpers";
+import {UserProfileComponent} from "@app/_modules/users/profile/user-profile.component";
+
+const routes = [
+ {path: 'profile', component: UserProfileComponent, canActivate: [AuthGuard]}
+];
+
+@NgModule({
+ imports: [
+ CommonModule,
+ RouterModule.forRoot(routes)
+ ],
+ declarations: [
+ UserProfileComponent
+ ],
+ exports: [
+ RouterModule
+ ]
+})
+export class UsersModule {}
diff --git a/src/app/_services/advisories.service.ts b/src/app/_services/advisories.service.ts
new file mode 100644
index 0000000..72b76bb
--- /dev/null
+++ b/src/app/_services/advisories.service.ts
@@ -0,0 +1,25 @@
+import { Injectable } from '@angular/core';
+import { HttpClient } from '@angular/common/http';
+
+import { environment } from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({ providedIn: 'root' })
+export class AdvisoriesService {
+
+ constructor(private http: HttpClient) {
+ }
+
+
+ show(id: string, params?: any): Observable {
+ return this.http.get(`${environment.apiUrl}/api/advisories/${id}`, {params: params});
+ }
+
+ siblings(id: string, params?: any): Observable {
+ return this.http.get(`${environment.apiUrl}/api/advisories/${id}/siblings`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/advisories/${id}`);
+ }
+}
diff --git a/src/app/_services/advisory-companies.service.ts b/src/app/_services/advisory-companies.service.ts
new file mode 100644
index 0000000..39e8e14
--- /dev/null
+++ b/src/app/_services/advisory-companies.service.ts
@@ -0,0 +1,23 @@
+import { Injectable } from '@angular/core';
+import { HttpClient } from '@angular/common/http';
+
+import { environment } from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({ providedIn: 'root' })
+export class AdvisoryCompaniesService {
+
+ constructor(private http: HttpClient) {
+
+ }
+
+
+ show(id: string, params?: any): Observable {
+ return this.http.get(`${environment.apiUrl}/api/advisory-companies/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/advisory-companies/${id}`);
+ }
+
+}
diff --git a/src/app/_services/advisory-members.service.ts b/src/app/_services/advisory-members.service.ts
new file mode 100644
index 0000000..3730040
--- /dev/null
+++ b/src/app/_services/advisory-members.service.ts
@@ -0,0 +1,23 @@
+import { Injectable } from '@angular/core';
+import { HttpClient } from '@angular/common/http';
+
+import { environment } from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({ providedIn: 'root' })
+export class AdvisoryMembersService {
+
+ constructor(private http: HttpClient) {
+
+ }
+
+
+ show(id: string, params?: any): Observable {
+ return this.http.get(`${environment.apiUrl}/api/advisory-members/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/advisory-members/${id}`);
+ }
+
+}
diff --git a/src/app/_services/applications.service.ts b/src/app/_services/applications.service.ts
new file mode 100644
index 0000000..e19ffd5
--- /dev/null
+++ b/src/app/_services/applications.service.ts
@@ -0,0 +1,23 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class ApplicationsService {
+ constructor(private http: HttpClient) {
+ }
+
+ list(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/applications`, {params: params});
+ }
+
+ show(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/applications/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/applications/${id}`);
+ }
+
+}
diff --git a/src/app/_services/assets.service.ts b/src/app/_services/assets.service.ts
new file mode 100644
index 0000000..fa00d99
--- /dev/null
+++ b/src/app/_services/assets.service.ts
@@ -0,0 +1,21 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class AssetsService {
+ constructor(private http: HttpClient) {
+ }
+
+ upload(file: any, params?: any): Observable {
+ let formData = new FormData();
+ formData.append('file', file);
+ if (params) params.forEach(el => {
+ formData.append(el.name, el.value);
+ });
+ return this.http.post(`${environment.apiUrl}/api/assets`, formData, {reportProgress: true, observe: 'events'});
+ }
+
+
+}
diff --git a/src/app/_services/authentication.service.ts b/src/app/_services/authentication.service.ts
new file mode 100644
index 0000000..6618787
--- /dev/null
+++ b/src/app/_services/authentication.service.ts
@@ -0,0 +1,80 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {BehaviorSubject, Observable} from 'rxjs';
+import {Router} from "@angular/router";
+
+import {environment} from '@environments/environment';
+import {OauthToken, User} from '@app/_models';
+
+@Injectable({providedIn: 'root'})
+export class AuthenticationService {
+ public token: BehaviorSubject;
+ public user: BehaviorSubject;
+
+ constructor(private http: HttpClient, private router: Router) {
+ this.token = new BehaviorSubject(JSON.parse(localStorage.getItem('oauthToken')));
+ this.user = new BehaviorSubject(null);
+ }
+
+ get oauthTokenValue() {
+ return this.token.value;
+ }
+
+ public get privileges() {
+ return this.user.value?.privileges;
+ }
+ get isAdmin() {
+ return this.privileges?.admin;
+ }
+ get isExpert() {
+ return this.privileges?.expert;
+ }
+ get isMainCompanyMember() {
+ return this.privileges?.mainCompanyMember;
+ }
+
+
+
+ signup(data: any): Observable {
+ return this.http.post(`${environment.apiUrl}/api/signup`, data);
+ }
+
+ getToken(username: string, password: string): Observable {
+ let data = {grant_type: 'password', client_id: environment.clientId, client_secret: environment.clientSecret, username: username, password: password};
+ return this.http.post(`${environment.apiUrl}/oauth/token`, data);
+ }
+ saveToken(token: OauthToken) {
+ localStorage.setItem('oauthToken', JSON.stringify(token));
+ this.token.next(token);
+ this.checkUser();
+ }
+
+ checkUser(params?: any) {
+ if (this.token.value) {
+ if (!params) params = {include: 'avatar,privileges'};
+ this.http.get(`${environment.apiUrl}/api/me`, {params: params}).subscribe((res: any) => {
+ this.user.next(res?.data);
+ });
+ }
+ }
+
+
+ logout() {
+ localStorage.removeItem('oauthToken');
+ this.token.next(null);
+ this.user.next(null);
+ }
+
+
+ forget(email: string): Observable {
+ return this.http.post(`${environment.apiUrl}/api/passwords/reset`, {email});
+ }
+
+ restore(data: any): Observable {
+ return this.http.put(`${environment.apiUrl}/api/passwords/reset`, data);
+ }
+
+ popup(path: any) {
+ this.router.navigate([ {outlets: {auth: path}}], {skipLocationChange: true}).then();
+ }
+}
diff --git a/src/app/_services/companies.service.ts b/src/app/_services/companies.service.ts
new file mode 100644
index 0000000..f370c44
--- /dev/null
+++ b/src/app/_services/companies.service.ts
@@ -0,0 +1,20 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class CompaniesService {
+ constructor(private http: HttpClient) {
+ }
+
+ fetch(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/companies/${id}`, {params: params});
+ }
+
+
+ getDataByInn(inn): Observable {
+ return this.http.get(`${environment.apiUrl}/api/dadata/${inn}`);
+ }
+
+}
diff --git a/src/app/_services/company-members.service.ts b/src/app/_services/company-members.service.ts
new file mode 100644
index 0000000..05772fe
--- /dev/null
+++ b/src/app/_services/company-members.service.ts
@@ -0,0 +1,23 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class CompanyMembersService {
+ constructor(private http: HttpClient) {
+ }
+
+ list(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/members`, {params: params});
+ }
+
+ fetch(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/members/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/members/${id}`);
+ }
+
+}
diff --git a/src/app/_services/departments.service.ts b/src/app/_services/departments.service.ts
new file mode 100644
index 0000000..15b38aa
--- /dev/null
+++ b/src/app/_services/departments.service.ts
@@ -0,0 +1,19 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class DepartmentsService {
+ constructor(private http: HttpClient) {
+ }
+
+ fetch(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/departments/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/departments/${id}`);
+ }
+
+}
diff --git a/src/app/_services/filters.service.ts b/src/app/_services/filters.service.ts
new file mode 100644
index 0000000..f4d5481
--- /dev/null
+++ b/src/app/_services/filters.service.ts
@@ -0,0 +1,18 @@
+import {Injectable} from '@angular/core';
+import {Router} from "@angular/router";
+import {FormsService} from "@app/_services/forms.service";
+
+@Injectable({providedIn: 'root'})
+export class FiltersService {
+
+ constructor(private router: Router, private formsService: FormsService) {
+ }
+
+ slider(target: string, type: string, params?: any, list?: string) {
+ let commands = ['filters', target, type];
+ if (list) commands.push(list);
+ this.router.navigate([{outlets: {slider: commands}}], {queryParams: this.formsService.makeQueryParams(params), skipLocationChange: true}).then();
+ }
+
+
+}
diff --git a/src/app/_services/form-fields.service.ts b/src/app/_services/form-fields.service.ts
new file mode 100644
index 0000000..f28a94f
--- /dev/null
+++ b/src/app/_services/form-fields.service.ts
@@ -0,0 +1,35 @@
+import {Injectable} from '@angular/core';
+
+@Injectable({providedIn: 'root'})
+export class FormFieldsService {
+ prepareGroup(group: any, params: any) {
+ let hiddenGroups = params.hidden?.groups || [];
+ let readonlyGroups = params.readonly?.groups || [];
+ if (params.hideGroupsTitles) group.title = null;
+ if (hiddenGroups.indexOf(group.name) !== -1) group.hidden = true;
+ if (readonlyGroups.indexOf(group.name) !== -1) group.readonly = true;
+ group.fields.data = group.fields?.data.map(field => {
+ return this.prepareField(field, params);
+ });
+ return group;
+ }
+
+ prepareField(field: any, params: any) {
+ let hiddenFields = params.hidden?.fields || [];
+ let readonlyFields = params.readonly?.fields || [];
+ let fieldTypes = params.fieldTypes || [];
+ if (fieldTypes.length && (fieldTypes.indexOf(field.type) === -1)) field.hidden = true;
+ if (hiddenFields.indexOf(field.name) !== -1) field.hidden = true;
+ if (readonlyFields.indexOf(field.name) !== -1) field.readonly = true;
+ return field;
+ }
+
+ prepareFieldValue(field: any) {
+ let result = field.value?.data || field.value || [];
+ if (result.data !== undefined) result = result.data;
+ if (!Array.isArray(result)) result = ((result !== null) && (result !== undefined)) ? [result] : [];
+ return result;
+ }
+
+
+}
diff --git a/src/app/_services/forms.service.ts b/src/app/_services/forms.service.ts
new file mode 100644
index 0000000..51ee584
--- /dev/null
+++ b/src/app/_services/forms.service.ts
@@ -0,0 +1,60 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+import {UtilityService} from "@app/_services/utility.service";
+import {Router} from "@angular/router";
+
+@Injectable({providedIn: 'root'})
+export class FormsService {
+ constructor(private http: HttpClient, private utility: UtilityService, private router: Router) {
+ }
+
+ get(target: string, type: string, id?: string, params?: {}): Observable {
+ let url = `${environment.apiUrl}/api/forms/${target}/${type}` + ((id && (id !== 'null')) ? `/${id}` : '');
+ return this.http.get(url, {params: params});
+ }
+
+ save(target: string, type: string, id?: string, data?: any): Observable {
+ let url = `${environment.apiUrl}/api/forms/${target}/${type}` + ((id && (id !== 'null')) ? `/${id}` : '');
+ return this.http.post(url, this.utility.normalizeData(data));
+ }
+
+
+
+ createModel(type: string, params?: any, list?: string) {
+ this.slider('model', type, null, params, list);
+ }
+
+ editModel(type: string, id: string, params?: any, list?: string) {
+ this.slider('model', type, id, params, list);
+ }
+
+ createObject(type: string, params?: any, list?: string) {
+ this.slider('object', type, null, params, list);
+ }
+
+ editObject(id: string, params?: any, list?: string) {
+ this.slider('object', null, id, params, list);
+ }
+
+
+ slider(target: string, type: string, id?: string, params?: any, list?: string) {
+ let commands = ['form', target, type || null, id || null];
+ if (list) commands.push(list);
+ this.router.navigate([{outlets: {slider: commands}}], {queryParams: this.makeQueryParams(params), skipLocationChange: true}).then();
+ }
+
+ makeQueryParams(params) {
+ let result: any = {};
+ if (params) {
+ for (let prop in params) {
+ if (params.hasOwnProperty(prop)) result[prop] = JSON.stringify(params[prop]);
+ }
+ }
+ return result;
+ }
+
+
+}
diff --git a/src/app/_services/index.ts b/src/app/_services/index.ts
new file mode 100644
index 0000000..20b57ed
--- /dev/null
+++ b/src/app/_services/index.ts
@@ -0,0 +1,10 @@
+export * from './assets.service';
+export * from './authentication.service';
+export * from './filters.service';
+export * from './form-fields.service';
+export * from './forms.service';
+export * from './lists.service';
+export * from './notification.service';
+export * from './objects.service';
+export * from './user.service';
+export * from './utility.service';
diff --git a/src/app/_services/lists.service.ts b/src/app/_services/lists.service.ts
new file mode 100644
index 0000000..af62faa
--- /dev/null
+++ b/src/app/_services/lists.service.ts
@@ -0,0 +1,71 @@
+import {Injectable} from '@angular/core';
+import {BehaviorSubject} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class ListsService {
+ public lists: any = {};
+
+ constructor() {
+ }
+
+
+ list(id?: string) {
+ id = id || null;
+ if (!this.lists[id]) this.lists[id] = this.init();
+ return this.lists[id];
+ }
+ init() {
+ return {
+ controls: new BehaviorSubject({filters: {}, order: {}, page: 1}),
+ result: new BehaviorSubject({})
+ };
+ }
+
+ controls(id?: string): BehaviorSubject {
+ return this.list(id).controls;
+ }
+ result(id?: string): BehaviorSubject {
+ return this.list(id).result;
+ }
+
+
+ setFilters(filters: any, id?: string) {
+ let controls = this.list(id).controls.value;
+ controls.filters = filters;
+ this.setControls(controls, id);
+ }
+ setFilter(prop: string, val: any, id?: string) {
+ let controls = this.list(id).controls.value;
+ controls.filters[prop] = val;
+ this.setControls(controls, id);
+ }
+ addFilters(filters: any, id?: string) {
+ let controls = this.list(id).controls.value;
+ for (let prop in filters) {
+ if (filters.hasOwnProperty(prop)) controls.filters[prop] = filters[prop];
+ }
+ this.setControls(controls, id);
+ }
+ setOrder(order: any, id?: string) {
+ let controls = this.list(id).controls.value;
+ controls.order = order;
+ this.setControls(controls, id);
+ }
+
+ setControls(controls: any, id?: string, keepPage?: boolean) {
+ if (!keepPage) controls.page = 1;
+ this.list(id).controls.next(controls);
+ }
+
+
+ setPage(page: number, id?: string) {
+ let controls = this.list(id).controls.value;
+ controls.page = page;
+ this.list(id).controls.next(controls);
+ }
+
+ refresh(id?: string, keepPage?: boolean) {
+ this.setControls(this.list(id).controls.value, id, keepPage);
+ }
+
+}
diff --git a/src/app/_services/notification.service.ts b/src/app/_services/notification.service.ts
new file mode 100644
index 0000000..59a5be7
--- /dev/null
+++ b/src/app/_services/notification.service.ts
@@ -0,0 +1,39 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+
+import {Observable} from 'rxjs';
+
+import {environment} from '@environments/environment';
+
+@Injectable({
+ providedIn: 'root'
+})
+
+export class NotificationService {
+ constructor(private http: HttpClient) {
+ }
+
+ getList(params?: {}): Observable {
+ let url = environment.apiUrl + `/api/me/notifications`;
+ return this.http.get(url, {params: params});
+ }
+
+ getCount(): Observable {
+ let url = environment.apiUrl + `/api/me/notifications/count`;
+ return this.http.get(url, {});
+ }
+
+ sendMessageRead(notificationId: string): Observable {
+ const url = environment.apiUrl + '/api/me/notifications';
+ return this.http.post(url, {id: notificationId});
+ }
+
+ show(id: string): Observable {
+ let url = environment.apiUrl + `/api/me/notifications/show/${id}`;
+ return this.http.get(url, {});
+ }
+
+ update(id: string, data): Observable {
+ return this.http.put(`${environment.apiUrl}/api/me/notifications/update/${id}`, data);
+ }
+}
diff --git a/src/app/_services/objects.service.ts b/src/app/_services/objects.service.ts
new file mode 100644
index 0000000..0502c28
--- /dev/null
+++ b/src/app/_services/objects.service.ts
@@ -0,0 +1,118 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class ObjectsService {
+ constructor(private http: HttpClient) {
+ }
+
+ listTypes(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/object-types`, {params: params});
+ }
+
+ listObjects(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/objects`, {params: params});
+ }
+
+ filters(type: string): Observable {
+ return this.http.get(`${environment.apiUrl}/api/${type}/filters`, {});
+ }
+
+ fetchType(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/object-types/${id}`, {params: params});
+ }
+
+ fetchObject(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/objects/${id}`, {params: params});
+ }
+
+ fetchModelForm(type: string, id?: string, params?: {}): Observable {
+ let url = `${environment.apiUrl}/api/forms/${type}` + (id ? `/${id}` : '');
+ return this.http.get(url, {params: params});
+ }
+
+ fetchModelFilters(type: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/filters/${type}`, {params: params});
+ }
+
+
+ documents(object: any) {
+ let result = [];
+ this.fields(object, 'document').forEach(field => {
+ field.value?.data.forEach(value => {
+ result.push({name: field.multiple ? value.name : field.title, link: value.links?.open});
+ });
+ });
+ return result;
+ }
+ fields(object: any, type?: string) {
+ let result = [];
+ object?.groups?.data.forEach(group => {
+ group.fields?.data.forEach(field => {
+ if (!type || (field.type === type)) result.push(field);
+ });
+ });
+ return result;
+ }
+
+ getValue(object: any, fieldName: string) {
+ let result = null;
+ object?.groups?.data.forEach(group => {
+ group.fields?.data.forEach(field => {
+ if (field.name === fieldName) result = this.fieldValue(field);
+ });
+ });
+ return result;
+ }
+
+ parsedFields(object: any, type?: string) {
+ let result = [];
+ this.fields(object, type).forEach(field => {
+ field.value = this.fieldValue(field);
+ result.push(field);
+ });
+ return result;
+ }
+ fieldValue(field) {
+ let result = field.value?.data || field.value;
+ if (!field.multiple && Array.isArray(result)) result = result[0];
+ return result;
+ }
+
+
+ save(target: any, data: any): Observable {
+ if (target.objectId) return this.update(target.objectId, data);
+ else if (target.objectTypeName) return this.store(target.objectTypeName, data);
+ else if (target.modelTypeName && target.modelId) return this.updateModel(target.modelTypeName, target.modelId, data);
+ else return this.storeModel(target.modelTypeName, data);
+ }
+
+
+ store(type: string, data: any): Observable {
+ return this.http.post(`${environment.apiUrl}/api/objects`, {type: type, properties: data});
+ }
+
+ update(id: string, data: any): Observable {
+ return this.http.put(`${environment.apiUrl}/api/objects/${id}`, data);
+ }
+
+ move(id: string, data: any): Observable {
+ return this.http.put(`${environment.apiUrl}/api/objects/move/${id}`, data);
+ }
+
+ destroy(id: string) {
+ return this.http.delete(`${environment.apiUrl}/api/objects/${id}`);
+ }
+
+
+ storeModel(type: string, data: any): Observable {
+ return this.http.post(`${environment.apiUrl}/api/forms/${type}`, data);
+ }
+
+ updateModel(type: string, id: string, data: any): Observable {
+ return this.http.put(`${environment.apiUrl}/api/forms/${type}/${id}`, data);
+ }
+
+}
diff --git a/src/app/_services/pages.service.ts b/src/app/_services/pages.service.ts
new file mode 100644
index 0000000..7567315
--- /dev/null
+++ b/src/app/_services/pages.service.ts
@@ -0,0 +1,33 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class PagesService {
+ constructor(private http: HttpClient) {
+ }
+
+ root(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/pages/root`, {params: params});
+ }
+
+ find(url: string, params?: any): Observable {
+ if (!params) params = {};
+ params.url = url;
+ return this.http.get(`${environment.apiUrl}/api/pages/find`, {params: params});
+ }
+
+ list(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/pages`, {params: params});
+ }
+
+ show(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/pages/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/pages/${id}`);
+ }
+
+}
diff --git a/src/app/_services/publications.service.ts b/src/app/_services/publications.service.ts
new file mode 100644
index 0000000..4d27af8
--- /dev/null
+++ b/src/app/_services/publications.service.ts
@@ -0,0 +1,32 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class PublicationsService {
+ constructor(private http: HttpClient) {
+ }
+
+ find(url: string, params?: any): Observable {
+ if (!params) params = {};
+ params.url = url;
+ return this.http.get(`${environment.apiUrl}/api/publications/find`, {params: params});
+ }
+
+ list(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/publications`, {params: params});
+ }
+
+ show(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/publications/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/publications/${id}`);
+ }
+
+ published(id: string, publish: boolean): Observable {
+ return this.http.put(`${environment.apiUrl}/api/publications/published/${id}`, {publish: publish});
+ }
+}
diff --git a/src/app/_services/registries.service.ts b/src/app/_services/registries.service.ts
new file mode 100644
index 0000000..7d6b266
--- /dev/null
+++ b/src/app/_services/registries.service.ts
@@ -0,0 +1,23 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class RegistriesService {
+ constructor(private http: HttpClient) {
+ }
+
+ list(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/registries`, {params: params});
+ }
+
+ show(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/registries/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/registries/${id}`);
+ }
+
+}
diff --git a/src/app/_services/registry-categories.service.ts b/src/app/_services/registry-categories.service.ts
new file mode 100644
index 0000000..89d98da
--- /dev/null
+++ b/src/app/_services/registry-categories.service.ts
@@ -0,0 +1,27 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class RegistryCategoriesService {
+ constructor(private http: HttpClient) {
+ }
+
+ list(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/registries/categories`, {params: params});
+ }
+
+ show(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/registries/categories/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/registries/categories/${id}`);
+ }
+
+ move(id: string, data: any): Observable {
+ return this.http.put(`${environment.apiUrl}/api/registries/categories/${id}`, data);
+ }
+
+}
diff --git a/src/app/_services/registry-entries.service.ts b/src/app/_services/registry-entries.service.ts
new file mode 100644
index 0000000..5626a09
--- /dev/null
+++ b/src/app/_services/registry-entries.service.ts
@@ -0,0 +1,27 @@
+import {Injectable} from '@angular/core';
+import {HttpClient} from '@angular/common/http';
+import {environment} from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({providedIn: 'root'})
+export class RegistryEntriesService {
+ constructor(private http: HttpClient) {
+ }
+
+ list(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/registries/entries`, {params: params});
+ }
+
+ show(id: string, params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/registries/entries/${id}`, {params: params});
+ }
+
+ delete(id: string): Observable {
+ return this.http.delete(`${environment.apiUrl}/api/registries/entries/${id}`);
+ }
+
+ move(id: string, data: any): Observable {
+ return this.http.put(`${environment.apiUrl}/api/registries/entries/${id}`, data);
+ }
+
+}
diff --git a/src/app/_services/user.service.ts b/src/app/_services/user.service.ts
new file mode 100644
index 0000000..c128c49
--- /dev/null
+++ b/src/app/_services/user.service.ts
@@ -0,0 +1,16 @@
+import { Injectable } from '@angular/core';
+import { HttpClient } from '@angular/common/http';
+
+import { environment } from '@environments/environment';
+import {Observable} from "rxjs";
+
+@Injectable({ providedIn: 'root' })
+export class UserService {
+ constructor(private http: HttpClient) {
+ }
+
+ me(params?: {}): Observable {
+ return this.http.get(`${environment.apiUrl}/api/me`, {params: params});
+ }
+
+}
diff --git a/src/app/_services/utility.service.ts b/src/app/_services/utility.service.ts
new file mode 100644
index 0000000..6e72368
--- /dev/null
+++ b/src/app/_services/utility.service.ts
@@ -0,0 +1,78 @@
+import {Injectable} from "@angular/core";
+import {HttpParams} from "@angular/common/http";
+import {FormGroup} from "@angular/forms";
+import {filter} from "rxjs/operators";
+
+@Injectable({
+ providedIn: 'root'
+})
+
+export class UtilityService {
+ normalizeData(data: any) {
+ for (let prop in data) {
+ if (data.hasOwnProperty(prop)) {
+ data[prop] = this.normalizeValue(data[prop]);
+ }
+ }
+ return data;
+ }
+ normalizeValue(value: any) {
+ let result = value;
+ if (Array.isArray(value)) {
+ result = value.map(val => {return this.normalizeValue(val)}).filter(val => {return (val !== null) && (val !== undefined)});
+ if (!result.length) result = null;
+ } else if (value instanceof FormGroup) result = this.normalizeData(value.value);
+ else if (value?.id) result = value.id;
+ return result;
+ }
+
+
+
+ filterOptions(search: string, options: []) {
+ let result: any = options;
+ if (search) {
+ let regExps = this.getSearchRegexps(search);
+ result = options.filter((option: any) => {
+ return this.testOption(option, regExps);
+ });
+ }
+ return result;
+ }
+ testOption(option: any, regExps: RegExp[]) {
+ let result = true;
+ regExps.forEach((regExp: RegExp) => {
+ if (!regExp.test(option.caption) && !regExp.test(option.title) && !regExp.test(option.subtitle) && !regExp.test(option.name)) result = false;
+ });
+ return result;
+ }
+ getSearchRegexps(search: string) {
+ return search.split(' ').map(term => {
+ return new RegExp(term.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&'), 'i');
+ });
+ }
+
+
+
+
+ makeHttpParams(params: any): HttpParams {
+ let result = new HttpParams()
+ for (let param in params) {
+ if (Object.prototype.hasOwnProperty.call(params, param)) {
+ if (params[param] !== null && params[param] !== '') {
+ if (typeof params[param] === 'object') {
+ for (let param2 in params[param]) {
+ if (Object.prototype.hasOwnProperty.call(params[param], param2)) {
+ if (params[param][param2] !== null && params[param][param2] !== '') {
+ result = result.append(param + '[' + param2 + ']', params[param][param2])
+ }
+ }
+ }
+ } else {
+ result = result.append(param, params[param])
+ }
+ }
+ }
+ }
+ return result
+ }
+}
diff --git a/src/app/_services/window-scrolling.service.ts b/src/app/_services/window-scrolling.service.ts
new file mode 100644
index 0000000..abf737d
--- /dev/null
+++ b/src/app/_services/window-scrolling.service.ts
@@ -0,0 +1,23 @@
+import {Injectable, Renderer2, RendererFactory2, RendererStyleFlags2} from '@angular/core';
+
+const importantFlag = RendererStyleFlags2.Important
+
+@Injectable({
+ providedIn: 'root'
+})
+export class WindowScrollingService {
+
+ private renderer: Renderer2
+
+ constructor(private rendererFactory: RendererFactory2) {
+ this.renderer = rendererFactory.createRenderer(null, null)
+ }
+
+ public disable(): void {
+ this.renderer.setStyle(document.body, 'overflow', 'hidden', importantFlag);
+ }
+
+ public enable(): void {
+ this.renderer.removeStyle(document.body, 'overflow');
+ }
+}
diff --git a/src/app/app.component.html b/src/app/app.component.html
new file mode 100644
index 0000000..6e7a429
--- /dev/null
+++ b/src/app/app.component.html
@@ -0,0 +1 @@
+
diff --git a/src/app/app.component.scss b/src/app/app.component.scss
new file mode 100644
index 0000000..e69de29
diff --git a/src/app/app.component.ts b/src/app/app.component.ts
new file mode 100644
index 0000000..1e7e08f
--- /dev/null
+++ b/src/app/app.component.ts
@@ -0,0 +1,12 @@
+import {Component} from '@angular/core';
+import {AuthenticationService} from "@app/_services";
+
+@Component({
+ selector: 'app',
+ templateUrl: 'app.component.html',
+ styleUrls: ['app.component.scss']})
+export class AppComponent {
+ constructor(private authService: AuthenticationService) {
+ authService.checkUser();
+ }
+}
diff --git a/src/app/app.module.ts b/src/app/app.module.ts
new file mode 100644
index 0000000..e6bca29
--- /dev/null
+++ b/src/app/app.module.ts
@@ -0,0 +1,46 @@
+import {NgModule} from '@angular/core';
+import {BrowserModule} from '@angular/platform-browser';
+import {HttpClientModule, HTTP_INTERCEPTORS} from '@angular/common/http';
+import {AppComponent} from './app.component';
+import {JwtInterceptor, ErrorInterceptor} from './_helpers';
+import {MAT_DATE_LOCALE} from "@angular/material/core";
+import {LayoutModule} from "@app/_modules/layout/layout.module";
+import {ObjectsModule} from "@app/_modules/objects/objects.module";
+import {AuthModule} from "@app/_modules/auth/auth.module";
+import {SortablejsModule} from "ngx-sortablejs";
+import {PublicationsModule} from "@app/_modules/publications/publications.module";
+import {AdministrationModule} from "@app/_modules/administration/administration.module";
+import {PhonebookModule} from "@app/_modules/phonebook/phonebook.module";
+import {ApplicationsModule} from "@app/_modules/applications/applications.module";
+import {UsersModule} from "@app/_modules/users/users.module";
+import {SearchModule} from "@app/_modules/search/search.module";
+import {PagesRoutingModule} from "@app/_modules/pages/pages-routing.module";
+
+@NgModule({
+ imports: [
+ BrowserModule,
+ HttpClientModule,
+ SortablejsModule.forRoot({animation: 150}),
+ ObjectsModule,
+ AuthModule,
+ UsersModule,
+ SearchModule,
+ AdministrationModule,
+ PhonebookModule,
+ ApplicationsModule,
+ LayoutModule,
+ PublicationsModule,
+ PagesRoutingModule // should be last
+ ],
+ declarations: [
+ AppComponent
+ ],
+ providers: [
+ {provide: HTTP_INTERCEPTORS, useClass: JwtInterceptor, multi: true},
+ {provide: HTTP_INTERCEPTORS, useClass: ErrorInterceptor, multi: true},
+ {provide: MAT_DATE_LOCALE, useValue: 'ru-RU'}
+ ],
+ bootstrap: [AppComponent]
+})
+export class AppModule {
+}
diff --git a/src/app/config/particles.ts b/src/app/config/particles.ts
new file mode 100644
index 0000000..853c5c0
--- /dev/null
+++ b/src/app/config/particles.ts
@@ -0,0 +1,55 @@
+export const ParticlesConfig = {
+ particles: {
+ number: {value: 80, density: {enable: true, value_area: 800}},
+ color: {value: "#ffffff"},
+ shape: {
+ type: "circle",
+ stroke: {width: 0, color: "#000000"},
+ polygon: {nb_sides: 5},
+ image: {src: "img/github.svg", width: 100, height: 100},
+ },
+ opacity: {
+ value: 0.7,
+ random: false,
+ anim: {enable: false, speed: 1, opacity_min: 0.1, sync: false},
+ },
+ size: {
+ value: 3,
+ random: true,
+ anim: {enable: false, speed: 40, size_min: 0.1, sync: false},
+ },
+ line_linked: {
+ enable: true,
+ distance: 150,
+ color: "#ffffff",
+ opacity: 0.7,
+ width: 1,
+ },
+ move: {
+ enable: true,
+ speed: 3,
+ direction: "none",
+ random: false,
+ straight: false,
+ out_mode: "out",
+ bounce: false,
+ attract: {enable: false, rotateX: 600, rotateY: 1200},
+ },
+ },
+ interactivity: {
+ detect_on: "canvas",
+ events: {
+ onhover: {enable: true, mode: "repulse"},
+ onclick: {enable: true, mode: "push"},
+ resize: true,
+ },
+ modes: {
+ grab: {distance: 400, line_linked: {opacity: 1}},
+ bubble: {distance: 400, size: 40, duration: 2, opacity: 8, speed: 3},
+ repulse: {distance: 200, duration: 0.4},
+ push: {particles_nb: 4},
+ remove: {particles_nb: 2},
+ },
+ },
+ retina_detect: true,
+};
diff --git a/src/assets/.gitkeep b/src/assets/.gitkeep
new file mode 100644
index 0000000..e69de29
diff --git a/src/assets/css/basics.scss b/src/assets/css/basics.scss
new file mode 100644
index 0000000..94e3fa2
--- /dev/null
+++ b/src/assets/css/basics.scss
@@ -0,0 +1,140 @@
+@import "~@angular/material/prebuilt-themes/indigo-pink.css";
+
+.mat-calendar-body-selected {
+ background-color: #0079c2;
+}
+
+.tox-promotion, .tox-statusbar__branding {
+ display: none!important;
+}
+
+
+*, ::after, ::before {
+ box-sizing: border-box;
+}
+
+* {scrollbar-color:transparent transparent; scrollbar-width:none;}
+*::-webkit-scrollbar-track {background-color:transparent;}
+*::-webkit-scrollbar {width:0; height:0; background-color:transparent;}
+*::-webkit-scrollbar-thumb {background-color:transparent; border-radius:2rem;}
+
+
+html {
+ height: 100%;
+ font-family: "Open Sans";
+ font-size: 16px;
+ -webkit-font-smoothing:antialiased;
+}
+
+body {
+ height: 100%;
+ padding: 0;
+ margin: 0;
+ color: var(--grey-7);
+}
+
+.limiter {
+ width: 100%;
+ max-width: 1240px;
+ padding: 0 40px;
+ margin: 0 auto;
+}
+
+
+h1 {
+ margin: 0 0 24px;
+ font-size: 2rem;
+ font-weight: bold;
+}
+
+a {
+ text-decoration: none;
+ &.document {
+ display: inline-flex;
+ color: var(--grey-7);
+ &:before {
+ width: 20px;
+ height: 20px;
+ margin-right: 8px;
+ flex-shrink: 0;
+ background: transparent url('~src/assets/images/icons/document_20.svg') 50% 50% no-repeat;
+ content: '';
+ }
+ }
+}
+
+span.link {
+ font-weight: normal;
+ color: #86898E;
+ cursor: pointer;
+}
+
+.fullwidth {
+ width: calc(100% + 80px);
+ margin-left: -40px;
+ margin-right: -40px;
+}
+
+.loader {
+ margin-top: 32px;
+ text-align: center;
+ animation: fade-in-and-scale 0.5s infinite;
+ &:before {
+ display: inline-block;
+ width: 80px;
+ height: 80px;
+ border-radius: 100px;
+ background-image: radial-gradient(rgba(44,134,205,1), rgba(44,134,205,0));
+ content: '';
+ }
+}
+
+
+@media screen and (min-width: 1240px) {
+ .fullwidth {
+ width: 100vw;
+ margin-left: calc((1160px - 100vw) / 2);
+ margin-right: 0;
+ }
+}
+
+
+
+@keyframes slide-from-right {
+ 0% {transform: translateX(100%);}
+ 100% {transform: translateX(0);}
+}
+
+@keyframes slide-from-left {
+ 0% {transform: translateX(-100%);}
+ 100% {transform: translateX(0);}
+}
+
+@keyframes slide-from-top-and-fade-in {
+ 0% {transform: translateY(-100%); opacity: 0}
+ 100% {transform: translateY(0); opacity: 1}
+}
+
+@keyframes slide-from-bottom-and-fade-in {
+ 0% {transform: translateY(100%); opacity: 0}
+ 100% {transform: translateY(0); opacity: 1}
+}
+
+
+@keyframes fade-in-and-scale {
+ 0% {transform:scale(0.3); opacity:0;}
+ 100% {transform:scale(1); opacity:0.5;}
+}
+
+
+@media screen and (max-width: 960px) {
+ .limiter {
+ padding: 0 24px;
+ }
+ .fullwidth {
+ width: calc(100% + 48px);
+ margin-left: -24px;
+ margin-right: -24px;
+ }
+
+}
diff --git a/src/assets/css/buttons.scss b/src/assets/css/buttons.scss
new file mode 100644
index 0000000..1326d33
--- /dev/null
+++ b/src/assets/css/buttons.scss
@@ -0,0 +1,115 @@
+button {
+ cursor: pointer;
+ border:none;
+ font-family: "Open Sans";
+ border-radius: 6px;
+ font-size: 0.875rem;
+ &[disabled] {
+ opacity: 0.5;
+ }
+}
+
+.inline-menu.default {
+ display: inline-flex;
+ align-items: center;
+ gap: 24px;
+ padding: 8px 24px;
+ background-color: #F5F4F4;
+ border: #E8E8E8 solid 1px;
+ border-radius: 4px;
+ button {
+ width: 20px;
+ height: 20px;
+ background: transparent none 50% 50% no-repeat;
+ &.add {background-image: url('~src/assets/images/icons/note_add_20.svg');}
+ &.edit {background-image: url('~src/assets/images/icons/edit_20.svg');}
+ &.delete {background-image: url('~src/assets/images/icons/trash_20.svg');}
+ &.move {background-image: url('~src/assets/images/icons/drag-n-drop_24.svg');}
+ }
+}
+
+.btn {
+ color: #ffffff;
+ padding: 11px 24px;
+ background: var(--orange-2);
+ border: 1px solid var(--orange-2);
+ border-radius: 4px;
+ font-weight: 500;
+ font-size: 0.875rem;
+ line-height: 18px;
+ letter-spacing: 0.02em;
+ text-transform: uppercase;
+
+
+ &.with-icon {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 8px 20px 8px 12px;
+ &:before {
+ display: block;
+ width: 24px;
+ height: 24px;
+ margin-right: 8px;
+ background: transparent none 50% 50% no-repeat;
+ content: "";
+ }
+ &.add {
+ &:before {
+ //background-image: url('~src/assets/images/icons/add_circle_white_24dp.svg');
+ }
+ }
+ }
+ &.small {
+ height: 28px;
+ padding: 4px 16px;
+ }
+ &.danger {
+ background-color: #db373a;
+ }
+ &.secondary {
+ background-color: var(--white);
+ color: var(--orange-2);
+ border: var(--orange-2) solid 1px;
+ &.danger {
+ border-color: #db373a;
+ color: #db373a;
+ }
+ }
+ &.icon {
+ width: 24px;
+ height: 24px;
+ padding: 0;
+ border-color: transparent;
+ background: transparent none 50% 50% no-repeat;
+ //&.reply {background-image: url('~src/assets/images/icons/add_comment_20dp.svg');}
+ //&.delete {background-image: url('~src/assets/images/icons/close_20dp.svg');}
+ &.trash {background-image: url('~src/assets/images/icons/delete_24dp.svg');}
+ &.edit {background-image: url('~src/assets/images/icons/edit_dark_24.svg');}
+ //&.chain {background-image: url('~src/assets/images/icons/linked_24dp.svg');}
+ &.checkbox {
+ display: flex;
+ width: 18px;
+ height: 18px;
+ border: solid 1px #7f7f7f;
+ border-radius: 2px;
+ &.checked,&.mixed {
+ background-color: #2c86cd;
+ border-color: #2c86cd;
+ }
+ &.checked {
+ //background-image: url('~src/assets/images/icons/checkbox_24dp.svg');
+ }
+ &.mixed {
+ &:before {
+ display: block;
+ width: 12px;
+ height: 2px;
+ margin: auto;
+ background-color: #ffffff;
+ content: "";
+ }
+ }
+ }
+ }
+}
diff --git a/src/assets/css/documents-lists.scss b/src/assets/css/documents-lists.scss
new file mode 100644
index 0000000..55290bc
--- /dev/null
+++ b/src/assets/css/documents-lists.scss
@@ -0,0 +1,60 @@
+.documents.list.default {
+ .title {
+ margin: 0 0 16px;
+ font-weight: bold;
+ }
+ .items {
+ .item {
+ margin: 0 0 16px;
+ a {
+ display: inline-block;
+ padding-left: 28px;
+ background: transparent url('~src/assets/images/icons/document_20dp.svg') 0 0 no-repeat;
+ }
+ &:last-child {
+ margin: 0;
+ }
+ }
+ .none {
+ color: #7f7f7f;
+ }
+ }
+ .buttons {
+ margin-top: 24px;
+ button {
+ margin-right: 24px;
+ margin-bottom: 8px;
+ &:last-child {
+ margin-right: 0;
+ }
+ }
+ }
+}
+
+.documents.list.inline {
+ .item {
+ display: inline-block;
+ padding: 3px 30px 3px 12px;
+ margin: 0 12px 4px 0;
+ border: solid 1px rgba(0, 0, 0, 0.06);
+ border-radius: 12px;
+ //background: #e3eff9 url('~src/assets/images/icons/open_in_new_18dp.svg') calc(100% - 8px) 50% no-repeat;
+ font-size: 0.875rem;
+ a {
+ color: #000000;
+ }
+ }
+}
+
+
+@media screen and (max-width: 410px) {
+ .documents.list.default {
+ .buttons {
+ button {
+ width: 100%;
+ margin: 0 0 12px;
+ }
+ }
+ }
+}
+
diff --git a/src/assets/css/dropdown.scss b/src/assets/css/dropdown.scss
new file mode 100644
index 0000000..7c77050
--- /dev/null
+++ b/src/assets/css/dropdown.scss
@@ -0,0 +1,62 @@
+.dropdown {
+ position: absolute;
+ top: 100%;
+ right: 0;
+ width: 100%;
+ background-color: #ffffff;
+ border: #dedede solid 1px;
+ box-shadow: 0 3px 6px 0 rgb(0 0 0 / 16%);
+ z-index: 1000;
+ border-radius: 8px;
+ .menu {
+ margin: 0;
+ padding: 0;
+ list-style: none;
+ border-radius: 8px;
+ .type {
+ width: 100%;
+ .row {
+ width: 100%;
+ display: flex;
+ flex-direction: row;
+ justify-content: space-between;
+ align-items: center;
+ column-gap: 16px;
+
+ .title {
+
+ }
+ .submenu {
+ width: 20px;
+ height: 20px;
+ background: transparent url('~src/assets/images/icons/expand_less_20.svg') 50% 50% no-repeat;
+ transform: rotateZ(180deg);
+ transition: transform 0.3s;
+ &.active {
+ transform: rotateZ(0deg);
+ }
+ }
+
+
+ a, span {
+ display: block;
+ padding: 12px 16px;
+ color: #000000;
+ cursor: pointer;
+ border-bottom: #E0E0E0 solid 1px;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ }
+ &:last-child {
+ a, span {
+ border-bottom: none;
+ }
+ }
+ &:hover {
+ background-color: #f7f7f7;
+ }
+ }
+ }
+ }
+}
diff --git a/src/assets/css/fonts.scss b/src/assets/css/fonts.scss
new file mode 100644
index 0000000..87c8e61
--- /dev/null
+++ b/src/assets/css/fonts.scss
@@ -0,0 +1,119 @@
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-Italic.eot');
+ src: local('Open Sans Italic'), local('OpenSans-Italic'),
+ url('../fonts/sans/OpenSans-Italic.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-Italic.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-Italic.woff') format('woff'),
+ url('../fonts/sans/OpenSans-Italic.ttf') format('truetype');
+ font-weight: normal;
+ font-style: italic;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-Regular.eot');
+ src: local('Open Sans Regular'), local('OpenSans-Regular'),
+ url('../fonts/sans/OpenSans-Regular.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-Regular.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-Regular.woff') format('woff'),
+ url('../fonts/sans/OpenSans-Regular.ttf') format('truetype');
+ font-weight: normal;
+ font-style: normal;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-BoldItalic.eot');
+ src: local('Open Sans Bold Italic'), local('OpenSans-BoldItalic'),
+ url('../fonts/sans/OpenSans-BoldItalic.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-BoldItalic.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-BoldItalic.woff') format('woff'),
+ url('../fonts/sans/OpenSans-BoldItalic.ttf') format('truetype');
+ font-weight: bold;
+ font-style: italic;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-SemiBold.eot');
+ src: local('Open Sans SemiBold'), local('OpenSans-SemiBold'),
+ url('../fonts/sans/OpenSans-SemiBold.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-SemiBold.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-SemiBold.woff') format('woff'),
+ url('../fonts/sans/OpenSans-SemiBold.ttf') format('truetype');
+ font-weight: 600;
+ font-style: normal;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-ExtraBoldItalic.eot');
+ src: local('Open Sans ExtraBold Italic'), local('OpenSans-ExtraBoldItalic'),
+ url('../fonts/sans/OpenSans-ExtraBoldItalic.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-ExtraBoldItalic.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-ExtraBoldItalic.woff') format('woff'),
+ url('../fonts/sans/OpenSans-ExtraBoldItalic.ttf') format('truetype');
+ font-weight: 800;
+ font-style: italic;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-LightItalic.eot');
+ src: local('Open Sans Light Italic'), local('OpenSans-LightItalic'),
+ url('../fonts/sans/OpenSans-LightItalic.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-LightItalic.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-LightItalic.woff') format('woff'),
+ url('../fonts/sans/OpenSans-LightItalic.ttf') format('truetype');
+ font-weight: 300;
+ font-style: italic;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-Bold.eot');
+ src: local('Open Sans Bold'), local('OpenSans-Bold'),
+ url('../fonts/sans/OpenSans-Bold.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-Bold.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-Bold.woff') format('woff'),
+ url('../fonts/sans/OpenSans-Bold.ttf') format('truetype');
+ font-weight: bold;
+ font-style: normal;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-SemiBoldItalic.eot');
+ src: local('Open Sans SemiBold Italic'), local('OpenSans-SemiBoldItalic'),
+ url('../fonts/sans/OpenSans-SemiBoldItalic.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-SemiBoldItalic.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-SemiBoldItalic.woff') format('woff'),
+ url('../fonts/sans/OpenSans-SemiBoldItalic.ttf') format('truetype');
+ font-weight: 600;
+ font-style: italic;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-ExtraBold.eot');
+ src: local('Open Sans ExtraBold'), local('OpenSans-ExtraBold'),
+ url('../fonts/sans/OpenSans-ExtraBold.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-ExtraBold.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-ExtraBold.woff') format('woff'),
+ url('../fonts/sans/OpenSans-ExtraBold.ttf') format('truetype');
+ font-weight: 800;
+ font-style: normal;
+}
+
+@font-face {
+ font-family: 'Open Sans';
+ src: url('../fonts/sans/OpenSans-Light.eot');
+ src: local('Open Sans Light'), local('OpenSans-Light'),
+ url('../fonts/sans/OpenSans-Light.eot?#iefix') format('embedded-opentype'),
+ url('../fonts/sans/OpenSans-Light.woff2') format('woff2'),
+ url('../fonts/sans/OpenSans-Light.woff') format('woff'),
+ url('../fonts/sans/OpenSans-Light.ttf') format('truetype');
+ font-weight: 300;
+ font-style: normal;
+}
diff --git a/src/assets/css/forms.scss b/src/assets/css/forms.scss
new file mode 100644
index 0000000..34b631e
--- /dev/null
+++ b/src/assets/css/forms.scss
@@ -0,0 +1,51 @@
+input, select, textarea {
+ width: 100%;
+ height: 40px;
+ padding: 8px 16px;
+ border-radius: var(--radius-1);
+ border: solid 1px var(--grey-3);
+ font-family: "Open Sans";
+ font-size: 1rem;
+ &:focus, &:focus-visible {
+ border-color: #111111;
+ outline: none;
+ }
+}
+
+.invalid {
+ input, select, .textbox {
+ border-color: #e60046!important;
+ }
+}
+
+
+.switch {
+ width: 40px;
+ height: 20px;
+ margin: auto 0;
+ padding: 2px;
+ border-radius: 10px;
+ background-color: #c0c0c0;
+ box-shadow: inset 0 0 2px 0 rgba(0, 0, 0, 0.25);
+ cursor: pointer;
+ transition: background-color 0.3s;
+ &:before {
+ display: block;
+ width: 16px;
+ height: 16px;
+ background-color: #ffffff;
+ box-shadow: rgba(0, 0, 0, 0.12) 0 0 2px 0;
+ border-radius: 20px;
+ transition: transform 0.3s;
+ content: '';
+ }
+ &.active {
+ background-color: #F9B417;
+ &:before {
+ transform: translateX(20px);
+ }
+ }
+ &.disabled {
+ opacity: 0.5;
+ }
+}
diff --git a/src/assets/css/list-items.scss b/src/assets/css/list-items.scss
new file mode 100644
index 0000000..8d98622
--- /dev/null
+++ b/src/assets/css/list-items.scss
@@ -0,0 +1,86 @@
+.list.item.default {
+ padding: 24px;
+ margin-bottom: 24px;
+ background-color: #FFFFFF;
+ box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.16);
+ .main-bar {
+ display: flex;
+ flex-direction: row;
+ width: 100%;
+ .left {
+ flex-grow: 1;
+ }
+ .right {
+ display: flex;
+ flex-direction: column;
+ margin-left: 24px;
+ flex-shrink: 0;
+ .row {
+ display: flex;
+ flex-direction: row;
+ button {
+ margin: 0 12px 0 0;
+ &:last-child {
+ margin-right: 0;
+ }
+ }
+ }
+ }
+
+ .params {
+ p {
+ margin-bottom: 14px;
+ &:last-child {
+ margin-bottom: 0;
+ }
+ }
+ }
+ }
+
+ .title {
+ margin-bottom: 12px;
+ font-weight: bold;
+ }
+
+ .status {
+ margin-bottom: 14px;
+ font-size: 0.875rem;
+ font-weight: bold;
+ color: #7f7f7f;
+ }
+ .yellow, .reviewing {color: #c48723;}
+ .green, .active {color: #669933;}
+ .red, .declined {color: #e60046;}
+ .edit {
+ //background-image: url("~src/assets/images/icons/edit_24dp.svg");
+ }
+ .delete {
+ //background-image: url("~src/assets/images/icons/delete_24dp.svg");
+ }
+ .toggle {
+ margin-top: auto;
+ margin-left: auto;
+ //background-image: url("~src/assets/images/icons/arrow_down_24dp.svg");
+ transition: transform 0.2s;
+ &.active {
+ transform: rotateZ(180deg);
+ }
+ }
+ .name {
+ margin-bottom: 14px;
+ font-weight: bold;
+ }
+
+ .details {
+ margin-top: 24px;
+ }
+}
+
+
+@media screen and (max-width: 767px) {
+ .list.item.default {
+ padding: 16px;
+ margin-left: -16px;
+ margin-right: -16px;
+ }
+}
diff --git a/src/assets/css/main-menu.scss b/src/assets/css/main-menu.scss
new file mode 100644
index 0000000..650464e
--- /dev/null
+++ b/src/assets/css/main-menu.scss
@@ -0,0 +1,261 @@
+
+@media screen and (max-width: 960px){
+
+
+
+ .main-menu {
+
+ // level 1
+ &>pages-menu{
+ display: block;
+
+ pages-menu-item {
+ display: flex;
+ flex-direction: row;
+ flex-wrap: wrap;
+ justify-content: flex-start;
+ align-items: stretch;
+ align-content: flex-start;
+ font-family: Open Sans;
+ font-size: 16px;
+ font-style: normal;
+ font-weight: 700;
+ line-height: 24px;
+ margin: 16px 0;
+
+ :last-child{
+ margin-bottom: 0;
+ }
+
+
+
+ .expand{
+
+ width:24px;
+ height: 24px;
+ display: inline-block;
+ }
+ .toggle{
+ background: url('~src/assets/images/icons/expand_less_24.svg') center no-repeat;
+ transform: rotateZ(90deg);
+ transition: transform 0.3s;
+ }
+ .open {
+ transform: rotateZ(180deg);
+ }
+
+ a {
+ color: #FFF;
+ display: block;
+ flex-grow: 1;
+ flex-shrink: 1;
+ flex-basis: calc(100% - 24px);
+ align-self: auto;
+ order: 0;
+ padding-left: 4px;
+ }
+ a.active-mob span{
+ border-bottom: 2px solid #F9B417;
+ }
+
+ :host-context(.active){
+ border-bottom: none !important;
+ }
+ pages-menu.hide-children{
+ display: none;
+ }
+ // level 2 and below
+ pages-menu{
+ flex-grow: 1;
+ flex-shrink: 0;
+ flex-basis: 100%;
+ align-self: auto;
+ order: 0;
+
+ pages-menu-item {
+ color: rgba(255, 255, 255, 0.75);
+ /* 16-24/Regular */
+ font-weight: 400;
+ margin-left: 28px;
+ }
+ }
+ }
+ }
+ }
+}
+
+
+
+
+
+
+
+@media screen and (min-width: 961px){
+ .main-menu {
+ pages-menu {
+ display: none;
+ animation: slide-from-bottom-and-fade-in 0.2s;
+ pages-menu-item {
+ a {
+ font-size: 0.875rem;
+ color: var(--grey-7);
+ transition: all 0.3s;
+ }
+ &:hover {
+ &>pages-menu {
+ display: flex;
+ }
+ }
+ }
+ }
+
+ // level 1
+ &>pages-menu {
+ width: 100%;
+ display: flex;
+ justify-content: space-between;
+ overflow: hidden;
+
+ &>pages-menu-item {
+ flex-grow: 1;
+ flex-shrink: 1;
+ flex-basis: 0;
+ text-align: center;
+ &>a {
+ display: block;
+ padding: 21px 24px;
+ color: white;
+ font-size: 1.125rem;
+ font-weight: 700;
+ line-height: 1rem;
+ border-right: #F9B417 solid 1px;
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+
+ &.active, &:hover {
+ background-color: #3E3D40;
+ text-decoration: none;
+ }
+ }
+
+ &:first-child {
+ &>a {border-left: #F9B417 solid 1px;}
+ }
+
+ &>:hover {
+ & > pages-menu {
+ display: flex;
+ }
+ }
+
+ // level 2
+ &>pages-menu {
+ display: none;
+ justify-content: center;
+ align-items: center;
+ position: absolute;
+ top: 100%;
+ left: 0;
+ width: 100%;
+ background-color: #ffffff;
+ border-bottom: #E8E8E8 solid 1px;
+ box-shadow: 0 0 6px rgba(0, 0, 0, 0.25);
+ z-index: 1000;
+ align-items: stretch;
+
+ &>pages-menu-item {
+ position: relative;
+ display: flex;
+ align-items: stretch;
+
+ &.hidden {display: none;}
+
+ &>a {
+ position: relative;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ padding: 23px 20px;
+ min-width: 118px;
+ max-width: 200px;
+ font-weight: bold;
+ text-align: center;
+
+ &>span {
+ display: block;
+ overflow: hidden;
+ }
+
+ &:after {
+ position: absolute;
+ width: 64px;
+ height: 4px;
+ bottom: 0;
+ left: calc(50% - 32px);
+ background-color: #F9B417;
+ content: '';
+ opacity: 0;
+ transition: opacity 0.3s;
+ }
+
+ &:hover {
+ background-color: #F5F4F4;
+ text-decoration: none;
+ }
+ &:hover, &.active {
+ &:after {
+ opacity: 1;
+ }
+ }
+ }
+
+ &:first-child {
+ &>pages-menu {
+ left: 0;
+ right: -100px;
+ }
+ }
+ &:last-child {
+ &>pages-menu {
+ left: -100px;
+ right: 0;
+ }
+ }
+
+ // level 3
+ &>pages-menu {
+ position: absolute;
+ top: 100%;
+ left: -50px;
+ right: -50px;
+ padding: 8px 24px;
+ background-color: #ffffff;
+ border: #dedede solid 1px;
+ box-shadow: 0 0 6px rgba(0, 0, 0, 0.25);
+ z-index: 990;
+ &>pages-menu-item {
+ display: block;
+ &>a {
+ display: block;
+ padding: 8px 0;
+ &:hover, &.active {
+ color: #F9B417;
+ text-decoration: none;
+ }
+ }
+ }
+ }
+ &:hover {
+ &>pages-menu {
+ display: block;
+ text-decoration: none;
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+
+}
\ No newline at end of file
diff --git a/src/assets/css/page-top-panel.scss b/src/assets/css/page-top-panel.scss
new file mode 100644
index 0000000..9892dbb
--- /dev/null
+++ b/src/assets/css/page-top-panel.scss
@@ -0,0 +1,68 @@
+.top-panel {
+ margin: 0 auto 32px;
+ max-width: 1240px;
+ &.pt-40 {
+ padding-top: 40px;
+ }
+
+ .buttons {
+ margin-bottom: 32px;
+ .btn {
+ font-weight: 700;
+ }
+ }
+
+ .filters {
+ padding: 16px 0 24px;
+
+ background-color: #F5F4F4;
+ border-top: #E8E8E8 solid 1px;
+ border-bottom: #E8E8E8 solid 1px;
+ .limiter {
+ display: flex;
+ flex-direction: row;
+ align-items: flex-end;
+ }
+ .search {
+ flex-grow: 1;
+ label {
+ margin-bottom: 2px;
+ color: #86898E;
+ }
+ input {
+ height: 40px;
+ padding: 8px 52px 8px 16px;
+ border: #BFBFBF solid 1px;
+ border-radius: 12px;
+ background: #ffffff url('~src/assets/images/icons/search_24dp.svg') calc(100% - 12px) 50% no-repeat;
+ }
+ }
+ .advanced {
+ margin-left: 24px;
+ button {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ gap: 8px;
+ height: 40px;
+ padding: 8px 16px;
+ background-color: #F9B417;
+ color: #ffffff;
+ border-radius: 20px;
+ font-size: 14px;
+ font-weight: 700;
+ text-transform: uppercase;
+ &:before {
+ width: 24px;
+ height: 24px;
+ background: transparent url('~src/assets/images/icons/filter_empty_24.svg') 50% 50% no-repeat;
+ content: '';
+ }
+ &.filled:before {
+ background-image: url('~src/assets/images/icons/filter_filled_24.svg');
+ }
+ }
+ }
+ }
+}
+
diff --git a/src/assets/css/registry.scss b/src/assets/css/registry.scss
new file mode 100644
index 0000000..36043cd
--- /dev/null
+++ b/src/assets/css/registry.scss
@@ -0,0 +1,56 @@
+.registry {
+ .bar {
+ background-color: #3E3D40;
+ color: #ffffff;
+ .menu {
+ button {
+ background: transparent 50% 50% no-repeat;
+ &.add.category {background-image: url('~src/assets/images/icons/add_library_24.svg');}
+ &.add.entry {background-image: url('~src/assets/images/icons/add_notes_24.svg');}
+ &.move {
+ background-image: url('~src/assets/images/icons/drag-n-drop_24w.svg');
+ cursor: move;
+ }
+ &.edit {background-image: url('~src/assets/images/icons/edit_24.svg');}
+ &.delete {background-image: url('~src/assets/images/icons/close_white_24dp.svg');}
+ }
+ }
+ .expand {
+ button {
+ background: url('~src/assets/images/icons/expand_less_24.svg') 50% 50% no-repeat;
+ }
+ }
+ }
+ registry-category {
+ display: block;
+ .bar {
+ background-color: #86898E;
+ }
+
+ registry-category {
+ .bar {
+ background-color: #F5F4F4;
+ color: #86898E;
+
+ .menu {
+ button {
+ &.add.category {background-image: url('~src/assets/images/icons/add_library_dark_24.svg');}
+ &.add.entry {background-image: url('~src/assets/images/icons/add_notes_dark_24.svg');}
+ &.move {background-image: url('~src/assets/images/icons/drag-n-drop_24.svg');}
+ &.edit {background-image: url('~src/assets/images/icons/edit_dark_24.svg');}
+ &.delete {background-image: url('~src/assets/images/icons/close_24dp.svg');}
+ }
+ }
+ .expand {
+ button {
+ background: url('~src/assets/images/icons/expand_less_dark_24.svg') 50% 50% no-repeat;
+ }
+ }
+ }
+
+ registry-category {
+ padding-left: 24px;
+ }
+ }
+ }
+}
diff --git a/src/assets/css/slider.scss b/src/assets/css/slider.scss
new file mode 100644
index 0000000..fb3d2b3
--- /dev/null
+++ b/src/assets/css/slider.scss
@@ -0,0 +1,176 @@
+.slider-bar {
+ position: fixed;
+ top: 0;
+ right: 0;
+ display: flex;
+ flex-direction: column;
+ width: 100%;
+ max-width: 768px;
+ height: 100%;
+ background-color: #ffffff;
+ box-shadow: -3px 0 6px 0 rgba(0, 0, 0, 0.16);
+ overflow: hidden;
+ animation: slide-from-right 0.3s;
+ z-index: 110;
+
+ .header {
+ padding: 24px;
+ border-bottom: 1px solid var(--grey-7);
+ background-color: #F7F8FA;
+
+ .title {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+
+ h2 {
+ margin: 0;
+ font-weight: 400;
+ font-size: 1.5rem;
+ line-height: 30px;
+ color: #000000;
+ }
+
+ .close {
+ width: 24px;
+ height: 24px;
+ margin-left: auto;
+ background: transparent url(/assets/images/icons/close_24dp.svg) 50% 50% no-repeat;
+ }
+ }
+
+ .stepper {
+ padding: 24px 0 0;
+ .items {
+ display: flex;
+ flex-direction: row;
+ gap: 24px;
+ .item {
+ width: 150px;
+ flex-shrink: 1;
+ font-size: 14px;
+ overflow: hidden;
+ .num {
+ position: relative;
+ width: calc(100% - 13px);
+ height: 24px;
+ padding: 4px 6px;
+ margin: 0 0 4px;
+ border-radius: 2px 0 0 2px;
+ background-color: #E8E9EB;
+ color: #86898E;
+ font-weight: bold;
+ &:after {
+ position: absolute;
+ left: 100%;
+ top: 0;
+ width: 13px;
+ height: 100%;
+ background: transparent url('~src/assets/images/icons/step_upcoming.svg') 100% 50% no-repeat;
+ content: '';
+ }
+ }
+ .name {
+ font-size: 14px;
+ color: #6c6c6c;
+ }
+ &.active {
+ .num {
+ background-color: #B88E12;
+ color: #ffffff;
+ &:after {
+ background-image: url('~src/assets/images/icons/step_active.svg');
+ }
+ }
+ .name {
+ color: #B88E12;
+ font-weight: bold;
+ }
+ }
+ &.finished {
+ .num {
+ background-color: rgba(184, 142, 18, 0.2);
+ color: #B88E12;
+ &:after {
+ background-image: url('~src/assets/images/icons/step_finished.svg');
+ }
+ }
+ .name {
+ color: #B88E12;
+ }
+ }
+ }
+ }
+ }
+ }
+
+ .body {
+ height: 100%;
+ padding: 24px;
+ flex-grow: 1;
+ overflow: auto;
+ -webkit-overflow-scrolling: touch;
+ }
+
+ .footer {
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ padding: 16px 24px;
+ background-color: #F7F8FA;
+ border-top: 1px solid var(--grey-7);
+
+ .left {
+ .reset {
+ color: #2c86cd;
+ cursor: pointer;
+ }
+
+ .notice {
+ font-weight: 400;
+ font-size: 0.875rem;
+ line-height: 18px;
+ color: var(--grey-7);
+ }
+ }
+
+ .right {
+ margin-left: auto;
+ display: flex;
+ button {
+ margin-left: 24px;
+ }
+ }
+ }
+}
+
+.slider-overlay {
+ position: fixed;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ background-color: rgba(0, 0, 0, 0.37);
+ z-index: 100;
+}
+
+
+@media screen and (max-width: 767px) {
+ .slider-bar {
+ .header, .body, .footer {
+ padding: 16px;
+ }
+
+ .footer {
+ .left {
+ font-size: 14px;
+ }
+ .right {
+ button {
+ padding: 8px 16px;
+ margin-left: 16px;
+ }
+ }
+ }
+ }
+}
diff --git a/src/assets/css/tables.scss b/src/assets/css/tables.scss
new file mode 100644
index 0000000..8fca50a
--- /dev/null
+++ b/src/assets/css/tables.scss
@@ -0,0 +1,60 @@
+table.default {
+ width: 100%;
+ border-collapse: collapse;
+ tr {
+ td {
+ padding: 6px 0;
+ &.caption {
+ width: 232px;
+ padding-right: 24px;
+ color: #86898E;
+ vertical-align: top;
+ }
+ &.value {
+ vertical-align: top;
+ p {
+ margin: 0 0 12px;
+ }
+ }
+ }
+ }
+ &.lined {
+ tr {
+ td {
+ border-bottom: #e0e0e0 solid 1px;
+ }
+ &:last-child {
+ td {
+ border-bottom: none;
+ }
+ }
+ }
+ }
+}
+
+
+@media screen and (max-width: 767px) {
+ table.default {
+ tr {
+ display: block;
+ td {
+ display: block;
+ padding: 0;
+ b {
+ display: block;
+ padding: 14px 0 0;
+ }
+ &.caption {
+ width: 100%;
+ margin: 14px 0 6px;
+ }
+ &.value {
+
+ }
+ }
+ }
+ &.lined tr td {
+ border-bottom: none;
+ }
+ }
+}
diff --git a/src/assets/css/tabs.scss b/src/assets/css/tabs.scss
new file mode 100644
index 0000000..d7534e1
--- /dev/null
+++ b/src/assets/css/tabs.scss
@@ -0,0 +1,47 @@
+.tabs.default {
+ display: flex;
+ margin-bottom: 32px;
+ max-width: 100%;
+ overflow: auto;
+ border-bottom: #E8E8E8 solid 1px;
+ -webkit-overflow-scrolling: touch;
+ &.simple {
+ margin-bottom: 24px;
+ }
+ button {
+ padding: 7px 16px;
+ margin-right: -1px;
+ background: #ffffff;
+ border-radius: 8px 8px 0 0;
+ border: #E8E8E8 solid 1px;
+ border-bottom: none;
+ color: #86898E;
+ font-size: 16px;
+ font-weight: 700;
+ cursor: pointer;
+ &:last-child {
+ margin-right: 0;
+ }
+ span {
+ white-space: nowrap;
+ }
+ &:last-child {
+ span {
+ }
+ }
+ &.active {
+ color: #ffffff;
+ background-color: #F9B417;
+ border-color: #F9B417;
+ }
+ &.disabled {
+ opacity: 0.7;
+ cursor: not-allowed;
+ }
+ &:hover {
+ background-color: #F9B417;
+ border-color: #F9B417;
+ color: #ffffff;
+ }
+ }
+}
diff --git a/src/assets/fonts/lato/Lato-Black.ttf b/src/assets/fonts/lato/Lato-Black.ttf
new file mode 100644
index 0000000000000000000000000000000000000000..3f7819f6090de0a0071efca4c02a6361cdb28c44
GIT binary patch
literal 584008
zcmdqK2YggT_dh)4_9eZNx|>abWD_7El_Z2TI)u;?5D2~Zj(`*kA_$@)VDHKUxB(UH
zT>-Hpc0oi%>>?IOcK_eGyBiV+>hpX5zxVTbUwpoqxpU{voH=vm%$YMMc?czh1mTB7
z0=rlBANct%_YWZQh8V&-z1V%=;8N$nrRhX_{um+cCiEZJA#+;9$w7qBE%>T#?DWyI
zj=XSJ4?;S1CM4{>u?yx|yH0zegph#_y#IQ_tclZ4gnsffA(bBzV!37F=()2{9*Fis
zk!lmCEuN5_vTr>hgF*?v_Qa&|qsOVA=F4b52Jdqwp};S@O?y0}Pm(xk`n*L^CpJlV
z{*#ang;U4RnK9$@L#K%3mq#dJ(`Jqx-Il-IhVakC`;zIS7tQk9OwXbIB7AS1F?#y=
zJ&(FJ64|eikcf%1X3m{g)9}JpA}8KQ$dsA0=8T^;)0kX9NVTBz3A9NF;~#X|JD83N
zC_F==)wfYX-Z}ZuVl(}=+m&ZeG(N2Vu04TgoiOtYbVrE#xN8U@#v^A>{4vPb;w={+
zng1+ri4x0O_z_695CvaWkvg&vFTVyj-b&IUekB1f)a>Qe(s}k7qVWCCxs?{CF>Q{-5@O?>rG6@yZcGL5{&Xx;>Tu?^}u94k%Y=u
zp-vP~M3_j`6{sWX35>uufHsyCN`IoxPbeEn3S>L-gGh{t7fGCSgtU`CCYPH4O4^rFrg^z;PB%s(?xsNoGskNKY2-cCtu!y)*)K0QMxYGnGtM9uVJn
zu@+-oOWG=*Azh9#0gRcQ15Yj|RsrQo;A&!(J|~kH=;ee&nb1j$yp2T3g-E*~y_ZCR
zcTwu=Bt|_*qR_`E6FKe%WgL;E689fcXZN4{K9a#cCtZ0Q$>kZOH|s~D*(y@ZQiu&{
zA{$O@bT^4-mysBD1?furkxsO~`x|yY@`Lc*cG8tC1Fl5<)ks$nJADo*B~kP+iN(7-
z*28_4Uqk%aHAG`Q-G8t^(vDj(9;^Fxq-TK>Kxi`<5aB=ZoCkyhQGh=%45$Kn0I9%j
zz$4!DS)}uTDZmlnbKoQ3Rc@sU&_)^zIp0hSA+z#Y_m_}~G9ky(J0u4(=1}e-J(cOC
zOgcb1ORLEw>3Y&vx*YO3opj_|K}%QCNqUq7Nzai!a#zxp^(JGaQACkm#XKdt&+$T%
z!^=pf+=g_OR*>P+k0g^n2fRfzX(}11^dX%D_!+kgG}J1SNIvN53>w4eha?l|C^dqf
zZXPI$iNChq{hPFzD1uJ;4&WEJOPdC)_pCqpE0j6hpUXSlUnsLlhSDF;qHHWF)z*^r
z+Ha`WhQzAXX!9GCr;-pkjTCCjk)Px~DgOa^aRYBdh9AOsr-R-!B
?a
zC_hEIDEE^7${5na2l+S1iksB%67XjY83x2kd60)SBn21?L<33E8uw399@gez5~B|y
zJ5gp}lc?qe(7RnpA1N0yISOmw4EQ^Ol=07@1FA@G=)cZrFBzx>DuIq@=MSV=Ui3!V
z73d_FVBHKsd)I*WYfx_&@yD7-mP$yfG>)XB&vw9gK#UDzb)Q4p6%hRC%5Ed=fqWnx
zNCi|N6X*z30y#h)&?{9Sd6(p?
zlw2+~kSw_ubn#E5o19MO0OREsu@*l8?!vydid=>Dew8!{Iyjm1W7|m*opysbpO
ztyB_+XCFjeJFp4ws0SoaathGN(9;C(j^o>707L!&@I6m;pGMsR>>o4uL6escYQK_7
zFUBDi80C9rb4WE?K>E_zWFWhT^ktjKaID9^Y#XqVjOP!LiS#I`qhCW#t|Yl^Cn>^M
z4+{|D9)iAmc=~pqR<@Ba`4Pfp8_}Wbiq!!m40^SrG>3GNUnjZJ1CWF1?t#!>`SM2h
z0d|mFBkzT-yqm00g53kf{-AXuh00KT_dWDxAL5YbVh@EaBlZV*KUpas#s2XMY@3I`
zhlfZvX)B47A0-7^FU;dE;8UPI*5ljIt!Ig@M3E9X1G?`%_c_xJvf@4F-F%-y0-$$u
zu*TO*%iW(s2SQJ}ALbuoZ3~;H3khY1-3yfaP`&^VHbkZSJLLwC&gDy>FQZAcumhxL
z+`sb&NC&>2bmp5$GT#LIMA%7H?&Ex&d%qlw_OOTZN1@lShs#mW!|h3;@+01G=L<&xEW%w<~?IKel3LwPsfd
zJ4M(gu=_^9cFG2XtuvXwhjnxshUK>w-6*O(b`uGw1?{yf@Qp{sAbn%bwH?cQR
zuYF_MQoM#Ju&pMEvBAC?r94RLJa(3QKI%=Dt^lxKDJu5k!O%ZANi@S`#HxtTfL
z-HbEk0dLx34}1-&kdrCIj}HJ}
zw~-L0!46&Ic1eYJ&H<12fPb%%2Km{ifVq(40iebW`?k)%qBhwei;WUQFah0XjbvBF-hVrPMS
z@l7t)*hUh@`eWZ&iSOn@Pu7w|`Ugp7G6{f<+KDa4-qj8|a|+gxz%|$x9>zX433lyu
zcsGUU&^=c0$i}*3Pg{j`uoZUpcF2xD&QveKUT#k$)(9HD!T$Rj_DnbSv4^4Wo&!z7
zUe3k0%Sb%>4WQSd4V+QvdeE^7ds-jZDL0X9dWZW9^LZm|nMYtdKWy61`D}%I7h3^3
zt^r_2i@qVhRyxT2F#VFmvAfX6eHhnu*kdO{USUr&KkTOuV;|-2lX#!OHj|;SgTm;?
zC?AD(o+jI+8nPWWWpBEX^a83_9&GSD(jEuxDgnsDX0CdXN`#(o0@V5{wjOQ$N$$Q7
z{3IDCAowiwt~>-b%sl9`%~=0i-M>Rd*UQgfO+JNrhYgK0LMC9BlSx}?Hz`mD!v0x-
zJ$s-mYmMO*@1Nq8y
zpOp&m{VMkv`7P9W5Hw_go;1|yioFdGwl?+`Md(cFOCXcvVhodouIJleM}wdIGU%e>wz!tep9;#`|Dt0l{Op9Y=r8!5v44Uq-^_P9?e+rZE1?gkY)6Sh`>2LFRxjy)ol6o7|WSPuqdU7SOO
zy~kj4YzCI09DXjee?RG{y$^rI`y})KCa^{)gJ;D+p@Q=UD|k|OyX
zQVg596l<(PpFzq&my1t=u0Km=;=AoiHCe#sz@C~z7V?kDa9|-DiFxwa)WWW=#rggU
z?j#kg0=9Ss>B8{Vb8Fa#(7IsrvydKT@5e&-XM4=^
zObbe?{v1wh(ziV;4Z2w-SKv
zfEa_I(MPYSV+T!bfh69EOeW(9QBtwz$G|rQh<%ulb8iT+_3qQyCmgVe{=&W^&dbAL
zo8`bx%;Z9EeMCx38|onTuJ5phM!}{S23!3a(vz2BpB+NF;Otz+ugCtIK`J1-p8)XV
z!mF7_wqj4~fOCBZb^?2jc?L1hGdR
z|4|RR1^VezoLf%9N9s*+&LH$RpfCDegA|@^au&b}M;jjkzvElchD&}Kewkm0L%R!p
zHk=bt>r?2v-5%N-Plk6N)0H5c67e2ABGW?tJo4^ae6R;iL0?xvZeg=EpNnkSkJ(t0j?2R*07S3N4
z?r)`QA^RR0cOYE?9llxq)!c(}1Z~n%_h564;H)UlEyB0Ph0psQvRTMHe;oSr2eMtB
zfHUq_WRCFv3BSEr=M55Q`tUJcHiTRbejgXMov`uvXIMj5k~UgbVHdcoUA|zVM7YrcN(#<9(dm$y2#rO?ieNrfL1FYWI{mjIS;%m_dT1w
z2lxrZdO_I@-Z|YQ&grm47UCQ=LY%kwM0W$urntpu1j`%#gY;wIW#q9^ns5qbk$CXnx(*nId>6d)_GPw(
ze$2K%M+&$?kzyYg{hRG#oQ*l&JnpQ8ba=F4)!PZ(;*iF<(*M}5m4?x
z`9(l^dz4=Ul=nw@Yxv)y<06{HIR1Y`$3;9AeE*wy`G3R@uRK2Dk;O)&E!P6p&snTx
zaUbHsJLqmx4uw2IE=~FL%4)+j)3(RD!(sv&|3Oww`QC+kfso(d0myITA}?_7*{}`y
z$AM>o?>#v83d&alST|=+0N5!T`r#egFxTjP*k9g4*&YDv@!ajejd)i8qvy>yB@R};P5pO|;A;{LT4Y15P!&vEcaHix*Mt#p5D>UU9&J>x_#><`(DfD0g;KUOcye>q{lL@gT5I33hb>e9t?~=P0)g>2c3D
zP48N*%VxO8;9mQ3q|X5_08aqtfcH^;Er5G(cUw=nna6wB_MY;`*bLWSp1SVOJ#}1f
zu^Ekz1NY%w3gCO*;(2zpAY$O48+7ASDt)#ADN`vTV*xuCH-FaS6v7q~V9
zw>H)9?EV5{jkzSeu^J*?<6onVJMv%G^|jjueyf=m_Tm0Tv;%uP(FfE2C44vn@aubR
z(nCyfi!&I?;Oh|Ylig1uy#wi4;n!lx
z=68o!gj+$mlZ`jOc?kK9sI$+!zZl`Z!jpm~_~xWLfl>HYL*Jr};Uoy@M5f`)s=40*
zu4A|0Zao`5)rZadA2Y^A-2bRLo*yMM&X3PG&Q{V7Q1=#;3%~S#i)+O)=cG$-S9E)>eRC_(0mqmTH;y4J?mLAlAU#LG4J}kaYcWdKZE-S
z+&|+C7sV<3Pi~|l??Zrlhg<+($iIPzO%nAMdg1*>J%CuHe*?raiFz91iv)b%U`{>p
zO|7MK|K?q5^?hX@G=1j~cY7wv;5$eB)TLm?Rf*UtftB#PBgX1~3Xa&UR`C|@dqkX8
zE3sNw59i~xM9kK;xch-`k&bcyX2xt)!KWZ%wnV&^H)abywqokW-Bt5=t(C-J+es9B
zzZ&M=A9pbA*>fB3^J0``D7ZIo_O8{s
zl8C$de*xmI(p~n!boOM2rDq$dpPli^Gc~
zaN$2D;>rqefAcFzgRg8A@Tu|^_~^si$iL%>4-zp#%^@LP=tAHeIqE{-jJ?(e_{J09
z!8QSZ!VRFO8QiPj!|RW-Hh}O6_dwbNJexjll(~FBneZk10H2yCmPn+{fOcCv55e<;
zz^xuyeEy22RMa=)ijZzP4@yxVaYl%s7E#nqpp)TWJdS4*cz+Ce6UZ~$T{1~42
zBf3ra#3}p|0%QiT8TAESKA15{c&-!>aY;yO<@8@||$e~Q~^HCDqLn*bVm3E-}zy*$KqM8pxuLmDRogYnFOL%^M$a`Dc!U73qD
zj=OoG1Ef5!y$!nw<2CPSkp3=!Ic_e$O?h!YEbe`UA4S;w!k41nMEvEuNEgrolSTm1
zB9KD-!|zLo9G(>hpE9J#{GZ7EkN+{+nU17$=oD!o9YsgbDms7;p?hd9?L`Y{CEY+b
z(i`X|dLz9_non<*7SPQ!pXSjg>0bI2&8BsrNg*oy=@#Ng{7C=_A|WJ{gpo+nmPBKH
z;l73>kVKM9+L87om81~|t)@NcKsp@vTiZ!G=}0<3Zn{8TMnJa5kO{awokymT>0~CE
zL*|kBWC2-9t|qvxCu_-dWE~wuyVJoGK6SN&nn^TunZ~ssZKSqU+oEmLZqshn?!?Xa
z+uB>&JKB4CtRADs=~lhBK3E^557BG%q55y}=zbRcUhxm7mZ4-Mi?$)?F;{J*ci;s=3i0>OeG`==|
zc>IX?W$};3za0Nw{3r20#s3!XvIbfctjX4n*3Q-fYq7Q5I?6iRdXx1r>yy^cY_cuH
z7Gbm65^Tw~3|pqHpKX-wO50Z3LkTP)AR#y*EFmf(KB0X=T0)P6(Fx=2%pPdBCC*L!
zEeV06No|q>lR}dslkQIXPtu{Jx01e2Cdq}#lT)s6Omi&EhCfd}O>ezDInOcPyjgSHwRa|7!e^_|M{h
zjsG22M!^_M2WzG^-&%;VjI_?O&a>WS-RB)kc(bwewGFhbwr%u|B?x0_n-J$6OI^Y^
zb1c@xy2Mk7?iOR&o^-I;SQa?y9P==ihzG403vpS^v0$P4{^16L1Nny7+CHAlTn-L1!ow?;?HcGNuXcaz__D)#SQl_80Gd+#3;4~Gn)&YoehgFsHBU((teL>j
zz;N$Vuy{sEus~q4r_}o{CeWnGR~8r^n1NcEfw-Lr%nK|r%m2Tv`55$$&|4Gf4BCU%
zLSG@S2>Rza=Z3;Omsp>g%E$Xxv!wWD^s+DW?uzY&Dr6xT#~0Qfd#r!JFKqK-d9&^M_?Zos#j?5s`qJb^?seG59m~VP-p6YV2uQl
z(dt1xUOlAS)Hn155=_RbZ<2B9w|aznO7Eoppl89~a#}A?f782=2r^av4!`XdPNry7
z@2N?8AC2j~j1Nf^nV|*iwOWWiObgYA3;nGX=_|Fa`f9CMU!_&**J<7Lb%-}vsP)j-
zYlHMHS`}h4lE`vxg#5iWN`FzS(_hj?>o03#^jAm|hE`K&wZ!FsY@Yys=d`mlwpuN=qvvBi2J
zTf+LYDq|oUK)2LzdUov+6m$RI_Mp^nq%bwo5&tCu{Ng1Z}*2
zK%1Z+)F$e$Ym@Xt+GPC=c9mMLJ)%}*bf_
zm()e-V(m@!VO?T%Y_z86ebp@OE_ICdgw|PKqE>2q)$ZEk>J8d=>L%@!`hlLVeyBS%
zo4!~}&=+YX`dY1dKsJW0VPn~~Y#dvw_R#9p
z8@1z_U7w^SDt~E7`eZFxpQ2r@|G=(e>ktt%kzLO=s6EwL+AHcAZ7|!&Zm`_MHmMWY
zcq2l+N&8a$Uhlvrup8M#{Yo~8-NbgVoop9-ggIF~+s*c{N7-ZSakkfZmF;6s$T93m
z-NK$?PqSy(v+Ozcyc}yx*He`w_5yp6y~JK-udr9yYivJ5JU@G#9WriaZ?HGnTkLK2
z4ttlq#}2di*%9`EWfS|5eZ)RypRiBaXY6x!lpSMVu;c7Yc7lDyzGmOBlk8h|ihXCi
z$i8Pk7;m#5*-z|e_KW3a%Vzc~JI#J$XV~xT5B4Yfi=9>c**Vt08V!jrHx$E#P%
zWfykc4SXZN!E1HA3=8BrzDdsIHyWDZZ-iKO@|*b0d^5j=Z{b_{HYHTP&-hrrUw%M-
zP<}{$SoukAP=1zA%IDen$khZGTchG(naZ{>PoJXucTX;
zMYd=b!{Vm~Sb{C#WVceLlv^S#Z7tFA2+Mygah7U2>SbPmYie$cN-3@`;{LJ|&-#&&g5!GV%q^r6Z%Ge*S<~$oHtTVQD(~f8=N7zvQ#(
zHR>AL#&A+y>!rS{zNdai{vv0opRvz)%y^PgHHZAHP9VRK)3`VMjhrFB8;_Dd$e(JX
zx=V{74O)&mQyWMciCbGt31yU1iON)=D%Ge#E!y2QfCkZE8mfIj!)Q2-Fb>d2+LlJs
z7=0v-*Du#zrdItVP0)`~J58d=G=;XK?P)4aqvXRR
z;l`WBLH%2rD3wUPsXy%~b(8u?rBYw1OzJ0
zGXIso!cX&8`EUF+eunSozw-n94}OsU$zSJxsoxm>@N=Kg-|X=lGkvfxpEY`PX-dBXCvvDR@he=(lXe>I*p-r?^{+<4A-mmiTN{(&U(4<&_vq`kpEmQ?7y(8g@5y@^
zLA*Eb!~61nyg#o}R0Z3YVkj1+4IjX(6+b>u{#HJv5QXwV3RAcu@xh9$D0~PX%4;ld
z$nnMueL1h?!?fqLL)s5|8$D09>fQBf{R(}JezWC9{X_jr{V#2gWrJ*!6J)#bn&l}y
zT6Xi{`g{B`K0Y(9t2
z#W`s{U%(ggMSQUljx*Ecd?{aMS!KD36T8&X-)i}#S%Ua7ib+oomouoaj
zPS&1Lr)bZrbF|mgdD?z;zIH%epdFOImcLOKYOkv|YbVsr+E?l=+Slq9?HhHgc2d1p
z`(E9y%c@fkQtS0#oB=|V1U*#Uqa>;y=~3#(dOP)JJzM=n&ryHXbJgGVBJ~fwSp8G)
zs{W;ys4l%+b?X%x(JM7o@26>ce@)k`G(#VtrRY<&cKS4}y*^z_)n{nA`cf@VU#6An
zS7~MX)mpiJjaH%9wch$ht&e_#)>q%8_0wbJ4U`kUG`
z{Vi>}{?541V@N7`KdV{N|vskT7>Ok1dbt}W5O&@R`HYuD&M
zYB%FAE^OBS&~DNH)Weiy{iyzvrCi^v=4$t-dD^{dzILBlpxv)_(H>9>wFlKA?IE>T
zdsywNZC6XQ|ES%x9crnzQ@vLESY4}qqF$$cs;<*MQ`c*stJiBs)eYJ)b))u$dRR|V
z-`Cq}k@_gDtzM@^>7%u1eT){PkJV!Jaax={-Z*9aW_)LyF}^o`H-0ewFn%=t)W+(s
zY2)<$#!tpy#?QuC;}_$c@vG5boHiP@rTPhNwSG#wO8;KFQvc5AXmmC*jU1zsk!@rd
zxoR)9pV~*QQhTfY)xPQgqnFXw=wtLZdK>-JZR+jnZR(xst?C`dAfv_@Vhl3|8@0wz
zW4QXLx=(#veNuf)eL~%$(zFaMUF)bhv<}8q#Iu}-_r*kasfY%}gKwi>q^w;FdE
zF^1KMGZKtg!)C-Ab|c@&GX@w{#t7pw<8ot(zCfRE++b`p?l$f+ij7jE#3(nq8f8W|
zqe3034p(c{5o!%ir^D2dMx8Ov7-LK@MjPXevBpI8IrSy=1@#s6dG%%WMfFwVKI0+d
z0b{#yzwxl~pz$9g#Yi*S8|g+n!(pTv8AhSe#prGn8I?wX(L)`q4pIlI)#?zrQtm0|
z$%S%-G1(YpOfp6qQ`EcFyVPgYr`2cWV!24}YAiRF8HoyNV!4&xqUmzJq@GLno$BUvtx
z^X1-hAGxpGOYSH4m#gFfa`t<=5o>bT%C$+1cd$e9YOn1v4$REk?
z%OA@}y*>uZBdVs!857I;Q9r`YPlfFUUqHn_^_b5DQuh18zM7mE(7QQ;E
zy_71Al4r|vvfJ29b_cstu9tVqd*nyu$K=OJiSXBvKKRY-74k}XmAsn3{pPSb$>5rb
zTC279KH@*1w^JE7tj5_n+S#tQZi02~;2I}O8vO)9gvi*j_A${mo0HT!NtwNTH+(5&
zb*1S}>Tp`?CZs!=!#d9De7?#lB@f%(jv8eZV=JnM*Vyc~=(ROgXH`{=%~?_#ZFS~}
zTwZOhwcb-{^f+fb6nUSl&W_@JM^W?nsv0YZSUcM4G^%RqP+}GD43WzbxtzM_y4u>>
zXeUjpt+gY7zh-=GZMu^?tQA(Llr$Oy$z@eFPT5}SRP3c7zt&0X(w&mS4!W%4>g6$|
zR`JHux%lan>ng@Nd8!TNW!AOUwP?G(qnw0c4XCNBiXL5ETVt=q+meAbcoi)M;KTX(c%zTs(wrh$YqjJVEPvDQ9XOoYiP5-qstv_^wSAC*p?
zWFKAb>B4e}&z*_*3LiHOt@%f7gv{7WcUufzQDcj?+iFv7=}tdKJ!2Klaih!Ao&F9C
zz-o22DeEQ1g^azl*6Amns`2E9r*vlknh7*nVg(1rf^4UMS)Fxloz>|NrlmUr9lZzD
z)Jx;aYZIM*X&)8bz7_
z8bxXcjUr71jUr6~jUr73jUr6}jUsIa8b#`GSPRW1knR9$0_&`0n4dZ^pQDjF9YWqR
z9M1GKXF66=2MBR@NL#B*$v!&IF4WlH)_^FbJ3BT_4-I#ANUfJ?SVaxgkeGx{%{g=N
z>r96=+oU%O^=QS#D;kQTRq{kR34hdd=av`S^XfBc7)I0?;|Ia5eo_a)9-Wu&%ywi%
z6s9|K{;4X2a4f3lVoFGOk~PEHT`XR(vgg{h-R<3>ENY@`pWp(51PF^;89Mlji8y$^&T`kt`h2M+@Nl?u8%F%hz
zcJxq*aUn5#L3^!q0z!ncl%N2>dl>=+)qVjbXmKX&{U`6k8
zvX=+;La?TbS?tuXz^&Fwdw0>9n5{ySWnutcj*>w&8P-DVje=rtAsRc+awQ2*J@Kk(
z_w`KF#llr*_s$GxOm`M}DJb(zO`X`DFC3z8DvKRz#{R`SPrED9o{6VzVZIED0Xj6F#adfC-^4xOQAh4+SY8oZM9w+D+DuqOsy2-
zw+YS*620SS8gh3GIn1*-vD;%EhGaN9V=eZ$M0ro>TpAkU%toDF4reZs-hyit;H$L~
z+nSG0eH=m@oxQ=MGgQL>-YCA?j2jGg8zMnNgyS$kd5C
zA~RalDMeaL6U|M}RCSJcFssfrbE4`zGbgIf
zckIEXg3ov=O>=7FojkE>k#EaMCj`d${%RO1^m=G!kNG{To+zb{&lpyjlOU5+@leuc
zwANQEQrc?~s;qg7rYb{~3Mosm%4U(J^x4Q2Au9q_7%LR~elF2bEwJ=iQquIFS;ohe
z*C*0717L%$si_xF$>QlrxNoUcvSus{F%-hot}SUZR_m{IRnoM!s@x`ZA9Y{ll-6T&
zDX*8um76=+zx{!@ffD$4zs7Hf63GuCQhUYUgOp!z|18D2fA%~zuOrvv_vTNZuO&Z^
zdfsPvjz1%Jk~@`cay`F={UKUX9+aQp8`wAIUzzm1znb6Dq7Lo{n%8U5-$yN}l8>5n
z-Rk+PmALt92fDj}db=6@(G^BtG0n=1V_~8GQUJB5Bo|BBos;be{>+|`64JStd0*l&
zgHc*3|gu;Iz=Kg|6#q~RgZuHhb$P@X|k{He;REg`uBwWle$cuS>D_4qK-S4r{qRQ2L!j#
z{YxY5w=ErU*TOO}2b2`Lf0iThd)AqF$PACCieyhnOa?8%If+6HBg7mh
zWT4a^@)~Cnms?Dwv27wPSJ$}yc#8#PlorIbiJ^;i%lf(VXTL^+?z)!-y*eW{t4Hcq|A@ed=!n4Lg*#`?+O@D)
z53@%beu6I7Z6;lP!5e?vgT!%@1qsP1xj9*x5Q7{nnUvfN_K&2Zc7z<+_luj2j$M-i
zQ!2+6wy#KzQDOpO!lJ^9dS=}4)t!U>4gCQa@rUE*`X#lorew6W=d}ydv=PxNuI@rD
zR|hP8nUb6TVOY9Fs5~a-Uf%1Sdu+}OJcnduO5wq>DFQ)40_45ZUv+)Ez40K+*-j%~
zo$h)dZ}OJW$B&QRGC7ZZbcgHAOVj20885od+&*pB;%*H?yDdg=40AW2?L%lg5YcFu
zQJ+)=Wrf*;LPQr~-u~>_SwZYW(VE%rZ@(QkyYY7Vzynl5i_=BhuC@DIS4lg~zRZ5v
z75mr{%#o1cT=a!u(IBjkAkTmF3wqF%!-g~r;oGI1UfDOrUVP)a-~7gY{+s3tJ02HO
z-qkM}^EGu@vxS`DUGI$(n>F9Gd}n%Bc2j>|8g;Y3^A!H-@^|ep8`$7F*Lc8F9rWd6
zJ=9`7bU=MukRay5)sT|G&o73Y+-yNE@5z)|jcXruee~{}X$NSmbNF4?%yNv0=$YEC
zd#~!OQCp@Kl+3?(Y|+>b8?A}#bmP|QUgy_AT<0FCH`@cFBJJTu*^>WEp7-d|Zjqs%
zB}9P)Q&z5O;<1;0TabK}Ye%EgwSx{~RdW5={%lg?7P-FhPBt3y<%bxiSbW0~1A9T4cm}ehqDCjHqQ};G8d`^7Lp%;zCmByZdG2@7o@6}xE&d6aHR+&Vm~E2w
zm~8rm=o`=C-DKDOOh-N%4^7i2x@_U$*PlalG-zUw%{bJ-PAlrD*`2$JG$|}pm4l?XhE2N?*W#0Y?OY#=
z@91BHPoxBNXFD2C-T!%qfGw_7h#vIx^9dqPMbsQ8yQ!yblq;vvHf#^kCU#RyO&SFY
zDRvVg*3({SEo4!C9`88VFm^$#tB+vA;Ur%gTyR)
zNig>pFg_dN>`cjyY8)VO*OA@fagpKv>@isq{j`ne<5PNC8!#5h5*pNSb83G(=iYX)
zM~HS)MZ2beU?NQk5&Kk55pAWPv{759$7Xfx7@c6)!*&0_Q2)}B#vvE=yK(ro*LIxB1La{?%gdhsatIL~d46jN*uP=(3VmDRncGt<*rcZy3Ms9DW
z-N$Sd+IZ_2pN{|ez??Y;Xy6@p(7^q3=I(d>eEYPWi%Los?VL7!=c2A%7wr^$;Gkgx
zXgEy_#3Li}52N;&5FMy#REC8{P@moh^Rc0)(U7JsK0G3~n0KMs@exe$0bMapo#wepkn&Hvo<*dRnITv)#F{?
z-*blxl-m=kI;7Ch2{d7sNx!3gUU*!H2C0Y5p;=9ybv$qR_;>_q_3R|srr|-w{%$V%
zh-_OB*M_bc*{RdWHA8E!9o4DRsB3w&cduDKPwY}&qf8JicnEa{t66EjZ<)KkKU3*VKH(BuzL;d`
zxa(BmsP>Ny9&>>_ru3Xz&OY)=*>tbeo!cIt`g+KD-kB0Pa_5#+Fdlt&O}5FyL@{1r
zdnAK#peO|g2akF^Z_-Avi4~)ZW0tL6!-u%u9GvuPP-@B$=+=+#IJ&+hx!3gWwt@&Q
z*^38utefVlYG^2-4@S3b{7SCxHt&uR-Iq@t6djZWD+2l@1}DKN@B_bxVeUVI5eke|
zKNY_S2#wNxNsBjdd+S3Y#tsFkyxw>~uR%O~9K@rIr
zxB$v3NwucrkGO6^^=(UfhPBTJKLnkw+e|uZTBGyQCN6KL)BcJ4oQYdTTUxbq(~B>k
zGcM)78ddG>%Z3CxS}}L8RN^~zOa7a|QnAlU_dym^j1^KY{*&%=O>pgUO^~jZ?mstN
zx}UZIPsG`H7wQF|Uen6=e85Ag!*v*697bw><*MJ;IELM^4>zH0Tq1rNzqbW@Z4|yY
zS1lwC9eF3+%*HYHL;2KRDYSa%JtuG2bn>1dv^u5NRBA~dw74%H)o}OK$L<+6?4Dy+
zBY#id#e>t$HgPT$Z9+Sl`wBE>)5)`$ftta+U6|T7NFG(TeDB=EPE99HkD*%7^~(1)
z^)q`d7nI2L4R_B!c-!QVu);*oiPJP$JC01%$J}+~3LhOF`Y=R7o6g|D_;XGa=WQHl
znl^5lB|p@-&-G^GJ{pJvFpUaL4)V8$(ny@Y#r`SRx3@O@mbJLFba57M6Jw4~!e2=1
zhw*{;qCL-<-rH~pEP|X|I4HW{I2aKUF3bbruF(3qid}EIe$@O`)n9X+LcW;BIJ)Tj
z^U+IQ>Nxa&Dk@kD()VkHX6O8xu&kJvtgwc~a(z2nqn0>0V`NYEXAI8Wjap@G
zdVf3nGuB~_@ic6NnV<>L^zBV6MN!3Cwt+w~TrU+iD$jK7vbAsH`cyMqKl>-gxn8F4
zyNYPFExrv+ko`25e|!Wjcja2csVh9t)h;vvfut`5g}TE0BK_#2;h~Ma&HlbZe?!rq
zuq`1oW-nswW=A~B#=EQk6d9Z)PZn^0xBP0pj_6t-f-
zqRQxkyux7_jqi^9YW2ulCg)x6NDl~4>Cty+cK3M$9C>R`?e1NXTbbKA(dzK04@i-T
z8PVBksU6tFfdh)BZ?0`z6q%fF%d`h2^_W_jH+NKti?&5u!!huF6{USESMHr{cSIScoK42Q*<+cKg%TO-jabaxiy{23|M?A
zOarF5s%?^S;l$x%{i7lyk}`@j@(1Qb%^jc9)sYmF6f&$M{?CT8N9|nQw`}zbS1j4r
zi$?^7hDV2|_M6@P=DVV8G0`&xUwT}-f5ohqHdOaB*FVW}-DdV(A^c1HZ#G|#u@LU{
zgSDhEfWgbXQ}KF*UDa>mzA72_Z>A0fG6`ZXaJhWoWNtzPn?WE|YH<+&G=x*k^EB
zQe%wVBPc3Ji_7Vq-gRM?E%U+wwwN!*QU;{+Jl*qWXDlbh_)X8gh?@UJ8-BrzyXjIngm;9iMZMr>Tb%fT6mG{*H?a_5NTAe!hp
zY0nIL**`9>uo(y2$7Z$tdjVyv&k!-*@Tdsd@I+83O>EoNwIS0Qlpf;>jEJQ(+XlF@
zTW~O_J**!OZ1&fT2TbvYKR9p~c>)J6ct!G{5tSKE6I{dAma8_E`^SWu>3dbxfdFpUuV`2wY
zSN;42UtG7De7PD-YB3a#F^65WRW?BoJkIZyi(agpf1xj$*cT@6Y&po0mtdbgDJC=W
z68!r&YNk0`CChmZ+}Mn%iP6PHU7DEMd2+{~c99ox^~ni{dRmX{xX84^q=ejz_MtTA`GVlc`11b4vj?mlmtQjf
zzOe&lq_aO#;uCr=8eBcABF--|DN@>cHl=faTTV(?k2S9>pZD4g)fp+wkH8lO8szKo
z|LKxo{&qfmVZ7R;Ef2KaW73A-Siguidn?3cdmN=%?AS##zPPS6B0v6^=B#7yBwJ(3
z=M1i%QXDBLnURc{FBjxFR&pjvXs1Bg1On!g_k!~IzNbY%_ncf=D
z$@RQ?PEk{mbGiy+J%hnd2;t0)2v<~=l|Hbf9gm$lIA>s9tTnF>t)9NDJNCNiPp;`(
zcKMD;!`A1A4(W5aAUH5CBeY$3s4du%IOWB`dy9htq7K{oUo)ZWz(ky}yNxSL;Ga))
zee%-gZ|@#hwqoD>VfQcZm77()JacJXY*t`|;-@GP2_51l294uX{fe^8O?>A3`PtK-+c2>E
zRnIJ(_@B!wl)&gPwmPXYH(~s!M_0{{vPOCK@$T#1UOVZ@b=4(H>Svjj3}}E&>Y<_h
z5;R=;1n1rKE=^cM-vNW#+dE!xs_W8q%)`ri{2i?+`R&@OVTJbQXS`9VdeypDRGn
z`dgmouO--)bgA7qAx}4M2@La70^65mbvoQ|z?>u4w`xB8gZbk3=6%+J&o$yP>^#Ef
z>BiQA26&0Hf?C>!(haSeefGY|*@Fw>Pk-w=Cm2I(1HF|joFrC#u>2X
zC|huwb&3+arqj-k>YsSvx{yk%I8xFLz
zt1+2Eb`bS_O!$2-mYtTI5QbngX%bGB*2mb2h`A2B?(ojc1?2a;Kb`D(?${2PIS2zhAJ?*wgq{+VyMOz;WNrOCe(
zFNM71jv7Cw_uq`>QmpkzhM_fnbddqwe0+l0zA;Jj1
z8Bvqg^p9toFv+{TlN>Pe!OMH-`t5B4tzAbJ$>+|PQ|jTH*+&AHDB=aYz6dNgv*G5t
zgNIj-jacKfr$+Q2GOIk=)4o?Xtp8R%o|SqgB%(jJ7Y{G+cF??Y>@7mJN6LrcOYC&<
zEQN)_$F2DK_0VB@vI5MDt`M6k+m69Y2gG%Xw1;&_@Q!cJo52Y|y~S?kr}Pa-3_fy-
zCVKmwJYezFL`#h^J9_WJSvu|H|#NP1*nd94geth0?yIKCk
z`Enr>*nj^6x%*ok)Z#MOV|c?vMv%`X#WAUwlgHyrE$cn}(h}O_(eZ@>H$XNmzWUi}S(l@?!r@q~+e2;|a
zG|#$I520MFyOIB9-TAoCe9yU<2hCTcGV-5Sqs#bP7PVNW|7MB)E%Ppr#wPykXvUwt
zf%7NXlDX
z@ut|Db`jR)VevQHe6#&eGT(f@|3Tba%;n!p`9%{Y_hX89w4%Sv
zy{rXw|Haf_MDo8^Z5NNioN(v?&z#r7rYpQ~EW(2OJMUj}OVng?lhyVQZoMXx)GM(*
zi|x{WyJm))k7oTB&rmFHxKU$|9q}?cvHvaeySF*pMLNUe$>S2mN!K&~R_yJx@wFA3s!dntq6q{>2@ljV_4&<5YsBRJ!W7=`n`)bkEV
z(f@_pk@v7>%gqtI36pL-?85M3KuZpcku0lL1pP2N5Dlb*Rvp3o*gVACP{B9DQ)
zqwAf+9=Sw}PIu5d_}}od>0Id}wVAuPig0iFf{|N%bC2Rp5U5Un
z>swLLw{JyIVlE9YowB-HY*I+a0mWrQvO;NQti89QcKbi9eFtD%#kHvB-fhx0ZSP%M
zv|YQ>uKKF?Zb_D9Te4N%d&3p?4z}aCQ9`qMq2mC?#5Oi9JO>C6Vgdm|`-De$2_Zm;
zZC(8{_wGuvEJKq2L#*vHXJ*cvUKStgQ2UkE>}e2yGA+Ao%lWmdA77r`RORrd+A`Cc
zyGoYcK6T3gQBYqHtE!3_Lw3c`9d?U|#J7vHW;e}c7x6xD$6RER$w$_
z7gYLY-Zl>+Vejh=)Wsqip){BH2UvHi7Bw8&8VVARU2U9k--=R2T2QwX99IUFEx*AN
zFt~MsnjPm?%zt)obE+|2lb(rb{cP~FE5N1;QI8YZ7Qj(CUg1WO3G4*#fP6H(5s$^S
zgS^=dxKAcMIy@iWf#HwgeQeVRZ9}
zRm$pn`s~@KVR+bkkh{=J&`Xku(**)BUSmWjsEerGm|5<0l!Oh2aEZfNo@rzWul$`Q
zM0$I1hQW|gYH*9<1(u>LLR>yi-lx!Ahdx
zbmDrvXdI+CCO3g%_^z>mqF{^oh{OSS2y4Nv8-~_IqGZXq6$~92_Xb*nBL4onmpN)}
za*&q1Wj>X6pr&Kn)BuV!l?5_Y*Dr4TVrN}7w(Xx=K#NhSuCh$M+mknIUpsMNXhD6e
z2FwF+uEUQ}x6$Xy#DtCmJZpke9w!e?c;tV(Mtp<3p^45P4L=TZ<2{$*J->F#VCMVB
z%>>6We%$!o8jR!p56VsGXFnnzvER9|Bm^MLZ=3)t{tvB$N!uWVDh!!O7
zgmvNA9EBWeYmLTS6L-2cQWtMeTZJMl{UZT!<`9cGSnvy%I7AFk&~_Zt8!~`>OHi>F
z(}^({*x>=8)Syq}zc^F}%$=B#;77*nIUBr35^Z*It*>j1Sz9}K
zW^l@`=|Sq^uGl2(ZgKS
zV7+5!@%P<+U1)VYfZ*DBADMdFqN1_E)x-)WE`WxEz;Pk0$pD88ONl5RF`9^Wl8tg_
zB~iKJx!v{kyPsRJ^7*~>^?RRRIk&%m?t*~v$!zWo=p>8M_umQY+b|#~Uj+h3Xj^pbX77u|hqz8@ib2?ZWedx)b
zdy{CHJA1)u5z$jpfkD_lUn=orgw>1gF0R0!Y@Op1>x@p_k&one9c#$DQ+C&}x;#kd
zJhu|Vm7&&HRwHjRlr>Y3VXj-6jS`1q!p+AUAbUGYp|-V;eIIa65Jfhl0N>o&;Xtb<1Bm0A65f
z3A;TrF)!TniRK+2*8~&OK}}<)&HYJlV%GGsoS+hzFdfk}I_+!Og5N}Gr5%sA9$+KO-n}f
zJq9{=1>nF5M0lG=!x-q;AUYfd?GCPMuJFp)DmhQ9Hwem__0+|uRVD?WMb2-XVfj><
z3fYiVMMJw-LY_n~$K#qIUaJalGX^gh?#l?t6U15L*zYlc*2GnTPNDRMi_-IA>1FMm
z?PclN3-6tiHK(_g5fVM2(r{YHC~}ug?wnla4i6j~%$_~1&Oo|lsWPR^=Q219TC*qC
z8LQval_|FdbW7wah*Y7zuy{Iyn5BD5C??=SNcLX<4g~
zAP#MMVqr#Fq%e{eC~qkblrK5d?435bo*_40U&P_e$!zFs$aLnHC>EeR}<(imTb=
zn{!X^Yydn0KOpfTzz+16$>txio@3w`E6-E3#RHpd{o3>br;IV->#|z|GHm&;5w=;$q^Uye(3wkdeqIbN2HUy0`q@<3-*_ns1(PylM
z1p5qNF7i$~mTE06FP%g^^c{g*8!`!CfG96n80WqgK+}gf016-?BhkCy8)kS!0kTC_
z!QCE#1LtmBZ^>FkJiP&;{upRBJpD>Md@pXa`Uu}ofQfw@V?zV3J&_e{EIf?*h_`-B
z&;z-IT6F!~Bhc-;&JG39H4|9S5`bQ3ZDK-hKo-zL4vB!)Z<_)1aoX&)diY3WWn#zT
z;fV2ly~f?5V)@4@wIg~u)o|m55ug8yI{Xb5Yq<(Ia^>4G+I{>ySQh~o>^NuR#}9;c
z5iF-a2;>jV9zXxPVZNe?@IP)Ooe(X?y*ch`Y+x*<<1Ppt;YwX=avgVRXlv=%i^JTh
zvG34#2Jn_w2zZNai(`@T21q;(+A(pwag1P=n!s;f_K4AxwoOlf-{Y2%2;OCGB(wYk
z=Cf^M!^b8%kg>}fAtE$_;Qff-2v|3L2e^0AcVNMPa0mXyZMgP&aL$gq9?!(hShJ{}
z>#xU;?+fvk=3g^@{rfvL_BzqDjXMQ!8_ak&x=a7!hH$6AHTw@2`|qy;(}8Z_)qJqA
zU|Yo4VA?oIh(skUK4@;z5qkuR&~^cA49v_o1i&0ICt*YL*ojZ*F(Ia85XJ-_Da}V1
ztL11E@#xrCts3DvD%N29!1)tQh$3SSbENLTL?B#a$pjE^T@9!ZFNApAksQ2{R5_>}
zPc5K6qZS~-;^Xa;86bV>5YHPo)S6UOAZK1=-a_<-3hWuMUu?+D?`Daxg*F)*WN{V(
z_!zh(2g2d8^=Kp!EuMv!$V)?EPB(S#s$9=I$d_=r68<4^_$%t%_b}@$p`0f)NH)Q=
zyWr(ou|dF7iWbD7Q0ob{t;}Ytuni4mvV<6N9Bk)m_)=n6Q%%;U*;kPaBbdZh)is;NtmjCYzX;vK=ccweGv)Jf!qT)fj9DSr!2
z#nV$KAr-GsViZyosZ3epP3BkJ`!f3iVKR&MJ9BX-e%Zmuw#+)
zVBC>hJg9s@=i+5q$azXB)rfv`^%c1sJxRq#E4kmCFB^K{v-PrE4N(e#6GT#sEFm_q
ze+9M}95*hyaULG6M~zLxL-z-A&3v^{=TTEn1ox%V-h`RFF_;o;ql1-aX%G
zF*;0UjmpSpg0NP^0ZcSd7g_*^;-lYffff{6G>6B
zkoXh(#UHniq5ZY%JHz45^|f^yriH`PHq?bPGQ!!xAp1q{q?NUGH?{g8&$O;~iV
zEN^ZuD{F3sgeW{mEm=c+40()P+QZ^>0Dg)Q8;~`CY!Dm*XB0*kbjchRm#sz1A5fck
zqMwV{7S%)l^AansOJNji`P2WVl7>R58e$N}(?NwT75mJ8vX>PWyNnHaCc0GW%gilR
znXUPjK7)zRliTd++SYb;$+GEMrAiOh0HrCJ)kP%pMI2E|iU@^0Zfjn%pE@Phic(dn
zyyj|cL8cvi2}%eoRsvQ4T!jEvH|N;DkpmY-3W1iNtdQ`zLTQRjBi5A$9pz!8t)Mli
zvg*|Wf~}G7dz+QZV<&5aE~`hAED-HhX&n^X21$bUCW}
zV+FJ7+!E0c%!}6>f%S6ftUo$mfXg1cNHAnWWT%C(7Gj&=GLo-WWC~D$skpd6n={xD
za8wNx<#d(Wr3UIBP}x{%(&=Sd0qYB{Tqex>2VQMj)%>c=8P#5E@$~$l$)@8A`QQ-2
zwAVx)Mn8id(~zf2^Obn8fo+`g9jbpTTe(RGa!PsN$wz5n=f<7<_7qV=u3)zk64@UIbgbO+0
zNX8o=*QAQI+SJrVYG+87Oo$9xttplLhD@bFC@t0+fbLa9prWNBkXAXntfafpU^R)Q
zR+l$yFK*8$iLySBOJs7nELB0BOyLoTNKWAhlR2CeKA~xn$k{x$fRkSAS0e%%S0Iid
zKjNs$vB6wgvs)l?=(SO)sw%@>>{F{?|6))zuLAG}8wBGfT#1c#a&X}>jFhSzm!~|S
zdD|}13f_L3eNZAdXV-dgwIFXYkJ``FZXuE~;2hF8_ruOHRbeF2xMrX5`XTA1&*c`s
zM(s7rWM;2gVUqK&8(pRd
zwH7Iy3NGSHCGr&VPco}-bS|G&26Op6b-7j+dof>53RH6R=JgXZ`>`AL1LG4-9dV%x
z$km`jbugRELtGA5sUmhiuX3={SyHj}?YC7@Iorpzs$T4ryUeNNVX^!^G539vqL2=gN#
zT_T~}S(Irn4Hhivyj9g}-ujbw*r|vYx9esD&xwI7!%!NmLoloj
zE-6!4K|;i~+fq6D;*hs2pt+=w0PTWmYM)uf8nZcC>p^YQgK{M#BY_?Z^6F){3-vG_
zpa~*v*xzdc%!IUmS}Z2&Uw+|NPbkeSV{$5&C*hk}COICA&`KqT(rX=#I`_d;;6_lz
z9lD9Fg>j$)hV0rwaPbX#OooDh3=qJXe^>?s9YJ(bX<sGE`|ye1DCN8gUW$RM62EwY
zJggM0OOfz8MbNDZk;$TU8fA@G@K5@zhyMZhsRia3k@KU>*w|&sY+VcWwMcKcXWr}Q
zRXVm?4Eeh}7uzI*?OSb9e1P6lh<2vCly1dVu^eD_0T014DoDi$-1%WzypJJUmIZxm
zzV|t*66oqP=wbHMfc^EmrU>22-~EinIWub?kqz~NlHqsp92O^32oCrqbhZk0m3_fv
zfZPQSwWITAp5fZAbI+gH^kEL3bLO}hJTT3QOQ=v{9htEeQ
zfbTMEAE{^NVf30P+-6cwT~)bl&+L%+1MCabKUK1C4e`71DMw5$WafeIgWDNXc5)$g
zR-jbtBp;s@sB|_Jx0d>ZFW?YJlqyRm==I299>7-`ALBfTMiu(_ETmw9jF;>4S^!=M
zZ6lQs2Zix^f^n1|N;CB#b~1~V%ns=@rI)@zT8>y~Y2XUD@c#yj5J8C$JkA(+pqnHkI2I3P34G_d1CHV4z2;35{C!ZXrae35~CLl
zc1HOP_1-rhCact{lspEk+!VE1mCUtMUqHJwu1GkAi}QTA9YQe|(Px?TJ!>(M4|Z*=
z6UHM87O1*a}-S>_t(ZM6ExUR@fS}7e{>TxtjD?f2BjESLxtMl@p%eF_q8@
zOAS;XP=KzOH99EB$;4jY1d^rJTN}z=tnabn0ZCe$xX_|F&vn8
z{@A<~IHSoJb!#;4s1av4p;t8S9J4tGzr#FowwNR7Dph*KY|6&finC4QUgLRDQYY(i
z;wAP%EHmMfy`987D9O0+9Q|1nM^3!XIhXjXiMV;_X3n_>=+CNH+lk*Zw28LXhZAMh
z@PVLxUF+-2zfab9Y*w!(`S<3!^{nl|=6MA=w@xI2KLzue!BBmI^j%DbGy^ho$N@cIoD*$Z4PBLW}8gejTttd4@x})iy@L8
zW&ba+n7i)B$A8pb(B$>E#O(H1i{IN+U_X!;pL5b*n`JO$)%v~FnR0Em;B^^|qw6B%)b}dccR)hPq;u?d$xXa2
zdVWxIe`tOLIwyqn0DV1Y&8bOu*XLTTx%KY!njGu)G>6scv^vs=f@>)+XTPUBq|=4U
zJ?W*84<0N{H@n^DwDffJ^Vcy&zQ7P}q>5)QhN;*pq*AzoDiIdbf5?q^ALVV%6yg?>M
zUqKsef_TQgw6uJ&cc`a(#`Nj#85yjj07ar!Db~3`YsT~1>1xnFT(Oi0pdpGRzxmhd
zmXe*+l`V7u&~b$#$CoZe!=J$Va7|v2H<+4lj2WE1Cdk4*PQ3>e<*3h?igwiJxS~8!
zg+l3OQot0nyZQ}NN*>k*sL8q)#v;M8#D}%Pmg0Z7WIOBLD|fMGT)FEq%?lm}0Znve
zI{r(vQU3#9#b-g+kp*#&_PxMw67`i?-?I|ufp9JvUE2+FG_cwm5lAC6>S9Tmi*Gn%
zU`_^Ey#OL=h_wa1!AQI9px!Fwuw^#=Z>>R9pvg*dLniIO#g^%Re%EpR+z
z^xF&~iPaS}QVx%Z%f7POR;fe3M}LsQlwfemx_at-;u$JB{M{qn-H&{Cm^$D8_`&5(9#7NqgOB$^
zPlI}*XwI!I&9}}iB8Z~7w>G!jI;V(WDT%>H|GaJ6pC270o_!Vt+m`P;K4r@BeaqW|
z2yPupss?`suB8XI2!vyfaRDk^91-raLV_WK*8nRNAr5mU*B|-x5cSZZkB-!Rnw6)@
z8)!tWO@sOBJSZGG^!0|<4^K^@{tHb>nR@v3^@J$qr@CvFGzYn4%hiXu!R95k=x%=u
z&k5(vaRZIbgBP^H5YI4D#fhF1Ymoqg3P8y$L{QD1#RPTYlj67w!b6|t&T0%4&-#=r2
zZ~KuIwLI$99N!5(&$8&iqceAXeR6Q{>pGj~mFRSZ{Wa8|SIW{1l9~o@zC9I+
zm#kR(o1eDih3uI_-vy@!j9w$-UzkNb$!cYv2mcSY7#Lv_>2N+Mf}6!W1xo}-r}mNB
zDY%YyJX{u{DepAZgbLatYFB=>C8i0Md1Ni6{+LrjUCdeWVa9e
zOoPx$o5z-3J}tAd#VznNyDQy&VROelYik;*6?i|%
zqFno$ChHgoLB(JosuE|!brOEZTBzO>X-g?`@lZYrAbKF|hc^G?%Y_AUkhLW{Ui`wiS(;
zG4G6{3(`fE1DmRrp4nF2_te#+7m(-Gxv?2b!X4`YMqKOl6l)zzP2UL-o4yfj*uVIe
zL3}ut2w3Yx8AT24Qz5by8k^-*wTB!+OO9{wj>VM{W5{Jl=7qqCSbFHryYDTQbYq|y4p((K-9H;b@qr7EdTq49-stEb;|
zxO>(wHrG^cJURE+M}9JaXiD-ORh
z53H+rAs{AT$W`R_;QV<5>1}teuIZ?7WLZfATkGK?bPx9lvj&0pX)H%y)Cl6xFt6
z>^amSwAt;csb;f9YN+koIBE8a=g!RJ@uUW;WFN*e3E){9?43Cw?~cTO1JNBRwL;fn
zPPON{8#dd@@1J{3PC(cnC4Yg*LTN>;5$6S5O(Wl9;_-=>^K;<7)xmvR3il239gypR
z>EXSP#v37UWg#QNZ6#={TD)F2TEj}qYYt~Lu7cY8eDhvyMXyMIZ2aq2YnKWDqU&mz_7Q%L#CZn#qf
z#O!~?cCgQZbO+hWxb8KOcEANV5fRWPOoA8~;0W-76R2%K46~&j+}WlLR(PW`tK2QsnH@zoM7>Xa7@D@Z<=KB^
zuyz`}CJ7O2&M{{^utI9prONE`2dU5gdqKgHlgPHEok=r;S!u#&+xZIH~6JNM+Esqj!~NC0YIpFP{f-x;4W!)md~k3V+n_Ha`QXQ
zL9-;IeL1i^l*EC1-VJ*I`VI66z?=h2Q8<2p!v#eHy79oNj4mDLF@#y&GFyfrFr&Rv
zHH9x=iDb8>xYDR^&@FX*mDyuzNp%(l)2B|ZR-ragH19Vn%}(eo6rNm$c=~`UkU@1Q
z&E(NPnVbsVd`x&G{^p{qxn2MO!-He|UxBp%5gLUDV*-dr23q(AJd9ge=_jmLFynGJ
zmSm=e)-=y379}4muEYT$WmB{$6867AvnX}2I@HkW_4Rn(D9UHOJ9K}2S9J+-(@=IE
z5DA!f7z84g9p;4)0tEEchUka^Y=vbgt6dVQXq(=jc|H-9A<^*dQJ0a=%>a_xeDdkj
zkKbF)L_&nRgO&H3xVzkMhxJ6L^JF#L_aYdVMl0GcIzn{-=P;gen7i*tT>W^~CvCX4
zkfjQXSJ@M4$}ue+T=?*;PIbYo=K1}>5KRDlk;eTCOQhb~oRTuNJJ(uSnL}J=XKCFA
zu_3E2SXc5t-Hnc%jF8cNb7#ZBI=KI7R*^j?RarW)XNI%0v&Cdv*x;(n56KI&=Fxir
z_0P_e@nDnsi;K+
zQ3jZb(lo|KUt$aEy$s(R#1+c4CRwI2RGL;jr`(z%N@Y{uvs8{q<&-R$$F5dbv)ww*
z3u2>N$MTRj+oL<4+uGn3tW?`I!i;G*H~FW}-_rUJ_2jY=4OgfXznr)At)m+xc9R@v
z%T&PQdX^D%5iH%0$~?5BV~I0K=EC7@6|~>kL#K@BLKSXjd6tp7ShW7knt{`MT5z&T
z-OZUG*?7VGAJ0@V=1<9+`^ehTnw`(zgp*Z#E@}zv2VFmp%>g_X(f+MCW23tdIO+Su
z&^6|s(|bW2IdV(?{Q3PnnOQ}Y2sJjvud)j3ApdB^3w!E2?)hXl={|Jtt$X$z^Gs_g
zl6v}*+qDIFU1d{4E&XL7vuDE?OwN|bJh_eY_jUC?v7;Fm;|1Tt@VDgi
zfD;gJ1U0jvPrx-K5f{(~2rT6Dk?_?q#F6??sBvn^R`PH-LaB4}fJ|B>8IzZlp?_|W
z+O(+*zI6fbf(wshvPXJI0iBH#rMQ^nfbq#Mlcl2Mj(xxEoqK#yE{e33*(!2ug49$t
zA<~+~EMd`2t8R)N{N1kN?7;(_Ov0z3=H}k;%o#mlU7CvaHGyB7I>ph!zKWA_fg+C4
zNyg$(TtUL<4!aGyBa>hb{Rk?TG