@cccsaurora/howler-ui 2.12.0-dev.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.fr.md +12 -0
- package/README.md +12 -0
- package/dist/api/action/execute.d.ts +3 -0
- package/dist/api/action/execute.js +17 -0
- package/dist/api/action/index.d.ts +10 -0
- package/dist/api/action/index.js +28 -0
- package/dist/api/action/operations.d.ts +3 -0
- package/dist/api/action/operations.js +8 -0
- package/dist/api/analytic/comments/index.d.ts +13 -0
- package/dist/api/analytic/comments/index.js +19 -0
- package/dist/api/analytic/comments/react.d.ts +3 -0
- package/dist/api/analytic/comments/react.js +11 -0
- package/dist/api/analytic/favourite.d.ts +7 -0
- package/dist/api/analytic/favourite.js +11 -0
- package/dist/api/analytic/index.d.ts +12 -0
- package/dist/api/analytic/index.js +19 -0
- package/dist/api/analytic/notebooks/index.d.ts +10 -0
- package/dist/api/analytic/notebooks/index.js +11 -0
- package/dist/api/analytic/owner.d.ts +5 -0
- package/dist/api/analytic/owner.js +8 -0
- package/dist/api/analytic/rules.d.ts +3 -0
- package/dist/api/analytic/rules.js +8 -0
- package/dist/api/auth/apikey.d.ts +8 -0
- package/dist/api/auth/apikey.js +11 -0
- package/dist/api/auth/index.d.ts +4 -0
- package/dist/api/auth/index.js +7 -0
- package/dist/api/auth/login.d.ts +14 -0
- package/dist/api/auth/login.js +18 -0
- package/dist/api/configs/index.d.ts +3 -0
- package/dist/api/configs/index.js +7 -0
- package/dist/api/dossier/hit.d.ts +2 -0
- package/dist/api/dossier/hit.js +6 -0
- package/dist/api/dossier/index.d.ts +8 -0
- package/dist/api/dossier/index.js +18 -0
- package/dist/api/help.d.ts +55 -0
- package/dist/api/help.js +7 -0
- package/dist/api/hit/assign.d.ts +3 -0
- package/dist/api/hit/assign.js +8 -0
- package/dist/api/hit/comments/index.d.ts +13 -0
- package/dist/api/hit/comments/index.js +19 -0
- package/dist/api/hit/comments/react.d.ts +3 -0
- package/dist/api/hit/comments/react.js +11 -0
- package/dist/api/hit/index.d.ts +35 -0
- package/dist/api/hit/index.js +19 -0
- package/dist/api/hit/labels.d.ts +5 -0
- package/dist/api/hit/labels.js +11 -0
- package/dist/api/hit/overwrite.d.ts +3 -0
- package/dist/api/hit/overwrite.js +8 -0
- package/dist/api/hit/transition.d.ts +4 -0
- package/dist/api/hit/transition.js +8 -0
- package/dist/api/index.d.ts +142 -0
- package/dist/api/index.js +240 -0
- package/dist/api/notebook/environments.d.ts +10 -0
- package/dist/api/notebook/environments.js +8 -0
- package/dist/api/notebook/index.d.ts +14 -0
- package/dist/api/notebook/index.js +9 -0
- package/dist/api/overview/index.d.ts +6 -0
- package/dist/api/overview/index.js +16 -0
- package/dist/api/search/action.d.ts +4 -0
- package/dist/api/search/action.js +8 -0
- package/dist/api/search/analytic.d.ts +4 -0
- package/dist/api/search/analytic.js +8 -0
- package/dist/api/search/count/hit.d.ts +3 -0
- package/dist/api/search/count/hit.js +8 -0
- package/dist/api/search/count/index.d.ts +10 -0
- package/dist/api/search/count/index.js +7 -0
- package/dist/api/search/dossier.d.ts +4 -0
- package/dist/api/search/dossier.js +8 -0
- package/dist/api/search/eql/hit.d.ts +4 -0
- package/dist/api/search/eql/hit.js +8 -0
- package/dist/api/search/facet/hit.d.ts +3 -0
- package/dist/api/search/facet/hit.js +8 -0
- package/dist/api/search/facet/index.d.ts +12 -0
- package/dist/api/search/facet/index.js +7 -0
- package/dist/api/search/fields/hit.d.ts +3 -0
- package/dist/api/search/fields/hit.js +9 -0
- package/dist/api/search/fields/index.d.ts +19 -0
- package/dist/api/search/fields/index.js +15 -0
- package/dist/api/search/fields/user.d.ts +3 -0
- package/dist/api/search/fields/user.js +11 -0
- package/dist/api/search/grouped/hit.d.ts +4 -0
- package/dist/api/search/grouped/hit.js +8 -0
- package/dist/api/search/grouped/index.d.ts +25 -0
- package/dist/api/search/grouped/index.js +8 -0
- package/dist/api/search/grouped/user.d.ts +7 -0
- package/dist/api/search/grouped/user.js +21 -0
- package/dist/api/search/histogram/hit.d.ts +3 -0
- package/dist/api/search/histogram/hit.js +8 -0
- package/dist/api/search/histogram/index.d.ts +14 -0
- package/dist/api/search/histogram/index.js +7 -0
- package/dist/api/search/hit.d.ts +7 -0
- package/dist/api/search/hit.js +11 -0
- package/dist/api/search/index.d.ts +52 -0
- package/dist/api/search/index.js +18 -0
- package/dist/api/search/overview.d.ts +4 -0
- package/dist/api/search/overview.js +8 -0
- package/dist/api/search/sigma/hit.d.ts +4 -0
- package/dist/api/search/sigma/hit.js +8 -0
- package/dist/api/search/template.d.ts +4 -0
- package/dist/api/search/template.js +8 -0
- package/dist/api/search/user.d.ts +7 -0
- package/dist/api/search/user.js +15 -0
- package/dist/api/search/view.d.ts +4 -0
- package/dist/api/search/view.js +8 -0
- package/dist/api/template/index.d.ts +6 -0
- package/dist/api/template/index.js +16 -0
- package/dist/api/user/avatar/index.d.ts +2 -0
- package/dist/api/user/avatar/index.js +8 -0
- package/dist/api/user/groups.d.ts +6 -0
- package/dist/api/user/groups.js +8 -0
- package/dist/api/user/index.d.ts +10 -0
- package/dist/api/user/index.js +15 -0
- package/dist/api/user/whoami.d.ts +3 -0
- package/dist/api/user/whoami.js +8 -0
- package/dist/api/view/favourite.d.ts +7 -0
- package/dist/api/view/favourite.js +11 -0
- package/dist/api/view/index.d.ts +8 -0
- package/dist/api/view/index.js +18 -0
- package/dist/branding/AppBrand.d.ts +85 -0
- package/dist/branding/AppBrand.js +103 -0
- package/dist/commons/components/app/AppConfigs.d.ts +131 -0
- package/dist/commons/components/app/AppConfigs.js +1 -0
- package/dist/commons/components/app/AppConstants.d.ts +10 -0
- package/dist/commons/components/app/AppConstants.js +10 -0
- package/dist/commons/components/app/AppContexts.d.ts +105 -0
- package/dist/commons/components/app/AppContexts.js +21 -0
- package/dist/commons/components/app/AppDefaults.d.ts +6 -0
- package/dist/commons/components/app/AppDefaults.js +40 -0
- package/dist/commons/components/app/AppNotificationService.d.ts +6 -0
- package/dist/commons/components/app/AppNotificationService.js +1 -0
- package/dist/commons/components/app/AppProvider.d.ts +15 -0
- package/dist/commons/components/app/AppProvider.js +41 -0
- package/dist/commons/components/app/AppSearchService.d.ts +21 -0
- package/dist/commons/components/app/AppSearchService.js +1 -0
- package/dist/commons/components/app/AppSkeleton.d.ts +5 -0
- package/dist/commons/components/app/AppSkeleton.js +152 -0
- package/dist/commons/components/app/AppUserService.d.ts +17 -0
- package/dist/commons/components/app/AppUserService.js +1 -0
- package/dist/commons/components/app/hooks/index.d.ts +18 -0
- package/dist/commons/components/app/hooks/index.js +18 -0
- package/dist/commons/components/app/hooks/useApp.d.ts +1 -0
- package/dist/commons/components/app/hooks/useApp.js +5 -0
- package/dist/commons/components/app/hooks/useAppBanner.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppBanner.js +6 -0
- package/dist/commons/components/app/hooks/useAppBar.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppBar.js +5 -0
- package/dist/commons/components/app/hooks/useAppBarHeight.d.ts +2 -0
- package/dist/commons/components/app/hooks/useAppBarHeight.js +22 -0
- package/dist/commons/components/app/hooks/useAppBarScrollTrigger.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppBarScrollTrigger.js +7 -0
- package/dist/commons/components/app/hooks/useAppBreadcrumbs.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppBreadcrumbs.js +5 -0
- package/dist/commons/components/app/hooks/useAppConfigs.d.ts +59 -0
- package/dist/commons/components/app/hooks/useAppConfigs.js +44 -0
- package/dist/commons/components/app/hooks/useAppLanguage.d.ts +6 -0
- package/dist/commons/components/app/hooks/useAppLanguage.js +17 -0
- package/dist/commons/components/app/hooks/useAppLayout.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppLayout.js +5 -0
- package/dist/commons/components/app/hooks/useAppLeftNav.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppLeftNav.js +5 -0
- package/dist/commons/components/app/hooks/useAppLogo.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppLogo.js +8 -0
- package/dist/commons/components/app/hooks/useAppNotification.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppNotification.js +5 -0
- package/dist/commons/components/app/hooks/useAppQuickSearch.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppQuickSearch.js +5 -0
- package/dist/commons/components/app/hooks/useAppSearchService.d.ts +2 -0
- package/dist/commons/components/app/hooks/useAppSearchService.js +5 -0
- package/dist/commons/components/app/hooks/useAppSitemap.d.ts +13 -0
- package/dist/commons/components/app/hooks/useAppSitemap.js +70 -0
- package/dist/commons/components/app/hooks/useAppSwitcher.d.ts +1 -0
- package/dist/commons/components/app/hooks/useAppSwitcher.js +5 -0
- package/dist/commons/components/app/hooks/useAppTheme.d.ts +8 -0
- package/dist/commons/components/app/hooks/useAppTheme.js +12 -0
- package/dist/commons/components/app/hooks/useAppUser.d.ts +2 -0
- package/dist/commons/components/app/hooks/useAppUser.js +5 -0
- package/dist/commons/components/app/providers/AppBarProvider.d.ts +10 -0
- package/dist/commons/components/app/providers/AppBarProvider.js +24 -0
- package/dist/commons/components/app/providers/AppBreadcrumbsProvider.d.ts +6 -0
- package/dist/commons/components/app/providers/AppBreadcrumbsProvider.js +43 -0
- package/dist/commons/components/app/providers/AppLayoutProvider.d.ts +6 -0
- package/dist/commons/components/app/providers/AppLayoutProvider.js +73 -0
- package/dist/commons/components/app/providers/AppLeftNavProvider.d.ts +6 -0
- package/dist/commons/components/app/providers/AppLeftNavProvider.js +22 -0
- package/dist/commons/components/app/providers/AppNotificationProvider.d.ts +6 -0
- package/dist/commons/components/app/providers/AppNotificationProvider.js +31 -0
- package/dist/commons/components/app/providers/AppQuickSearchProvider.d.ts +8 -0
- package/dist/commons/components/app/providers/AppQuickSearchProvider.js +19 -0
- package/dist/commons/components/app/providers/AppSearchServiceProvider.d.ts +6 -0
- package/dist/commons/components/app/providers/AppSearchServiceProvider.js +46 -0
- package/dist/commons/components/app/providers/AppSnackbarProvider.d.ts +3 -0
- package/dist/commons/components/app/providers/AppSnackbarProvider.js +15 -0
- package/dist/commons/components/app/providers/AppSwitcherProvider.d.ts +6 -0
- package/dist/commons/components/app/providers/AppSwitcherProvider.js +10 -0
- package/dist/commons/components/app/providers/AppUserProvider.d.ts +8 -0
- package/dist/commons/components/app/providers/AppUserProvider.js +12 -0
- package/dist/commons/components/breadcrumbs/BreadcrumbIcon.d.ts +6 -0
- package/dist/commons/components/breadcrumbs/BreadcrumbIcon.js +9 -0
- package/dist/commons/components/breadcrumbs/BreadcrumbLastItem.d.ts +7 -0
- package/dist/commons/components/breadcrumbs/BreadcrumbLastItem.js +19 -0
- package/dist/commons/components/breadcrumbs/BreadcrumbLinkItem.d.ts +7 -0
- package/dist/commons/components/breadcrumbs/BreadcrumbLinkItem.js +20 -0
- package/dist/commons/components/breadcrumbs/BreadcrumbList.d.ts +11 -0
- package/dist/commons/components/breadcrumbs/BreadcrumbList.js +44 -0
- package/dist/commons/components/breadcrumbs/Breadcrumbs.d.ts +4 -0
- package/dist/commons/components/breadcrumbs/Breadcrumbs.js +31 -0
- package/dist/commons/components/display/AppAvatar.d.ts +8 -0
- package/dist/commons/components/display/AppAvatar.js +18 -0
- package/dist/commons/components/display/AppInfoPanel.d.ts +5 -0
- package/dist/commons/components/display/AppInfoPanel.js +17 -0
- package/dist/commons/components/display/AppListEmpty.d.ts +2 -0
- package/dist/commons/components/display/AppListEmpty.js +5 -0
- package/dist/commons/components/display/AppToc.d.ts +19 -0
- package/dist/commons/components/display/AppToc.js +98 -0
- package/dist/commons/components/display/hooks/useAppColor.d.ts +5 -0
- package/dist/commons/components/display/hooks/useAppColor.js +10 -0
- package/dist/commons/components/leftnav/LeftNavDrawer.d.ts +2 -0
- package/dist/commons/components/leftnav/LeftNavDrawer.js +99 -0
- package/dist/commons/components/leftnav/LeftNavGroup.d.ts +7 -0
- package/dist/commons/components/leftnav/LeftNavGroup.js +55 -0
- package/dist/commons/components/leftnav/LeftNavItem.d.ts +10 -0
- package/dist/commons/components/leftnav/LeftNavItem.js +29 -0
- package/dist/commons/components/notification/FeedModels.d.ts +64 -0
- package/dist/commons/components/notification/FeedModels.js +94 -0
- package/dist/commons/components/notification/Notification.d.ts +10 -0
- package/dist/commons/components/notification/Notification.js +95 -0
- package/dist/commons/components/notification/elements/NotificationCloseButton.d.ts +3 -0
- package/dist/commons/components/notification/elements/NotificationCloseButton.js +6 -0
- package/dist/commons/components/notification/elements/NotificationContainer.d.ts +16 -0
- package/dist/commons/components/notification/elements/NotificationContainer.js +29 -0
- package/dist/commons/components/notification/elements/NotificationEndOfPage.d.ts +5 -0
- package/dist/commons/components/notification/elements/NotificationEndOfPage.js +36 -0
- package/dist/commons/components/notification/elements/NotificationError.d.ts +2 -0
- package/dist/commons/components/notification/elements/NotificationError.js +10 -0
- package/dist/commons/components/notification/elements/NotificationHeader.d.ts +8 -0
- package/dist/commons/components/notification/elements/NotificationHeader.js +18 -0
- package/dist/commons/components/notification/elements/NotificationItems.d.ts +12 -0
- package/dist/commons/components/notification/elements/NotificationItems.js +12 -0
- package/dist/commons/components/notification/elements/NotificationSkeleton.d.ts +2 -0
- package/dist/commons/components/notification/elements/NotificationSkeleton.js +12 -0
- package/dist/commons/components/notification/elements/NotificationTopNavButton.d.ts +9 -0
- package/dist/commons/components/notification/elements/NotificationTopNavButton.js +9 -0
- package/dist/commons/components/notification/elements/item/NotificationItem.d.ts +5 -0
- package/dist/commons/components/notification/elements/item/NotificationItem.js +25 -0
- package/dist/commons/components/notification/elements/item/NotificationItemAuthor.d.ts +5 -0
- package/dist/commons/components/notification/elements/item/NotificationItemAuthor.js +31 -0
- package/dist/commons/components/notification/elements/item/NotificationItemContent.d.ts +3 -0
- package/dist/commons/components/notification/elements/item/NotificationItemContent.js +9 -0
- package/dist/commons/components/notification/elements/item/NotificationItemDate.d.ts +3 -0
- package/dist/commons/components/notification/elements/item/NotificationItemDate.js +10 -0
- package/dist/commons/components/notification/elements/item/NotificationItemImage.d.ts +4 -0
- package/dist/commons/components/notification/elements/item/NotificationItemImage.js +8 -0
- package/dist/commons/components/notification/elements/item/NotificationItemTag.d.ts +4 -0
- package/dist/commons/components/notification/elements/item/NotificationItemTag.js +12 -0
- package/dist/commons/components/notification/elements/item/NotificationItemTitle.d.ts +3 -0
- package/dist/commons/components/notification/elements/item/NotificationItemTitle.js +15 -0
- package/dist/commons/components/notification/index.d.ts +2 -0
- package/dist/commons/components/notification/index.js +2 -0
- package/dist/commons/components/pages/PageCardCentered.d.ts +5 -0
- package/dist/commons/components/pages/PageCardCentered.js +30 -0
- package/dist/commons/components/pages/PageCenter.d.ts +8 -0
- package/dist/commons/components/pages/PageCenter.js +20 -0
- package/dist/commons/components/pages/PageContent.d.ts +7 -0
- package/dist/commons/components/pages/PageContent.js +8 -0
- package/dist/commons/components/pages/PageFullScreen.d.ts +10 -0
- package/dist/commons/components/pages/PageFullScreen.js +40 -0
- package/dist/commons/components/pages/PageFullWidth.d.ts +11 -0
- package/dist/commons/components/pages/PageFullWidth.js +7 -0
- package/dist/commons/components/pages/PageHeader.d.ts +23 -0
- package/dist/commons/components/pages/PageHeader.js +27 -0
- package/dist/commons/components/pages/hooks/usePageProps.d.ts +24 -0
- package/dist/commons/components/pages/hooks/usePageProps.js +19 -0
- package/dist/commons/components/search/AppSearch.d.ts +1 -0
- package/dist/commons/components/search/AppSearch.js +135 -0
- package/dist/commons/components/search/AppSearchInput.d.ts +11 -0
- package/dist/commons/components/search/AppSearchInput.js +35 -0
- package/dist/commons/components/search/AppSearchResult.d.ts +4 -0
- package/dist/commons/components/search/AppSearchResult.js +28 -0
- package/dist/commons/components/topnav/AppBar.d.ts +5 -0
- package/dist/commons/components/topnav/AppBar.js +80 -0
- package/dist/commons/components/topnav/AppName.d.ts +4 -0
- package/dist/commons/components/topnav/AppName.js +31 -0
- package/dist/commons/components/topnav/AppSwitcher.d.ts +2 -0
- package/dist/commons/components/topnav/AppSwitcher.js +44 -0
- package/dist/commons/components/topnav/Notifications.d.ts +2 -0
- package/dist/commons/components/topnav/Notifications.js +8 -0
- package/dist/commons/components/topnav/ThemeSelection.d.ts +2 -0
- package/dist/commons/components/topnav/ThemeSelection.js +33 -0
- package/dist/commons/components/topnav/ThemeSelectionIcon.d.ts +2 -0
- package/dist/commons/components/topnav/ThemeSelectionIcon.js +16 -0
- package/dist/commons/components/topnav/UserProfile.d.ts +5 -0
- package/dist/commons/components/topnav/UserProfile.js +59 -0
- package/dist/commons/components/utils/hooks/useClipboard.d.ts +3 -0
- package/dist/commons/components/utils/hooks/useClipboard.js +29 -0
- package/dist/commons/components/utils/hooks/useEnv.d.ts +1 -0
- package/dist/commons/components/utils/hooks/useEnv.js +11 -0
- package/dist/commons/components/utils/hooks/useFullscreenStatus.d.ts +2 -0
- package/dist/commons/components/utils/hooks/useFullscreenStatus.js +41 -0
- package/dist/commons/components/utils/hooks/useGravatar.d.ts +2 -0
- package/dist/commons/components/utils/hooks/useGravatar.js +9 -0
- package/dist/commons/components/utils/hooks/useLocalStorage.d.ts +12 -0
- package/dist/commons/components/utils/hooks/useLocalStorage.js +52 -0
- package/dist/commons/components/utils/hooks/useLocalStorageItem.d.ts +14 -0
- package/dist/commons/components/utils/hooks/useLocalStorageItem.js +39 -0
- package/dist/commons/components/utils/hooks/useThemeBuilder.d.ts +7 -0
- package/dist/commons/components/utils/hooks/useThemeBuilder.js +48 -0
- package/dist/commons/components/utils/keyboard.d.ts +30 -0
- package/dist/commons/components/utils/keyboard.js +50 -0
- package/dist/components/app/App.d.ts +3 -0
- package/dist/components/app/App.js +342 -0
- package/dist/components/app/AppContainer.d.ts +3 -0
- package/dist/components/app/AppContainer.js +10 -0
- package/dist/components/app/drawers/ApiKeyDrawer.d.ts +6 -0
- package/dist/components/app/drawers/ApiKeyDrawer.js +67 -0
- package/dist/components/app/drawers/AppDrawerType.d.ts +6 -0
- package/dist/components/app/drawers/AppDrawerType.js +1 -0
- package/dist/components/app/drawers/AssignUserDrawer.d.ts +9 -0
- package/dist/components/app/drawers/AssignUserDrawer.js +50 -0
- package/dist/components/app/drawers/ViewGroupsDrawer.d.ts +7 -0
- package/dist/components/app/drawers/ViewGroupsDrawer.js +6 -0
- package/dist/components/app/hooks/useTitle.d.ts +2 -0
- package/dist/components/app/hooks/useTitle.js +67 -0
- package/dist/components/app/providers/AnalyticProvider.d.ts +14 -0
- package/dist/components/app/providers/AnalyticProvider.js +104 -0
- package/dist/components/app/providers/ApiConfigProvider.d.ts +9 -0
- package/dist/components/app/providers/ApiConfigProvider.js +17 -0
- package/dist/components/app/providers/AppDrawerProvider.d.ts +10 -0
- package/dist/components/app/providers/AppDrawerProvider.js +29 -0
- package/dist/components/app/providers/AvatarProvider.d.ts +7 -0
- package/dist/components/app/providers/AvatarProvider.js +31 -0
- package/dist/components/app/providers/CustomPluginProvider.d.ts +3 -0
- package/dist/components/app/providers/CustomPluginProvider.js +14 -0
- package/dist/components/app/providers/DossierProvider.d.ts +15 -0
- package/dist/components/app/providers/DossierProvider.js +79 -0
- package/dist/components/app/providers/FavouritesProvider.d.ts +4 -0
- package/dist/components/app/providers/FavouritesProvider.js +137 -0
- package/dist/components/app/providers/FieldProvider.d.ts +9 -0
- package/dist/components/app/providers/FieldProvider.js +19 -0
- package/dist/components/app/providers/HitProvider.d.ts +20 -0
- package/dist/components/app/providers/HitProvider.js +104 -0
- package/dist/components/app/providers/HitSearchProvider.d.ts +25 -0
- package/dist/components/app/providers/HitSearchProvider.js +168 -0
- package/dist/components/app/providers/LocalStorageProvider.d.ts +13 -0
- package/dist/components/app/providers/LocalStorageProvider.js +41 -0
- package/dist/components/app/providers/ModalProvider.d.ts +16 -0
- package/dist/components/app/providers/ModalProvider.js +28 -0
- package/dist/components/app/providers/OverviewProvider.d.ts +13 -0
- package/dist/components/app/providers/OverviewProvider.js +59 -0
- package/dist/components/app/providers/ParameterProvider.d.ts +25 -0
- package/dist/components/app/providers/ParameterProvider.js +180 -0
- package/dist/components/app/providers/SocketProvider.d.ts +57 -0
- package/dist/components/app/providers/SocketProvider.js +226 -0
- package/dist/components/app/providers/TemplateProvider.d.ts +13 -0
- package/dist/components/app/providers/TemplateProvider.js +100 -0
- package/dist/components/app/providers/UserListProvider.d.ts +12 -0
- package/dist/components/app/providers/UserListProvider.js +30 -0
- package/dist/components/app/providers/ViewProvider.d.ts +18 -0
- package/dist/components/app/providers/ViewProvider.js +99 -0
- package/dist/components/elements/Comment.d.ts +17 -0
- package/dist/components/elements/Comment.js +115 -0
- package/dist/components/elements/EditRow.d.ts +14 -0
- package/dist/components/elements/EditRow.js +118 -0
- package/dist/components/elements/PluginChip.d.ts +8 -0
- package/dist/components/elements/PluginChip.js +21 -0
- package/dist/components/elements/PluginTypography.d.ts +8 -0
- package/dist/components/elements/PluginTypography.js +21 -0
- package/dist/components/elements/ThemedEditor.d.ts +3 -0
- package/dist/components/elements/ThemedEditor.js +104 -0
- package/dist/components/elements/UserList.d.ts +9 -0
- package/dist/components/elements/UserList.js +26 -0
- package/dist/components/elements/addons/buttons/CustomButton.d.ts +12 -0
- package/dist/components/elements/addons/buttons/CustomButton.js +43 -0
- package/dist/components/elements/addons/buttons/CustomIconButton.d.ts +15 -0
- package/dist/components/elements/addons/buttons/CustomIconButton.js +48 -0
- package/dist/components/elements/addons/buttons/index.d.ts +3 -0
- package/dist/components/elements/addons/buttons/index.js +4 -0
- package/dist/components/elements/addons/layout/FlexOne.d.ts +4 -0
- package/dist/components/elements/addons/layout/FlexOne.js +6 -0
- package/dist/components/elements/addons/layout/FlexPort.d.ts +12 -0
- package/dist/components/elements/addons/layout/FlexPort.js +15 -0
- package/dist/components/elements/addons/layout/FlexVertical.d.ts +8 -0
- package/dist/components/elements/addons/layout/FlexVertical.js +13 -0
- package/dist/components/elements/addons/layout/vsbox/VSBox.d.ts +16 -0
- package/dist/components/elements/addons/layout/vsbox/VSBox.js +27 -0
- package/dist/components/elements/addons/layout/vsbox/VSBoxContent.d.ts +4 -0
- package/dist/components/elements/addons/layout/vsbox/VSBoxContent.js +6 -0
- package/dist/components/elements/addons/layout/vsbox/VSBoxElement.d.ts +8 -0
- package/dist/components/elements/addons/layout/vsbox/VSBoxElement.js +39 -0
- package/dist/components/elements/addons/layout/vsbox/VSBoxHeader.d.ts +5 -0
- package/dist/components/elements/addons/layout/vsbox/VSBoxHeader.js +23 -0
- package/dist/components/elements/addons/lists/TuiList.d.ts +8 -0
- package/dist/components/elements/addons/lists/TuiList.js +9 -0
- package/dist/components/elements/addons/lists/TuiListBase.d.ts +10 -0
- package/dist/components/elements/addons/lists/TuiListBase.js +61 -0
- package/dist/components/elements/addons/lists/TuiListElement.d.ts +9 -0
- package/dist/components/elements/addons/lists/TuiListElement.js +24 -0
- package/dist/components/elements/addons/lists/TuiListMenu.d.ts +49 -0
- package/dist/components/elements/addons/lists/TuiListMenu.js +33 -0
- package/dist/components/elements/addons/lists/TuiListProvider.d.ts +22 -0
- package/dist/components/elements/addons/lists/TuiListProvider.js +117 -0
- package/dist/components/elements/addons/lists/hooks/useTuiListKeyboard.d.ts +5 -0
- package/dist/components/elements/addons/lists/hooks/useTuiListKeyboard.js +41 -0
- package/dist/components/elements/addons/lists/index.d.ts +19 -0
- package/dist/components/elements/addons/lists/index.js +4 -0
- package/dist/components/elements/addons/lists/table/TuiTable.d.ts +14 -0
- package/dist/components/elements/addons/lists/table/TuiTable.js +81 -0
- package/dist/components/elements/addons/lists/table/TuiTableBody.d.ts +14 -0
- package/dist/components/elements/addons/lists/table/TuiTableBody.js +19 -0
- package/dist/components/elements/addons/lists/table/TuiTableHead.d.ts +8 -0
- package/dist/components/elements/addons/lists/table/TuiTableHead.js +9 -0
- package/dist/components/elements/addons/lists/table/TuiTableHeader.d.ts +6 -0
- package/dist/components/elements/addons/lists/table/TuiTableHeader.js +8 -0
- package/dist/components/elements/addons/lists/table/TuiTableLayout.d.ts +12 -0
- package/dist/components/elements/addons/lists/table/TuiTableLayout.js +41 -0
- package/dist/components/elements/addons/lists/table/index.d.ts +15 -0
- package/dist/components/elements/addons/lists/table/index.js +1 -0
- package/dist/components/elements/addons/search/SearchPagination.d.ts +9 -0
- package/dist/components/elements/addons/search/SearchPagination.js +12 -0
- package/dist/components/elements/addons/search/SearchTotal.d.ts +8 -0
- package/dist/components/elements/addons/search/SearchTotal.js +13 -0
- package/dist/components/elements/addons/search/phrase/Phrase.d.ts +19 -0
- package/dist/components/elements/addons/search/phrase/Phrase.js +89 -0
- package/dist/components/elements/addons/search/phrase/PhraseConsumer.d.ts +13 -0
- package/dist/components/elements/addons/search/phrase/PhraseConsumer.js +22 -0
- package/dist/components/elements/addons/search/phrase/PhraseLexer.d.ts +26 -0
- package/dist/components/elements/addons/search/phrase/PhraseLexer.js +130 -0
- package/dist/components/elements/addons/search/phrase/index.d.ts +40 -0
- package/dist/components/elements/addons/search/phrase/index.js +45 -0
- package/dist/components/elements/addons/search/phrase/word/WordLexer.d.ts +5 -0
- package/dist/components/elements/addons/search/phrase/word/WordLexer.js +8 -0
- package/dist/components/elements/addons/search/phrase/word/WordSuggester.d.ts +6 -0
- package/dist/components/elements/addons/search/phrase/word/WordSuggester.js +9 -0
- package/dist/components/elements/addons/search/phrase/word/consumers/WhitespaceConsumer.d.ts +7 -0
- package/dist/components/elements/addons/search/phrase/word/consumers/WhitespaceConsumer.js +17 -0
- package/dist/components/elements/addons/search/phrase/word/consumers/WordConsumer.d.ts +7 -0
- package/dist/components/elements/addons/search/phrase/word/consumers/WordConsumer.js +17 -0
- package/dist/components/elements/display/Classification.d.ts +3 -0
- package/dist/components/elements/display/Classification.js +22 -0
- package/dist/components/elements/display/DocumentationButton.d.ts +3 -0
- package/dist/components/elements/display/DocumentationButton.js +34 -0
- package/dist/components/elements/display/DynamicTabs.d.ts +8 -0
- package/dist/components/elements/display/DynamicTabs.js +21 -0
- package/dist/components/elements/display/HandlebarsMarkdown.d.ts +9 -0
- package/dist/components/elements/display/HandlebarsMarkdown.js +77 -0
- package/dist/components/elements/display/HowlerAvatar.d.ts +6 -0
- package/dist/components/elements/display/HowlerAvatar.js +44 -0
- package/dist/components/elements/display/HowlerAvatarHeader.d.ts +6 -0
- package/dist/components/elements/display/HowlerAvatarHeader.js +19 -0
- package/dist/components/elements/display/HowlerCard.d.ts +3 -0
- package/dist/components/elements/display/HowlerCard.js +5 -0
- package/dist/components/elements/display/Image.d.ts +3 -0
- package/dist/components/elements/display/Image.js +23 -0
- package/dist/components/elements/display/ItemManager.d.ts +25 -0
- package/dist/components/elements/display/ItemManager.js +35 -0
- package/dist/components/elements/display/Markdown.d.ts +10 -0
- package/dist/components/elements/display/Markdown.js +133 -0
- package/dist/components/elements/display/Modal.d.ts +3 -0
- package/dist/components/elements/display/Modal.js +30 -0
- package/dist/components/elements/display/Notebook.d.ts +5 -0
- package/dist/components/elements/display/Notebook.js +6 -0
- package/dist/components/elements/display/QueryResultText.d.ts +6 -0
- package/dist/components/elements/display/QueryResultText.js +15 -0
- package/dist/components/elements/display/TextDivider.d.ts +3 -0
- package/dist/components/elements/display/TextDivider.js +40 -0
- package/dist/components/elements/display/TypingIndicator.d.ts +2 -0
- package/dist/components/elements/display/TypingIndicator.js +29 -0
- package/dist/components/elements/display/UserPageWrapper.d.ts +6 -0
- package/dist/components/elements/display/UserPageWrapper.js +6 -0
- package/dist/components/elements/display/features/DevelopmentBanner.d.ts +3 -0
- package/dist/components/elements/display/features/DevelopmentBanner.js +14 -0
- package/dist/components/elements/display/features/DevelopmentIcon.d.ts +3 -0
- package/dist/components/elements/display/features/DevelopmentIcon.js +15 -0
- package/dist/components/elements/display/handlebars/helpers.d.ts +9 -0
- package/dist/components/elements/display/handlebars/helpers.js +145 -0
- package/dist/components/elements/display/icons/BundleButton.d.ts +6 -0
- package/dist/components/elements/display/icons/BundleButton.js +32 -0
- package/dist/components/elements/display/icons/Iconified.d.ts +9 -0
- package/dist/components/elements/display/icons/Iconified.js +11 -0
- package/dist/components/elements/display/icons/SocketBadge.d.ts +5 -0
- package/dist/components/elements/display/icons/SocketBadge.js +60 -0
- package/dist/components/elements/display/json/JSONViewer.d.ts +6 -0
- package/dist/components/elements/display/json/JSONViewer.js +57 -0
- package/dist/components/elements/display/json/worker.d.ts +1 -0
- package/dist/components/elements/display/json/worker.js +7 -0
- package/dist/components/elements/display/markdownPlugins/tabs.d.ts +3 -0
- package/dist/components/elements/display/markdownPlugins/tabs.js +70 -0
- package/dist/components/elements/display/modals/ConfirmDeleteModal.d.ts +5 -0
- package/dist/components/elements/display/modals/ConfirmDeleteModal.js +15 -0
- package/dist/components/elements/display/modals/ConfirmNotebookModal.d.ts +5 -0
- package/dist/components/elements/display/modals/ConfirmNotebookModal.js +15 -0
- package/dist/components/elements/display/modals/CreateActionModal.d.ts +5 -0
- package/dist/components/elements/display/modals/CreateActionModal.js +35 -0
- package/dist/components/elements/display/modals/LoginErrorModal.d.ts +5 -0
- package/dist/components/elements/display/modals/LoginErrorModal.js +9 -0
- package/dist/components/elements/display/modals/RationaleModal.d.ts +5 -0
- package/dist/components/elements/display/modals/RationaleModal.js +28 -0
- package/dist/components/elements/hit/HitActions.d.ts +6 -0
- package/dist/components/elements/hit/HitActions.js +165 -0
- package/dist/components/elements/hit/HitBanner.d.ts +15 -0
- package/dist/components/elements/hit/HitBanner.js +113 -0
- package/dist/components/elements/hit/HitBannerTooltip.d.ts +6 -0
- package/dist/components/elements/hit/HitBannerTooltip.js +9 -0
- package/dist/components/elements/hit/HitCard.d.ts +7 -0
- package/dist/components/elements/hit/HitCard.js +30 -0
- package/dist/components/elements/hit/HitComments.d.ts +11 -0
- package/dist/components/elements/hit/HitComments.js +175 -0
- package/dist/components/elements/hit/HitDetails.d.ts +5 -0
- package/dist/components/elements/hit/HitDetails.js +125 -0
- package/dist/components/elements/hit/HitLabels.d.ts +6 -0
- package/dist/components/elements/hit/HitLabels.js +121 -0
- package/dist/components/elements/hit/HitLayout.d.ts +5 -0
- package/dist/components/elements/hit/HitLayout.js +6 -0
- package/dist/components/elements/hit/HitNotebooks.d.ts +8 -0
- package/dist/components/elements/hit/HitNotebooks.js +145 -0
- package/dist/components/elements/hit/HitOutline.d.ts +9 -0
- package/dist/components/elements/hit/HitOutline.js +46 -0
- package/dist/components/elements/hit/HitOverview.d.ts +6 -0
- package/dist/components/elements/hit/HitOverview.js +19 -0
- package/dist/components/elements/hit/HitQuickSearch.d.ts +8 -0
- package/dist/components/elements/hit/HitQuickSearch.js +31 -0
- package/dist/components/elements/hit/HitRelated.d.ts +6 -0
- package/dist/components/elements/hit/HitRelated.js +7 -0
- package/dist/components/elements/hit/HitShortcuts.d.ts +5 -0
- package/dist/components/elements/hit/HitShortcuts.js +6 -0
- package/dist/components/elements/hit/HitSummary.d.ts +10 -0
- package/dist/components/elements/hit/HitSummary.js +151 -0
- package/dist/components/elements/hit/HitWorklog.d.ts +10 -0
- package/dist/components/elements/hit/HitWorklog.js +97 -0
- package/dist/components/elements/hit/actions/ButtonActions.d.ts +12 -0
- package/dist/components/elements/hit/actions/ButtonActions.js +126 -0
- package/dist/components/elements/hit/actions/DropdownActions.d.ts +12 -0
- package/dist/components/elements/hit/actions/DropdownActions.js +28 -0
- package/dist/components/elements/hit/actions/SharedComponents.d.ts +18 -0
- package/dist/components/elements/hit/actions/SharedComponents.js +21 -0
- package/dist/components/elements/hit/aggregate/HitGraph.d.ts +6 -0
- package/dist/components/elements/hit/aggregate/HitGraph.js +238 -0
- package/dist/components/elements/hit/elements/Assigned.d.ts +9 -0
- package/dist/components/elements/hit/elements/Assigned.js +31 -0
- package/dist/components/elements/hit/elements/EscalationChip.d.ts +9 -0
- package/dist/components/elements/hit/elements/EscalationChip.js +10 -0
- package/dist/components/elements/hit/elements/HitTimestamp.d.ts +8 -0
- package/dist/components/elements/hit/elements/HitTimestamp.js +48 -0
- package/dist/components/elements/hit/outlines/DefaultOutline.d.ts +12 -0
- package/dist/components/elements/hit/outlines/DefaultOutline.js +47 -0
- package/dist/components/elements/hit/outlines/al/AssemblyLineRules.d.ts +5 -0
- package/dist/components/elements/hit/outlines/al/AssemblyLineRules.js +46 -0
- package/dist/components/elements/hit/related/PivotLink.d.ts +10 -0
- package/dist/components/elements/hit/related/PivotLink.js +43 -0
- package/dist/components/elements/hit/related/RelatedLink.d.ts +8 -0
- package/dist/components/elements/hit/related/RelatedLink.js +43 -0
- package/dist/components/elements/view/ViewTitle.d.ts +10 -0
- package/dist/components/elements/view/ViewTitle.js +27 -0
- package/dist/components/hooks/useHitActions.d.ts +14 -0
- package/dist/components/hooks/useHitActions.js +191 -0
- package/dist/components/hooks/useHitSelection.d.ts +9 -0
- package/dist/components/hooks/useHitSelection.js +77 -0
- package/dist/components/hooks/useMyApi.d.ts +10 -0
- package/dist/components/hooks/useMyApi.js +43 -0
- package/dist/components/hooks/useMyChart.d.ts +276 -0
- package/dist/components/hooks/useMyChart.js +115 -0
- package/dist/components/hooks/useMyLocalStorage.d.ts +17 -0
- package/dist/components/hooks/useMyLocalStorage.js +15 -0
- package/dist/components/hooks/useMyPreferences.d.ts +3 -0
- package/dist/components/hooks/useMyPreferences.js +248 -0
- package/dist/components/hooks/useMySearch.d.ts +4 -0
- package/dist/components/hooks/useMySearch.js +47 -0
- package/dist/components/hooks/useMySitemap.d.ts +3 -0
- package/dist/components/hooks/useMySitemap.js +217 -0
- package/dist/components/hooks/useMySnackbar.d.ts +8 -0
- package/dist/components/hooks/useMySnackbar.js +47 -0
- package/dist/components/hooks/useMyTheme.d.ts +3 -0
- package/dist/components/hooks/useMyTheme.js +30 -0
- package/dist/components/hooks/useMyUser.d.ts +4 -0
- package/dist/components/hooks/useMyUser.js +27 -0
- package/dist/components/hooks/useMyUserFunctions.d.ts +118 -0
- package/dist/components/hooks/useMyUserFunctions.js +113 -0
- package/dist/components/hooks/useMyUserList.d.ts +4 -0
- package/dist/components/hooks/useMyUserList.js +11 -0
- package/dist/components/hooks/useMyUtils.d.ts +4 -0
- package/dist/components/hooks/useMyUtils.js +10 -0
- package/dist/components/hooks/useScrollRestoration.d.ts +7 -0
- package/dist/components/hooks/useScrollRestoration.js +32 -0
- package/dist/components/logins/Login.d.ts +2 -0
- package/dist/components/logins/Login.js +32 -0
- package/dist/components/logins/auth/OAuthLogin.d.ts +6 -0
- package/dist/components/logins/auth/OAuthLogin.js +25 -0
- package/dist/components/logins/auth/UserPassLogin.d.ts +2 -0
- package/dist/components/logins/auth/UserPassLogin.js +26 -0
- package/dist/components/logins/hooks/useLogin.d.ts +7 -0
- package/dist/components/logins/hooks/useLogin.js +90 -0
- package/dist/components/routes/404.d.ts +3 -0
- package/dist/components/routes/404.js +10 -0
- package/dist/components/routes/ErrorBoundary.d.ts +14 -0
- package/dist/components/routes/ErrorBoundary.js +24 -0
- package/dist/components/routes/ErrorOccured.d.ts +3 -0
- package/dist/components/routes/ErrorOccured.js +13 -0
- package/dist/components/routes/Logout.d.ts +3 -0
- package/dist/components/routes/Logout.js +37 -0
- package/dist/components/routes/action/edit/ActionEditor.d.ts +14 -0
- package/dist/components/routes/action/edit/ActionEditor.js +137 -0
- package/dist/components/routes/action/shared/ActionReportDisplay.d.ts +7 -0
- package/dist/components/routes/action/shared/ActionReportDisplay.js +21 -0
- package/dist/components/routes/action/shared/OperationEntry.d.ts +13 -0
- package/dist/components/routes/action/shared/OperationEntry.js +31 -0
- package/dist/components/routes/action/shared/OperationStep.d.ts +11 -0
- package/dist/components/routes/action/shared/OperationStep.js +102 -0
- package/dist/components/routes/action/useMyActionFunctions.d.ts +19 -0
- package/dist/components/routes/action/useMyActionFunctions.js +156 -0
- package/dist/components/routes/action/view/ActionDetails.d.ts +2 -0
- package/dist/components/routes/action/view/ActionDetails.js +80 -0
- package/dist/components/routes/action/view/ActionSearch.d.ts +3 -0
- package/dist/components/routes/action/view/ActionSearch.js +119 -0
- package/dist/components/routes/action/view/Integrations.d.ts +3 -0
- package/dist/components/routes/action/view/Integrations.js +25 -0
- package/dist/components/routes/admin/users/UserEditor.d.ts +3 -0
- package/dist/components/routes/admin/users/UserEditor.js +28 -0
- package/dist/components/routes/admin/users/UserSearch.d.ts +3 -0
- package/dist/components/routes/admin/users/UserSearch.js +124 -0
- package/dist/components/routes/advanced/QueryBuilder.d.ts +3 -0
- package/dist/components/routes/advanced/QueryBuilder.js +228 -0
- package/dist/components/routes/advanced/QueryEditor.d.ts +14 -0
- package/dist/components/routes/advanced/QueryEditor.js +95 -0
- package/dist/components/routes/advanced/RuleModal.d.ts +7 -0
- package/dist/components/routes/advanced/RuleModal.js +83 -0
- package/dist/components/routes/advanced/eqlCompletionProvider.d.ts +3 -0
- package/dist/components/routes/advanced/eqlCompletionProvider.js +84 -0
- package/dist/components/routes/advanced/eqlTokenProvider.d.ts +8 -0
- package/dist/components/routes/advanced/eqlTokenProvider.js +86 -0
- package/dist/components/routes/advanced/historyCompletionProvider.d.ts +3 -0
- package/dist/components/routes/advanced/historyCompletionProvider.js +48 -0
- package/dist/components/routes/advanced/luceneCompletionProvider.d.ts +3 -0
- package/dist/components/routes/advanced/luceneCompletionProvider.js +96 -0
- package/dist/components/routes/advanced/luceneTokenProvider.d.ts +9 -0
- package/dist/components/routes/advanced/luceneTokenProvider.js +104 -0
- package/dist/components/routes/advanced/yamlCompletionProvider.d.ts +3 -0
- package/dist/components/routes/advanced/yamlCompletionProvider.js +50 -0
- package/dist/components/routes/analytics/AnalyticComments.d.ts +7 -0
- package/dist/components/routes/analytics/AnalyticComments.js +115 -0
- package/dist/components/routes/analytics/AnalyticDetails.d.ts +2 -0
- package/dist/components/routes/analytics/AnalyticDetails.js +133 -0
- package/dist/components/routes/analytics/AnalyticHitComments.d.ts +6 -0
- package/dist/components/routes/analytics/AnalyticHitComments.js +49 -0
- package/dist/components/routes/analytics/AnalyticNotebooks.d.ts +7 -0
- package/dist/components/routes/analytics/AnalyticNotebooks.js +60 -0
- package/dist/components/routes/analytics/AnalyticOverview.d.ts +8 -0
- package/dist/components/routes/analytics/AnalyticOverview.js +60 -0
- package/dist/components/routes/analytics/AnalyticOverviews.d.ts +7 -0
- package/dist/components/routes/analytics/AnalyticOverviews.js +39 -0
- package/dist/components/routes/analytics/AnalyticSearch.d.ts +3 -0
- package/dist/components/routes/analytics/AnalyticSearch.js +126 -0
- package/dist/components/routes/analytics/AnalyticTemplates.d.ts +7 -0
- package/dist/components/routes/analytics/AnalyticTemplates.js +40 -0
- package/dist/components/routes/analytics/RuleView.d.ts +8 -0
- package/dist/components/routes/analytics/RuleView.js +48 -0
- package/dist/components/routes/analytics/TriageSettings.d.ts +8 -0
- package/dist/components/routes/analytics/TriageSettings.js +49 -0
- package/dist/components/routes/analytics/widgets/Assessment.d.ts +6 -0
- package/dist/components/routes/analytics/widgets/Assessment.js +44 -0
- package/dist/components/routes/analytics/widgets/Created.d.ts +6 -0
- package/dist/components/routes/analytics/widgets/Created.js +44 -0
- package/dist/components/routes/analytics/widgets/Detection.d.ts +7 -0
- package/dist/components/routes/analytics/widgets/Detection.js +9 -0
- package/dist/components/routes/analytics/widgets/Escalation.d.ts +7 -0
- package/dist/components/routes/analytics/widgets/Escalation.js +39 -0
- package/dist/components/routes/analytics/widgets/Stacked.d.ts +8 -0
- package/dist/components/routes/analytics/widgets/Stacked.js +76 -0
- package/dist/components/routes/analytics/widgets/Status.d.ts +6 -0
- package/dist/components/routes/analytics/widgets/Status.js +11 -0
- package/dist/components/routes/dossiers/DossierCard.d.ts +8 -0
- package/dist/components/routes/dossiers/DossierCard.js +11 -0
- package/dist/components/routes/dossiers/DossierEditor.d.ts +2 -0
- package/dist/components/routes/dossiers/DossierEditor.js +124 -0
- package/dist/components/routes/dossiers/Dossiers.d.ts +2 -0
- package/dist/components/routes/dossiers/Dossiers.js +116 -0
- package/dist/components/routes/dossiers/LeadEditor.d.ts +13 -0
- package/dist/components/routes/dossiers/LeadEditor.js +36 -0
- package/dist/components/routes/dossiers/LeadForm.d.ts +8 -0
- package/dist/components/routes/dossiers/LeadForm.js +51 -0
- package/dist/components/routes/dossiers/PivotForm.d.ts +13 -0
- package/dist/components/routes/dossiers/PivotForm.js +82 -0
- package/dist/components/routes/help/ActionDocumentation.d.ts +9 -0
- package/dist/components/routes/help/ActionDocumentation.js +31 -0
- package/dist/components/routes/help/ActionIntroductionDocumentation.d.ts +3 -0
- package/dist/components/routes/help/ActionIntroductionDocumentation.js +61 -0
- package/dist/components/routes/help/ApiDocumentation.d.ts +3 -0
- package/dist/components/routes/help/ApiDocumentation.js +55 -0
- package/dist/components/routes/help/AuthDocumentation.d.ts +3 -0
- package/dist/components/routes/help/AuthDocumentation.js +15 -0
- package/dist/components/routes/help/BundleDocumentation.d.ts +3 -0
- package/dist/components/routes/help/BundleDocumentation.js +12 -0
- package/dist/components/routes/help/ClientDocumentation.d.ts +3 -0
- package/dist/components/routes/help/ClientDocumentation.js +15 -0
- package/dist/components/routes/help/Help.d.ts +2 -0
- package/dist/components/routes/help/Help.js +24 -0
- package/dist/components/routes/help/HitBannerDocumentation.d.ts +3 -0
- package/dist/components/routes/help/HitBannerDocumentation.js +49 -0
- package/dist/components/routes/help/HitDocumentation.d.ts +3 -0
- package/dist/components/routes/help/HitDocumentation.js +34 -0
- package/dist/components/routes/help/HitLabelsDocumentation.d.ts +3 -0
- package/dist/components/routes/help/HitLabelsDocumentation.js +21 -0
- package/dist/components/routes/help/HitLinksDocumentation.d.ts +3 -0
- package/dist/components/routes/help/HitLinksDocumentation.js +17 -0
- package/dist/components/routes/help/HitSchemaDocumentation.d.ts +3 -0
- package/dist/components/routes/help/HitSchemaDocumentation.js +80 -0
- package/dist/components/routes/help/NotebookDocumentation.d.ts +3 -0
- package/dist/components/routes/help/NotebookDocumentation.js +18 -0
- package/dist/components/routes/help/OverviewDocumentation.d.ts +3 -0
- package/dist/components/routes/help/OverviewDocumentation.js +13 -0
- package/dist/components/routes/help/RetentionDocumentation.d.ts +3 -0
- package/dist/components/routes/help/RetentionDocumentation.js +35 -0
- package/dist/components/routes/help/SearchDocumentation.d.ts +3 -0
- package/dist/components/routes/help/SearchDocumentation.js +113 -0
- package/dist/components/routes/help/TemplateDocumentation.d.ts +3 -0
- package/dist/components/routes/help/TemplateDocumentation.js +46 -0
- package/dist/components/routes/help/ViewDocumentation.d.ts +3 -0
- package/dist/components/routes/help/ViewDocumentation.js +18 -0
- package/dist/components/routes/help/components/HelpTabs.d.ts +6 -0
- package/dist/components/routes/help/components/HelpTabs.js +30 -0
- package/dist/components/routes/hits/search/BundleParentMenu.d.ts +6 -0
- package/dist/components/routes/hits/search/BundleParentMenu.js +32 -0
- package/dist/components/routes/hits/search/BundleScroller.d.ts +2 -0
- package/dist/components/routes/hits/search/BundleScroller.js +6 -0
- package/dist/components/routes/hits/search/CustomSort.d.ts +2 -0
- package/dist/components/routes/hits/search/CustomSort.js +37 -0
- package/dist/components/routes/hits/search/HitBrowser.d.ts +3 -0
- package/dist/components/routes/hits/search/HitBrowser.js +174 -0
- package/dist/components/routes/hits/search/HitContextMenu.d.ts +6 -0
- package/dist/components/routes/hits/search/HitContextMenu.js +116 -0
- package/dist/components/routes/hits/search/HitQuery.d.ts +9 -0
- package/dist/components/routes/hits/search/HitQuery.js +151 -0
- package/dist/components/routes/hits/search/InformationPane.d.ts +5 -0
- package/dist/components/routes/hits/search/InformationPane.js +204 -0
- package/dist/components/routes/hits/search/SearchPane.d.ts +3 -0
- package/dist/components/routes/hits/search/SearchPane.js +138 -0
- package/dist/components/routes/hits/search/ViewLink.d.ts +2 -0
- package/dist/components/routes/hits/search/ViewLink.js +41 -0
- package/dist/components/routes/hits/search/grid/AddColumnModal.d.ts +8 -0
- package/dist/components/routes/hits/search/grid/AddColumnModal.js +22 -0
- package/dist/components/routes/hits/search/grid/EnchancedCell.d.ts +7 -0
- package/dist/components/routes/hits/search/grid/EnchancedCell.js +18 -0
- package/dist/components/routes/hits/search/grid/HitGrid.d.ts +3 -0
- package/dist/components/routes/hits/search/grid/HitGrid.js +137 -0
- package/dist/components/routes/hits/search/grid/HitRow.d.ts +9 -0
- package/dist/components/routes/hits/search/grid/HitRow.js +54 -0
- package/dist/components/routes/hits/search/shared/CustomSpan.d.ts +2 -0
- package/dist/components/routes/hits/search/shared/CustomSpan.js +24 -0
- package/dist/components/routes/hits/search/shared/HitFilter.d.ts +4 -0
- package/dist/components/routes/hits/search/shared/HitFilter.js +64 -0
- package/dist/components/routes/hits/search/shared/HitSort.d.ts +4 -0
- package/dist/components/routes/hits/search/shared/HitSort.js +64 -0
- package/dist/components/routes/hits/search/shared/QuerySettings.d.ts +6 -0
- package/dist/components/routes/hits/search/shared/QuerySettings.js +22 -0
- package/dist/components/routes/hits/search/shared/SearchSpan.d.ts +5 -0
- package/dist/components/routes/hits/search/shared/SearchSpan.js +40 -0
- package/dist/components/routes/hits/view/HitViewer.d.ts +7 -0
- package/dist/components/routes/hits/view/HitViewer.js +170 -0
- package/dist/components/routes/hits/view/LeadRenderer.d.ts +7 -0
- package/dist/components/routes/hits/view/LeadRenderer.js +21 -0
- package/dist/components/routes/home/AddNewCard.d.ts +7 -0
- package/dist/components/routes/home/AddNewCard.js +53 -0
- package/dist/components/routes/home/AnalyticCard.d.ts +7 -0
- package/dist/components/routes/home/AnalyticCard.js +30 -0
- package/dist/components/routes/home/EntryWrapper.d.ts +7 -0
- package/dist/components/routes/home/EntryWrapper.js +19 -0
- package/dist/components/routes/home/ViewCard.d.ts +7 -0
- package/dist/components/routes/home/ViewCard.js +39 -0
- package/dist/components/routes/home/index.d.ts +3 -0
- package/dist/components/routes/home/index.js +121 -0
- package/dist/components/routes/overviews/OverviewCard.d.ts +8 -0
- package/dist/components/routes/overviews/OverviewCard.js +16 -0
- package/dist/components/routes/overviews/OverviewEditor.d.ts +12 -0
- package/dist/components/routes/overviews/OverviewEditor.js +56 -0
- package/dist/components/routes/overviews/OverviewViewer.d.ts +2 -0
- package/dist/components/routes/overviews/OverviewViewer.js +217 -0
- package/dist/components/routes/overviews/Overviews.d.ts +2 -0
- package/dist/components/routes/overviews/Overviews.js +116 -0
- package/dist/components/routes/overviews/markdownExtendedTokenProvider.d.ts +6 -0
- package/dist/components/routes/overviews/markdownExtendedTokenProvider.js +254 -0
- package/dist/components/routes/overviews/startingTemplate.d.ts +1 -0
- package/dist/components/routes/overviews/startingTemplate.js +181 -0
- package/dist/components/routes/settings/AdminSection.d.ts +3 -0
- package/dist/components/routes/settings/AdminSection.js +11 -0
- package/dist/components/routes/settings/LocalSection.d.ts +3 -0
- package/dist/components/routes/settings/LocalSection.js +25 -0
- package/dist/components/routes/settings/ProfileSection.d.ts +10 -0
- package/dist/components/routes/settings/ProfileSection.js +53 -0
- package/dist/components/routes/settings/SecuritySection.d.ts +10 -0
- package/dist/components/routes/settings/SecuritySection.js +31 -0
- package/dist/components/routes/settings/Settings.d.ts +3 -0
- package/dist/components/routes/settings/Settings.js +22 -0
- package/dist/components/routes/settings/SettingsSection.d.ts +7 -0
- package/dist/components/routes/settings/SettingsSection.js +10 -0
- package/dist/components/routes/templates/TemplateCard.d.ts +7 -0
- package/dist/components/routes/templates/TemplateCard.js +13 -0
- package/dist/components/routes/templates/TemplateDnD.d.ts +8 -0
- package/dist/components/routes/templates/TemplateDnD.js +12 -0
- package/dist/components/routes/templates/TemplateEditor.d.ts +9 -0
- package/dist/components/routes/templates/TemplateEditor.js +55 -0
- package/dist/components/routes/templates/TemplateViewer.d.ts +2 -0
- package/dist/components/routes/templates/TemplateViewer.js +165 -0
- package/dist/components/routes/templates/Templates.d.ts +2 -0
- package/dist/components/routes/templates/Templates.js +116 -0
- package/dist/components/routes/views/ViewComposer.d.ts +3 -0
- package/dist/components/routes/views/ViewComposer.js +167 -0
- package/dist/components/routes/views/Views.d.ts +2 -0
- package/dist/components/routes/views/Views.js +155 -0
- package/dist/i18n.d.ts +3 -0
- package/dist/i18n.js +43 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +10 -0
- package/dist/locales/en/help/main.json +13 -0
- package/dist/locales/en/help/search.json +167 -0
- package/dist/locales/en/translation.json +675 -0
- package/dist/locales/fr/help/main.json +13 -0
- package/dist/locales/fr/help/search.json +167 -0
- package/dist/locales/fr/translation.json +675 -0
- package/dist/models/ActionTypes.d.ts +48 -0
- package/dist/models/ActionTypes.js +1 -0
- package/dist/models/entities/HowlerUser.d.ts +21 -0
- package/dist/models/entities/HowlerUser.js +1 -0
- package/dist/models/entities/generated/Account.d.ts +7 -0
- package/dist/models/entities/generated/Account.js +1 -0
- package/dist/models/entities/generated/Action.d.ts +12 -0
- package/dist/models/entities/generated/Action.js +1 -0
- package/dist/models/entities/generated/Agent.d.ts +9 -0
- package/dist/models/entities/generated/Agent.js +1 -0
- package/dist/models/entities/generated/Analytic.d.ts +20 -0
- package/dist/models/entities/generated/Analytic.js +1 -0
- package/dist/models/entities/generated/Answer.d.ts +10 -0
- package/dist/models/entities/generated/Answer.js +1 -0
- package/dist/models/entities/generated/Antivirus.d.ts +9 -0
- package/dist/models/entities/generated/Antivirus.js +1 -0
- package/dist/models/entities/generated/ApiType.d.ts +265 -0
- package/dist/models/entities/generated/ApiType.js +1 -0
- package/dist/models/entities/generated/Assemblyline.d.ts +21 -0
- package/dist/models/entities/generated/Assemblyline.js +1 -0
- package/dist/models/entities/generated/Attachment.d.ts +7 -0
- package/dist/models/entities/generated/Attachment.js +1 -0
- package/dist/models/entities/generated/Attribution.d.ts +9 -0
- package/dist/models/entities/generated/Attribution.js +1 -0
- package/dist/models/entities/generated/AutonomousSystems.d.ts +7 -0
- package/dist/models/entities/generated/AutonomousSystems.js +1 -0
- package/dist/models/entities/generated/Aws.d.ts +9 -0
- package/dist/models/entities/generated/Aws.js +1 -0
- package/dist/models/entities/generated/Azure.d.ts +10 -0
- package/dist/models/entities/generated/Azure.js +1 -0
- package/dist/models/entities/generated/Bcc.d.ts +6 -0
- package/dist/models/entities/generated/Bcc.js +1 -0
- package/dist/models/entities/generated/Behaviour.d.ts +9 -0
- package/dist/models/entities/generated/Behaviour.js +1 -0
- package/dist/models/entities/generated/Body.d.ts +7 -0
- package/dist/models/entities/generated/Body.js +1 -0
- package/dist/models/entities/generated/Cbs.d.ts +7 -0
- package/dist/models/entities/generated/Cbs.js +1 -0
- package/dist/models/entities/generated/Cc.d.ts +6 -0
- package/dist/models/entities/generated/Cc.js +1 -0
- package/dist/models/entities/generated/Client.d.ts +7 -0
- package/dist/models/entities/generated/Client.js +1 -0
- package/dist/models/entities/generated/Cloud.d.ts +19 -0
- package/dist/models/entities/generated/Cloud.js +1 -0
- package/dist/models/entities/generated/CloudAccount.d.ts +7 -0
- package/dist/models/entities/generated/CloudAccount.js +1 -0
- package/dist/models/entities/generated/CodeSignature.d.ts +14 -0
- package/dist/models/entities/generated/CodeSignature.js +1 -0
- package/dist/models/entities/generated/Comment.d.ts +14 -0
- package/dist/models/entities/generated/Comment.js +1 -0
- package/dist/models/entities/generated/Container.d.ts +13 -0
- package/dist/models/entities/generated/Container.js +1 -0
- package/dist/models/entities/generated/Created.d.ts +7 -0
- package/dist/models/entities/generated/Created.js +1 -0
- package/dist/models/entities/generated/Dashboard.d.ts +8 -0
- package/dist/models/entities/generated/Dashboard.js +1 -0
- package/dist/models/entities/generated/Data.d.ts +8 -0
- package/dist/models/entities/generated/Data.js +1 -0
- package/dist/models/entities/generated/Destination.d.ts +22 -0
- package/dist/models/entities/generated/Destination.js +1 -0
- package/dist/models/entities/generated/Device.d.ts +6 -0
- package/dist/models/entities/generated/Device.js +1 -0
- package/dist/models/entities/generated/Dns.d.ts +15 -0
- package/dist/models/entities/generated/Dns.js +1 -0
- package/dist/models/entities/generated/Domain.d.ts +9 -0
- package/dist/models/entities/generated/Domain.js +1 -0
- package/dist/models/entities/generated/Dossier.d.ts +14 -0
- package/dist/models/entities/generated/Dossier.js +1 -0
- package/dist/models/entities/generated/Ecs.d.ts +6 -0
- package/dist/models/entities/generated/Ecs.js +1 -0
- package/dist/models/entities/generated/Egress.d.ts +6 -0
- package/dist/models/entities/generated/Egress.js +1 -0
- package/dist/models/entities/generated/Elf.d.ts +19 -0
- package/dist/models/entities/generated/Elf.js +1 -0
- package/dist/models/entities/generated/Email.d.ts +29 -0
- package/dist/models/entities/generated/Email.js +1 -0
- package/dist/models/entities/generated/Enrichment.d.ts +9 -0
- package/dist/models/entities/generated/Enrichment.js +1 -0
- package/dist/models/entities/generated/EntryMeta.d.ts +6 -0
- package/dist/models/entities/generated/EntryMeta.js +1 -0
- package/dist/models/entities/generated/Error.d.ts +7 -0
- package/dist/models/entities/generated/Error.js +1 -0
- package/dist/models/entities/generated/Event.d.ts +31 -0
- package/dist/models/entities/generated/Event.js +1 -0
- package/dist/models/entities/generated/Faas.d.ts +12 -0
- package/dist/models/entities/generated/Faas.js +1 -0
- package/dist/models/entities/generated/Feed.d.ts +9 -0
- package/dist/models/entities/generated/Feed.js +1 -0
- package/dist/models/entities/generated/File.d.ts +11 -0
- package/dist/models/entities/generated/File.js +1 -0
- package/dist/models/entities/generated/FileHash.d.ts +12 -0
- package/dist/models/entities/generated/FileHash.js +1 -0
- package/dist/models/entities/generated/From.d.ts +6 -0
- package/dist/models/entities/generated/From.js +1 -0
- package/dist/models/entities/generated/Gcp.d.ts +10 -0
- package/dist/models/entities/generated/Gcp.js +1 -0
- package/dist/models/entities/generated/Geo.d.ts +17 -0
- package/dist/models/entities/generated/Geo.js +1 -0
- package/dist/models/entities/generated/Group.d.ts +8 -0
- package/dist/models/entities/generated/Group.js +1 -0
- package/dist/models/entities/generated/Hash.d.ts +6 -0
- package/dist/models/entities/generated/Hash.js +1 -0
- package/dist/models/entities/generated/Header.d.ts +13 -0
- package/dist/models/entities/generated/Header.js +1 -0
- package/dist/models/entities/generated/Heuristic.d.ts +9 -0
- package/dist/models/entities/generated/Heuristic.js +1 -0
- package/dist/models/entities/generated/Hit.d.ts +103 -0
- package/dist/models/entities/generated/Hit.js +1 -0
- package/dist/models/entities/generated/HitFile.d.ts +35 -0
- package/dist/models/entities/generated/HitFile.js +1 -0
- package/dist/models/entities/generated/HitOrganization.d.ts +7 -0
- package/dist/models/entities/generated/HitOrganization.js +1 -0
- package/dist/models/entities/generated/Host.d.ts +11 -0
- package/dist/models/entities/generated/Host.js +1 -0
- package/dist/models/entities/generated/Howler.d.ts +47 -0
- package/dist/models/entities/generated/Howler.js +1 -0
- package/dist/models/entities/generated/HowlerComment.d.ts +13 -0
- package/dist/models/entities/generated/HowlerComment.js +1 -0
- package/dist/models/entities/generated/HowlerDossier.d.ts +11 -0
- package/dist/models/entities/generated/HowlerDossier.js +1 -0
- package/dist/models/entities/generated/Http.d.ts +10 -0
- package/dist/models/entities/generated/Http.js +1 -0
- package/dist/models/entities/generated/Image.d.ts +9 -0
- package/dist/models/entities/generated/Image.js +1 -0
- package/dist/models/entities/generated/Incident.d.ts +8 -0
- package/dist/models/entities/generated/Incident.js +1 -0
- package/dist/models/entities/generated/Indicator.d.ts +20 -0
- package/dist/models/entities/generated/Indicator.js +1 -0
- package/dist/models/entities/generated/IndicatorEmail.d.ts +6 -0
- package/dist/models/entities/generated/IndicatorEmail.js +1 -0
- package/dist/models/entities/generated/IndicatorFile.d.ts +35 -0
- package/dist/models/entities/generated/IndicatorFile.js +1 -0
- package/dist/models/entities/generated/Ingress.d.ts +8 -0
- package/dist/models/entities/generated/Ingress.js +1 -0
- package/dist/models/entities/generated/Instance.d.ts +7 -0
- package/dist/models/entities/generated/Instance.js +1 -0
- package/dist/models/entities/generated/Interface.d.ts +7 -0
- package/dist/models/entities/generated/Interface.js +1 -0
- package/dist/models/entities/generated/Label.d.ts +7 -0
- package/dist/models/entities/generated/Label.js +1 -0
- package/dist/models/entities/generated/Labels.d.ts +13 -0
- package/dist/models/entities/generated/Labels.js +1 -0
- package/dist/models/entities/generated/Lead.d.ts +11 -0
- package/dist/models/entities/generated/Lead.js +1 -0
- package/dist/models/entities/generated/Link.d.ts +8 -0
- package/dist/models/entities/generated/Link.js +1 -0
- package/dist/models/entities/generated/Location.d.ts +7 -0
- package/dist/models/entities/generated/Location.js +1 -0
- package/dist/models/entities/generated/Log.d.ts +13 -0
- package/dist/models/entities/generated/Log.js +1 -0
- package/dist/models/entities/generated/Machine.d.ts +6 -0
- package/dist/models/entities/generated/Machine.js +1 -0
- package/dist/models/entities/generated/Mapping.d.ts +8 -0
- package/dist/models/entities/generated/Mapping.js +1 -0
- package/dist/models/entities/generated/Matched.d.ts +6 -0
- package/dist/models/entities/generated/Matched.js +1 -0
- package/dist/models/entities/generated/Mitre.d.ts +9 -0
- package/dist/models/entities/generated/Mitre.js +1 -0
- package/dist/models/entities/generated/Modified.d.ts +7 -0
- package/dist/models/entities/generated/Modified.js +1 -0
- package/dist/models/entities/generated/Nat.d.ts +7 -0
- package/dist/models/entities/generated/Nat.js +1 -0
- package/dist/models/entities/generated/Network.d.ts +8 -0
- package/dist/models/entities/generated/Network.js +1 -0
- package/dist/models/entities/generated/Notebook.d.ts +10 -0
- package/dist/models/entities/generated/Notebook.js +1 -0
- package/dist/models/entities/generated/Observer.d.ts +20 -0
- package/dist/models/entities/generated/Observer.js +1 -0
- package/dist/models/entities/generated/Operation.d.ts +7 -0
- package/dist/models/entities/generated/Operation.js +1 -0
- package/dist/models/entities/generated/Organization.d.ts +7 -0
- package/dist/models/entities/generated/Organization.js +1 -0
- package/dist/models/entities/generated/Original.d.ts +18 -0
- package/dist/models/entities/generated/Original.js +1 -0
- package/dist/models/entities/generated/Os.d.ts +12 -0
- package/dist/models/entities/generated/Os.js +1 -0
- package/dist/models/entities/generated/Outline.d.ts +9 -0
- package/dist/models/entities/generated/Outline.js +1 -0
- package/dist/models/entities/generated/Overview.d.ts +10 -0
- package/dist/models/entities/generated/Overview.js +1 -0
- package/dist/models/entities/generated/Parent.d.ts +18 -0
- package/dist/models/entities/generated/Parent.js +1 -0
- package/dist/models/entities/generated/ParentHash.d.ts +12 -0
- package/dist/models/entities/generated/ParentHash.js +1 -0
- package/dist/models/entities/generated/ParentParent.d.ts +33 -0
- package/dist/models/entities/generated/ParentParent.js +1 -0
- package/dist/models/entities/generated/ParentUser.d.ts +9 -0
- package/dist/models/entities/generated/ParentUser.js +1 -0
- package/dist/models/entities/generated/Pe.d.ts +13 -0
- package/dist/models/entities/generated/Pe.js +1 -0
- package/dist/models/entities/generated/Pivot.d.ts +12 -0
- package/dist/models/entities/generated/Pivot.js +1 -0
- package/dist/models/entities/generated/Process.d.ts +35 -0
- package/dist/models/entities/generated/Process.js +1 -0
- package/dist/models/entities/generated/ProcessHash.d.ts +12 -0
- package/dist/models/entities/generated/ProcessHash.js +1 -0
- package/dist/models/entities/generated/ProcessParent.d.ts +35 -0
- package/dist/models/entities/generated/ProcessParent.js +1 -0
- package/dist/models/entities/generated/ProcessUser.d.ts +9 -0
- package/dist/models/entities/generated/ProcessUser.js +1 -0
- package/dist/models/entities/generated/Project.d.ts +7 -0
- package/dist/models/entities/generated/Project.js +1 -0
- package/dist/models/entities/generated/Question.d.ts +11 -0
- package/dist/models/entities/generated/Question.js +1 -0
- package/dist/models/entities/generated/Registry.d.ts +11 -0
- package/dist/models/entities/generated/Registry.js +1 -0
- package/dist/models/entities/generated/Related.d.ts +13 -0
- package/dist/models/entities/generated/Related.js +1 -0
- package/dist/models/entities/generated/ReplyTo.d.ts +6 -0
- package/dist/models/entities/generated/ReplyTo.js +1 -0
- package/dist/models/entities/generated/Request.d.ts +12 -0
- package/dist/models/entities/generated/Request.js +1 -0
- package/dist/models/entities/generated/Response.d.ts +10 -0
- package/dist/models/entities/generated/Response.js +1 -0
- package/dist/models/entities/generated/Rule.d.ts +15 -0
- package/dist/models/entities/generated/Rule.js +1 -0
- package/dist/models/entities/generated/Section.d.ts +14 -0
- package/dist/models/entities/generated/Section.js +1 -0
- package/dist/models/entities/generated/Segment.d.ts +14 -0
- package/dist/models/entities/generated/Segment.js +1 -0
- package/dist/models/entities/generated/Sender.d.ts +6 -0
- package/dist/models/entities/generated/Sender.js +1 -0
- package/dist/models/entities/generated/Server.d.ts +8 -0
- package/dist/models/entities/generated/Server.js +1 -0
- package/dist/models/entities/generated/Service.d.ts +6 -0
- package/dist/models/entities/generated/Service.js +1 -0
- package/dist/models/entities/generated/Settings.d.ts +6 -0
- package/dist/models/entities/generated/Settings.js +1 -0
- package/dist/models/entities/generated/Sharepoint.d.ts +9 -0
- package/dist/models/entities/generated/Sharepoint.js +1 -0
- package/dist/models/entities/generated/Software.d.ts +11 -0
- package/dist/models/entities/generated/Software.js +1 -0
- package/dist/models/entities/generated/Source.d.ts +22 -0
- package/dist/models/entities/generated/Source.js +1 -0
- package/dist/models/entities/generated/SourceOriginal.d.ts +18 -0
- package/dist/models/entities/generated/SourceOriginal.js +1 -0
- package/dist/models/entities/generated/Tactic.d.ts +9 -0
- package/dist/models/entities/generated/Tactic.js +1 -0
- package/dist/models/entities/generated/Technique.d.ts +9 -0
- package/dist/models/entities/generated/Technique.js +1 -0
- package/dist/models/entities/generated/Template.d.ts +11 -0
- package/dist/models/entities/generated/Template.js +1 -0
- package/dist/models/entities/generated/Threat.d.ts +20 -0
- package/dist/models/entities/generated/Threat.js +1 -0
- package/dist/models/entities/generated/ThreatGroup.d.ts +9 -0
- package/dist/models/entities/generated/ThreatGroup.js +1 -0
- package/dist/models/entities/generated/ThreatIndicator.d.ts +20 -0
- package/dist/models/entities/generated/ThreatIndicator.js +1 -0
- package/dist/models/entities/generated/ThreatTactic.d.ts +8 -0
- package/dist/models/entities/generated/ThreatTactic.js +1 -0
- package/dist/models/entities/generated/ThreatTechnique.d.ts +8 -0
- package/dist/models/entities/generated/ThreatTechnique.js +1 -0
- package/dist/models/entities/generated/Tls.d.ts +11 -0
- package/dist/models/entities/generated/Tls.js +1 -0
- package/dist/models/entities/generated/TlsServer.d.ts +6 -0
- package/dist/models/entities/generated/TlsServer.js +1 -0
- package/dist/models/entities/generated/To.d.ts +6 -0
- package/dist/models/entities/generated/To.js +1 -0
- package/dist/models/entities/generated/TriageSettings.d.ts +8 -0
- package/dist/models/entities/generated/TriageSettings.js +1 -0
- package/dist/models/entities/generated/Trigger.d.ts +7 -0
- package/dist/models/entities/generated/Trigger.js +1 -0
- package/dist/models/entities/generated/Uri.d.ts +9 -0
- package/dist/models/entities/generated/Uri.js +1 -0
- package/dist/models/entities/generated/Url.d.ts +19 -0
- package/dist/models/entities/generated/Url.js +1 -0
- package/dist/models/entities/generated/User.d.ts +14 -0
- package/dist/models/entities/generated/User.js +1 -0
- package/dist/models/entities/generated/UserAgent.d.ts +12 -0
- package/dist/models/entities/generated/UserAgent.js +1 -0
- package/dist/models/entities/generated/UserUser.d.ts +18 -0
- package/dist/models/entities/generated/UserUser.js +1 -0
- package/dist/models/entities/generated/View.d.ts +14 -0
- package/dist/models/entities/generated/View.js +1 -0
- package/dist/models/entities/generated/Votes.d.ts +8 -0
- package/dist/models/entities/generated/Votes.js +1 -0
- package/dist/models/entities/generated/Vulnerability.d.ts +12 -0
- package/dist/models/entities/generated/Vulnerability.js +1 -0
- package/dist/models/entities/generated/Yara.d.ts +9 -0
- package/dist/models/entities/generated/Yara.js +1 -0
- package/dist/models/socket/HitUpdate.d.ts +12 -0
- package/dist/models/socket/HitUpdate.js +1 -0
- package/dist/plugins/HowlerPlugin.d.ts +45 -0
- package/dist/plugins/HowlerPlugin.js +111 -0
- package/dist/plugins/store.d.ts +23 -0
- package/dist/plugins/store.js +52 -0
- package/dist/rest/AxiosClient.d.ts +10 -0
- package/dist/rest/AxiosClient.js +60 -0
- package/dist/rest/FetchClient.d.ts +7 -0
- package/dist/rest/FetchClient.js +16 -0
- package/dist/rest/index.d.ts +6 -0
- package/dist/rest/index.js +1 -0
- package/dist/utils/Throttler.d.ts +9 -0
- package/dist/utils/Throttler.js +38 -0
- package/dist/utils/actionUtils.d.ts +31 -0
- package/dist/utils/actionUtils.js +88 -0
- package/dist/utils/constants.d.ts +78 -0
- package/dist/utils/constants.js +113 -0
- package/dist/utils/hit.json +30356 -0
- package/dist/utils/hitFunctions.d.ts +2 -0
- package/dist/utils/hitFunctions.js +8 -0
- package/dist/utils/localStorage.d.ts +21 -0
- package/dist/utils/localStorage.js +48 -0
- package/dist/utils/sessionStorage.d.ts +7 -0
- package/dist/utils/sessionStorage.js +44 -0
- package/dist/utils/socketUtils.d.ts +8 -0
- package/dist/utils/socketUtils.js +8 -0
- package/dist/utils/stringUtils.d.ts +7 -0
- package/dist/utils/stringUtils.js +38 -0
- package/dist/utils/utils.d.ts +33 -0
- package/dist/utils/utils.js +180 -0
- package/dist/utils/xsrf.d.ts +2 -0
- package/dist/utils/xsrf.js +16 -0
- package/package.json +153 -0
- package/public/branding/howler/favicon.svg +38 -0
- package/public/branding/howler/name-dark.svg +21 -0
- package/public/branding/howler/name-light.svg +21 -0
- package/public/branding/howler/noswoosh-dark.svg +24 -0
- package/public/branding/howler/noswoosh-light.svg +28 -0
- package/public/branding/howler/swoosh-dark.svg +41 -0
- package/public/branding/howler/swoosh-light.svg +45 -0
- package/public/images/doggie.png +0 -0
- package/public/manifest.json +16 -0
- package/public/robots.txt +3 -0
- package/public/scripts/background.js +14 -0
- package/public/serve.json +14 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { Add, Check, ChevronRight, Clear } from '@mui/icons-material';
|
|
3
|
+
import { Chip, CircularProgress, Grid, TableCell, TableRow, Typography } from '@mui/material';
|
|
4
|
+
import { ApiConfigContext } from 'components/app/providers/ApiConfigProvider';
|
|
5
|
+
import howlerPluginStore from 'plugins/store';
|
|
6
|
+
import { useCallback, useContext, useState } from 'react';
|
|
7
|
+
import { useTranslation } from 'react-i18next';
|
|
8
|
+
import { usePluginStore } from 'react-pluggable';
|
|
9
|
+
import { delay } from 'utils/utils';
|
|
10
|
+
import EditRow from '../../elements/EditRow';
|
|
11
|
+
import SettingsSection from './SettingsSection';
|
|
12
|
+
const ProfileSection = ({ user, editName, addRole, removeRole, viewGroups }) => {
|
|
13
|
+
const { t } = useTranslation();
|
|
14
|
+
const { config } = useContext(ApiConfigContext);
|
|
15
|
+
const pluginStore = usePluginStore();
|
|
16
|
+
const [loading, setLoading] = useState({});
|
|
17
|
+
const [loadingGroups, setLoadingGroups] = useState(false);
|
|
18
|
+
const wrapChange = useCallback(async (r, fn) => {
|
|
19
|
+
const delayedLoad = delay(250);
|
|
20
|
+
delayedLoad.then(() => {
|
|
21
|
+
setLoading({
|
|
22
|
+
...loading,
|
|
23
|
+
[r]: true
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
try {
|
|
27
|
+
await fn(r);
|
|
28
|
+
}
|
|
29
|
+
finally {
|
|
30
|
+
delayedLoad.cancel();
|
|
31
|
+
setLoading({
|
|
32
|
+
...loading,
|
|
33
|
+
[r]: false
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
}, [loading]);
|
|
37
|
+
const onViewGroups = useCallback(async () => {
|
|
38
|
+
setLoadingGroups(true);
|
|
39
|
+
try {
|
|
40
|
+
await viewGroups();
|
|
41
|
+
}
|
|
42
|
+
finally {
|
|
43
|
+
setLoadingGroups(false);
|
|
44
|
+
}
|
|
45
|
+
}, [viewGroups]);
|
|
46
|
+
return (_jsxs(SettingsSection, { title: t('page.settings.profile.title'), colSpan: 3, children: [_jsxs(TableRow, { children: [_jsx(TableCell, { style: { whiteSpace: 'nowrap' }, children: t('page.settings.profile.table.username') }), _jsx(TableCell, { width: "100%", colSpan: 2, children: user?.username })] }), _jsx(EditRow, { titleKey: "page.settings.profile.table.name", value: user?.name, onEdit: editName }), _jsxs(TableRow, { children: [_jsx(TableCell, { style: { whiteSpace: 'nowrap' }, children: t('page.settings.profile.table.email') }), _jsx(TableCell, { width: "100%", colSpan: 2, children: user?.email })] }), viewGroups && (_jsxs(_Fragment, { children: [_jsxs(TableRow, { onClick: onViewGroups, sx: theme => ({
|
|
47
|
+
cursor: 'pointer',
|
|
48
|
+
transitionProperty: 'background-color',
|
|
49
|
+
transitionDuration: theme.transitions.duration.shortest + 'ms',
|
|
50
|
+
'&:hover': { backgroundColor: 'rgba(128, 128, 128, 0.25)' }
|
|
51
|
+
}), children: [_jsx(TableCell, { sx: { borderBottom: 0 }, style: { whiteSpace: 'nowrap' }, children: t('page.settings.profile.table.groups') }), _jsx(TableCell, { sx: { borderBottom: 0 }, align: "right", width: "100%", colSpan: 2, children: loadingGroups ? _jsx(CircularProgress, { size: 20 }) : _jsx(ChevronRight, { fontSize: "small" }) })] }), _jsx(TableRow, { children: _jsx(TableCell, { colSpan: 3, sx: { paddingTop: '0 !important' }, children: _jsx(Typography, { variant: "caption", color: "text.secondary", children: t('page.settings.profile.table.groups.description') }) }) })] })), _jsxs(TableRow, { children: [_jsx(TableCell, { style: { whiteSpace: 'nowrap' }, children: t('page.settings.profile.table.roles') }), _jsx(TableCell, { width: "100%", colSpan: 2, children: _jsx(Grid, { container: true, direction: "row", spacing: 1, children: config?.lookups?.roles?.map((r) => (_jsx(Grid, { item: true, children: _jsx(Chip, { label: r.toLocaleLowerCase(), color: user?.roles?.includes(r) ? 'primary' : 'default', icon: loading[r] ? (_jsx(CircularProgress, { size: 24 })) : addRole && !user?.roles?.includes(r) ? (_jsx(Add, {})) : user?.roles?.includes(r) ? (removeRole ? null : (_jsx(Check, {}))) : (_jsx(Clear, {})), onClick: addRole && !user?.roles?.includes(r) ? () => wrapChange(r, addRole) : null, onDelete: removeRole && user?.roles?.includes(r) ? () => wrapChange(r, removeRole) : null }) }, r))) }) })] }), howlerPluginStore.plugins.map(plugin => pluginStore.executeFunction(`${plugin}.settings`, 'profile'))] }));
|
|
52
|
+
};
|
|
53
|
+
export default ProfileSection;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { HowlerUser } from 'models/entities/HowlerUser';
|
|
2
|
+
import type { FC } from 'react';
|
|
3
|
+
declare const SecuritySection: FC<{
|
|
4
|
+
user: HowlerUser;
|
|
5
|
+
editPassword?: (password: string) => Promise<void>;
|
|
6
|
+
addApiKey?: () => void;
|
|
7
|
+
removeApiKey?: (apiKey: [string, string[], string]) => Promise<void>;
|
|
8
|
+
editQuota?: (quote?: string) => Promise<void>;
|
|
9
|
+
}>;
|
|
10
|
+
export default SecuritySection;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import AddIcon from '@mui/icons-material/Add';
|
|
3
|
+
import { Chip, Grid, IconButton, TableCell, TableRow } from '@mui/material';
|
|
4
|
+
import { ApiConfigContext } from 'components/app/providers/ApiConfigProvider';
|
|
5
|
+
import useMyLocalStorage from 'components/hooks/useMyLocalStorage';
|
|
6
|
+
import moment from 'moment';
|
|
7
|
+
import howlerPluginStore from 'plugins/store';
|
|
8
|
+
import { useContext, useMemo } from 'react';
|
|
9
|
+
import { Trans, useTranslation } from 'react-i18next';
|
|
10
|
+
import { usePluginStore } from 'react-pluggable';
|
|
11
|
+
import { StorageKey } from 'utils/constants';
|
|
12
|
+
import EditRow from '../../elements/EditRow';
|
|
13
|
+
import SettingsSection from './SettingsSection';
|
|
14
|
+
const APIKEY_LABELS = {
|
|
15
|
+
R: 'apikey.read',
|
|
16
|
+
W: 'apikey.write',
|
|
17
|
+
E: 'apikey.extended',
|
|
18
|
+
I: 'apikey.impersonate'
|
|
19
|
+
};
|
|
20
|
+
const SecuritySection = ({ user, editPassword, addApiKey, removeApiKey, editQuota }) => {
|
|
21
|
+
const { t } = useTranslation();
|
|
22
|
+
const { get } = useMyLocalStorage();
|
|
23
|
+
const { config } = useContext(ApiConfigContext);
|
|
24
|
+
const pluginStore = usePluginStore();
|
|
25
|
+
const isOAuth = useMemo(() => get(StorageKey.APP_TOKEN)?.includes('.'), [get]);
|
|
26
|
+
return (_jsxs(SettingsSection, { title: t('page.settings.security.title'), colSpan: 3, children: [!isOAuth && editPassword && (_jsx(EditRow, { titleKey: "page.settings.security.table.password", value: "\u25CF\u25CF\u25CF\u25CF\u25CF\u25CF\u25CF\u25CF\u25CF\u25CF\u25CF", onEdit: editPassword, type: "password" })), config?.configuration.auth.allow_apikeys && (_jsxs(TableRow, { sx: { cursor: 'pointer' }, children: [_jsx(TableCell, { style: { whiteSpace: 'nowrap' }, children: t('page.settings.security.table.apikeys') }), _jsx(TableCell, { width: "100%", children: _jsxs(Grid, { container: true, spacing: 1, children: [user?.apikeys?.map(apiKey => (_jsx(Grid, { item: true, children: _jsx(Chip, { label: apiKey[0].toLocaleLowerCase() +
|
|
27
|
+
(apiKey[1].length > 0
|
|
28
|
+
? ` (${apiKey[1].map(permission => t(APIKEY_LABELS[permission])).join(', ')})`
|
|
29
|
+
: ''), style: { backgroundColor: moment.utc(apiKey[2]).isBefore(moment().utc()) ? 'orange' : 'default' }, onDelete: removeApiKey ? () => removeApiKey(apiKey) : null }) }, apiKey[0]))), user?.apikeys?.length < 1 && (_jsx(Grid, { item: true, children: _jsx(Trans, { i18nKey: "none" }) }))] }) }), _jsx(TableCell, { align: "right", children: addApiKey && (_jsx(IconButton, { onClick: addApiKey, children: _jsx(AddIcon, { fontSize: "small" }) })) })] })), _jsx(EditRow, { titleKey: "page.settings.security.table.apiquota", descriptionKey: "page.settings.security.table.apiquota.description", value: user?.api_quota, validate: value => value && /^[0-9]*$/m.test(value.toString()), type: "number", onEdit: editQuota }), howlerPluginStore.plugins.map(plugin => pluginStore.executeFunction(`${plugin}.settings`, 'security'))] }));
|
|
30
|
+
};
|
|
31
|
+
export default SecuritySection;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useAppUser } from 'commons/components/app/hooks';
|
|
3
|
+
import UserPageWrapper from 'components/elements/display/UserPageWrapper';
|
|
4
|
+
import useMyLocalStorage from 'components/hooks/useMyLocalStorage';
|
|
5
|
+
import useMyUserFunctions from 'components/hooks/useMyUserFunctions';
|
|
6
|
+
import { useCallback, useMemo } from 'react';
|
|
7
|
+
import { StorageKey } from 'utils/constants';
|
|
8
|
+
import AdminSection from './AdminSection';
|
|
9
|
+
import LocalSection from './LocalSection';
|
|
10
|
+
import ProfileSection from './ProfileSection';
|
|
11
|
+
import SecuritySection from './SecuritySection';
|
|
12
|
+
const Settings = () => {
|
|
13
|
+
const { user: currentUser, setUser } = useAppUser();
|
|
14
|
+
const { editName, editPassword, editQuota, addApiKey, removeApiKey, addRole, removeRole, viewGroups } = useMyUserFunctions();
|
|
15
|
+
const { get } = useMyLocalStorage();
|
|
16
|
+
const isOAuth = useMemo(() => get(StorageKey.APP_TOKEN)?.includes('.'), [get]);
|
|
17
|
+
const currentUserWrapper = useCallback((fn) => {
|
|
18
|
+
return async (value) => setUser(await fn(currentUser, value));
|
|
19
|
+
}, [currentUser, setUser]);
|
|
20
|
+
return (_jsxs(UserPageWrapper, { user: currentUser, children: [_jsx(ProfileSection, { user: currentUser, editName: !isOAuth && currentUserWrapper(editName), addRole: currentUser.is_admin && !isOAuth && currentUserWrapper(addRole), removeRole: currentUser.is_admin && !isOAuth && currentUserWrapper(removeRole), viewGroups: viewGroups }), _jsx(SecuritySection, { user: currentUser, editPassword: editPassword, addApiKey: addApiKey, removeApiKey: currentUserWrapper(removeApiKey), editQuota: currentUser.is_admin && currentUserWrapper(editQuota) }), _jsx(LocalSection, {}), currentUser.roles.includes('admin') && _jsx(AdminSection, {})] }));
|
|
21
|
+
};
|
|
22
|
+
export default Settings;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Paper, Table, TableBody, TableCell, TableContainer, TableHead, TableRow, Typography } from '@mui/material';
|
|
3
|
+
const SettingsSection = ({ title, colSpan, children }) => {
|
|
4
|
+
return (_jsx(TableContainer, { sx: {
|
|
5
|
+
'& table tr:last-child td': {
|
|
6
|
+
borderBottom: 0
|
|
7
|
+
}
|
|
8
|
+
}, component: Paper, children: _jsxs(Table, { "aria-label": title, children: [_jsx(TableHead, { children: _jsx(TableRow, { children: _jsx(TableCell, { colSpan: colSpan, children: _jsx(Typography, { variant: "h6", children: title }) }) }) }), _jsx(TableBody, { children: children })] }) }));
|
|
9
|
+
};
|
|
10
|
+
export default SettingsSection;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Language, Lock, Person } from '@mui/icons-material';
|
|
3
|
+
import { Card, Divider, Stack, Tooltip, Typography } from '@mui/material';
|
|
4
|
+
import { useTranslation } from 'react-i18next';
|
|
5
|
+
const TemplateCard = ({ template, className }) => {
|
|
6
|
+
const { t } = useTranslation();
|
|
7
|
+
return (_jsx(Card, { variant: "outlined", sx: { p: 1, mb: 1 }, className: className, children: _jsxs(Stack, { direction: "row", spacing: 1, children: [_jsx(Tooltip, { title: t(`route.templates.manager.${template.type}`), children: {
|
|
8
|
+
readonly: _jsx(Lock, {}),
|
|
9
|
+
global: _jsx(Language, {}),
|
|
10
|
+
personal: _jsx(Person, {})
|
|
11
|
+
}[template.type] }), _jsx(Divider, { orientation: "vertical", flexItem: true }), _jsxs(Stack, { children: [_jsxs(Typography, { variant: "body1", children: [t(template.analytic), " - ", t(template.detection ?? 'all')] }), template.keys.map(key => (_jsx(Typography, { variant: "caption", sx: { ml: 1 }, children: _jsx("code", { children: key }) }, template.template_id + key)))] })] }) }, template.template_id));
|
|
12
|
+
};
|
|
13
|
+
export default TemplateCard;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useSortable } from '@dnd-kit/sortable';
|
|
3
|
+
import { CSS } from '@dnd-kit/utilities';
|
|
4
|
+
import { Delete, DragHandle } from '@mui/icons-material';
|
|
5
|
+
import { IconButton, Stack, Tooltip, Typography } from '@mui/material';
|
|
6
|
+
import { useTranslation } from 'react-i18next';
|
|
7
|
+
const TemplateDnD = ({ field, data, onRemove, tooltipTitle }) => {
|
|
8
|
+
const { t } = useTranslation();
|
|
9
|
+
const { attributes, listeners, setNodeRef, transform, transition } = useSortable({ id: field });
|
|
10
|
+
return (_jsxs(Stack, { direction: "row", spacing: 1, ref: setNodeRef, style: { transition, transform: CSS.Transform.toString(transform) }, children: [_jsx(Tooltip, { title: t('button.drag'), ...attributes, ...listeners, children: _jsx(IconButton, { size: "medium", onClick: () => onRemove(field), children: _jsx(DragHandle, { fontSize: "medium" }) }) }), _jsx(Tooltip, { title: tooltipTitle, sx: { alignContent: 'center' }, children: _jsxs(Typography, { variant: "body1", fontWeight: "bold", children: [field, ":"] }) }), _jsx(Typography, { variant: "body1", whiteSpace: "normal", sx: { width: '100%', wordBreak: 'break-all', alignContent: 'center' }, children: data }), _jsx(Tooltip, { title: t('button.delete'), children: _jsx(IconButton, { size: "medium", onClick: () => onRemove(field), sx: { marginLeft: 'auto' }, children: _jsx(Delete, { fontSize: "medium" }) }) })] }));
|
|
11
|
+
};
|
|
12
|
+
export default TemplateDnD;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { type Hit } from 'models/entities/generated/Hit';
|
|
2
|
+
declare const _default: import("react").MemoExoticComponent<({ hit, fields, setFields, onRemove, onAdd }: {
|
|
3
|
+
hit: Hit;
|
|
4
|
+
fields: string[];
|
|
5
|
+
setFields: (displayFields: string[]) => void;
|
|
6
|
+
onRemove: (field: string) => void;
|
|
7
|
+
onAdd: (field: string) => void;
|
|
8
|
+
}) => import("react/jsx-runtime").JSX.Element>;
|
|
9
|
+
export default _default;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { closestCorners, DndContext } from '@dnd-kit/core';
|
|
3
|
+
import { arrayMove, SortableContext } from '@dnd-kit/sortable';
|
|
4
|
+
import { Add } from '@mui/icons-material';
|
|
5
|
+
import { Button, Stack, Typography } from '@mui/material';
|
|
6
|
+
import { ApiConfigContext } from 'components/app/providers/ApiConfigProvider';
|
|
7
|
+
import { FieldContext } from 'components/app/providers/FieldProvider';
|
|
8
|
+
import Phrase from 'components/elements/addons/search/phrase/Phrase';
|
|
9
|
+
import { get, isObject } from 'lodash-es';
|
|
10
|
+
import {} from 'models/entities/generated/Hit';
|
|
11
|
+
import { memo, useCallback, useContext, useEffect, useState } from 'react';
|
|
12
|
+
import { useTranslation } from 'react-i18next';
|
|
13
|
+
import TemplateDnD from './TemplateDnD';
|
|
14
|
+
const TemplateEditor = ({ hit, fields, setFields, onRemove, onAdd }) => {
|
|
15
|
+
const { t } = useTranslation();
|
|
16
|
+
const { config } = useContext(ApiConfigContext);
|
|
17
|
+
const { getHitFields } = useContext(FieldContext);
|
|
18
|
+
const [phrase, setPhrase] = useState('');
|
|
19
|
+
const [suggestions, setSuggestions] = useState([]);
|
|
20
|
+
const tryAddField = useCallback(() => {
|
|
21
|
+
if (suggestions.includes(phrase)) {
|
|
22
|
+
if (!fields.includes(phrase)) {
|
|
23
|
+
onAdd(phrase);
|
|
24
|
+
setPhrase('');
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}, [fields, onAdd, phrase, suggestions]);
|
|
28
|
+
const checkForActions = useCallback((e) => {
|
|
29
|
+
if (e.isEnter) {
|
|
30
|
+
tryAddField();
|
|
31
|
+
}
|
|
32
|
+
}, [tryAddField]);
|
|
33
|
+
useEffect(() => {
|
|
34
|
+
getHitFields().then(suggestionFields => setSuggestions(suggestionFields.map(f => f.key)));
|
|
35
|
+
}, [getHitFields]);
|
|
36
|
+
const handleDragEnd = useCallback((event) => {
|
|
37
|
+
const { active, over } = event;
|
|
38
|
+
if (active.id !== over.id) {
|
|
39
|
+
const oldIndex = (fields ?? []).findIndex(entry => entry === active.id);
|
|
40
|
+
const newIndex = (fields ?? []).findIndex(entry => entry === over.id);
|
|
41
|
+
setFields(arrayMove(fields, oldIndex, newIndex));
|
|
42
|
+
}
|
|
43
|
+
}, [fields, setFields]);
|
|
44
|
+
return (_jsxs(Stack, { spacing: 1, width: "100%", alignItems: "stretch", children: [_jsx(DndContext, { collisionDetection: closestCorners, onDragEnd: handleDragEnd, children: _jsx(SortableContext, { items: (fields ?? []).map(entry => entry), children: fields.map(field => {
|
|
45
|
+
let data = get(hit, field);
|
|
46
|
+
if (!data) {
|
|
47
|
+
data = 'N/A';
|
|
48
|
+
}
|
|
49
|
+
else if (isObject(data)) {
|
|
50
|
+
data = JSON.stringify(data);
|
|
51
|
+
}
|
|
52
|
+
return (_jsx(TemplateDnD, { field: field, data: data, onRemove: onRemove, tooltipTitle: (config.indexes.hit[field].description ?? t('none')).split('\n')[0] }, field));
|
|
53
|
+
}) }) }), _jsxs(Stack, { direction: "row", sx: { '& > div': { flex: 1 } }, spacing: 1, children: [_jsx(Phrase, { suggestions: suggestions, value: phrase, onChange: setPhrase, onKeyDown: checkForActions, size: "small" }), _jsx(Button, { variant: "outlined", size: "small", sx: { marginLeft: 'auto' }, startIcon: _jsx(Add, { fontSize: "small" }), disabled: !suggestions.includes(phrase) || fields.includes(phrase), onClick: tryAddField, children: t('button.add') })] }), _jsx(Typography, { variant: "caption", color: "text.secondary", children: t('route.templates.prompt') })] }));
|
|
54
|
+
};
|
|
55
|
+
export default memo(TemplateEditor);
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Autocomplete, Button, CircularProgress, Divider, FormControl, LinearProgress, Stack, TextField, ToggleButton, ToggleButtonGroup, Tooltip } from '@mui/material';
|
|
3
|
+
import api from 'api';
|
|
4
|
+
import PageCenter from 'commons/components/pages/PageCenter';
|
|
5
|
+
import TemplateEditor from 'components/routes/templates/TemplateEditor';
|
|
6
|
+
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
7
|
+
import { useTranslation } from 'react-i18next';
|
|
8
|
+
import { Check, Delete, Remove, SsidChart } from '@mui/icons-material';
|
|
9
|
+
import AppInfoPanel from 'commons/components/display/AppInfoPanel';
|
|
10
|
+
import { TemplateContext } from 'components/app/providers/TemplateProvider';
|
|
11
|
+
import { HitLayout } from 'components/elements/hit/HitLayout';
|
|
12
|
+
import HitOutline, { DEFAULT_FIELDS } from 'components/elements/hit/HitOutline';
|
|
13
|
+
import useMyApi from 'components/hooks/useMyApi';
|
|
14
|
+
import isEqual from 'lodash-es/isEqual';
|
|
15
|
+
import { useSearchParams } from 'react-router-dom';
|
|
16
|
+
import { useContextSelector } from 'use-context-selector';
|
|
17
|
+
import hitsData from 'utils/hit.json';
|
|
18
|
+
import { sanitizeLuceneQuery } from 'utils/stringUtils';
|
|
19
|
+
const CUSTOM_OUTLINES = ['cmt.aws.sigma.rules', 'assemblyline', '6tailphish'];
|
|
20
|
+
const TemplateViewer = () => {
|
|
21
|
+
const { t } = useTranslation();
|
|
22
|
+
const [params, setParams] = useSearchParams();
|
|
23
|
+
const getTemplates = useContextSelector(TemplateContext, ctx => ctx.getTemplates);
|
|
24
|
+
const { dispatchApi } = useMyApi();
|
|
25
|
+
const [templateList, setTemplateList] = useState([]);
|
|
26
|
+
const [selectedTemplate, setSelectedTemplate] = useState(null);
|
|
27
|
+
const [displayFields, setDisplayFields] = useState([]);
|
|
28
|
+
const [analytics, setAnalytics] = useState([]);
|
|
29
|
+
const [detections, setDetections] = useState([]);
|
|
30
|
+
const [analytic, setAnalytic] = useState(params.get('analytic') ?? '');
|
|
31
|
+
const [detection, setDetection] = useState(params.get('detection') ?? 'ANY');
|
|
32
|
+
const [type, setType] = useState((params.get('type') ?? 'personal').replace('readonly', 'global'));
|
|
33
|
+
const [loading, setLoading] = useState(false);
|
|
34
|
+
const [templateLoading, setTemplateLoading] = useState(false);
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
setLoading(true);
|
|
37
|
+
dispatchApi(api.search.analytic.post({ query: 'analytic_id:*', rows: 1000 }), {
|
|
38
|
+
logError: false,
|
|
39
|
+
showError: true,
|
|
40
|
+
throwError: true
|
|
41
|
+
})
|
|
42
|
+
.finally(() => setLoading(false))
|
|
43
|
+
.then(result => result.items)
|
|
44
|
+
.then(_analytics => {
|
|
45
|
+
if (!_analytics.some(_analytic => _analytic.name.toLowerCase() === analytic.toLowerCase())) {
|
|
46
|
+
setAnalytic('');
|
|
47
|
+
}
|
|
48
|
+
setAnalytics(_analytics);
|
|
49
|
+
});
|
|
50
|
+
getTemplates(true).then(setTemplateList);
|
|
51
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
52
|
+
}, [analytic, dispatchApi]);
|
|
53
|
+
useEffect(() => {
|
|
54
|
+
if (analytic) {
|
|
55
|
+
setLoading(true);
|
|
56
|
+
dispatchApi(api.search.grouped.hit.post('howler.detection', {
|
|
57
|
+
limit: 0,
|
|
58
|
+
query: `howler.analytic:"${sanitizeLuceneQuery(analytic)}"`
|
|
59
|
+
}), {
|
|
60
|
+
logError: false,
|
|
61
|
+
showError: true,
|
|
62
|
+
throwError: true
|
|
63
|
+
})
|
|
64
|
+
.finally(() => setLoading(false))
|
|
65
|
+
.then(result => result.items.map(i => i.value))
|
|
66
|
+
.then(_detections => {
|
|
67
|
+
if (_detections.length < 1 || (type === 'global' && CUSTOM_OUTLINES.includes(analytic.toLowerCase()))) {
|
|
68
|
+
setDetection('ANY');
|
|
69
|
+
}
|
|
70
|
+
if (detection && !_detections.includes(detection)) {
|
|
71
|
+
setDetection('ANY');
|
|
72
|
+
}
|
|
73
|
+
setDetections(_detections);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
}, [analytic, detection, dispatchApi, params, setParams, type]);
|
|
77
|
+
useEffect(() => {
|
|
78
|
+
if (analytic && detection) {
|
|
79
|
+
const template = (templateList ?? []).find(_template => _template.analytic === analytic &&
|
|
80
|
+
((detection === 'ANY' && !_template.detection) || _template.detection === detection) &&
|
|
81
|
+
_template.type === type);
|
|
82
|
+
if (template) {
|
|
83
|
+
setSelectedTemplate(template);
|
|
84
|
+
setDisplayFields(template.keys);
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
setSelectedTemplate(null);
|
|
88
|
+
setDisplayFields(DEFAULT_FIELDS);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}, [analytic, detection, templateList, type]);
|
|
92
|
+
useEffect(() => {
|
|
93
|
+
if (analytic) {
|
|
94
|
+
params.set('analytic', analytic);
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
params.delete('analytic');
|
|
98
|
+
}
|
|
99
|
+
if (detection && detection !== 'ANY') {
|
|
100
|
+
params.set('detection', detection);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
params.delete('detection');
|
|
104
|
+
}
|
|
105
|
+
params.set('type', type);
|
|
106
|
+
params.sort();
|
|
107
|
+
setParams(params, {
|
|
108
|
+
replace: true
|
|
109
|
+
});
|
|
110
|
+
}, [analytic, detection, params, setParams, type]);
|
|
111
|
+
const exampleHit = useMemo(() => {
|
|
112
|
+
const _hit = hitsData.GET[Object.keys(hitsData.GET)[0]];
|
|
113
|
+
if (analytic) {
|
|
114
|
+
_hit.howler.analytic = analytic;
|
|
115
|
+
}
|
|
116
|
+
return { ..._hit };
|
|
117
|
+
}, [analytic]);
|
|
118
|
+
const onDelete = useCallback(async () => {
|
|
119
|
+
await dispatchApi(api.template.del(selectedTemplate.template_id), {
|
|
120
|
+
logError: false,
|
|
121
|
+
showError: true,
|
|
122
|
+
throwError: false
|
|
123
|
+
});
|
|
124
|
+
setSelectedTemplate(null);
|
|
125
|
+
setDisplayFields(DEFAULT_FIELDS);
|
|
126
|
+
}, [dispatchApi, selectedTemplate?.template_id]);
|
|
127
|
+
const onSave = useCallback(async () => {
|
|
128
|
+
if (analytic && detection) {
|
|
129
|
+
try {
|
|
130
|
+
setTemplateLoading(true);
|
|
131
|
+
const result = await dispatchApi(selectedTemplate
|
|
132
|
+
? api.template.put(selectedTemplate.template_id, displayFields)
|
|
133
|
+
: api.template.post({
|
|
134
|
+
analytic,
|
|
135
|
+
detection: detection !== 'ANY' ? detection : null,
|
|
136
|
+
type,
|
|
137
|
+
keys: displayFields
|
|
138
|
+
}), {
|
|
139
|
+
logError: false,
|
|
140
|
+
showError: true,
|
|
141
|
+
throwError: true
|
|
142
|
+
});
|
|
143
|
+
setSelectedTemplate(result);
|
|
144
|
+
const newList = [result, ...templateList];
|
|
145
|
+
setTemplateList(newList.filter((v1, i) => newList.findIndex(v2 => v1.template_id === v2.template_id) === i));
|
|
146
|
+
}
|
|
147
|
+
finally {
|
|
148
|
+
setTemplateLoading(false);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}, [analytic, detection, dispatchApi, displayFields, selectedTemplate, templateList, type]);
|
|
152
|
+
const isCustomOutline = useMemo(() => CUSTOM_OUTLINES.includes(analytic.toLowerCase()), [analytic]);
|
|
153
|
+
const analyticOrDetectionMissing = useMemo(() => !analytic || !detection, [analytic, detection]);
|
|
154
|
+
const noFieldChange = useMemo(() => displayFields.length < 1 || isEqual(selectedTemplate?.keys ?? DEFAULT_FIELDS, displayFields), [displayFields, selectedTemplate?.keys]);
|
|
155
|
+
return (_jsxs(PageCenter, { maxWidth: "1500px", textAlign: "left", height: "100%", children: [_jsx(LinearProgress, { sx: { mb: 1, opacity: +loading } }), _jsxs(Stack, { direction: "column", spacing: 2, divider: _jsx(Divider, { orientation: "horizontal", flexItem: true }), height: "100%", children: [_jsxs(Stack, { direction: "row", spacing: 2, mb: 2, alignItems: "stretch", children: [_jsx(FormControl, { sx: { flex: 1, maxWidth: '450px' }, children: _jsx(Autocomplete, { id: "analytic", options: analytics.sort((a, b) => a.name.toLowerCase().localeCompare(b.name.toLowerCase())), getOptionLabel: option => option.name, value: analytics.find(a => a.name === analytic) || null, onChange: (__, newValue) => setAnalytic(newValue ? newValue.name : ''), renderInput: autocompleteAnalyticParams => (_jsx(TextField, { ...autocompleteAnalyticParams, label: t('route.templates.analytic'), size: "small" })) }) }), !(detections?.length < 2 && detections[0]?.toLowerCase() === 'rule') ? (_jsx(FormControl, { sx: { flex: 1, maxWidth: '300px' }, disabled: !analytic || (isCustomOutline && type === 'global'), children: _jsx(Autocomplete, { id: "detection", options: ['ANY', ...detections.sort()], getOptionLabel: option => option, value: isCustomOutline && type === 'global' ? 'any' : (detection ?? ''), onChange: (__, newValue) => setDetection(newValue), renderInput: autocompleteDetectionParams => (_jsx(TextField, { ...autocompleteDetectionParams, label: t('route.templates.detection'), size: "small" })) }) })) : (_jsx(Tooltip, { title: t('route.templates.rule.explanation'), children: _jsx(SsidChart, { color: "info", sx: { alignSelf: 'center' } }) })), _jsxs(ToggleButtonGroup, { sx: { display: 'grid', gridTemplateColumns: '1fr 1fr' }, size: "small", exclusive: true, value: type, disabled: analyticOrDetectionMissing, onChange: (__, _type) => {
|
|
156
|
+
if (_type) {
|
|
157
|
+
setType(_type);
|
|
158
|
+
}
|
|
159
|
+
}, children: [_jsx(ToggleButton, { sx: { flex: 1 }, value: "personal", "aria-label": "personal", children: t('route.templates.personal') }), _jsx(ToggleButton, { sx: { flex: 1 }, value: "global", "aria-label": "global", children: t('route.templates.global') })] }), selectedTemplate && (_jsx(Button, { variant: "outlined", startIcon: _jsx(Delete, {}), onClick: onDelete, children: t('button.delete') })), _jsx(Button, { variant: "outlined", disabled: analyticOrDetectionMissing || (isCustomOutline && type === 'global') || noFieldChange, startIcon: templateLoading ? (_jsx(CircularProgress, { size: 16 })) : isCustomOutline && type === 'global' ? (_jsx(Remove, {})) : (_jsx(Check, {})), onClick: onSave, children: t(isCustomOutline && type === 'global'
|
|
160
|
+
? 'button.readonly'
|
|
161
|
+
: !analyticOrDetectionMissing && !noFieldChange
|
|
162
|
+
? 'button.save'
|
|
163
|
+
: 'button.saved') })] }), isCustomOutline && type === 'global' ? (_jsx(HitOutline, { hit: exampleHit, layout: HitLayout.COMFY, type: "global" })) : analyticOrDetectionMissing ? (_jsx(AppInfoPanel, { i18nKey: "route.templates.select", sx: { width: '100%', alignSelf: 'start' } })) : (_jsx(TemplateEditor, { hit: exampleHit, fields: displayFields, setFields: setDisplayFields, onAdd: field => setDisplayFields([...displayFields, field]), onRemove: field => setDisplayFields(displayFields.filter(f => f !== field)) }))] })] }));
|
|
164
|
+
};
|
|
165
|
+
export default TemplateViewer;
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Article, KeyboardArrowDown } from '@mui/icons-material';
|
|
3
|
+
import { Box, Card, Collapse, IconButton, Stack, ToggleButton, ToggleButtonGroup, Tooltip, Typography } from '@mui/material';
|
|
4
|
+
import api from 'api';
|
|
5
|
+
import { useAppUser } from 'commons/components/app/hooks';
|
|
6
|
+
import { TemplateContext } from 'components/app/providers/TemplateProvider';
|
|
7
|
+
import { TuiListProvider } from 'components/elements/addons/lists';
|
|
8
|
+
import { TuiListMethodContext } from 'components/elements/addons/lists/TuiListProvider';
|
|
9
|
+
import ItemManager from 'components/elements/display/ItemManager';
|
|
10
|
+
import useMyApi from 'components/hooks/useMyApi';
|
|
11
|
+
import { useMyLocalStorageItem } from 'components/hooks/useMyLocalStorage';
|
|
12
|
+
import { useCallback, useContext, useEffect, useMemo, useState } from 'react';
|
|
13
|
+
import { useTranslation } from 'react-i18next';
|
|
14
|
+
import { useNavigate, useSearchParams } from 'react-router-dom';
|
|
15
|
+
import { useContextSelector } from 'use-context-selector';
|
|
16
|
+
import { StorageKey } from 'utils/constants';
|
|
17
|
+
import TemplateCard from './TemplateCard';
|
|
18
|
+
const TemplatesBase = () => {
|
|
19
|
+
const { t } = useTranslation();
|
|
20
|
+
const { user } = useAppUser();
|
|
21
|
+
const navigate = useNavigate();
|
|
22
|
+
const { dispatchApi } = useMyApi();
|
|
23
|
+
const [searchParams, setSearchParams] = useSearchParams();
|
|
24
|
+
const { load } = useContext(TuiListMethodContext);
|
|
25
|
+
const templates = useContextSelector(TemplateContext, ctx => ctx.templates);
|
|
26
|
+
const pageCount = useMyLocalStorageItem(StorageKey.PAGE_COUNT, 25)[0];
|
|
27
|
+
const [phrase, setPhrase] = useState('');
|
|
28
|
+
const [offset, setOffset] = useState(parseInt(searchParams.get('offset')) || 0);
|
|
29
|
+
const [showBuiltins, setShowBuiltins] = useState(true);
|
|
30
|
+
const [response, setResponse] = useState(null);
|
|
31
|
+
const [types, setTypes] = useState([]);
|
|
32
|
+
const [hasError, setHasError] = useState(false);
|
|
33
|
+
const [searching, setSearching] = useState(false);
|
|
34
|
+
const onSearch = useCallback(async () => {
|
|
35
|
+
try {
|
|
36
|
+
setSearching(true);
|
|
37
|
+
setHasError(false);
|
|
38
|
+
if (phrase) {
|
|
39
|
+
searchParams.set('phrase', phrase);
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
searchParams.delete('phrase');
|
|
43
|
+
}
|
|
44
|
+
setSearchParams(searchParams, { replace: true });
|
|
45
|
+
// Check for the actual search query
|
|
46
|
+
const phraseQuery = phrase ? `*:*${phrase}*` : '*:*';
|
|
47
|
+
// Ensure the template should be visible and/or matches the type we are filtering for
|
|
48
|
+
const typeQuery = `(type:global OR owner:(${user.username} OR none)) AND type:(${types.join(' ') || '*'})`;
|
|
49
|
+
setResponse(await dispatchApi(api.search.template.post({
|
|
50
|
+
query: `${phraseQuery} AND ${typeQuery}`,
|
|
51
|
+
rows: pageCount,
|
|
52
|
+
offset
|
|
53
|
+
})));
|
|
54
|
+
}
|
|
55
|
+
catch (e) {
|
|
56
|
+
setHasError(true);
|
|
57
|
+
}
|
|
58
|
+
finally {
|
|
59
|
+
setSearching(false);
|
|
60
|
+
}
|
|
61
|
+
}, [phrase, setSearchParams, searchParams, user.username, types, dispatchApi, pageCount, offset]);
|
|
62
|
+
// Load the items into list when response changes.
|
|
63
|
+
// This hook should only trigger when the 'response' changes.
|
|
64
|
+
useEffect(() => {
|
|
65
|
+
if (response) {
|
|
66
|
+
load(response.items.map((item) => ({
|
|
67
|
+
id: item.template_id,
|
|
68
|
+
item,
|
|
69
|
+
selected: false,
|
|
70
|
+
cursor: false
|
|
71
|
+
})));
|
|
72
|
+
}
|
|
73
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
74
|
+
}, [response, load]);
|
|
75
|
+
const onPageChange = useCallback((_offset) => {
|
|
76
|
+
if (_offset !== offset) {
|
|
77
|
+
searchParams.set('offset', _offset.toString());
|
|
78
|
+
setSearchParams(searchParams, { replace: true });
|
|
79
|
+
setOffset(_offset);
|
|
80
|
+
}
|
|
81
|
+
}, [offset, searchParams, setSearchParams]);
|
|
82
|
+
useEffect(() => {
|
|
83
|
+
onSearch();
|
|
84
|
+
if (!searchParams.has('offset')) {
|
|
85
|
+
searchParams.set('offset', '0');
|
|
86
|
+
setSearchParams(searchParams, { replace: true });
|
|
87
|
+
}
|
|
88
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
89
|
+
}, [dispatchApi, types]);
|
|
90
|
+
useEffect(() => {
|
|
91
|
+
if (response?.total <= offset) {
|
|
92
|
+
setOffset(0);
|
|
93
|
+
searchParams.set('offset', '0');
|
|
94
|
+
setSearchParams(searchParams, { replace: true });
|
|
95
|
+
}
|
|
96
|
+
}, [offset, response?.total, searchParams, setSearchParams]);
|
|
97
|
+
useEffect(() => {
|
|
98
|
+
if (!searching) {
|
|
99
|
+
onSearch();
|
|
100
|
+
}
|
|
101
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
102
|
+
}, [offset]);
|
|
103
|
+
const builtInTemplates = useMemo(() => templates.filter(template => template.type === 'readonly'), [templates]);
|
|
104
|
+
const renderer = useCallback((item, className) => _jsx(TemplateCard, { template: item, className: className }), []);
|
|
105
|
+
return (_jsx(ItemManager, { onSearch: onSearch, onPageChange: onPageChange, phrase: phrase, setPhrase: setPhrase, hasError: hasError, searching: searching, searchFilters: _jsx(Stack, { direction: "row", spacing: 1, alignItems: "center", children: _jsxs(ToggleButtonGroup, { sx: { display: 'grid', gridTemplateColumns: '1fr 1fr', alignSelf: 'start' }, size: "small", value: types, onChange: (__, _types) => {
|
|
106
|
+
if (_types) {
|
|
107
|
+
setTypes(_types.length < 2 ? _types : []);
|
|
108
|
+
}
|
|
109
|
+
}, children: [_jsx(ToggleButton, { value: "personal", "aria-label": "personal", children: t('route.templates.manager.personal') }), _jsx(ToggleButton, { value: "global", "aria-label": "global", children: t('route.templates.manager.global') })] }) }), aboveSearch: _jsx(Typography, { sx: theme => ({ fontStyle: 'italic', color: theme.palette.text.disabled, mb: 0.5 }), variant: "body2", children: t('route.templates.search.prompt') }), belowSearch: types.length !== 1 &&
|
|
110
|
+
offset < 1 &&
|
|
111
|
+
builtInTemplates.length > 0 && (_jsx(Card, { sx: { p: 1, mb: 1 }, children: _jsxs(Stack, { children: [_jsxs(Stack, { direction: "row", alignItems: "center", spacing: 1, children: [_jsx(Typography, { children: t('route.templates.builtin.show') }), _jsx(Tooltip, { title: t(`route.templates.builtin.${showBuiltins ? 'hide' : 'show'}`), children: _jsx(IconButton, { size: "small", onClick: () => setShowBuiltins(!showBuiltins), children: _jsx(KeyboardArrowDown, { fontSize: "small", sx: { transition: 'rotate 250ms', rotate: showBuiltins ? '180deg' : '0deg' } }) }) })] }), _jsxs(Collapse, { in: showBuiltins, children: [_jsx(Box, { sx: { mt: 1 } }), builtInTemplates.map(template => renderer(template))] })] }) })), renderer: ({ item }, classRenderer) => renderer(item.item, classRenderer()), response: response, onSelect: (item) => navigate(`/templates/view?type=${item.item.type}&analytic=${item.item.analytic}${item.item.detection ? '&detection=' + item.item.detection : ''}`), onCreate: () => navigate('/templates/view'), createPrompt: "route.templates.create", searchPrompt: "route.templates.manager.search", createIcon: _jsx(Article, { sx: { mr: 1 } }) }));
|
|
112
|
+
};
|
|
113
|
+
const Templates = () => {
|
|
114
|
+
return (_jsx(TuiListProvider, { children: _jsx(TemplatesBase, {}) }));
|
|
115
|
+
};
|
|
116
|
+
export default Templates;
|