@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.
Files changed (391) hide show
  1. package/.babelrc.cjs +18 -0
  2. package/.eslintrc.cjs +125 -0
  3. package/README.md +27 -0
  4. package/dist/multi/154.app-9ac9d027.js +1 -0
  5. package/dist/multi/216.app-9ac9d027.js +1 -0
  6. package/dist/multi/232.app-9ac9d027.js +1 -0
  7. package/dist/multi/250.app-9ac9d027.js +1 -0
  8. package/dist/multi/256.app-9ac9d027.js +1 -0
  9. package/dist/multi/301.app-9ac9d027.js +1 -0
  10. package/dist/multi/323.app-9ac9d027.js +1 -0
  11. package/dist/multi/353.app-9ac9d027.js +1 -0
  12. package/dist/multi/411d15fc5bb62472eea6ead4fb276ca9.ico +0 -0
  13. package/dist/multi/564.app-9ac9d027.js +1 -0
  14. package/dist/multi/594.app-9ac9d027.js +1 -0
  15. package/dist/multi/623.app-9ac9d027.js +1 -0
  16. package/dist/multi/7.app-9ac9d027.js +1 -0
  17. package/dist/multi/729.app-9ac9d027.js +1 -0
  18. package/dist/multi/783.app-9ac9d027.js +1 -0
  19. package/dist/multi/826.app-9ac9d027.js +1 -0
  20. package/dist/multi/925.app-9ac9d027.js +1 -0
  21. package/dist/multi/app-9ac9d027.js +2 -0
  22. package/dist/multi/app-9ac9d027.js.LICENSE.txt +29 -0
  23. package/dist/multi/checkmark-c1a9ce12.svg +8 -0
  24. package/dist/multi/manifest.json +27 -0
  25. package/dist/multi/sort-down-icon-41195b0d.svg +8 -0
  26. package/dist/multi/sort-icon-fddc6c81.svg +8 -0
  27. package/dist/multi/sort-up-icon-d5bc65f6.svg +8 -0
  28. package/dist/multi/sprite.svg +4 -0
  29. package/dist/multi/styles-9ac9d027.css +558 -0
  30. package/dist/multi/vertical-5e6d1df4.png +0 -0
  31. package/dist/single/411d15fc5bb62472eea6ead4fb276ca9.ico +0 -0
  32. package/dist/single/app-f726ff87.js +2 -0
  33. package/dist/single/app-f726ff87.js.LICENSE.txt +29 -0
  34. package/dist/single/checkmark-c1a9ce12.svg +8 -0
  35. package/dist/single/manifest.json +10 -0
  36. package/dist/single/sort-down-icon-41195b0d.svg +8 -0
  37. package/dist/single/sort-icon-fddc6c81.svg +8 -0
  38. package/dist/single/sort-up-icon-d5bc65f6.svg +8 -0
  39. package/dist/single/sprite.svg +4 -0
  40. package/dist/single/styles-f726ff87.css +558 -0
  41. package/package.json +107 -0
  42. package/src/app.js +69 -0
  43. package/src/assets/icons/allure-logo.svg +45 -0
  44. package/src/assets/icons/bamboo.svg +31 -0
  45. package/src/assets/icons/bitbucket.svg +10 -0
  46. package/src/assets/icons/bomb.svg +7 -0
  47. package/src/assets/icons/broken.svg +10 -0
  48. package/src/assets/icons/bug.svg +10 -0
  49. package/src/assets/icons/chevron-down.svg +10 -0
  50. package/src/assets/icons/chevron-left.svg +10 -0
  51. package/src/assets/icons/chevron-right-fat.svg +10 -0
  52. package/src/assets/icons/chevron-right.svg +10 -0
  53. package/src/assets/icons/chevron-up.svg +10 -0
  54. package/src/assets/icons/circleci.svg +1 -0
  55. package/src/assets/icons/close.svg +10 -0
  56. package/src/assets/icons/collapse.svg +5 -0
  57. package/src/assets/icons/compare.svg +10 -0
  58. package/src/assets/icons/copy.svg +11 -0
  59. package/src/assets/icons/csv.svg +13 -0
  60. package/src/assets/icons/download.svg +11 -0
  61. package/src/assets/icons/draggable.svg +15 -0
  62. package/src/assets/icons/expand.svg +5 -0
  63. package/src/assets/icons/failed.svg +10 -0
  64. package/src/assets/icons/file.svg +3 -0
  65. package/src/assets/icons/folder.svg +10 -0
  66. package/src/assets/icons/github.svg +4 -0
  67. package/src/assets/icons/gitlab.svg +12 -0
  68. package/src/assets/icons/graphs.svg +11 -0
  69. package/src/assets/icons/history.svg +11 -0
  70. package/src/assets/icons/image.svg +3 -0
  71. package/src/assets/icons/info.svg +12 -0
  72. package/src/assets/icons/jenkins.svg +327 -0
  73. package/src/assets/icons/jobs.svg +12 -0
  74. package/src/assets/icons/link.svg +11 -0
  75. package/src/assets/icons/list.svg +13 -0
  76. package/src/assets/icons/maximize.svg +11 -0
  77. package/src/assets/icons/new-broken.svg +6 -0
  78. package/src/assets/icons/new-failed.svg +6 -0
  79. package/src/assets/icons/new-passed.svg +5 -0
  80. package/src/assets/icons/overview.svg +5 -0
  81. package/src/assets/icons/passed.svg +10 -0
  82. package/src/assets/icons/pdf.svg +13 -0
  83. package/src/assets/icons/refresh.svg +4 -0
  84. package/src/assets/icons/retries.svg +11 -0
  85. package/src/assets/icons/save.svg +10 -0
  86. package/src/assets/icons/skipped.svg +3 -0
  87. package/src/assets/icons/sort-down.svg +10 -0
  88. package/src/assets/icons/sort-up.svg +10 -0
  89. package/src/assets/icons/sort.svg +11 -0
  90. package/src/assets/icons/table.svg +10 -0
  91. package/src/assets/icons/task.svg +11 -0
  92. package/src/assets/icons/teamcity.svg +40 -0
  93. package/src/assets/icons/timeline.svg +12 -0
  94. package/src/assets/icons/tree.svg +10 -0
  95. package/src/assets/icons/txt.svg +11 -0
  96. package/src/assets/icons/unknown.svg +10 -0
  97. package/src/behaviors/ClipboardBehavior.js +34 -0
  98. package/src/behaviors/DownloadBehavior.js +42 -0
  99. package/src/behaviors/GaBehavior.js +27 -0
  100. package/src/behaviors/LoadBehavior.js +18 -0
  101. package/src/behaviors/TooltipBehavior.js +25 -0
  102. package/src/behaviors/index.js +7 -0
  103. package/src/blocks/alert/styles.scss +8 -0
  104. package/src/blocks/arrow/styles.scss +21 -0
  105. package/src/blocks/attachment-row/attachment-row.hbs +34 -0
  106. package/src/blocks/attachment-row/styles.scss +71 -0
  107. package/src/blocks/bar/styles.scss +22 -0
  108. package/src/blocks/button/styles.scss +60 -0
  109. package/src/blocks/clipboard-copy/clipboard-copy.hbs +5 -0
  110. package/src/blocks/executor-icon/bamboo.svg +31 -0
  111. package/src/blocks/executor-icon/bitbucket.svg +10 -0
  112. package/src/blocks/executor-icon/circleci.svg +1 -0
  113. package/src/blocks/executor-icon/default-icon.png +0 -0
  114. package/src/blocks/executor-icon/github.svg +4 -0
  115. package/src/blocks/executor-icon/gitlab.svg +12 -0
  116. package/src/blocks/executor-icon/jenkins.svg +327 -0
  117. package/src/blocks/executor-icon/styles.scss +15 -0
  118. package/src/blocks/executor-icon/teamcity.svg +40 -0
  119. package/src/blocks/island/styles.scss +7 -0
  120. package/src/blocks/label/styles.scss +15 -0
  121. package/src/blocks/link/styles.scss +10 -0
  122. package/src/blocks/pane/styles.scss +52 -0
  123. package/src/blocks/pane-header/pane-header.hbs +15 -0
  124. package/src/blocks/parameters-table/parameters-table.hbs +10 -0
  125. package/src/blocks/parameters-table/styles.scss +22 -0
  126. package/src/blocks/spinner/styles.scss +30 -0
  127. package/src/blocks/splash/styles.scss +13 -0
  128. package/src/blocks/status-details/status-details.hbs +13 -0
  129. package/src/blocks/status-details/styles.scss +32 -0
  130. package/src/blocks/step-stats/step-stats.hbs +15 -0
  131. package/src/blocks/step-stats/styles.scss +19 -0
  132. package/src/blocks/table/sort-down-icon.svg +1 -0
  133. package/src/blocks/table/sort-icon.svg +1 -0
  134. package/src/blocks/table/sort-up-icon.svg +1 -0
  135. package/src/blocks/table/sortable-col.hbs +4 -0
  136. package/src/blocks/table/styles.scss +64 -0
  137. package/src/blocks/tabs/styles.scss +29 -0
  138. package/src/blocks/tabs/tabs.hbs +5 -0
  139. package/src/blocks/text/styles.scss +5 -0
  140. package/src/blocks/widget/draggable.svg +1 -0
  141. package/src/blocks/widget/styles.scss +76 -0
  142. package/src/components/attachment/AttachmentView.hbs +58 -0
  143. package/src/components/attachment/AttachmentView.js +90 -0
  144. package/src/components/attachment/styles.scss +78 -0
  145. package/src/components/empty/EmptyView.hbs +3 -0
  146. package/src/components/empty/EmptyView.js +18 -0
  147. package/src/components/empty/styles.scss +4 -0
  148. package/src/components/error-splash/ErrorSplashView.hbs +4 -0
  149. package/src/components/error-splash/ErrorSplashView.js +19 -0
  150. package/src/components/error-splash/styles.scss +4 -0
  151. package/src/components/graph-base/BaseChartView.hbs +5 -0
  152. package/src/components/graph-base/BaseChartView.js +78 -0
  153. package/src/components/graph-base/styles.scss +66 -0
  154. package/src/components/graph-duration-chart/DurationChartView.js +100 -0
  155. package/src/components/graph-pie-chart/PieChartView.js +155 -0
  156. package/src/components/graph-severity-chart/SeverityChartView.js +100 -0
  157. package/src/components/graph-trend-chart/TrendChartView.js +202 -0
  158. package/src/components/graph-trend-chart/styles.scss +16 -0
  159. package/src/components/graph-trend-chart/trend-tooltip.hbs +9 -0
  160. package/src/components/language-select/LanguageSelectView.hbs +5 -0
  161. package/src/components/language-select/LanguageSelectView.js +42 -0
  162. package/src/components/language-select/checkmark.svg +1 -0
  163. package/src/components/language-select/styles.scss +34 -0
  164. package/src/components/loader/LoaderView.hbs +6 -0
  165. package/src/components/loader/LoaderView.js +21 -0
  166. package/src/components/loader/styles.scss +26 -0
  167. package/src/components/marks-toggle/MarksToggleView.hbs +14 -0
  168. package/src/components/marks-toggle/MarksToggleView.js +41 -0
  169. package/src/components/marks-toggle/styles.scss +38 -0
  170. package/src/components/modal/ModalView.hbs +13 -0
  171. package/src/components/modal/ModalView.js +43 -0
  172. package/src/components/modal/styles.scss +31 -0
  173. package/src/components/node-search/NodeSearchView.hbs +4 -0
  174. package/src/components/node-search/NodeSearchView.js +32 -0
  175. package/src/components/node-search/styles.scss +29 -0
  176. package/src/components/node-sorter/NodeSorterView.hbs +22 -0
  177. package/src/components/node-sorter/NodeSorterView.js +43 -0
  178. package/src/components/node-sorter/styles.scss +26 -0
  179. package/src/components/popover/PopoverView.js +8 -0
  180. package/src/components/popover/styles.scss +32 -0
  181. package/src/components/side-by-side/SideBySideView.hbs +2 -0
  182. package/src/components/side-by-side/SideBySideView.js +42 -0
  183. package/src/components/side-by-side/styles.scss +59 -0
  184. package/src/components/side-by-side/vertical.png +0 -0
  185. package/src/components/side-nav/SideNavView.hbs +39 -0
  186. package/src/components/side-nav/SideNavView.js +81 -0
  187. package/src/components/side-nav/styles.scss +118 -0
  188. package/src/components/status-toggle/StatusToggleView.hbs +16 -0
  189. package/src/components/status-toggle/StatusToggleView.js +42 -0
  190. package/src/components/status-toggle/styles.scss +35 -0
  191. package/src/components/testresult/TestResultView.hbs +32 -0
  192. package/src/components/testresult/TestResultView.js +90 -0
  193. package/src/components/testresult/styles.scss +29 -0
  194. package/src/components/testresult-execution/TestResultExecutionView.hbs +13 -0
  195. package/src/components/testresult-execution/TestResultExecutionView.js +85 -0
  196. package/src/components/testresult-execution/stages-block.hbs +47 -0
  197. package/src/components/testresult-execution/steps-list.hbs +31 -0
  198. package/src/components/testresult-execution/styles.scss +70 -0
  199. package/src/components/testresult-overview/TestResultOverviewView.hbs +8 -0
  200. package/src/components/testresult-overview/TestResultOverviewView.js +46 -0
  201. package/src/components/testresult-overview/styles.scss +22 -0
  202. package/src/components/testresult-tree/TestResultTreeView.js +60 -0
  203. package/src/components/tooltip/TooltipView.js +111 -0
  204. package/src/components/tooltip/styles.scss +43 -0
  205. package/src/components/tree/TreeView.hbs +9 -0
  206. package/src/components/tree/TreeView.js +200 -0
  207. package/src/components/tree/styles.scss +141 -0
  208. package/src/components/tree/tree-group.hbs +36 -0
  209. package/src/components/tree/tree-leaf.hbs +53 -0
  210. package/src/components/tree/tree-time.hbs +6 -0
  211. package/src/components/tree-view-container/TreeViewContainer.hbs +34 -0
  212. package/src/components/tree-view-container/TreeViewContainer.js +103 -0
  213. package/src/components/tree-view-container/styles.scss +38 -0
  214. package/src/components/widget-status/WidgetStatusView.hbs +21 -0
  215. package/src/components/widget-status/WidgetStatusView.js +17 -0
  216. package/src/components/widgets-grid/WidgetsGridView.js +90 -0
  217. package/src/components/widgets-grid/styles.scss +34 -0
  218. package/src/data/localstorage/LocalStorageModel.js +23 -0
  219. package/src/data/testresult/TestResultModel.js +36 -0
  220. package/src/data/tree/TreeCollection.js +153 -0
  221. package/src/data/tree/comparator.js +63 -0
  222. package/src/data/tree/filter.js +66 -0
  223. package/src/data/trend/TrendCollection.js +36 -0
  224. package/src/data/widgets/WidgetsModel.js +25 -0
  225. package/src/decorators/index.js +53 -0
  226. package/src/favicon.ico +0 -0
  227. package/src/helpers/allure-icon.js +228 -0
  228. package/src/helpers/and.js +3 -0
  229. package/src/helpers/angle.js +15 -0
  230. package/src/helpers/arrow.js +17 -0
  231. package/src/helpers/b.js +6 -0
  232. package/src/helpers/concat.js +3 -0
  233. package/src/helpers/date.js +11 -0
  234. package/src/helpers/default.js +8 -0
  235. package/src/helpers/duration.js +60 -0
  236. package/src/helpers/eq.js +3 -0
  237. package/src/helpers/fileicon.js +5 -0
  238. package/src/helpers/filesize.js +8 -0
  239. package/src/helpers/gt.js +3 -0
  240. package/src/helpers/inc.js +3 -0
  241. package/src/helpers/is-def.js +3 -0
  242. package/src/helpers/job-icon.js +8 -0
  243. package/src/helpers/linky.js +7 -0
  244. package/src/helpers/not.js +3 -0
  245. package/src/helpers/or.js +3 -0
  246. package/src/helpers/sort-class.js +6 -0
  247. package/src/helpers/statistic-bar.js +12 -0
  248. package/src/helpers/status-bar.js +14 -0
  249. package/src/helpers/t.js +5 -0
  250. package/src/helpers/text-with-links.js +18 -0
  251. package/src/helpers/time.js +18 -0
  252. package/src/helpers/timeago.js +10 -0
  253. package/src/index.html +17 -0
  254. package/src/index.js +52 -0
  255. package/src/layouts/application/AppLayout.hbs +2 -0
  256. package/src/layouts/application/AppLayout.js +50 -0
  257. package/src/layouts/application/styles.scss +17 -0
  258. package/src/layouts/error/ErrorLayout.js +11 -0
  259. package/src/layouts/overview/OverviewLayout.js +8 -0
  260. package/src/layouts/testresult/TestResultLayout.js +43 -0
  261. package/src/layouts/tree/TreeLayout.js +45 -0
  262. package/src/mixins.scss +128 -0
  263. package/src/pluginApi.js +26 -0
  264. package/src/plugins/.eslintrc +5 -0
  265. package/src/plugins/default/index.js +11 -0
  266. package/src/plugins/screen-diff/index.js +186 -0
  267. package/src/plugins/screen-diff/styles.css +30 -0
  268. package/src/plugins/tab-behaviors/index.js +239 -0
  269. package/src/plugins/tab-category/index.js +15 -0
  270. package/src/plugins/tab-graph/GraphCollection.js +12 -0
  271. package/src/plugins/tab-graph/GraphLayout.js +17 -0
  272. package/src/plugins/tab-graph/index.js +8 -0
  273. package/src/plugins/tab-packages/index.js +137 -0
  274. package/src/plugins/tab-suites/index.js +15 -0
  275. package/src/plugins/tab-timeline/TimelineLayout.js +18 -0
  276. package/src/plugins/tab-timeline/TimelineView.hbs +17 -0
  277. package/src/plugins/tab-timeline/TimelineView.js +250 -0
  278. package/src/plugins/tab-timeline/index.js +12 -0
  279. package/src/plugins/tab-timeline/styles.scss +76 -0
  280. package/src/plugins/testresult-category/CategoryView.hbs +6 -0
  281. package/src/plugins/testresult-category/CategoryView.js +17 -0
  282. package/src/plugins/testresult-category/index.js +3 -0
  283. package/src/plugins/testresult-description/DescriptionView.hbs +4 -0
  284. package/src/plugins/testresult-description/DescriptionView.js +16 -0
  285. package/src/plugins/testresult-description/index.js +3 -0
  286. package/src/plugins/testresult-duration/DurationView.hbs +7 -0
  287. package/src/plugins/testresult-duration/DurationView.js +16 -0
  288. package/src/plugins/testresult-duration/index.js +3 -0
  289. package/src/plugins/testresult-history/HistoryView.hbs +27 -0
  290. package/src/plugins/testresult-history/HistoryView.js +33 -0
  291. package/src/plugins/testresult-history/index.js +3 -0
  292. package/src/plugins/testresult-history/styles.scss +10 -0
  293. package/src/plugins/testresult-links/LinksView.hbs +17 -0
  294. package/src/plugins/testresult-links/LinksView.js +17 -0
  295. package/src/plugins/testresult-links/index.js +3 -0
  296. package/src/plugins/testresult-links/styles.scss +19 -0
  297. package/src/plugins/testresult-owner/OwnerView.hbs +4 -0
  298. package/src/plugins/testresult-owner/OwnerView.js +17 -0
  299. package/src/plugins/testresult-owner/index.js +3 -0
  300. package/src/plugins/testresult-parameters/ParametersView.hbs +13 -0
  301. package/src/plugins/testresult-parameters/ParametersView.js +22 -0
  302. package/src/plugins/testresult-parameters/index.js +3 -0
  303. package/src/plugins/testresult-parameters/styles.scss +8 -0
  304. package/src/plugins/testresult-retries/RetriesView.hbs +13 -0
  305. package/src/plugins/testresult-retries/RetriesView.js +28 -0
  306. package/src/plugins/testresult-retries/index.js +3 -0
  307. package/src/plugins/testresult-retries/styles.scss +11 -0
  308. package/src/plugins/testresult-severity/SeverityView.hbs +4 -0
  309. package/src/plugins/testresult-severity/SeverityView.js +17 -0
  310. package/src/plugins/testresult-severity/index.js +3 -0
  311. package/src/plugins/testresult-tags/TagsView.hbs +5 -0
  312. package/src/plugins/testresult-tags/TagsView.js +17 -0
  313. package/src/plugins/testresult-tags/index.js +3 -0
  314. package/src/plugins/widget-categories/index.js +12 -0
  315. package/src/plugins/widget-categories-trend/CategoriesTrendWidgetView.hbs +4 -0
  316. package/src/plugins/widget-categories-trend/CategoriesTrendWidgetView.js +33 -0
  317. package/src/plugins/widget-categories-trend/index.js +4 -0
  318. package/src/plugins/widget-categories-trend/styles.scss +6 -0
  319. package/src/plugins/widget-duration/DurationWidgetView.hbs +4 -0
  320. package/src/plugins/widget-duration/DurationWidgetView.js +23 -0
  321. package/src/plugins/widget-duration/index.js +3 -0
  322. package/src/plugins/widget-duration-trend/DurationTrendWidgetView.hbs +4 -0
  323. package/src/plugins/widget-duration-trend/DurationTrendWidgetView.js +49 -0
  324. package/src/plugins/widget-duration-trend/index.js +4 -0
  325. package/src/plugins/widget-duration-trend/styles.scss +6 -0
  326. package/src/plugins/widget-environment/EnvironmentWidget.hbs +27 -0
  327. package/src/plugins/widget-environment/EnvironmentWidget.js +25 -0
  328. package/src/plugins/widget-environment/index.js +3 -0
  329. package/src/plugins/widget-executor/ExecutorsWidgetView.hbs +40 -0
  330. package/src/plugins/widget-executor/ExecutorsWidgetView.js +8 -0
  331. package/src/plugins/widget-executor/index.js +3 -0
  332. package/src/plugins/widget-history-trend/HistoryTrendWidgetView.hbs +4 -0
  333. package/src/plugins/widget-history-trend/HistoryTrendWidgetView.js +30 -0
  334. package/src/plugins/widget-history-trend/index.js +6 -0
  335. package/src/plugins/widget-history-trend/styles.scss +6 -0
  336. package/src/plugins/widget-launch/LaunchesWidgetView.hbs +23 -0
  337. package/src/plugins/widget-launch/LaunchesWidgetView.js +8 -0
  338. package/src/plugins/widget-launch/index.js +3 -0
  339. package/src/plugins/widget-retry-trend/RetryTrendWidgetView.hbs +4 -0
  340. package/src/plugins/widget-retry-trend/RetryTrendWidgetView.js +33 -0
  341. package/src/plugins/widget-retry-trend/index.js +4 -0
  342. package/src/plugins/widget-retry-trend/styles.scss +6 -0
  343. package/src/plugins/widget-severity/SeverityWidgetView.hbs +4 -0
  344. package/src/plugins/widget-severity/SeverityWidgetView.js +23 -0
  345. package/src/plugins/widget-severity/index.js +3 -0
  346. package/src/plugins/widget-status/StatusWidgetView.hbs +4 -0
  347. package/src/plugins/widget-status/StatusWidgetView.js +44 -0
  348. package/src/plugins/widget-status/index.js +3 -0
  349. package/src/plugins/widget-suites/index.js +12 -0
  350. package/src/plugins/widget-summary/SummaryWidgetView.hbs +20 -0
  351. package/src/plugins/widget-summary/SummaryWidgetView.js +33 -0
  352. package/src/plugins/widget-summary/index.js +3 -0
  353. package/src/plugins/widget-summary/styles.scss +14 -0
  354. package/src/router.js +52 -0
  355. package/src/rtl.scss +19 -0
  356. package/src/styles.scss +91 -0
  357. package/src/translations/az.json +217 -0
  358. package/src/translations/br.json +205 -0
  359. package/src/translations/de.json +205 -0
  360. package/src/translations/en.json +222 -0
  361. package/src/translations/es.json +209 -0
  362. package/src/translations/fr.json +217 -0
  363. package/src/translations/he.json +205 -0
  364. package/src/translations/isv.json +216 -0
  365. package/src/translations/ja.json +210 -0
  366. package/src/translations/kr.json +210 -0
  367. package/src/translations/nl.json +217 -0
  368. package/src/translations/pl.json +220 -0
  369. package/src/translations/ru.json +215 -0
  370. package/src/translations/sv.json +222 -0
  371. package/src/translations/tr.json +217 -0
  372. package/src/translations/zh.json +191 -0
  373. package/src/utils/arrays.js +3 -0
  374. package/src/utils/attachmentType.js +101 -0
  375. package/src/utils/clipboard.js +38 -0
  376. package/src/utils/escape.js +5 -0
  377. package/src/utils/gtag.js +8 -0
  378. package/src/utils/highlight.js +14 -0
  379. package/src/utils/hotkeys.js +25 -0
  380. package/src/utils/loading.js +9 -0
  381. package/src/utils/marks.js +1 -0
  382. package/src/utils/pluginsRegistry.js +56 -0
  383. package/src/utils/settings.js +4 -0
  384. package/src/utils/settingsFactory.js +149 -0
  385. package/src/utils/sorting.js +21 -0
  386. package/src/utils/statuses.js +1 -0
  387. package/src/utils/translation.js +63 -0
  388. package/src/variables.scss +71 -0
  389. package/types.d.ts +5 -0
  390. package/webpack/utils.js +10 -0
  391. 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,16 @@
1
+ @import "../../mixins.scss";
2
+
3
+ .trend {
4
+ &__tooltip {
5
+ white-space: nowrap;
6
+ display: flex;
7
+ flex-direction: column;
8
+ &_label {
9
+ text-align: left;
10
+ display: inline-block;
11
+ }
12
+ &_name {
13
+ vertical-align: middle;
14
+ }
15
+ }
16
+ }
@@ -0,0 +1,9 @@
1
+ {{name}}
2
+ <div class="trend__tooltip">
3
+ {{#each data}}
4
+ <div class="trend__tooltip_label">
5
+ <span class="label" style="background-color: {{color}}">{{num}}</span>
6
+ <span class="trend__tooltip_name">{{key}}</span>
7
+ </div>
8
+ {{/each}}
9
+ </div>
@@ -0,0 +1,5 @@
1
+ <ul class="{{b 'language-select' 'menu'}}">
2
+ {{#each languages}}
3
+ <li class="{{b 'language-select' 'item' active=(eq id ../currentLang)}}" data-id="{{id}}">{{title}}</li>
4
+ {{/each}}
5
+ </ul>
@@ -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>