@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,32 @@
|
|
|
1
|
+
@import "../../mixins.scss";
|
|
2
|
+
|
|
3
|
+
.status-details {
|
|
4
|
+
overflow: auto;
|
|
5
|
+
margin-bottom: 7px;
|
|
6
|
+
@include status-border();
|
|
7
|
+
@include status-bg-light();
|
|
8
|
+
&__expanded > &__content > &__trace {
|
|
9
|
+
display: block;
|
|
10
|
+
}
|
|
11
|
+
&__expanded > &__content {
|
|
12
|
+
display: inline-block;
|
|
13
|
+
}
|
|
14
|
+
&__message {
|
|
15
|
+
padding: $gap-size;
|
|
16
|
+
}
|
|
17
|
+
&__trace {
|
|
18
|
+
float: left;
|
|
19
|
+
display: none;
|
|
20
|
+
padding: $gap-size;
|
|
21
|
+
white-space: pre;
|
|
22
|
+
border-top: 1px solid $pane-bg-color;
|
|
23
|
+
}
|
|
24
|
+
&__content {
|
|
25
|
+
display: block;
|
|
26
|
+
}
|
|
27
|
+
&__trace-toggle {
|
|
28
|
+
&:hover {
|
|
29
|
+
background-color: $hover-color;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
<span class="step-stats">
|
|
2
|
+
{{~#if parameters.length ~}}
|
|
3
|
+
<span class="step-stats__info">{{~t 'testResult.stats.count.parameters' count=parameters.length~}}</span>
|
|
4
|
+
<span class="step-stats__separator">, </span>
|
|
5
|
+
{{~/if~}}
|
|
6
|
+
{{~#if stepsCount ~}}
|
|
7
|
+
<span class="step-stats__info">{{~t 'testResult.stats.count.steps' count=stepsCount~}}</span>
|
|
8
|
+
<span class="step-stats__separator">, </span>
|
|
9
|
+
{{~/if~}}
|
|
10
|
+
{{~#if attachmentsCount ~}}
|
|
11
|
+
<span class="step-stats__info">{{~t 'testResult.stats.count.attachments' count=attachmentsCount~}}</span>
|
|
12
|
+
<span class="step-stats__separator">, </span>
|
|
13
|
+
{{~/if~}}
|
|
14
|
+
</span>
|
|
15
|
+
<span class="step-stats__info step-stats__info_time" data-tooltip="{{date time.start}} {{time time.start true}} – {{time time.stop true}}">{{duration time.duration}}</span>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.step-stats {
|
|
4
|
+
display: contents;
|
|
5
|
+
|
|
6
|
+
&__info {
|
|
7
|
+
color: $text-muted-color;
|
|
8
|
+
font-size: small;
|
|
9
|
+
white-space: nowrap;
|
|
10
|
+
|
|
11
|
+
&_time {
|
|
12
|
+
float: right;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
&__separator:last-child {
|
|
17
|
+
display: none;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="512" height="512" viewBox="0 0 512 512"><path fill="#a5a5a5" d="M256 50l132.034 176h-264.068l132.034-176z"/><path d="M388.034 286h-264.068l132.034 176 132.034-176z"/></svg>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="512" height="512" viewBox="0 0 512 512"><path fill="#a5a5a5" d="M256 50l132.034 176h-264.068l132.034-176zM388.034 286h-264.068l132.034 176 132.034-176z"/></svg>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="512" height="512" viewBox="0 0 512 512"><path d="M256 50l132.034 176h-264.068l132.034-176z"/><path fill="#a5a5a5" d="M388.034 286h-264.068l132.034 176 132.034-176z"/></svg>
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.table {
|
|
4
|
+
&__row,
|
|
5
|
+
&__head {
|
|
6
|
+
display: flex;
|
|
7
|
+
}
|
|
8
|
+
&__row {
|
|
9
|
+
border-bottom: 1px solid $border-color;
|
|
10
|
+
text-decoration: none;
|
|
11
|
+
color: $text-color;
|
|
12
|
+
}
|
|
13
|
+
&__head {
|
|
14
|
+
border-bottom: 1px solid $border-accent-color;
|
|
15
|
+
font-weight: bold;
|
|
16
|
+
}
|
|
17
|
+
&__col {
|
|
18
|
+
line-height: 1.5em;
|
|
19
|
+
padding: 10px 15px;
|
|
20
|
+
flex: 1;
|
|
21
|
+
&_center {
|
|
22
|
+
text-align: center;
|
|
23
|
+
}
|
|
24
|
+
&_right {
|
|
25
|
+
text-align: right;
|
|
26
|
+
justify-content: flex-end;
|
|
27
|
+
}
|
|
28
|
+
&_sortable {
|
|
29
|
+
cursor: pointer;
|
|
30
|
+
display: flex;
|
|
31
|
+
& > span {
|
|
32
|
+
overflow: hidden;
|
|
33
|
+
padding-right: 5px;
|
|
34
|
+
}
|
|
35
|
+
&:after {
|
|
36
|
+
flex-shrink: 0;
|
|
37
|
+
vertical-align: middle;
|
|
38
|
+
content: " ";
|
|
39
|
+
display: inline-block;
|
|
40
|
+
width: 12px;
|
|
41
|
+
height: 18px;
|
|
42
|
+
background: url(./sort-icon.svg?inline) center no-repeat;
|
|
43
|
+
background-size: contain;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
&_sorted_down:after {
|
|
47
|
+
background-image: url(./sort-down-icon.svg?inline);
|
|
48
|
+
}
|
|
49
|
+
&_sorted_up:after {
|
|
50
|
+
background-image: url(./sort-up-icon.svg?inline);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
&_hover {
|
|
54
|
+
.table__row:not([disabled]):hover {
|
|
55
|
+
background: $hover-color;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
.table__row_summary {
|
|
59
|
+
background: $summary-color;
|
|
60
|
+
}
|
|
61
|
+
.table__row_active {
|
|
62
|
+
background: $selected-color;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.tabs {
|
|
4
|
+
list-style-type: none;
|
|
5
|
+
position: relative;
|
|
6
|
+
// top: -1px;
|
|
7
|
+
background: #fff;
|
|
8
|
+
border-bottom: 1px solid $border-accent-color;
|
|
9
|
+
padding: 0;
|
|
10
|
+
margin: 0;
|
|
11
|
+
}
|
|
12
|
+
.tab {
|
|
13
|
+
display: inline-block;
|
|
14
|
+
font-size: 16px;
|
|
15
|
+
& > a {
|
|
16
|
+
display: inline-block;
|
|
17
|
+
padding: calc($gap-size / 2) $gap-size;
|
|
18
|
+
border-bottom: 3px solid transparent;
|
|
19
|
+
&:hover {
|
|
20
|
+
border-bottom-color: $border-color;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
&_active > a {
|
|
24
|
+
&,
|
|
25
|
+
&:hover {
|
|
26
|
+
border-bottom-color: $text-color;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns='http://www.w3.org/2000/svg' width='5' height='5'><rect x='0' y='0' width='3' height='3' fill='#cccccc' /></svg>
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.widget {
|
|
4
|
+
margin-bottom: $gap-size;
|
|
5
|
+
position: relative;
|
|
6
|
+
|
|
7
|
+
&_ghost {
|
|
8
|
+
border: 1px dashed $border-accent-color;
|
|
9
|
+
box-shadow: none;
|
|
10
|
+
min-height: 50px;
|
|
11
|
+
& > * {
|
|
12
|
+
display: none;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
&__title {
|
|
17
|
+
margin-top: 0;
|
|
18
|
+
margin-bottom: 15px;
|
|
19
|
+
font-weight: lighter;
|
|
20
|
+
text-transform: uppercase;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
&__subtitle {
|
|
24
|
+
color: $text-muted-color;
|
|
25
|
+
font-size: 16px;
|
|
26
|
+
text-transform: none;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
&__noitems {
|
|
30
|
+
font-size: 16px;
|
|
31
|
+
text-align: center;
|
|
32
|
+
padding: 10px 15px;
|
|
33
|
+
line-height: 1.5em;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
&__flex-line {
|
|
37
|
+
display: flex;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
&__column {
|
|
41
|
+
width: 50%;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
&__handle {
|
|
45
|
+
display: none;
|
|
46
|
+
position: absolute;
|
|
47
|
+
right: $gap-size;
|
|
48
|
+
top: $gap-size;
|
|
49
|
+
color: $text-muted-color;
|
|
50
|
+
cursor: move; /* fallback if grab cursor is unsupported */
|
|
51
|
+
cursor: grab;
|
|
52
|
+
|
|
53
|
+
&:active {
|
|
54
|
+
cursor: grabbing;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.widget:hover & {
|
|
58
|
+
display: block;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
&__table {
|
|
63
|
+
border-top: 1px solid $border-color;
|
|
64
|
+
margin: 0 (-$gap-size);
|
|
65
|
+
word-break: break-all;
|
|
66
|
+
.table__row:last-child {
|
|
67
|
+
border-bottom: 0;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
.draggable-icon {
|
|
73
|
+
position: absolute;
|
|
74
|
+
right: 0;
|
|
75
|
+
z-index: 1;
|
|
76
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
{{#if (eq type "custom")}}
|
|
2
|
+
<div class="attachment__custom-view"></div>
|
|
3
|
+
{{else if (eq type "code")}}
|
|
4
|
+
<div class="{{b 'attachment__text-container' fullscreen=fullScreen}}">
|
|
5
|
+
<pre class="attachment__code">{{content}}</pre>
|
|
6
|
+
</div>
|
|
7
|
+
{{else if (eq type "text")}}
|
|
8
|
+
<div class="{{b 'attachment__text-container' fullscreen=fullScreen}}">
|
|
9
|
+
<pre class="attachment__text">{{content}}</pre>
|
|
10
|
+
</div>
|
|
11
|
+
{{else if (eq type "table")}}
|
|
12
|
+
<div class="{{b 'attachment__table-container' fullscreen=fullScreen}}">
|
|
13
|
+
<table class="table attachment__table">
|
|
14
|
+
<tbody>
|
|
15
|
+
{{#each content}}
|
|
16
|
+
<tr>
|
|
17
|
+
{{#each .}}
|
|
18
|
+
<td>{{.}}</td>
|
|
19
|
+
{{/each}}
|
|
20
|
+
</tr>
|
|
21
|
+
{{/each}}
|
|
22
|
+
</tbody>
|
|
23
|
+
</table>
|
|
24
|
+
</div>
|
|
25
|
+
{{else if (eq type "image")}}
|
|
26
|
+
<div class="{{b 'attachment__media-container' fullscreen=fullScreen}}"><img class="attachment__media" src="{{sourceUrl}}"/>
|
|
27
|
+
</div>
|
|
28
|
+
{{else if (eq type "svg")}}
|
|
29
|
+
<object class="attachment__embed" type="image/svg+xml" data="{{sourceUrl}}">
|
|
30
|
+
Your browser does not support SVG
|
|
31
|
+
</object>
|
|
32
|
+
{{else if (eq type "video")}}
|
|
33
|
+
<div class="attachment__media-container">
|
|
34
|
+
<video class="attachment__media" controls>
|
|
35
|
+
<source src="{{sourceUrl}}" type="{{attachment.type}}">
|
|
36
|
+
Your browser does not support video tag
|
|
37
|
+
</video>
|
|
38
|
+
</div>
|
|
39
|
+
{{else if (eq type "uri")}}
|
|
40
|
+
<div class="{{b 'attachment__text-container' fullscreen=fullScreen}}">
|
|
41
|
+
{{#each content}}
|
|
42
|
+
<p class="{{b 'attachment' 'url' comment=comment}}">
|
|
43
|
+
{{#if comment}}
|
|
44
|
+
{{text}}
|
|
45
|
+
{{else}}
|
|
46
|
+
<a href="{{text}}" target="_blank" class="link">{{text}}</a>
|
|
47
|
+
{{/if}}
|
|
48
|
+
</p>
|
|
49
|
+
{{/each}}
|
|
50
|
+
</div>
|
|
51
|
+
{{else if (eq type "html")}}
|
|
52
|
+
<iframe class="{{b 'attachment__iframe' fullscreen=fullScreen}}" frameborder="0" src="{{sourceUrl}}"></iframe>
|
|
53
|
+
{{else}}
|
|
54
|
+
<div class="{{b 'attachment__text-container' fullscreen=fullScreen}}">
|
|
55
|
+
{{allure-icon "download" noTooltip=true width="14px" height="14px"}}
|
|
56
|
+
<a class="link" href="{{sourceUrl}}" download="{{attachment.name}}">Click to download attachment</a>
|
|
57
|
+
</div>
|
|
58
|
+
{{/if}}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { reportDataUrl } from "@allurereport/web-commons";
|
|
2
|
+
import { $ } from "backbone";
|
|
3
|
+
import { View } from "backbone.marionette";
|
|
4
|
+
import { behavior, className, on, regions } from "@/decorators/index.js";
|
|
5
|
+
import router from "@/router.js";
|
|
6
|
+
import attachmentType from "@/utils/attachmentType.js";
|
|
7
|
+
import highlight from "@/utils/highlight.js";
|
|
8
|
+
import template from "./AttachmentView.hbs";
|
|
9
|
+
import "./styles.scss";
|
|
10
|
+
|
|
11
|
+
@className("attachment")
|
|
12
|
+
@behavior("TooltipBehavior", { position: "bottom" })
|
|
13
|
+
@regions({
|
|
14
|
+
customView: ".attachment__custom-view",
|
|
15
|
+
})
|
|
16
|
+
class AttachmentView extends View {
|
|
17
|
+
template = template;
|
|
18
|
+
|
|
19
|
+
initialize() {
|
|
20
|
+
this.fullScreen = !!this.options.fullScreen;
|
|
21
|
+
this.attachment = this.options.attachment;
|
|
22
|
+
this.attachmentInfo = attachmentType(this.attachment.type);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
onRender() {
|
|
26
|
+
if (!this.sourceUrl) {
|
|
27
|
+
reportDataUrl(`data/attachments/${this.attachment.source}`, this.attachment.type)
|
|
28
|
+
.then((sourceUrl) => {
|
|
29
|
+
this.sourceUrl = sourceUrl;
|
|
30
|
+
})
|
|
31
|
+
.then(() => {
|
|
32
|
+
if (this.needsFetch()) {
|
|
33
|
+
return this.loadContent();
|
|
34
|
+
}
|
|
35
|
+
})
|
|
36
|
+
.then(this.render);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
if (this.attachmentInfo.type === "custom") {
|
|
40
|
+
this.showChildView(
|
|
41
|
+
"customView",
|
|
42
|
+
new this.attachmentInfo.View({
|
|
43
|
+
sourceUrl: this.sourceUrl,
|
|
44
|
+
attachment: this.attachment,
|
|
45
|
+
}),
|
|
46
|
+
);
|
|
47
|
+
} else if (this.attachmentInfo.type === "code") {
|
|
48
|
+
const codeBlock = this.$(".attachment__code");
|
|
49
|
+
codeBlock.addClass(`language-${this.attachment.type.split("/").pop()}`);
|
|
50
|
+
highlight.highlightElement(codeBlock[0]);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
onDestroy() {
|
|
55
|
+
router.setSearch({ attachment: null });
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
@on("click .attachment__media-container")
|
|
59
|
+
onImageClick(e) {
|
|
60
|
+
const el = this.$(e.currentTarget);
|
|
61
|
+
if (el.hasClass("attachment__media-container_fullscreen")) {
|
|
62
|
+
this.onDestroy();
|
|
63
|
+
} else {
|
|
64
|
+
router.setSearch({ attachment: this.attachment.uid });
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
needsFetch() {
|
|
69
|
+
return "parser" in this.attachmentInfo;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
loadContent() {
|
|
73
|
+
return $.ajax(this.sourceUrl, { dataType: "text" }).then((responseText) => {
|
|
74
|
+
const parser = this.attachmentInfo.parser;
|
|
75
|
+
this.content = parser(responseText);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
serializeData() {
|
|
80
|
+
return {
|
|
81
|
+
type: this.attachmentInfo.type,
|
|
82
|
+
content: this.content,
|
|
83
|
+
sourceUrl: this.sourceUrl,
|
|
84
|
+
attachment: this.attachment,
|
|
85
|
+
fullScreen: this.fullScreen,
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
export default AttachmentView;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
@import "../../variables.scss";
|
|
2
|
+
|
|
3
|
+
.attachment {
|
|
4
|
+
&__filename {
|
|
5
|
+
background: $heading-bg;
|
|
6
|
+
padding: $gap-size;
|
|
7
|
+
}
|
|
8
|
+
&__text {
|
|
9
|
+
white-space: pre-wrap;
|
|
10
|
+
word-break: break-word;
|
|
11
|
+
margin: 0;
|
|
12
|
+
padding: 0;
|
|
13
|
+
}
|
|
14
|
+
&__code {
|
|
15
|
+
font: 14px normal "Courier New" monospace;
|
|
16
|
+
white-space: pre-wrap;
|
|
17
|
+
word-break: break-word;
|
|
18
|
+
margin: 0;
|
|
19
|
+
padding: 0;
|
|
20
|
+
}
|
|
21
|
+
&__table {
|
|
22
|
+
width: 100%;
|
|
23
|
+
|
|
24
|
+
tr {
|
|
25
|
+
border-bottom: 1px solid $border-color;
|
|
26
|
+
}
|
|
27
|
+
td {
|
|
28
|
+
padding: 10px 15px;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
&__url {
|
|
32
|
+
padding: 0 $gap-size;
|
|
33
|
+
margin: 0.5em 0;
|
|
34
|
+
|
|
35
|
+
&_comment {
|
|
36
|
+
color: $text-muted-color;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
&__table-container {
|
|
40
|
+
overflow: auto;
|
|
41
|
+
}
|
|
42
|
+
&__text-container,
|
|
43
|
+
&__table-container {
|
|
44
|
+
&_fullscreen {
|
|
45
|
+
padding: $gap-size;
|
|
46
|
+
background-color: $pane-bg-color;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
&__media-container {
|
|
50
|
+
text-align: center;
|
|
51
|
+
cursor: zoom-in;
|
|
52
|
+
|
|
53
|
+
&_fullscreen {
|
|
54
|
+
cursor: zoom-out;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
&__iframe-container {
|
|
58
|
+
height: 100%;
|
|
59
|
+
}
|
|
60
|
+
&__embed,
|
|
61
|
+
&__media {
|
|
62
|
+
max-width: 100%;
|
|
63
|
+
display: block;
|
|
64
|
+
margin: auto;
|
|
65
|
+
|
|
66
|
+
&_fullscreen {
|
|
67
|
+
margin: auto;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
&__iframe {
|
|
71
|
+
width: 100%;
|
|
72
|
+
|
|
73
|
+
&_fullscreen {
|
|
74
|
+
background-color: $pane-bg-color;
|
|
75
|
+
height: 85vh;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { View } from "backbone.marionette";
|
|
2
|
+
import { className } from "@/decorators/index.js";
|
|
3
|
+
import template from "./EmptyView.hbs";
|
|
4
|
+
import "./styles.scss";
|
|
5
|
+
|
|
6
|
+
@className("empty-view")
|
|
7
|
+
class EmptyView extends View {
|
|
8
|
+
template = template;
|
|
9
|
+
|
|
10
|
+
serializeData() {
|
|
11
|
+
return {
|
|
12
|
+
cls: this.className,
|
|
13
|
+
message: this.options.message,
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export default EmptyView;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { View } from "backbone.marionette";
|
|
2
|
+
import { className } from "@/decorators/index.js";
|
|
3
|
+
import template from "./ErrorSplashView.hbs";
|
|
4
|
+
import "./styles.scss";
|
|
5
|
+
|
|
6
|
+
@className("error-splash")
|
|
7
|
+
class ErrorSplashView extends View {
|
|
8
|
+
template = template;
|
|
9
|
+
|
|
10
|
+
serializeData() {
|
|
11
|
+
return {
|
|
12
|
+
cls: this.className,
|
|
13
|
+
code: this.options.code,
|
|
14
|
+
message: this.options.message,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export default ErrorSplashView;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { View } from "backbone";
|
|
2
|
+
import { axisBottom, axisLeft } from "d3-axis";
|
|
3
|
+
import { select } from "d3-selection";
|
|
4
|
+
import template from "./BaseChartView.hbs";
|
|
5
|
+
import "./styles.scss";
|
|
6
|
+
|
|
7
|
+
export default class BaseChartView extends View {
|
|
8
|
+
PAD_LEFT = 50;
|
|
9
|
+
PAD_RIGHT = 15;
|
|
10
|
+
PAD_TOP = 10;
|
|
11
|
+
PAD_BOTTOM = 30;
|
|
12
|
+
|
|
13
|
+
constructor(options) {
|
|
14
|
+
super(options);
|
|
15
|
+
this.options = options;
|
|
16
|
+
this.firstRender = true;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
onRender() {
|
|
20
|
+
select(window).on(`resize.${this.cid}`, this.onAttach.bind(this));
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
onDestroy() {
|
|
24
|
+
select(window).on(`resize.${this.cid}`, null);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
onAttach() {
|
|
28
|
+
this.firstRender = false;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
setupViewport() {
|
|
32
|
+
this.width = Math.floor(this.$el.outerWidth()) - this.PAD_LEFT - this.PAD_RIGHT;
|
|
33
|
+
this.height = Math.floor(this.$el.outerHeight()) - this.PAD_BOTTOM - this.PAD_TOP;
|
|
34
|
+
this.$el.html(template(this));
|
|
35
|
+
this.svg = select(this.$el[0]).select(".chart__svg");
|
|
36
|
+
this.plot = this.svg.select(".chart__plot");
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
makeLeftAxis(options) {
|
|
40
|
+
const axis = axisLeft();
|
|
41
|
+
return this.makeAxis(axis, this.svg.select(".chart__axis_y"), options, {
|
|
42
|
+
left: this.PAD_LEFT,
|
|
43
|
+
top: this.PAD_TOP,
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
makeBottomAxis(options) {
|
|
48
|
+
const axis = axisBottom();
|
|
49
|
+
return this.makeAxis(axis, this.svg.select(".chart__axis_x"), options, {
|
|
50
|
+
left: this.PAD_LEFT,
|
|
51
|
+
top: this.PAD_TOP + this.height,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
makeAxis(axis, element, options, { left = 0, top = 0 } = {}) {
|
|
56
|
+
Object.keys(options).forEach((option) => axis[option](options[option]));
|
|
57
|
+
element.call(axis).attr("transform", `translate(${left},${top})`);
|
|
58
|
+
return axis;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
getTooltipContent() {}
|
|
62
|
+
|
|
63
|
+
onItemOver(event, d) {
|
|
64
|
+
this.showTooltip(d, event.target);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
showTooltip(d, element) {
|
|
68
|
+
this.tooltip.show(this.getTooltipContent(d), this.$(element));
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
hideTooltip() {
|
|
72
|
+
this.tooltip.hide();
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
bindTooltip(selection) {
|
|
76
|
+
selection.on("mouseenter", this.onItemOver.bind(this)).on("mouseleave", this.hideTooltip.bind(this));
|
|
77
|
+
}
|
|
78
|
+
}
|