@allurereport/web-allure2 3.0.0-beta.10
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,66 @@
|
|
|
1
|
+
@import "../../mixins.scss";
|
|
2
|
+
|
|
3
|
+
.chart {
|
|
4
|
+
margin-right: $gap-size;
|
|
5
|
+
margin-bottom: $gap-size;
|
|
6
|
+
margin-top: $gap-size;
|
|
7
|
+
position: relative;
|
|
8
|
+
flex: 1;
|
|
9
|
+
&__title {
|
|
10
|
+
margin-top: 0;
|
|
11
|
+
margin-bottom: $gap-size;
|
|
12
|
+
font-size: 18px;
|
|
13
|
+
}
|
|
14
|
+
&__caption {
|
|
15
|
+
text-anchor: middle;
|
|
16
|
+
}
|
|
17
|
+
&__body > div {
|
|
18
|
+
padding-top: 50%;
|
|
19
|
+
position: relative;
|
|
20
|
+
}
|
|
21
|
+
&__svg {
|
|
22
|
+
position: absolute;
|
|
23
|
+
top: 0;
|
|
24
|
+
left: 0;
|
|
25
|
+
width: 100%;
|
|
26
|
+
height: 100%;
|
|
27
|
+
}
|
|
28
|
+
&__legend {
|
|
29
|
+
position: absolute;
|
|
30
|
+
height: 50%;
|
|
31
|
+
top: 10%;
|
|
32
|
+
right: 10%;
|
|
33
|
+
display: grid;
|
|
34
|
+
}
|
|
35
|
+
&__legend-icon {
|
|
36
|
+
position: relative;
|
|
37
|
+
top: -1px;
|
|
38
|
+
border-radius: 3px;
|
|
39
|
+
display: inline-block;
|
|
40
|
+
vertical-align: middle;
|
|
41
|
+
width: 20px;
|
|
42
|
+
height: 16px;
|
|
43
|
+
margin-right: 5px;
|
|
44
|
+
@include status-bg-bright();
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
&__bar {
|
|
48
|
+
shape-rendering: crispEdges;
|
|
49
|
+
fill: steelblue;
|
|
50
|
+
}
|
|
51
|
+
&__arc {
|
|
52
|
+
stroke: #fff;
|
|
53
|
+
stop-opacity: 0;
|
|
54
|
+
}
|
|
55
|
+
&__fill {
|
|
56
|
+
@include status-fill();
|
|
57
|
+
}
|
|
58
|
+
&__axis {
|
|
59
|
+
path,
|
|
60
|
+
line {
|
|
61
|
+
shape-rendering: crispEdges;
|
|
62
|
+
stroke: #000;
|
|
63
|
+
fill: none;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { histogram, max } from "d3-array";
|
|
2
|
+
import { scaleLinear, scaleSqrt } from "d3-scale";
|
|
3
|
+
import BaseChartView from "@/components/graph-base/BaseChartView.js";
|
|
4
|
+
import PopoverView from "@/components/popover/PopoverView.js";
|
|
5
|
+
import duration from "@/helpers/duration.js";
|
|
6
|
+
import translate from "@/helpers/t.js";
|
|
7
|
+
import escape from "@/utils/escape.js";
|
|
8
|
+
|
|
9
|
+
export default class DurationChart extends BaseChartView {
|
|
10
|
+
initialize() {
|
|
11
|
+
this.collection = this.model;
|
|
12
|
+
this.getChartData();
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
getChartData() {
|
|
16
|
+
this.data = this.collection
|
|
17
|
+
.map((testResult) => ({
|
|
18
|
+
value: testResult.time.duration,
|
|
19
|
+
name: testResult.name,
|
|
20
|
+
}))
|
|
21
|
+
.filter((testResult) => {
|
|
22
|
+
return testResult.value !== null;
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
onAttach() {
|
|
27
|
+
if (this.data && this.data.length) {
|
|
28
|
+
this.doShow();
|
|
29
|
+
} else {
|
|
30
|
+
this.$el.html(`<div class="widget__noitems">${translate("chart.duration.empty")}</div>`);
|
|
31
|
+
}
|
|
32
|
+
super.onAttach();
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
doShow() {
|
|
36
|
+
this.x = scaleLinear();
|
|
37
|
+
this.y = scaleSqrt();
|
|
38
|
+
this.tooltip = new PopoverView({ position: "right" });
|
|
39
|
+
|
|
40
|
+
this.setupViewport();
|
|
41
|
+
|
|
42
|
+
this.x.range([0, this.width]);
|
|
43
|
+
this.y.range([this.height, 0], 1);
|
|
44
|
+
|
|
45
|
+
const maxDuration = max(this.data, (d) => d.value);
|
|
46
|
+
this.x.domain([0, Math.max(maxDuration, 10)]).nice();
|
|
47
|
+
|
|
48
|
+
const bins = histogram()
|
|
49
|
+
.value((d) => d.value)
|
|
50
|
+
.domain(this.x.domain())
|
|
51
|
+
.thresholds(this.x.ticks())(this.data)
|
|
52
|
+
.map((bin) => ({
|
|
53
|
+
x0: bin.x0,
|
|
54
|
+
x1: bin.x1,
|
|
55
|
+
y: bin.length,
|
|
56
|
+
testResults: bin,
|
|
57
|
+
}));
|
|
58
|
+
|
|
59
|
+
const maxY = max(bins, (d) => d.y);
|
|
60
|
+
this.y.domain([0, maxY]).nice();
|
|
61
|
+
|
|
62
|
+
this.makeBottomAxis({
|
|
63
|
+
scale: this.x,
|
|
64
|
+
tickFormat: (time) => duration(time, 1),
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
this.makeLeftAxis({
|
|
68
|
+
scale: this.y,
|
|
69
|
+
ticks: Math.min(10, maxY),
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
let bars = this.plot.selectAll(".chart__bar").data(bins).enter().append("rect").classed("chart__bar", true);
|
|
73
|
+
|
|
74
|
+
this.bindTooltip(bars);
|
|
75
|
+
|
|
76
|
+
bars
|
|
77
|
+
.attr("x", (d) => this.x(d.x0) + 2)
|
|
78
|
+
.attr("y", this.height)
|
|
79
|
+
.attr("width", (d) => Math.max(this.x(d.x1) - this.x(d.x0) - 2, 0))
|
|
80
|
+
.attr("height", 0);
|
|
81
|
+
|
|
82
|
+
if (this.firstRender) {
|
|
83
|
+
bars = bars.transition().duration(500);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
bars.attr("y", (d) => this.y(d.y)).attr("height", (d) => this.height - this.y(d.y));
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
getTooltipContent({ testResults }) {
|
|
90
|
+
const LIST_LIMIT = 10;
|
|
91
|
+
const items = testResults.slice(0, LIST_LIMIT);
|
|
92
|
+
const overLimit = testResults.length - items.length;
|
|
93
|
+
return `<b>${testResults.length} test cases</b><br>
|
|
94
|
+
<ul class="popover__list">
|
|
95
|
+
${items.map((testResult) => escape`<li>${testResult.name}</li>`).join("")}
|
|
96
|
+
</ul>
|
|
97
|
+
${overLimit ? `...and ${overLimit} more` : ""}
|
|
98
|
+
`;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import { interpolate } from "d3-interpolate";
|
|
2
|
+
import { select } from "d3-selection";
|
|
3
|
+
import { arc, pie } from "d3-shape";
|
|
4
|
+
import { omit } from "underscore";
|
|
5
|
+
import BaseChartView from "@/components/graph-base/BaseChartView.js";
|
|
6
|
+
import TooltipView from "@/components/tooltip/TooltipView.js";
|
|
7
|
+
import { on } from "@/decorators/index.js";
|
|
8
|
+
import translate from "@/helpers/t.js";
|
|
9
|
+
import escape from "@/utils/escape.js";
|
|
10
|
+
import { values } from "@/utils/statuses.js";
|
|
11
|
+
|
|
12
|
+
const PADDING = 5;
|
|
13
|
+
|
|
14
|
+
class PieChartView extends BaseChartView {
|
|
15
|
+
initialize(options) {
|
|
16
|
+
this.options = options;
|
|
17
|
+
this.model = this.options.model;
|
|
18
|
+
this.showLegend = this.options ? this.options.showLegend || false : false;
|
|
19
|
+
|
|
20
|
+
this.arc = arc();
|
|
21
|
+
this.pie = pie()
|
|
22
|
+
.sort(null)
|
|
23
|
+
.value((d) => d.value);
|
|
24
|
+
this.tooltip = new TooltipView({ position: "center" });
|
|
25
|
+
this.getChartData();
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
getChartData() {
|
|
29
|
+
this.statistic = this.model.get("statistic");
|
|
30
|
+
const { total } = this.statistic;
|
|
31
|
+
const stats = omit(this.statistic, "total");
|
|
32
|
+
this.data = Object.keys(stats)
|
|
33
|
+
.map((key) => ({
|
|
34
|
+
name: key.toUpperCase(),
|
|
35
|
+
value: stats[key],
|
|
36
|
+
part: stats[key] / total,
|
|
37
|
+
}))
|
|
38
|
+
.filter((item) => item.value);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
setupViewport() {
|
|
42
|
+
super.setupViewport();
|
|
43
|
+
if (this.showLegend) {
|
|
44
|
+
this.$el.append(this.getLegendTpl());
|
|
45
|
+
}
|
|
46
|
+
return this.svg;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
onAttach() {
|
|
50
|
+
const data = this.data;
|
|
51
|
+
const width = this.$el.outerWidth();
|
|
52
|
+
const height = this.$el.outerHeight();
|
|
53
|
+
const radius = Math.min(width, height) / 2 - 2 * PADDING;
|
|
54
|
+
const topOffset = height / 2;
|
|
55
|
+
let leftOffset = width / 2;
|
|
56
|
+
|
|
57
|
+
if (this.showLegend) {
|
|
58
|
+
leftOffset -= 70;
|
|
59
|
+
}
|
|
60
|
+
this.arc.innerRadius(0.8 * radius).outerRadius(radius);
|
|
61
|
+
|
|
62
|
+
this.svg = this.setupViewport();
|
|
63
|
+
|
|
64
|
+
const sectors = this.svg
|
|
65
|
+
.select(".chart__plot")
|
|
66
|
+
.attr("transform", `translate(${leftOffset},${topOffset})`)
|
|
67
|
+
.selectAll(".chart__arc")
|
|
68
|
+
.data(this.pie(data))
|
|
69
|
+
.enter()
|
|
70
|
+
.append("path")
|
|
71
|
+
.attr("class", (d) => `chart__arc chart__fill_status_${d.data.name.toLowerCase()}`);
|
|
72
|
+
|
|
73
|
+
this.bindTooltip(sectors);
|
|
74
|
+
|
|
75
|
+
this.svg
|
|
76
|
+
.select(".chart__plot")
|
|
77
|
+
.append("text")
|
|
78
|
+
.classed("chart__caption", true)
|
|
79
|
+
.attr("dy", "0.4em")
|
|
80
|
+
.style("font-size", `${radius / 3}px`)
|
|
81
|
+
.text(this.getChartTitle());
|
|
82
|
+
|
|
83
|
+
if (this.firstRender) {
|
|
84
|
+
sectors
|
|
85
|
+
.transition()
|
|
86
|
+
.duration(750)
|
|
87
|
+
.attrTween("d", (d) => {
|
|
88
|
+
const startAngleFn = interpolate(0, d.startAngle);
|
|
89
|
+
const endAngleFn = interpolate(0, d.endAngle);
|
|
90
|
+
return (t) => this.arc({ startAngle: startAngleFn(t), endAngle: endAngleFn(t) });
|
|
91
|
+
});
|
|
92
|
+
} else {
|
|
93
|
+
sectors.attr("d", (d) => this.arc(d));
|
|
94
|
+
}
|
|
95
|
+
super.onAttach();
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
formatNumber(n) {
|
|
99
|
+
return (Math.floor(n * 100) / 100).toString();
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
getChartTitle() {
|
|
103
|
+
const { passed = 0, failed = 0, broken = 0, total = 0 } = this.statistic;
|
|
104
|
+
if (!total) {
|
|
105
|
+
return "???";
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
if (!passed) {
|
|
109
|
+
return "0%";
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
return `${this.formatNumber((passed / (passed + failed + broken)) * 100)}%`;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
getTooltipContent({ data }) {
|
|
116
|
+
const value = data.value || 0;
|
|
117
|
+
const part = data.part || 0;
|
|
118
|
+
const status = data.name.toLowerCase();
|
|
119
|
+
const name = translate(`status.${status}`, {});
|
|
120
|
+
return escape`
|
|
121
|
+
${value} tests (${this.formatNumber(part * 100)}%)<br>
|
|
122
|
+
${name}
|
|
123
|
+
`;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
getLegendTpl() {
|
|
127
|
+
return `<div class="chart__legend">
|
|
128
|
+
${values
|
|
129
|
+
.map(
|
|
130
|
+
(status) =>
|
|
131
|
+
`<div class="chart__legend-row" data-status="${status}">
|
|
132
|
+
<span class="chart__legend-icon chart__legend-icon_status_${status}"></span> ${translate(`status.${status}`)}</div>`,
|
|
133
|
+
)
|
|
134
|
+
.join("")}
|
|
135
|
+
</div>`;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
@on("mouseleave .chart__legend-row")
|
|
139
|
+
onLegendOut() {
|
|
140
|
+
this.hideTooltip();
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
@on("mouseenter .chart__legend-row")
|
|
144
|
+
onLegendHover(e) {
|
|
145
|
+
const el = this.$(e.currentTarget);
|
|
146
|
+
const status = el.data("status");
|
|
147
|
+
const sector = this.$el.find(`.chart__fill_status_${status}`)[0];
|
|
148
|
+
if (sector) {
|
|
149
|
+
const data = select(sector).datum();
|
|
150
|
+
this.showTooltip(data, sector);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
export default PieChartView;
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { max } from "d3-array";
|
|
2
|
+
import { scaleBand, scaleSqrt } from "d3-scale";
|
|
3
|
+
import BaseChartView from "@/components/graph-base/BaseChartView.js";
|
|
4
|
+
import PopoverView from "@/components/popover/PopoverView.js";
|
|
5
|
+
import escape from "@/utils/escape.js";
|
|
6
|
+
import { values } from "@/utils/statuses.js";
|
|
7
|
+
|
|
8
|
+
const severities = ["blocker", "critical", "normal", "minor", "trivial"];
|
|
9
|
+
|
|
10
|
+
export default class SeverityChartView extends BaseChartView {
|
|
11
|
+
initialize() {
|
|
12
|
+
this.x = scaleBand().domain(severities);
|
|
13
|
+
this.y = scaleSqrt();
|
|
14
|
+
this.status = scaleBand().domain(values);
|
|
15
|
+
this.tooltip = new PopoverView({ position: "right" });
|
|
16
|
+
this.collection = this.model;
|
|
17
|
+
this.getChartData();
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
getChartData() {
|
|
21
|
+
this.data = severities.map((severity) =>
|
|
22
|
+
values.map((status) => {
|
|
23
|
+
const testResults = this.collection.filter(function (item) {
|
|
24
|
+
return item.status === status && item.severity === severity;
|
|
25
|
+
});
|
|
26
|
+
return {
|
|
27
|
+
value: testResults.length,
|
|
28
|
+
testResults,
|
|
29
|
+
severity,
|
|
30
|
+
status,
|
|
31
|
+
};
|
|
32
|
+
}),
|
|
33
|
+
);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
onAttach() {
|
|
37
|
+
const data = this.data;
|
|
38
|
+
this.setupViewport();
|
|
39
|
+
|
|
40
|
+
this.x.range([0, this.width]);
|
|
41
|
+
this.y.range([this.height, 0], 1);
|
|
42
|
+
this.y.domain([0, max(data, (d) => max(d, (dd) => dd.value))]).nice();
|
|
43
|
+
this.status.rangeRound([0, this.x.step()]);
|
|
44
|
+
|
|
45
|
+
this.makeBottomAxis({
|
|
46
|
+
tickFormat: (d) => d.toLowerCase(),
|
|
47
|
+
scale: this.x,
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
this.svg
|
|
51
|
+
.selectAll(".tick")
|
|
52
|
+
.select("line")
|
|
53
|
+
.attr("transform", `translate(${this.x.step() / 2} , 0)`);
|
|
54
|
+
|
|
55
|
+
this.makeLeftAxis({
|
|
56
|
+
scale: this.y,
|
|
57
|
+
ticks: Math.min(10, this.y.domain()[1]),
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
let bars = this.svg
|
|
61
|
+
.select(".chart__plot")
|
|
62
|
+
.selectAll(".chart__group")
|
|
63
|
+
.data(data)
|
|
64
|
+
.enter()
|
|
65
|
+
.append("g")
|
|
66
|
+
.attr("transform", (d) => `translate(${this.x(d[0].severity)},0)`)
|
|
67
|
+
.selectAll(".bar")
|
|
68
|
+
.data((d) => d)
|
|
69
|
+
.enter()
|
|
70
|
+
.append("rect");
|
|
71
|
+
|
|
72
|
+
bars
|
|
73
|
+
.attr("x", (d) => this.status(d.status))
|
|
74
|
+
.attr("y", this.height)
|
|
75
|
+
.attr("height", 0)
|
|
76
|
+
.attr("width", this.status.step())
|
|
77
|
+
.attr("class", (d) => `chart__bar chart__fill_status_${d.status}`);
|
|
78
|
+
|
|
79
|
+
this.bindTooltip(bars);
|
|
80
|
+
|
|
81
|
+
if (this.firstRender) {
|
|
82
|
+
bars = bars.transition().duration(500);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
bars.attr("y", (d) => this.y(d.value)).attr("height", (d) => this.height - this.y(d.value));
|
|
86
|
+
super.onAttach();
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
getTooltipContent({ value, severity, status, testResults }) {
|
|
90
|
+
const LIST_LIMIT = 10;
|
|
91
|
+
const items = testResults.slice(0, LIST_LIMIT);
|
|
92
|
+
const overLimit = testResults.length - items.length;
|
|
93
|
+
return `<b>${value} ${severity.toLowerCase()} test cases ${status.toLowerCase()}</b><br>
|
|
94
|
+
<ul class="popover__list">
|
|
95
|
+
${items.map((testResult) => escape`<li>${testResult.name}</li>`).join("")}
|
|
96
|
+
</ul>
|
|
97
|
+
${overLimit ? `...and ${overLimit} more` : ""}
|
|
98
|
+
`;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
import { max } from "d3-array";
|
|
2
|
+
import { scaleLinear, scalePoint } from "d3-scale";
|
|
3
|
+
import { scaleOrdinal } from "d3-scale";
|
|
4
|
+
import { schemeCategory10 } from "d3-scale-chromatic";
|
|
5
|
+
import { area, line, stack } from "d3-shape";
|
|
6
|
+
import BaseChartView from "@/components/graph-base/BaseChartView.js";
|
|
7
|
+
import TooltipView from "@/components/tooltip/TooltipView.js";
|
|
8
|
+
import translate from "@/helpers/t.js";
|
|
9
|
+
import "./styles.scss";
|
|
10
|
+
import trendTooltip from "./trend-tooltip.hbs";
|
|
11
|
+
|
|
12
|
+
class TrendChartView extends BaseChartView {
|
|
13
|
+
PAD_BOTTOM = 50;
|
|
14
|
+
|
|
15
|
+
initialize(options) {
|
|
16
|
+
this.x = scalePoint();
|
|
17
|
+
this.y = scaleLinear();
|
|
18
|
+
|
|
19
|
+
this.tooltip = new TooltipView({ position: "top" });
|
|
20
|
+
this.keys = options.keys || this.model.keys();
|
|
21
|
+
|
|
22
|
+
this.stack = stack()
|
|
23
|
+
.keys(this.keys)
|
|
24
|
+
.value((d, key) => d.data[key] || 0);
|
|
25
|
+
|
|
26
|
+
this.color = options.colors || scaleOrdinal(schemeCategory10);
|
|
27
|
+
|
|
28
|
+
options.notStacked && this.stack.offset(() => {});
|
|
29
|
+
this.yTickFormat = options.yTickFormat || ((d) => d);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
onAttach() {
|
|
33
|
+
const data = this.model.toJSON();
|
|
34
|
+
if (data && data.length > 1) {
|
|
35
|
+
this.doShow(data);
|
|
36
|
+
} else {
|
|
37
|
+
this.$el.html(`<div class="widget__noitems">${translate("chart.trend.empty")}</div>`);
|
|
38
|
+
}
|
|
39
|
+
super.onAttach();
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
doShow(data) {
|
|
43
|
+
this.setupViewport();
|
|
44
|
+
this.x.range([0, this.width]);
|
|
45
|
+
this.y.range([this.height, 0]);
|
|
46
|
+
this.x.domain(data.map((d) => d.id));
|
|
47
|
+
this.y.domain([0, max(data, (d) => d.total)]).nice();
|
|
48
|
+
|
|
49
|
+
const trendStack = this.stack(data);
|
|
50
|
+
this.makeBottomAxis({
|
|
51
|
+
scale: this.x,
|
|
52
|
+
tickFormat: (d, i) => data[i].name,
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
this.makeLeftAxis({
|
|
56
|
+
scale: this.y,
|
|
57
|
+
tickFormat: this.yTickFormat,
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
if (document.dir === "rtl") {
|
|
61
|
+
this.svg.selectAll(".chart__axis_x").selectAll("text").style("text-anchor", "start");
|
|
62
|
+
} else {
|
|
63
|
+
this.svg.selectAll(".chart__axis_x").selectAll("text").style("text-anchor", "end");
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
this.svg
|
|
67
|
+
.selectAll(".chart__axis_x")
|
|
68
|
+
.selectAll("text")
|
|
69
|
+
.attr("dx", "-.8em")
|
|
70
|
+
.attr("dy", "-.6em")
|
|
71
|
+
.attr("transform", "rotate(-90)");
|
|
72
|
+
|
|
73
|
+
this.options.hideAreas || this.showAreas(trendStack);
|
|
74
|
+
this.options.hideLines || this.showLines(trendStack);
|
|
75
|
+
this.options.hidePoints || this.showPoints(trendStack);
|
|
76
|
+
this.showSlices(data);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
showAreas(trendStack) {
|
|
80
|
+
const trendArea = area()
|
|
81
|
+
.x((d) => this.x(d.data.id))
|
|
82
|
+
.y0((d) => this.y(d[0]))
|
|
83
|
+
.y1((d) => this.y(d[1]));
|
|
84
|
+
|
|
85
|
+
this.plot
|
|
86
|
+
.selectAll(".trend__area")
|
|
87
|
+
.data(trendStack)
|
|
88
|
+
.enter()
|
|
89
|
+
.append("path")
|
|
90
|
+
.attr("class", "trend__area")
|
|
91
|
+
.attr("d", trendArea)
|
|
92
|
+
.style("fill", (d) => this.color(d.key))
|
|
93
|
+
.style("opacity", 0.85);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
showLines(trendStack) {
|
|
97
|
+
const trendLine = line()
|
|
98
|
+
.x((d) => this.x(d.data.id))
|
|
99
|
+
.y((d) => this.y(d[1]));
|
|
100
|
+
|
|
101
|
+
this.plot
|
|
102
|
+
.selectAll(".trend__line")
|
|
103
|
+
.data(trendStack)
|
|
104
|
+
.enter()
|
|
105
|
+
.append("path")
|
|
106
|
+
.attr("class", ".trend__line")
|
|
107
|
+
.attr("d", trendLine)
|
|
108
|
+
.style("stroke-width", 2)
|
|
109
|
+
.style("stroke", (d) => this.color(d.key));
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
showPoints(trendStack) {
|
|
113
|
+
const points = this.plot
|
|
114
|
+
.selectAll(".trend_points")
|
|
115
|
+
.data(trendStack)
|
|
116
|
+
.enter()
|
|
117
|
+
.append("g")
|
|
118
|
+
.attr("class", ".trend_point")
|
|
119
|
+
.style("fill", (d) => this.color(d.key));
|
|
120
|
+
|
|
121
|
+
points
|
|
122
|
+
.selectAll(".trend_point")
|
|
123
|
+
.data((d) => d)
|
|
124
|
+
.enter()
|
|
125
|
+
.append("circle")
|
|
126
|
+
.attr("r", 2)
|
|
127
|
+
.attr("cx", (d) => this.x(d.data.id))
|
|
128
|
+
.attr("cy", (d) => this.y(d[1]))
|
|
129
|
+
.attr("class", "trend_point");
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
showSlices(data) {
|
|
133
|
+
this.plot.selectAll(".slice").data(data).enter().append("g").attr("class", "slice");
|
|
134
|
+
|
|
135
|
+
this.plot
|
|
136
|
+
.selectAll(".slice")
|
|
137
|
+
.filter((d) => d.reportUrl)
|
|
138
|
+
.append("a")
|
|
139
|
+
.attr("class", "edge")
|
|
140
|
+
.filter((d) => d.reportUrl)
|
|
141
|
+
.attr("xlink:href", (d) => d.reportUrl);
|
|
142
|
+
|
|
143
|
+
this.plot
|
|
144
|
+
.selectAll(".slice")
|
|
145
|
+
.filter((d) => !d.reportUrl)
|
|
146
|
+
.append("g")
|
|
147
|
+
.attr("class", "edge");
|
|
148
|
+
|
|
149
|
+
this.plot
|
|
150
|
+
.selectAll(".edge")
|
|
151
|
+
.append("line")
|
|
152
|
+
.attr("id", (d) => d.id)
|
|
153
|
+
.attr("x1", (d) => this.x(d.id))
|
|
154
|
+
.attr("y1", (d) => this.y(d.total))
|
|
155
|
+
.attr("x2", (d) => this.x(d.id))
|
|
156
|
+
.attr("y2", this.y(0))
|
|
157
|
+
.attr("stroke", "white")
|
|
158
|
+
.attr("stroke-width", 1)
|
|
159
|
+
.attr("class", "report-line");
|
|
160
|
+
|
|
161
|
+
this.plot
|
|
162
|
+
.selectAll(".edge")
|
|
163
|
+
.append("rect")
|
|
164
|
+
.style("opacity", 0.0)
|
|
165
|
+
.attr("class", "report-edge")
|
|
166
|
+
.attr("x", (d, i) => (i > 0 ? this.x(d.id) - this.x.step() / 2 : 0))
|
|
167
|
+
.attr("y", 0)
|
|
168
|
+
.attr("height", this.height)
|
|
169
|
+
.attr("width", (d, i) => (i === 0 || this.x(d.id) === this.width ? this.x.step() / 2 : this.x.step()))
|
|
170
|
+
.on("mouseover", (event, d) => {
|
|
171
|
+
const anchor = this.plot
|
|
172
|
+
.append("circle")
|
|
173
|
+
.attr("class", "anchor")
|
|
174
|
+
.attr("cx", `${this.x(d.id)}`)
|
|
175
|
+
.attr("cy", `${this.y(d.total / 2)}`);
|
|
176
|
+
this.showTooltip(d, anchor.node());
|
|
177
|
+
})
|
|
178
|
+
.on("mouseout", () => {
|
|
179
|
+
this.plot.selectAll(".anchor").remove();
|
|
180
|
+
this.hideTooltip();
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
getTooltipContent(selectedData) {
|
|
185
|
+
const tooltipData = {
|
|
186
|
+
...selectedData,
|
|
187
|
+
data: this.keys
|
|
188
|
+
.map((key) => {
|
|
189
|
+
return {
|
|
190
|
+
key,
|
|
191
|
+
num: this.yTickFormat(selectedData.data[key]),
|
|
192
|
+
color: this.color(key),
|
|
193
|
+
};
|
|
194
|
+
})
|
|
195
|
+
.filter((item) => !!item.num)
|
|
196
|
+
.reverse(),
|
|
197
|
+
};
|
|
198
|
+
return trendTooltip(tooltipData);
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
export default TrendChartView;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import $ from "jquery";
|
|
2
|
+
import PopoverView from "@/components/popover/PopoverView.js";
|
|
3
|
+
import { className, on } from "@/decorators/index.js";
|
|
4
|
+
import gtag from "@/utils/gtag.js";
|
|
5
|
+
import settings from "@/utils/settings.js";
|
|
6
|
+
import i18next, { LANGUAGES } from "@/utils/translation.js";
|
|
7
|
+
import template from "./LanguageSelectView.hbs";
|
|
8
|
+
import "./styles.scss";
|
|
9
|
+
|
|
10
|
+
@className("language-select popover")
|
|
11
|
+
class LanguageSelectView extends PopoverView {
|
|
12
|
+
initialize() {
|
|
13
|
+
super.initialize({ position: "top-right" });
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
setContent() {
|
|
17
|
+
this.$el.html(
|
|
18
|
+
template({
|
|
19
|
+
languages: LANGUAGES,
|
|
20
|
+
currentLang: settings.getLanguage(),
|
|
21
|
+
}),
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
show(anchor) {
|
|
26
|
+
super.show(null, anchor);
|
|
27
|
+
this.delegateEvents();
|
|
28
|
+
setTimeout(() => {
|
|
29
|
+
$(document).one("click", () => this.hide());
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
@on("click .language-select__item")
|
|
34
|
+
onLanguageClick(e) {
|
|
35
|
+
const langId = this.$(e.currentTarget).data("id");
|
|
36
|
+
settings.setLanguage(langId);
|
|
37
|
+
i18next.changeLanguage(langId);
|
|
38
|
+
gtag("language_change", { language: langId });
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export default LanguageSelectView;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="14" height="15" viewBox="0 0 14 15"><path d="M12.035.373l-7.531 11.268-3.529-3.934-.976 1.242 4.625 5.109 8.546-12.598z"/></svg>
|