diff --git a/package-lock.json b/package-lock.json
index f9256b3..543d702 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -6,7 +6,7 @@
"packages": {
"": {
"name": "angles-ui",
- "version": "2.0.0",
+ "version": "2.0.13",
"license": "Apache-2.0",
"dependencies": {
"@rsuite/charts": "5.2.0",
diff --git a/src/components/pages/dashboard/DashboardPage.js b/src/components/pages/dashboard/DashboardPage.js
index 712ddb7..2dcb9df 100644
--- a/src/components/pages/dashboard/DashboardPage.js
+++ b/src/components/pages/dashboard/DashboardPage.js
@@ -164,7 +164,7 @@ const DashboardPage = function (props) {
metrics,
}) => {
setBuilds(addIndexToBuilds(retrievedBuilds, skip));
- setTestRunMetrics(metrics);
+ setTestRunMetrics(metrics || {});
setCurrentSkip(skip);
});
};
@@ -375,7 +375,7 @@ const DashboardPage = function (props) {
id="page.dashboard.panel.total-test-runs"
/>
-
{totalTestRuns}
+ {totalTestRuns || 0}
diff --git a/src/components/pages/introduction/IntroductionPage.js b/src/components/pages/introduction/IntroductionPage.js
new file mode 100644
index 0000000..ab89ec1
--- /dev/null
+++ b/src/components/pages/introduction/IntroductionPage.js
@@ -0,0 +1,54 @@
+import React from 'react';
+import {
+ Panel,
+} from 'rsuite';
+import { FormattedMessage } from 'react-intl';
+
+const IntroductionPage = function () {
+ const getSwaggerUrl = function () {
+ return `${process.env.REACT_APP_ANGLES_API_URL}/api-docs`;
+ };
+
+ return (
+
+
+
+
+ )}
+ >
+
+
+
+
+
+ ),
+ }}
+ />
+
+
+
+
+
+ ),
+ }}
+ />
+
+
+
+
+ );
+};
+
+export default IntroductionPage;
diff --git a/src/components/pages/introduction/index.js b/src/components/pages/introduction/index.js
new file mode 100644
index 0000000..4bc93cf
--- /dev/null
+++ b/src/components/pages/introduction/index.js
@@ -0,0 +1,22 @@
+import React from 'react';
+import { FormattedMessage } from 'react-intl';
+import { Breadcrumb, Panel } from 'rsuite';
+import IntroductionPage from './IntroductionPage';
+
+const Page = function () {
+ return (
+
+
+
+
+
+
+
+
+
+
+
+ );
+};
+
+export default Page;
diff --git a/src/components/pages/introduction/styles.less b/src/components/pages/introduction/styles.less
new file mode 100644
index 0000000..d791bea
--- /dev/null
+++ b/src/components/pages/introduction/styles.less
@@ -0,0 +1,28 @@
+
+.introduction-page-panel {
+ background-color: var(--main-panel-background);
+ color: var(--main-panel-font-color);
+ border: none;
+
+ .introduction-page-header {
+ color: var(--main-panel-font-color);
+ font-weight: bold;
+ }
+
+ .introduction-page-section {
+ padding-bottom: 10px;
+ }
+
+ .introduction-page-section-table {
+ padding-top: 10px;
+ }
+
+ .introduction-main-div {
+ white-space: pre-line;
+ }
+
+ .introduction-alternative-description {
+ padding-top: 20px;
+ }
+}
+
diff --git a/src/components/pages/metrics/MetricsPage.js b/src/components/pages/metrics/MetricsPage.js
index 644a3d0..a204b44 100644
--- a/src/components/pages/metrics/MetricsPage.js
+++ b/src/components/pages/metrics/MetricsPage.js
@@ -1,6 +1,7 @@
import React, { useEffect, useState } from 'react';
import axios from 'axios';
import moment from 'moment';
+import { connect } from 'react-redux';
import { FormattedMessage, useIntl } from 'react-intl';
import queryString from 'query-string';
import { useLocation, useNavigate } from 'react-router-dom';
@@ -41,7 +42,7 @@ const MetricsPage = function (props) {
const [startDate, setStartDate] = useState(queryStartDate ? moment(queryStartDate) : moment().subtract(30, 'days'));
const [endDate, setEndDate] = useState(queryEndDate ? moment(queryEndDate) : moment());
const [groupingPeriod, setGroupingPeriod] = useState(grouping || 'week');
- const [selectedTeam, setSelectedTeam] = useState(currentTeam._id);
+ const [selectedTeam, setSelectedTeam] = useState(currentTeam._id || undefined);
const [selectedComponent, setSelectedComponent] = useState(component || 'any');
const [key, setKey] = useState('execution');
const [metrics, setMetrics] = useState({});
@@ -312,4 +313,9 @@ const MetricsPage = function (props) {
);
};
-export default MetricsPage;
+const mapStateToProps = (state) => ({
+ currentTeam: state.teamsReducer.currentTeam,
+ teams: state.teamsReducer.teams,
+});
+
+export default connect(mapStateToProps, null)(MetricsPage);
diff --git a/src/components/pages/metrics/index.js b/src/components/pages/metrics/index.js
index c921497..1abfb85 100644
--- a/src/components/pages/metrics/index.js
+++ b/src/components/pages/metrics/index.js
@@ -4,7 +4,7 @@ import { Breadcrumb, Panel } from 'rsuite';
import MetricsPage from './MetricsPage';
const Page = function (props) {
- const { teams, currentTeam, changeCurrentTeam } = props;
+ const { changeCurrentTeam } = props;
return (
@@ -16,8 +16,6 @@ const Page = function (props) {
diff --git a/src/containers/App.js b/src/containers/App.js
index 3e863e6..f286b1f 100644
--- a/src/containers/App.js
+++ b/src/containers/App.js
@@ -37,6 +37,7 @@ import ScreenshotLibraryPage from '../components/pages/screenshot-library';
import ExecutionHistoryPage from '../components/pages/test-execution-history';
import AboutPage from '../components/pages/about';
import NotFoundPage from '../components/pages/not-found';
+import IntroductionPage from '../components/pages/introduction';
import MetricsPage from '../components/pages/metrics';
import { storeCurrentTeam, storeTeams, storeTeamsError } from '../redux/teamActions';
@@ -336,6 +337,7 @@ const App = function (props) {
) : (
+ // eslint-disable-next-line no-nested-ternary
(!teamsError && teams === undefined) ? (
@@ -348,7 +350,11 @@ const App = function (props) {
) : (
-
+ (teams.length === 0) ? (
+
+ ) : (
+
+ )
)
)
}
@@ -396,14 +402,17 @@ const App = function (props) {
exact
path="/metrics/"
element={
- (currentTeam === undefined || !currentTeam._id) ? (
- Please select a team
+ // eslint-disable-next-line no-nested-ternary
+ (Object.keys(teams).length === 0 || teams.length === 0) ? (
+
) : (
-
+ (!currentTeam || !currentTeam._id) ? (
+ null
+ ) : (
+
+ )
)
}
/>
diff --git a/src/styles/index.less b/src/styles/index.less
index b8dca69..1836ed0 100644
--- a/src/styles/index.less
+++ b/src/styles/index.less
@@ -7,6 +7,7 @@
@import '../components/pages/not-found/styles.less';
@import '../components/pages/test-execution-history/styles.less';
@import '../components/pages/screenshot-library/styles.less';
+@import '../components/pages/introduction/styles.less';
@import '../components/common/execution-timeline/styles.less';
@import '../components/common/screenshot-view/styles.less';
@import '../components/common/test-suite/styles.less';
@@ -167,6 +168,10 @@ body {
left: 19px;
top: 14px;
}
+ .rs-sidenav-body {
+ margin-left: -3px;
+ padding-right: 3px;
+ }
.rs-sidenav-item {
color: var(--nav-font-color);
diff --git a/src/translations/cn.json b/src/translations/cn.json
index ee03481..0731a39 100644
--- a/src/translations/cn.json
+++ b/src/translations/cn.json
@@ -143,6 +143,13 @@
"page.about.about-api": "透過提供明確定義的 {apiLink},任何框架都可以適應將其測試結果存儲在Angles中,使用提供的客戶端之一(或直接使用API)。",
"page.about.about-github": "有關 Angles 的更多信息,請訪問頁面:{githubLink}",
+ "page.introduction.bread-crumb": "簡介",
+ "page.introduction.header": "歡迎來到角度",
+ "page.introduction.description": "您似乎尚未設定任何團隊或環境。\n\n這可以透過使用 {apiLink} 來完成。",
+ "page.introduction.api-link-text": "Swagger API",
+ "page.introduction.description-alternative": "或您也可以使用 {githubLink} 開始。",
+ "page.introduction.github-link-text": "Github 頁面",
+
"page.not-found.bread-crumb": "找不到",
"page.not-found.description": "哎呀,糟糕,我們無法找到您要找的東西。點選 {homeLink} 返回主頁。",
"page.not-found.home-link-text": "此處",
diff --git a/src/translations/en.json b/src/translations/en.json
index c27685b..f293c5f 100644
--- a/src/translations/en.json
+++ b/src/translations/en.json
@@ -143,6 +143,13 @@
"page.about.about-api": "By providing a clearly defined {apiLink} any framework can be adapted to store its test result in Angles, using one of the clients provided (or by using the API directly)",
"page.about.about-github": "For more information about Angles go to page: {githubLink}",
+ "page.introduction.bread-crumb": "Introduction",
+ "page.introduction.header": "Welcome to Angles",
+ "page.introduction.description": "It looks like you haven't setup any teams or environments.\n\nThis can be done by using {apiLink}.",
+ "page.introduction.api-link-text": "the Swagger API",
+ "page.introduction.description-alternative": "Or alternatively you can use {githubLink} to get started.",
+ "page.introduction.github-link-text": "the Github page",
+
"page.not-found.bread-crumb" : "Not found",
"page.not-found.description": "Oops, we were unable to find the \"Angle\" you were looking for. Click {homeLink} to go back to home page.",
"page.not-found.home-link-text": "here",
diff --git a/src/translations/nl.json b/src/translations/nl.json
index 6c753ec..0ab3a59 100644
--- a/src/translations/nl.json
+++ b/src/translations/nl.json
@@ -143,6 +143,13 @@
"page.about.about-api": "Via het duidelijk omschreven {apiLink} van Angles kan elke geautomatiseerde test framework aangepast worden om zijn resultaten in Angles op te slaan",
"page.about.about-github": "Voor meer information over Angles kun je terecht op onze pagine: {githubLink}",
+ "page.introduction.bread-crumb": "Inleiding",
+ "page.introduction.header": "Welkom bij Angles",
+ "page.introduction.description": "Het lijkt erop dat u geen teams of omgevingen heeft ingesteld.\n\nDit kunt u doen door {apiLink} te gebruiken.",
+ "page.introduction.api-link-text": "de Swagger-API",
+ "page.introduction.description-alternative": "Of u kunt ook {githubLink} gebruiken om aan de slag te gaan.",
+ "page.introduction.github-link-text": "de Github-pagina",
+
"page.not-found.bread-crumb" : "Pagina niet gevonden",
"page.not-found.description": "Oeps, we hebben de pagina die je aan het zoeken was niet kunnen vinden. Klik {homeLink} om terug te gaan naar de home pagina.",
"page.not-found.home-link-text": "hier",
diff --git a/src/translations/th.json b/src/translations/th.json
index e26fd1d..33ede58 100644
--- a/src/translations/th.json
+++ b/src/translations/th.json
@@ -143,6 +143,13 @@
"page.about.about-api": "ด้วยการจัดเตรียม {apiLink} ที่กำหนดไว้อย่างชัดเจน คุณสามารถปรับใช้เฟรมเวิร์กใดๆ เพื่อจัดเก็บผลการทดสอบใน Angles ได้โดยใช้หนึ่งในไคลเอนต์ที่ให้มา (หรือโดยใช้ API โดยตรง)",
"page.about.about-github": "สำหรับข้อมูลเพิ่มเติมเกี่ยวกับ Angles ให้ไปที่หน้า: {githubLink}",
+ "page.introduction.bread-crumb": "บทนำ",
+ "page.introduction.header": "ยินดีต้อนรับสู่ Angles",
+ "page.introduction.description": "ดูเหมือนว่าคุณยังไม่ได้ตั้งค่าทีมหรือสภาพแวดล้อมใดๆ\n\nซึ่งสามารถทำได้โดยใช้ {apiLink}",
+ "page.introduction.api-link-text": "Swagger API",
+ "page.introduction.description-alternative": "หรืออีกทางหนึ่ง คุณสามารถใช้ {githubLink} เพื่อเริ่มต้นได้",
+ "page.introduction.github-link-text": "หน้า Github",
+
"page.not-found.bread-crumb" : "ไม่เจอ",
"page.not-found.description": "อ๊ะ เราไม่พบที่คุณกำลังหา คลิก {homeLink} เพื่อกลับไปที่หน้าแรก",
"page.not-found.home-link-text": "ที่นี่",