@allurereport/web-allure2 3.0.0-beta.9
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/.babelrc.cjs +18 -0
- package/.eslintrc.cjs +125 -0
- package/README.md +27 -0
- package/dist/multi/154.app-9ac9d027.js +1 -0
- package/dist/multi/216.app-9ac9d027.js +1 -0
- package/dist/multi/232.app-9ac9d027.js +1 -0
- package/dist/multi/250.app-9ac9d027.js +1 -0
- package/dist/multi/256.app-9ac9d027.js +1 -0
- package/dist/multi/301.app-9ac9d027.js +1 -0
- package/dist/multi/323.app-9ac9d027.js +1 -0
- package/dist/multi/353.app-9ac9d027.js +1 -0
- package/dist/multi/411d15fc5bb62472eea6ead4fb276ca9.ico +0 -0
- package/dist/multi/564.app-9ac9d027.js +1 -0
- package/dist/multi/594.app-9ac9d027.js +1 -0
- package/dist/multi/623.app-9ac9d027.js +1 -0
- package/dist/multi/7.app-9ac9d027.js +1 -0
- package/dist/multi/729.app-9ac9d027.js +1 -0
- package/dist/multi/783.app-9ac9d027.js +1 -0
- package/dist/multi/826.app-9ac9d027.js +1 -0
- package/dist/multi/925.app-9ac9d027.js +1 -0
- package/dist/multi/app-9ac9d027.js +2 -0
- package/dist/multi/app-9ac9d027.js.LICENSE.txt +29 -0
- package/dist/multi/checkmark-c1a9ce12.svg +8 -0
- package/dist/multi/manifest.json +27 -0
- package/dist/multi/sort-down-icon-41195b0d.svg +8 -0
- package/dist/multi/sort-icon-fddc6c81.svg +8 -0
- package/dist/multi/sort-up-icon-d5bc65f6.svg +8 -0
- package/dist/multi/sprite.svg +4 -0
- package/dist/multi/styles-9ac9d027.css +558 -0
- package/dist/multi/vertical-5e6d1df4.png +0 -0
- package/dist/single/411d15fc5bb62472eea6ead4fb276ca9.ico +0 -0
- package/dist/single/app-f726ff87.js +2 -0
- package/dist/single/app-f726ff87.js.LICENSE.txt +29 -0
- package/dist/single/checkmark-c1a9ce12.svg +8 -0
- package/dist/single/manifest.json +10 -0
- package/dist/single/sort-down-icon-41195b0d.svg +8 -0
- package/dist/single/sort-icon-fddc6c81.svg +8 -0
- package/dist/single/sort-up-icon-d5bc65f6.svg +8 -0
- package/dist/single/sprite.svg +4 -0
- package/dist/single/styles-f726ff87.css +558 -0
- package/package.json +107 -0
- package/src/app.js +69 -0
- package/src/assets/icons/allure-logo.svg +45 -0
- package/src/assets/icons/bamboo.svg +31 -0
- package/src/assets/icons/bitbucket.svg +10 -0
- package/src/assets/icons/bomb.svg +7 -0
- package/src/assets/icons/broken.svg +10 -0
- package/src/assets/icons/bug.svg +10 -0
- package/src/assets/icons/chevron-down.svg +10 -0
- package/src/assets/icons/chevron-left.svg +10 -0
- package/src/assets/icons/chevron-right-fat.svg +10 -0
- package/src/assets/icons/chevron-right.svg +10 -0
- package/src/assets/icons/chevron-up.svg +10 -0
- package/src/assets/icons/circleci.svg +1 -0
- package/src/assets/icons/close.svg +10 -0
- package/src/assets/icons/collapse.svg +5 -0
- package/src/assets/icons/compare.svg +10 -0
- package/src/assets/icons/copy.svg +11 -0
- package/src/assets/icons/csv.svg +13 -0
- package/src/assets/icons/download.svg +11 -0
- package/src/assets/icons/draggable.svg +15 -0
- package/src/assets/icons/expand.svg +5 -0
- package/src/assets/icons/failed.svg +10 -0
- package/src/assets/icons/file.svg +3 -0
- package/src/assets/icons/folder.svg +10 -0
- package/src/assets/icons/github.svg +4 -0
- package/src/assets/icons/gitlab.svg +12 -0
- package/src/assets/icons/graphs.svg +11 -0
- package/src/assets/icons/history.svg +11 -0
- package/src/assets/icons/image.svg +3 -0
- package/src/assets/icons/info.svg +12 -0
- package/src/assets/icons/jenkins.svg +327 -0
- package/src/assets/icons/jobs.svg +12 -0
- package/src/assets/icons/link.svg +11 -0
- package/src/assets/icons/list.svg +13 -0
- package/src/assets/icons/maximize.svg +11 -0
- package/src/assets/icons/new-broken.svg +6 -0
- package/src/assets/icons/new-failed.svg +6 -0
- package/src/assets/icons/new-passed.svg +5 -0
- package/src/assets/icons/overview.svg +5 -0
- package/src/assets/icons/passed.svg +10 -0
- package/src/assets/icons/pdf.svg +13 -0
- package/src/assets/icons/refresh.svg +4 -0
- package/src/assets/icons/retries.svg +11 -0
- package/src/assets/icons/save.svg +10 -0
- package/src/assets/icons/skipped.svg +3 -0
- package/src/assets/icons/sort-down.svg +10 -0
- package/src/assets/icons/sort-up.svg +10 -0
- package/src/assets/icons/sort.svg +11 -0
- package/src/assets/icons/table.svg +10 -0
- package/src/assets/icons/task.svg +11 -0
- package/src/assets/icons/teamcity.svg +40 -0
- package/src/assets/icons/timeline.svg +12 -0
- package/src/assets/icons/tree.svg +10 -0
- package/src/assets/icons/txt.svg +11 -0
- package/src/assets/icons/unknown.svg +10 -0
- package/src/behaviors/ClipboardBehavior.js +34 -0
- package/src/behaviors/DownloadBehavior.js +42 -0
- package/src/behaviors/GaBehavior.js +27 -0
- package/src/behaviors/LoadBehavior.js +18 -0
- package/src/behaviors/TooltipBehavior.js +25 -0
- package/src/behaviors/index.js +7 -0
- package/src/blocks/alert/styles.scss +8 -0
- package/src/blocks/arrow/styles.scss +21 -0
- package/src/blocks/attachment-row/attachment-row.hbs +34 -0
- package/src/blocks/attachment-row/styles.scss +71 -0
- package/src/blocks/bar/styles.scss +22 -0
- package/src/blocks/button/styles.scss +60 -0
- package/src/blocks/clipboard-copy/clipboard-copy.hbs +5 -0
- package/src/blocks/executor-icon/bamboo.svg +31 -0
- package/src/blocks/executor-icon/bitbucket.svg +10 -0
- package/src/blocks/executor-icon/circleci.svg +1 -0
- package/src/blocks/executor-icon/default-icon.png +0 -0
- package/src/blocks/executor-icon/github.svg +4 -0
- package/src/blocks/executor-icon/gitlab.svg +12 -0
- package/src/blocks/executor-icon/jenkins.svg +327 -0
- package/src/blocks/executor-icon/styles.scss +15 -0
- package/src/blocks/executor-icon/teamcity.svg +40 -0
- package/src/blocks/island/styles.scss +7 -0
- package/src/blocks/label/styles.scss +15 -0
- package/src/blocks/link/styles.scss +10 -0
- package/src/blocks/pane/styles.scss +52 -0
- package/src/blocks/pane-header/pane-header.hbs +15 -0
- package/src/blocks/parameters-table/parameters-table.hbs +10 -0
- package/src/blocks/parameters-table/styles.scss +22 -0
- package/src/blocks/spinner/styles.scss +30 -0
- package/src/blocks/splash/styles.scss +13 -0
- package/src/blocks/status-details/status-details.hbs +13 -0
- package/src/blocks/status-details/styles.scss +32 -0
- package/src/blocks/step-stats/step-stats.hbs +15 -0
- package/src/blocks/step-stats/styles.scss +19 -0
- package/src/blocks/table/sort-down-icon.svg +1 -0
- package/src/blocks/table/sort-icon.svg +1 -0
- package/src/blocks/table/sort-up-icon.svg +1 -0
- package/src/blocks/table/sortable-col.hbs +4 -0
- package/src/blocks/table/styles.scss +64 -0
- package/src/blocks/tabs/styles.scss +29 -0
- package/src/blocks/tabs/tabs.hbs +5 -0
- package/src/blocks/text/styles.scss +5 -0
- package/src/blocks/widget/draggable.svg +1 -0
- package/src/blocks/widget/styles.scss +76 -0
- package/src/components/attachment/AttachmentView.hbs +58 -0
- package/src/components/attachment/AttachmentView.js +90 -0
- package/src/components/attachment/styles.scss +78 -0
- package/src/components/empty/EmptyView.hbs +3 -0
- package/src/components/empty/EmptyView.js +18 -0
- package/src/components/empty/styles.scss +4 -0
- package/src/components/error-splash/ErrorSplashView.hbs +4 -0
- package/src/components/error-splash/ErrorSplashView.js +19 -0
- package/src/components/error-splash/styles.scss +4 -0
- package/src/components/graph-base/BaseChartView.hbs +5 -0
- package/src/components/graph-base/BaseChartView.js +78 -0
- package/src/components/graph-base/styles.scss +66 -0
- package/src/components/graph-duration-chart/DurationChartView.js +100 -0
- package/src/components/graph-pie-chart/PieChartView.js +155 -0
- package/src/components/graph-severity-chart/SeverityChartView.js +100 -0
- package/src/components/graph-trend-chart/TrendChartView.js +202 -0
- package/src/components/graph-trend-chart/styles.scss +16 -0
- package/src/components/graph-trend-chart/trend-tooltip.hbs +9 -0
- package/src/components/language-select/LanguageSelectView.hbs +5 -0
- package/src/components/language-select/LanguageSelectView.js +42 -0
- package/src/components/language-select/checkmark.svg +1 -0
- package/src/components/language-select/styles.scss +34 -0
- package/src/components/loader/LoaderView.hbs +6 -0
- package/src/components/loader/LoaderView.js +21 -0
- package/src/components/loader/styles.scss +26 -0
- package/src/components/marks-toggle/MarksToggleView.hbs +14 -0
- package/src/components/marks-toggle/MarksToggleView.js +41 -0
- package/src/components/marks-toggle/styles.scss +38 -0
- package/src/components/modal/ModalView.hbs +13 -0
- package/src/components/modal/ModalView.js +43 -0
- package/src/components/modal/styles.scss +31 -0
- package/src/components/node-search/NodeSearchView.hbs +4 -0
- package/src/components/node-search/NodeSearchView.js +32 -0
- package/src/components/node-search/styles.scss +29 -0
- package/src/components/node-sorter/NodeSorterView.hbs +22 -0
- package/src/components/node-sorter/NodeSorterView.js +43 -0
- package/src/components/node-sorter/styles.scss +26 -0
- package/src/components/popover/PopoverView.js +8 -0
- package/src/components/popover/styles.scss +32 -0
- package/src/components/side-by-side/SideBySideView.hbs +2 -0
- package/src/components/side-by-side/SideBySideView.js +42 -0
- package/src/components/side-by-side/styles.scss +59 -0
- package/src/components/side-by-side/vertical.png +0 -0
- package/src/components/side-nav/SideNavView.hbs +39 -0
- package/src/components/side-nav/SideNavView.js +81 -0
- package/src/components/side-nav/styles.scss +118 -0
- package/src/components/status-toggle/StatusToggleView.hbs +16 -0
- package/src/components/status-toggle/StatusToggleView.js +42 -0
- package/src/components/status-toggle/styles.scss +35 -0
- package/src/components/testresult/TestResultView.hbs +32 -0
- package/src/components/testresult/TestResultView.js +90 -0
- package/src/components/testresult/styles.scss +29 -0
- package/src/components/testresult-execution/TestResultExecutionView.hbs +13 -0
- package/src/components/testresult-execution/TestResultExecutionView.js +85 -0
- package/src/components/testresult-execution/stages-block.hbs +47 -0
- package/src/components/testresult-execution/steps-list.hbs +31 -0
- package/src/components/testresult-execution/styles.scss +70 -0
- package/src/components/testresult-overview/TestResultOverviewView.hbs +8 -0
- package/src/components/testresult-overview/TestResultOverviewView.js +46 -0
- package/src/components/testresult-overview/styles.scss +22 -0
- package/src/components/testresult-tree/TestResultTreeView.js +60 -0
- package/src/components/tooltip/TooltipView.js +111 -0
- package/src/components/tooltip/styles.scss +43 -0
- package/src/components/tree/TreeView.hbs +9 -0
- package/src/components/tree/TreeView.js +200 -0
- package/src/components/tree/styles.scss +141 -0
- package/src/components/tree/tree-group.hbs +36 -0
- package/src/components/tree/tree-leaf.hbs +53 -0
- package/src/components/tree/tree-time.hbs +6 -0
- package/src/components/tree-view-container/TreeViewContainer.hbs +34 -0
- package/src/components/tree-view-container/TreeViewContainer.js +103 -0
- package/src/components/tree-view-container/styles.scss +38 -0
- package/src/components/widget-status/WidgetStatusView.hbs +21 -0
- package/src/components/widget-status/WidgetStatusView.js +17 -0
- package/src/components/widgets-grid/WidgetsGridView.js +90 -0
- package/src/components/widgets-grid/styles.scss +34 -0
- package/src/data/localstorage/LocalStorageModel.js +23 -0
- package/src/data/testresult/TestResultModel.js +36 -0
- package/src/data/tree/TreeCollection.js +153 -0
- package/src/data/tree/comparator.js +63 -0
- package/src/data/tree/filter.js +66 -0
- package/src/data/trend/TrendCollection.js +36 -0
- package/src/data/widgets/WidgetsModel.js +25 -0
- package/src/decorators/index.js +53 -0
- package/src/favicon.ico +0 -0
- package/src/helpers/allure-icon.js +228 -0
- package/src/helpers/and.js +3 -0
- package/src/helpers/angle.js +15 -0
- package/src/helpers/arrow.js +17 -0
- package/src/helpers/b.js +6 -0
- package/src/helpers/concat.js +3 -0
- package/src/helpers/date.js +11 -0
- package/src/helpers/default.js +8 -0
- package/src/helpers/duration.js +60 -0
- package/src/helpers/eq.js +3 -0
- package/src/helpers/fileicon.js +5 -0
- package/src/helpers/filesize.js +8 -0
- package/src/helpers/gt.js +3 -0
- package/src/helpers/inc.js +3 -0
- package/src/helpers/is-def.js +3 -0
- package/src/helpers/job-icon.js +8 -0
- package/src/helpers/linky.js +7 -0
- package/src/helpers/not.js +3 -0
- package/src/helpers/or.js +3 -0
- package/src/helpers/sort-class.js +6 -0
- package/src/helpers/statistic-bar.js +12 -0
- package/src/helpers/status-bar.js +14 -0
- package/src/helpers/t.js +5 -0
- package/src/helpers/text-with-links.js +18 -0
- package/src/helpers/time.js +18 -0
- package/src/helpers/timeago.js +10 -0
- package/src/index.html +17 -0
- package/src/index.js +52 -0
- package/src/layouts/application/AppLayout.hbs +2 -0
- package/src/layouts/application/AppLayout.js +50 -0
- package/src/layouts/application/styles.scss +17 -0
- package/src/layouts/error/ErrorLayout.js +11 -0
- package/src/layouts/overview/OverviewLayout.js +8 -0
- package/src/layouts/testresult/TestResultLayout.js +43 -0
- package/src/layouts/tree/TreeLayout.js +45 -0
- package/src/mixins.scss +128 -0
- package/src/pluginApi.js +26 -0
- package/src/plugins/.eslintrc +5 -0
- package/src/plugins/default/index.js +11 -0
- package/src/plugins/screen-diff/index.js +186 -0
- package/src/plugins/screen-diff/styles.css +30 -0
- package/src/plugins/tab-behaviors/index.js +239 -0
- package/src/plugins/tab-category/index.js +15 -0
- package/src/plugins/tab-graph/GraphCollection.js +12 -0
- package/src/plugins/tab-graph/GraphLayout.js +17 -0
- package/src/plugins/tab-graph/index.js +8 -0
- package/src/plugins/tab-packages/index.js +137 -0
- package/src/plugins/tab-suites/index.js +15 -0
- package/src/plugins/tab-timeline/TimelineLayout.js +18 -0
- package/src/plugins/tab-timeline/TimelineView.hbs +17 -0
- package/src/plugins/tab-timeline/TimelineView.js +250 -0
- package/src/plugins/tab-timeline/index.js +12 -0
- package/src/plugins/tab-timeline/styles.scss +76 -0
- package/src/plugins/testresult-category/CategoryView.hbs +6 -0
- package/src/plugins/testresult-category/CategoryView.js +17 -0
- package/src/plugins/testresult-category/index.js +3 -0
- package/src/plugins/testresult-description/DescriptionView.hbs +4 -0
- package/src/plugins/testresult-description/DescriptionView.js +16 -0
- package/src/plugins/testresult-description/index.js +3 -0
- package/src/plugins/testresult-duration/DurationView.hbs +7 -0
- package/src/plugins/testresult-duration/DurationView.js +16 -0
- package/src/plugins/testresult-duration/index.js +3 -0
- package/src/plugins/testresult-history/HistoryView.hbs +27 -0
- package/src/plugins/testresult-history/HistoryView.js +33 -0
- package/src/plugins/testresult-history/index.js +3 -0
- package/src/plugins/testresult-history/styles.scss +10 -0
- package/src/plugins/testresult-links/LinksView.hbs +17 -0
- package/src/plugins/testresult-links/LinksView.js +17 -0
- package/src/plugins/testresult-links/index.js +3 -0
- package/src/plugins/testresult-links/styles.scss +19 -0
- package/src/plugins/testresult-owner/OwnerView.hbs +4 -0
- package/src/plugins/testresult-owner/OwnerView.js +17 -0
- package/src/plugins/testresult-owner/index.js +3 -0
- package/src/plugins/testresult-parameters/ParametersView.hbs +13 -0
- package/src/plugins/testresult-parameters/ParametersView.js +22 -0
- package/src/plugins/testresult-parameters/index.js +3 -0
- package/src/plugins/testresult-parameters/styles.scss +8 -0
- package/src/plugins/testresult-retries/RetriesView.hbs +13 -0
- package/src/plugins/testresult-retries/RetriesView.js +28 -0
- package/src/plugins/testresult-retries/index.js +3 -0
- package/src/plugins/testresult-retries/styles.scss +11 -0
- package/src/plugins/testresult-severity/SeverityView.hbs +4 -0
- package/src/plugins/testresult-severity/SeverityView.js +17 -0
- package/src/plugins/testresult-severity/index.js +3 -0
- package/src/plugins/testresult-tags/TagsView.hbs +5 -0
- package/src/plugins/testresult-tags/TagsView.js +17 -0
- package/src/plugins/testresult-tags/index.js +3 -0
- package/src/plugins/widget-categories/index.js +12 -0
- package/src/plugins/widget-categories-trend/CategoriesTrendWidgetView.hbs +4 -0
- package/src/plugins/widget-categories-trend/CategoriesTrendWidgetView.js +33 -0
- package/src/plugins/widget-categories-trend/index.js +4 -0
- package/src/plugins/widget-categories-trend/styles.scss +6 -0
- package/src/plugins/widget-duration/DurationWidgetView.hbs +4 -0
- package/src/plugins/widget-duration/DurationWidgetView.js +23 -0
- package/src/plugins/widget-duration/index.js +3 -0
- package/src/plugins/widget-duration-trend/DurationTrendWidgetView.hbs +4 -0
- package/src/plugins/widget-duration-trend/DurationTrendWidgetView.js +49 -0
- package/src/plugins/widget-duration-trend/index.js +4 -0
- package/src/plugins/widget-duration-trend/styles.scss +6 -0
- package/src/plugins/widget-environment/EnvironmentWidget.hbs +27 -0
- package/src/plugins/widget-environment/EnvironmentWidget.js +25 -0
- package/src/plugins/widget-environment/index.js +3 -0
- package/src/plugins/widget-executor/ExecutorsWidgetView.hbs +40 -0
- package/src/plugins/widget-executor/ExecutorsWidgetView.js +8 -0
- package/src/plugins/widget-executor/index.js +3 -0
- package/src/plugins/widget-history-trend/HistoryTrendWidgetView.hbs +4 -0
- package/src/plugins/widget-history-trend/HistoryTrendWidgetView.js +30 -0
- package/src/plugins/widget-history-trend/index.js +6 -0
- package/src/plugins/widget-history-trend/styles.scss +6 -0
- package/src/plugins/widget-launch/LaunchesWidgetView.hbs +23 -0
- package/src/plugins/widget-launch/LaunchesWidgetView.js +8 -0
- package/src/plugins/widget-launch/index.js +3 -0
- package/src/plugins/widget-retry-trend/RetryTrendWidgetView.hbs +4 -0
- package/src/plugins/widget-retry-trend/RetryTrendWidgetView.js +33 -0
- package/src/plugins/widget-retry-trend/index.js +4 -0
- package/src/plugins/widget-retry-trend/styles.scss +6 -0
- package/src/plugins/widget-severity/SeverityWidgetView.hbs +4 -0
- package/src/plugins/widget-severity/SeverityWidgetView.js +23 -0
- package/src/plugins/widget-severity/index.js +3 -0
- package/src/plugins/widget-status/StatusWidgetView.hbs +4 -0
- package/src/plugins/widget-status/StatusWidgetView.js +44 -0
- package/src/plugins/widget-status/index.js +3 -0
- package/src/plugins/widget-suites/index.js +12 -0
- package/src/plugins/widget-summary/SummaryWidgetView.hbs +20 -0
- package/src/plugins/widget-summary/SummaryWidgetView.js +33 -0
- package/src/plugins/widget-summary/index.js +3 -0
- package/src/plugins/widget-summary/styles.scss +14 -0
- package/src/router.js +52 -0
- package/src/rtl.scss +19 -0
- package/src/styles.scss +91 -0
- package/src/translations/az.json +217 -0
- package/src/translations/br.json +205 -0
- package/src/translations/de.json +205 -0
- package/src/translations/en.json +222 -0
- package/src/translations/es.json +209 -0
- package/src/translations/fr.json +217 -0
- package/src/translations/he.json +205 -0
- package/src/translations/isv.json +216 -0
- package/src/translations/ja.json +210 -0
- package/src/translations/kr.json +210 -0
- package/src/translations/nl.json +217 -0
- package/src/translations/pl.json +220 -0
- package/src/translations/ru.json +215 -0
- package/src/translations/sv.json +222 -0
- package/src/translations/tr.json +217 -0
- package/src/translations/zh.json +191 -0
- package/src/utils/arrays.js +3 -0
- package/src/utils/attachmentType.js +101 -0
- package/src/utils/clipboard.js +38 -0
- package/src/utils/escape.js +5 -0
- package/src/utils/gtag.js +8 -0
- package/src/utils/highlight.js +14 -0
- package/src/utils/hotkeys.js +25 -0
- package/src/utils/loading.js +9 -0
- package/src/utils/marks.js +1 -0
- package/src/utils/pluginsRegistry.js +56 -0
- package/src/utils/settings.js +4 -0
- package/src/utils/settingsFactory.js +149 -0
- package/src/utils/sorting.js +21 -0
- package/src/utils/statuses.js +1 -0
- package/src/utils/translation.js +63 -0
- package/src/variables.scss +71 -0
- package/types.d.ts +5 -0
- package/webpack/utils.js +10 -0
- package/webpack.config.js +127 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.language-select {
|
|
4
|
+
z-index: 1;
|
|
5
|
+
&.popover {
|
|
6
|
+
padding: 0;
|
|
7
|
+
}
|
|
8
|
+
&__menu {
|
|
9
|
+
list-style-type: none;
|
|
10
|
+
padding: 0;
|
|
11
|
+
margin: 0;
|
|
12
|
+
}
|
|
13
|
+
&__item {
|
|
14
|
+
padding: 0.5em 0.8em;
|
|
15
|
+
border-bottom: 1px solid $border-color;
|
|
16
|
+
cursor: pointer;
|
|
17
|
+
&::before {
|
|
18
|
+
content: " ";
|
|
19
|
+
display: inline-block;
|
|
20
|
+
background: url(checkmark.svg?inline) center no-repeat;
|
|
21
|
+
background-size: contain;
|
|
22
|
+
width: 0.8em;
|
|
23
|
+
height: 0.8em;
|
|
24
|
+
margin-right: 0.5em;
|
|
25
|
+
visibility: hidden;
|
|
26
|
+
}
|
|
27
|
+
&_active::before {
|
|
28
|
+
visibility: visible;
|
|
29
|
+
}
|
|
30
|
+
&:hover {
|
|
31
|
+
background: $hover-color;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { View } from "backbone.marionette";
|
|
2
|
+
import { options } from "@/decorators/index.js";
|
|
3
|
+
import template from "./LoaderView.hbs";
|
|
4
|
+
import "./styles.scss";
|
|
5
|
+
|
|
6
|
+
@options({
|
|
7
|
+
text: "Loading...",
|
|
8
|
+
})
|
|
9
|
+
class LoaderView extends View {
|
|
10
|
+
template = template;
|
|
11
|
+
|
|
12
|
+
initialize(opts) {
|
|
13
|
+
this.options = opts;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
serializeData() {
|
|
17
|
+
return this.options;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export default LoaderView;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.loader {
|
|
4
|
+
margin: auto;
|
|
5
|
+
text-align: center;
|
|
6
|
+
&__mask {
|
|
7
|
+
position: relative;
|
|
8
|
+
top: 0;
|
|
9
|
+
bottom: 0;
|
|
10
|
+
left: 0;
|
|
11
|
+
right: 0;
|
|
12
|
+
display: flex;
|
|
13
|
+
}
|
|
14
|
+
&__text {
|
|
15
|
+
font-size: 14px;
|
|
16
|
+
margin-top: 1em;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
.loader_container {
|
|
21
|
+
position: absolute;
|
|
22
|
+
top: 50%;
|
|
23
|
+
left: 50%;
|
|
24
|
+
margin-left: -19px;
|
|
25
|
+
margin-top: -19px;
|
|
26
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
<div class="{{b 'marks-toggle' 'items'}}">
|
|
2
|
+
{{t 'component.tree.filter-marks'}}:
|
|
3
|
+
{{#each marks}}
|
|
4
|
+
<div class="{{b 'marks-toggle' 'item'}}">
|
|
5
|
+
{{#if active}}
|
|
6
|
+
<span class="{{b 'marks-toggle' 'mark' y=true}} y-label-mark y-label_mark_{{mark}}" data-mark="{{mark}}"
|
|
7
|
+
data-tooltip="{{t 'component.markToggle.hideCases' mark=markName}}">{{allure-icon mark noTooltip=true width="18px" height="18px"}}</span>
|
|
8
|
+
{{else}}
|
|
9
|
+
<span class="{{b 'marks-toggle' 'mark' n=true}} n-label-mark n-label_mark_{{mark}}" data-mark="{{mark}}"
|
|
10
|
+
data-tooltip="{{t 'component.markToggle.showCases' mark=markName}}">{{allure-icon mark noTooltip=true width="18px" height="18px"}}</span>
|
|
11
|
+
{{/if}}
|
|
12
|
+
</div>
|
|
13
|
+
{{/each}}
|
|
14
|
+
</div>
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { View } from "backbone.marionette";
|
|
2
|
+
import { className, on } from "@/decorators/index.js";
|
|
3
|
+
import translate from "@/helpers/t.js";
|
|
4
|
+
import gtag from "@/utils/gtag.js";
|
|
5
|
+
import { values } from "@/utils/marks.js";
|
|
6
|
+
import template from "./MarksToggleView.hbs";
|
|
7
|
+
import "./styles.scss";
|
|
8
|
+
|
|
9
|
+
@className("marks-toggle")
|
|
10
|
+
class MarksToggleView extends View {
|
|
11
|
+
template = template;
|
|
12
|
+
|
|
13
|
+
initialize({ settings }) {
|
|
14
|
+
this.settings = settings;
|
|
15
|
+
this.listenTo(settings, "change", this.render);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
serializeData() {
|
|
19
|
+
const marks = this.settings.getVisibleMarks();
|
|
20
|
+
return {
|
|
21
|
+
marks: values.map((mark) => ({
|
|
22
|
+
mark,
|
|
23
|
+
markName: translate(`marks.${mark}`, {}),
|
|
24
|
+
active: !!marks[mark],
|
|
25
|
+
count: this.statistic ? this.statistic[status.toLowerCase()] : 0,
|
|
26
|
+
})),
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
@on("click .y-label-mark, .n-label-mark")
|
|
31
|
+
onToggleMark(e) {
|
|
32
|
+
const el = this.$(e.currentTarget);
|
|
33
|
+
const name = el.data("mark");
|
|
34
|
+
const checked = el.hasClass("n-label-mark");
|
|
35
|
+
const marks = this.settings.getVisibleMarks();
|
|
36
|
+
this.settings.setVisibleMarks(Object.assign({}, marks, { [name]: checked }));
|
|
37
|
+
gtag("marks_toggle_click", { status: name, checked });
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export default MarksToggleView;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
.marks-toggle {
|
|
2
|
+
&__items {
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
gap: 0 4px;
|
|
6
|
+
user-select: none;
|
|
7
|
+
word-break: break-word;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
&__item {
|
|
11
|
+
flex: 0 0 24px;
|
|
12
|
+
width: 24px;
|
|
13
|
+
height: 24px;
|
|
14
|
+
cursor: pointer;
|
|
15
|
+
white-space: nowrap;
|
|
16
|
+
position: relative;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
&__mark {
|
|
20
|
+
display: flex;
|
|
21
|
+
align-items: center;
|
|
22
|
+
justify-content: center;
|
|
23
|
+
width: 100%;
|
|
24
|
+
height: 100%;
|
|
25
|
+
border-radius: 3px;
|
|
26
|
+
border-width: 1px;
|
|
27
|
+
border-style: solid;
|
|
28
|
+
|
|
29
|
+
&_y {
|
|
30
|
+
background: #97cc64;
|
|
31
|
+
border-color: #97cc64;
|
|
32
|
+
color: #fff;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
&_n {
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
<div class="modal__background">
|
|
2
|
+
<div class="modal__window">
|
|
3
|
+
<h2 class="{{b cls 'title'}}">
|
|
4
|
+
<span>{{title}}</span>
|
|
5
|
+
<span class="{{b cls 'close'}}" data-tooltip="Close">
|
|
6
|
+
{{allure-icon "close" noTooltip=true width="16px" height="16px"}}
|
|
7
|
+
</span>
|
|
8
|
+
</h2>
|
|
9
|
+
<div class="modal__content"></div>
|
|
10
|
+
<br>
|
|
11
|
+
</div>
|
|
12
|
+
|
|
13
|
+
</div>
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { View } from "backbone.marionette";
|
|
2
|
+
import $ from "jquery";
|
|
3
|
+
import { className, on, regions } from "@/decorators/index.js";
|
|
4
|
+
import template from "./ModalView.hbs";
|
|
5
|
+
import "./styles.scss";
|
|
6
|
+
|
|
7
|
+
@className("modal")
|
|
8
|
+
@regions({
|
|
9
|
+
content: ".modal__content",
|
|
10
|
+
})
|
|
11
|
+
class ModalView extends View {
|
|
12
|
+
template = template;
|
|
13
|
+
static container = $(document.body);
|
|
14
|
+
|
|
15
|
+
show() {
|
|
16
|
+
this.constructor.container.append(this.$el);
|
|
17
|
+
this.showChildView("content", this.options.childView);
|
|
18
|
+
$("#content").toggleClass("blur", true);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
onDestroy() {
|
|
22
|
+
$("#content").toggleClass("blur", false);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
@on("click .modal__content")
|
|
26
|
+
onKeepOpen(e) {
|
|
27
|
+
e.stopPropagation();
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
@on("click .modal__background, .modal__close")
|
|
31
|
+
onClose() {
|
|
32
|
+
this.destroy();
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
serializeData() {
|
|
36
|
+
return {
|
|
37
|
+
cls: this.className,
|
|
38
|
+
title: this.options.title,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export default ModalView;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.modal {
|
|
4
|
+
&__background {
|
|
5
|
+
position: absolute;
|
|
6
|
+
width: 100%;
|
|
7
|
+
height: 100%;
|
|
8
|
+
top: 0;
|
|
9
|
+
margin: 0 auto;
|
|
10
|
+
overflow: auto;
|
|
11
|
+
background-color: rgba(235, 235, 235, 0.7);
|
|
12
|
+
z-index: 1000;
|
|
13
|
+
}
|
|
14
|
+
&__title {
|
|
15
|
+
display: flex;
|
|
16
|
+
}
|
|
17
|
+
&__close {
|
|
18
|
+
margin-left: auto;
|
|
19
|
+
}
|
|
20
|
+
&__window {
|
|
21
|
+
position: absolute;
|
|
22
|
+
width: 90%;
|
|
23
|
+
margin-left: 5%;
|
|
24
|
+
top: 0;
|
|
25
|
+
z-index: 1001;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.blur {
|
|
30
|
+
filter: blur(3px);
|
|
31
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { View } from "backbone.marionette";
|
|
2
|
+
import { className, on } from "@/decorators/index.js";
|
|
3
|
+
import gtag from "@/utils/gtag.js";
|
|
4
|
+
import template from "./NodeSearchView.hbs";
|
|
5
|
+
import "./styles.scss";
|
|
6
|
+
|
|
7
|
+
export const SEARCH_QUERY_KEY = "searchQuery";
|
|
8
|
+
|
|
9
|
+
@className("search")
|
|
10
|
+
class NodeSearchView extends View {
|
|
11
|
+
template = template;
|
|
12
|
+
|
|
13
|
+
initialize({ state }) {
|
|
14
|
+
this.state = state;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
onRender() {
|
|
18
|
+
this.$("input").val(this.state.get(SEARCH_QUERY_KEY));
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
@on("input input")
|
|
22
|
+
onChangeSorting(e) {
|
|
23
|
+
this.state.set(SEARCH_QUERY_KEY, e.target.value);
|
|
24
|
+
gtag("search");
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
close() {
|
|
28
|
+
this.state.set(SEARCH_QUERY_KEY, "");
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export default NodeSearchView;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.search {
|
|
4
|
+
&__container {
|
|
5
|
+
width: 100%;
|
|
6
|
+
max-width: 350px;
|
|
7
|
+
float: right;
|
|
8
|
+
}
|
|
9
|
+
&__input {
|
|
10
|
+
width: 100%;
|
|
11
|
+
height: 32px;
|
|
12
|
+
font-size: 0.8em;
|
|
13
|
+
display: inline-block;
|
|
14
|
+
padding: 0 30px 0 10px;
|
|
15
|
+
border: 1px solid $border-accent-color;
|
|
16
|
+
line-height: 20px;
|
|
17
|
+
background: no-repeat right 8px center;
|
|
18
|
+
&:hover {
|
|
19
|
+
border-color: #888;
|
|
20
|
+
}
|
|
21
|
+
&:focus {
|
|
22
|
+
border-color: #51a7e8;
|
|
23
|
+
outline: none;
|
|
24
|
+
box-shadow:
|
|
25
|
+
inset 0 1px 2px rgba(0, 0, 0, 0.075),
|
|
26
|
+
0 0 5px rgba(81, 167, 232, 0.5);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
<div class="sorter">
|
|
2
|
+
{{#each sorters}}
|
|
3
|
+
<div class="{{b 'sorter' 'item'}}"
|
|
4
|
+
data-name="{{name}}"
|
|
5
|
+
data-asc="{{asc}}"
|
|
6
|
+
data-ga4-event="sort_click"
|
|
7
|
+
data-ga4-param-name="{{name}}">
|
|
8
|
+
<span class="{{b 'sorter' enabled=(or asc desc)}} {{b 'sorter' 'name'}}">{{t name}}</span>
|
|
9
|
+
<svg width="16px" height="16px" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
10
|
+
<g clip-path="url(#clip0_7_44)">
|
|
11
|
+
<path class="{{b 'sorter' enabled=asc}}" data-asc="true" d="M16 28L9 21L10.41 19.59L16 25.17L21.59 19.59L23 21L16 28Z" fill="currentColor"/>
|
|
12
|
+
<path class="{{b 'sorter' enabled=desc}}" data-desc="true" d="M16 4L23 11L21.59 12.41L16 6.83L10.41 12.41L9 11L16 4Z" fill="currentColor"/>
|
|
13
|
+
</g>
|
|
14
|
+
<defs>
|
|
15
|
+
<clipPath id="clip0_7_44">
|
|
16
|
+
<rect width="32" height="32" fill="white"/>
|
|
17
|
+
</clipPath>
|
|
18
|
+
</defs>
|
|
19
|
+
</svg>
|
|
20
|
+
</div>
|
|
21
|
+
{{/each}}
|
|
22
|
+
</div>
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { View } from "backbone.marionette";
|
|
2
|
+
import { className, on } from "@/decorators/index.js";
|
|
3
|
+
import template from "./NodeSorterView.hbs";
|
|
4
|
+
import "./styles.scss";
|
|
5
|
+
|
|
6
|
+
const AVAILABLE_SORTERS = ["sorter.order", "sorter.name", "sorter.duration", "sorter.status"];
|
|
7
|
+
|
|
8
|
+
@className("sorter")
|
|
9
|
+
class NodeSorterView extends View {
|
|
10
|
+
template = template;
|
|
11
|
+
|
|
12
|
+
initialize({ settings }) {
|
|
13
|
+
this.settings = settings;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
@on("click .sorter__item")
|
|
17
|
+
onChangeSorting(e) {
|
|
18
|
+
const el = this.$(e.currentTarget);
|
|
19
|
+
this.settings.setTreeSorting({
|
|
20
|
+
sorter: el.data("name"),
|
|
21
|
+
ascending: !el.data("asc"),
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
const ascending = el.data("asc");
|
|
25
|
+
this.$(".sorter_enabled").toggleClass("sorter_enabled");
|
|
26
|
+
el.data("asc", !ascending);
|
|
27
|
+
el.find(".sorter__name").toggleClass("sorter_enabled");
|
|
28
|
+
el.find(ascending ? "[data-asc]" : "[data-desc]").toggleClass("sorter_enabled");
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
serializeData() {
|
|
32
|
+
const sortSettings = this.settings.getTreeSorting();
|
|
33
|
+
return {
|
|
34
|
+
sorters: AVAILABLE_SORTERS.map((sorter) => ({
|
|
35
|
+
name: sorter,
|
|
36
|
+
asc: sortSettings.sorter === sorter && sortSettings.ascending,
|
|
37
|
+
desc: sortSettings.sorter === sorter && !sortSettings.ascending,
|
|
38
|
+
})),
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export default NodeSorterView;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.sorter {
|
|
4
|
+
overflow: hidden;
|
|
5
|
+
color: $text-muted-color;
|
|
6
|
+
user-select: none;
|
|
7
|
+
|
|
8
|
+
&_enabled {
|
|
9
|
+
color: $text-color;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
&__item {
|
|
13
|
+
cursor: pointer;
|
|
14
|
+
display: inline-flex;
|
|
15
|
+
align-items: center;
|
|
16
|
+
padding-right: $gap-size;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
&__icon {
|
|
20
|
+
display: none;
|
|
21
|
+
|
|
22
|
+
&_visible {
|
|
23
|
+
display: block;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.popover {
|
|
4
|
+
position: absolute;
|
|
5
|
+
background: $pane-bg-color;
|
|
6
|
+
color: $text-color;
|
|
7
|
+
border: 1px solid $border-accent-color;
|
|
8
|
+
padding: 8px;
|
|
9
|
+
font-size: 14px;
|
|
10
|
+
&::before,
|
|
11
|
+
&::after {
|
|
12
|
+
content: " ";
|
|
13
|
+
position: absolute;
|
|
14
|
+
border: 8px solid transparent;
|
|
15
|
+
top: 50%;
|
|
16
|
+
margin-top: -8px;
|
|
17
|
+
}
|
|
18
|
+
&_position_right {
|
|
19
|
+
&::before {
|
|
20
|
+
left: -16px;
|
|
21
|
+
border-right-color: $border-accent-color;
|
|
22
|
+
}
|
|
23
|
+
&::after {
|
|
24
|
+
left: -15px;
|
|
25
|
+
border-right-color: $pane-bg-color;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
&__list {
|
|
29
|
+
margin: 0.5em 0;
|
|
30
|
+
padding-left: 20px;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { View } from "backbone.marionette";
|
|
2
|
+
import split from "split.js";
|
|
3
|
+
import { className, regions } from "@/decorators/index.js";
|
|
4
|
+
import gtag from "@/utils/gtag.js";
|
|
5
|
+
import settings from "@/utils/settings.js";
|
|
6
|
+
import template from "./SideBySideView.hbs";
|
|
7
|
+
import "./styles.scss";
|
|
8
|
+
|
|
9
|
+
@className("side-by-side")
|
|
10
|
+
@regions({
|
|
11
|
+
left: ".side-by-side__left",
|
|
12
|
+
right: ".side-by-side__right",
|
|
13
|
+
})
|
|
14
|
+
class SideBySideView extends View {
|
|
15
|
+
template = template;
|
|
16
|
+
|
|
17
|
+
onAttach() {
|
|
18
|
+
const splitter = split([".side-by-side__left", ".side-by-side__right"], {
|
|
19
|
+
gutterSize: 7,
|
|
20
|
+
sizes: settings.getSideBySidePosition(),
|
|
21
|
+
onDragEnd: function () {
|
|
22
|
+
const sizes = splitter.getSizes();
|
|
23
|
+
settings.setSideBySidePosition(sizes);
|
|
24
|
+
gtag("side-by-side-resize", { sizes });
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
onRender() {
|
|
30
|
+
const { left, right } = this.options;
|
|
31
|
+
this.showChildView("left", left);
|
|
32
|
+
this.showChildView("right", right);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
templateContext() {
|
|
36
|
+
return {
|
|
37
|
+
cls: "side-by-side",
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export default SideBySideView;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.side-by-side {
|
|
4
|
+
height: 100%;
|
|
5
|
+
width: 100%;
|
|
6
|
+
padding: 0;
|
|
7
|
+
margin: 0;
|
|
8
|
+
overflow: hidden;
|
|
9
|
+
display: flex;
|
|
10
|
+
position: absolute;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
[dir="ltr"] .side-by-side {
|
|
14
|
+
direction: ltr;
|
|
15
|
+
flex-direction: row;
|
|
16
|
+
|
|
17
|
+
&__left {
|
|
18
|
+
overflow: auto;
|
|
19
|
+
flex: 0 0 auto;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
&__right {
|
|
23
|
+
overflow: auto;
|
|
24
|
+
flex: 1 1 auto;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
[dir="rtl"] .side-by-side {
|
|
29
|
+
direction: ltr;
|
|
30
|
+
box-orient: horizontal;
|
|
31
|
+
flex-direction: row-reverse;
|
|
32
|
+
|
|
33
|
+
&__left {
|
|
34
|
+
direction: rtl;
|
|
35
|
+
overflow: auto;
|
|
36
|
+
flex: 0 0 auto;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
&__right {
|
|
40
|
+
direction: rtl;
|
|
41
|
+
overflow: auto;
|
|
42
|
+
flex: 1 1 auto;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
[dir="rtl"] .tree__ctrl {
|
|
47
|
+
overflow: hidden;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
.gutter {
|
|
51
|
+
background: $border-color no-repeat 50%;
|
|
52
|
+
&:hover {
|
|
53
|
+
cursor: ew-resize;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.gutter-horizontal {
|
|
58
|
+
background-image: url("vertical.png");
|
|
59
|
+
}
|
|
Binary file
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
<div class="{{b 'side-nav' 'head'}}">
|
|
2
|
+
<a href="#" class="{{b 'side-nav' 'brand'}}" data-ga4-event="home_click">
|
|
3
|
+
{{allure-icon "allureLogo" noTooltip=true width="40px" height="40px"}}
|
|
4
|
+
<span class="{{b 'side-nav' 'brand-text'}}">Allure</span>
|
|
5
|
+
</a>
|
|
6
|
+
</div>
|
|
7
|
+
<ul class="{{b 'side-nav' 'menu'}}">
|
|
8
|
+
{{#each tabs}}
|
|
9
|
+
<li class="{{b 'side-nav' 'item'}}"
|
|
10
|
+
data-tooltip="{{t title}}"
|
|
11
|
+
data-ga4-event="tab_click"
|
|
12
|
+
data-ga4-param-tab="{{tabName}}">
|
|
13
|
+
<a href="#{{tabName}}" class="{{b 'side-nav' 'link' active=active}}">
|
|
14
|
+
<span class="{{b 'side-nav' 'icon'}}">
|
|
15
|
+
{{allure-icon icon noTooltip=true width="22px" height="22px"}}
|
|
16
|
+
</span>
|
|
17
|
+
<div class="{{b 'side-nav' 'text'}}">{{t title}}</div>
|
|
18
|
+
</a>
|
|
19
|
+
</li>
|
|
20
|
+
{{/each}}
|
|
21
|
+
</ul>
|
|
22
|
+
<div class="{{b 'side-nav' 'strut'}}"></div>
|
|
23
|
+
<div class="{{b 'side-nav' 'footer'}}">
|
|
24
|
+
<div class="{{b 'side-nav' 'item'}}" data-tooltip="{{t 'controls.language'}}">
|
|
25
|
+
<button class="{{b 'button'}} {{b 'button' inverse=true}} {{b 'side-nav' 'language-small' lang=language.id}}"
|
|
26
|
+
data-ga4-event="language_menu_click">
|
|
27
|
+
{{language.id}}
|
|
28
|
+
</button>
|
|
29
|
+
</div>
|
|
30
|
+
|
|
31
|
+
<div class="{{b 'side-nav' 'item'}} " data-tooltip="{{t 'controls.expand'}}" data-ga4-event="expand_menu_click">
|
|
32
|
+
<div class="{{b 'side-nav' 'collapse'}}">
|
|
33
|
+
<span class="{{b 'side-nav' 'icon'}}">
|
|
34
|
+
{{allure-icon "chevronLeft" noTooltip=true width="20px" height="20px"}}
|
|
35
|
+
</span>
|
|
36
|
+
<span class="{{b 'side-nav' 'text'}}">{{t 'controls.collapse'}}</span>
|
|
37
|
+
</div>
|
|
38
|
+
</div>
|
|
39
|
+
</div>
|