diff --git a/package-lock.json b/package-lock.json index f405c5292..7343a5fd0 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,15 +10,15 @@ "hasInstallScript": true, "license": "GNU AGPLv3", "dependencies": { - "@patternfly/patternfly": "5.4.0", - "@patternfly/react-charts": "7.4.0", - "@patternfly/react-component-groups": "^5.2.0", - "@patternfly/react-core": "5.4.0", - "@patternfly/react-icons": "5.4.0", - "@patternfly/react-table": "5.4.0", - "@patternfly/react-tokens": "5.4.0", + "@ausuliv/frontend-components-notifications": "^4.1.5", + "@patternfly/patternfly": "6.0.0-alpha.222", + "@patternfly/react-charts": "8.0.0-alpha.38", + "@patternfly/react-component-groups": "6.0.0-alpha.14", + "@patternfly/react-core": "6.0.0-alpha.102", + "@patternfly/react-icons": "6.0.0-alpha.36", + "@patternfly/react-table": "6.0.0-alpha.103", + "@patternfly/react-tokens": "6.0.0-alpha.35", "@redhat-cloud-services/frontend-components": "^4.2.14", - "@redhat-cloud-services/frontend-components-notifications": "^4.1.0", "@redhat-cloud-services/frontend-components-translations": "^3.2.8", "@redhat-cloud-services/frontend-components-utilities": "^4.0.17", "@redhat-cloud-services/rbac-client": "^2.2.2", @@ -119,6 +119,141 @@ "node": ">=6.0.0" } }, + "node_modules/@ausuliv/frontend-components": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/@ausuliv/frontend-components/-/frontend-components-4.2.11.tgz", + "integrity": "sha512-5EiOvSy/cW4O3H1mhEY2D/GwihmoNkq6U7+3c+Ek/oNHqD4dw+dKGUk1/XQ0GTGUozy4+DmiZ8OzrBzQDW0BLw==", + "license": "Apache-2.0", + "dependencies": { + "@ausuliv/frontend-components-utilities": "^4.0.10", + "@patternfly/react-component-groups": "6.0.0-alpha.12", + "@redhat-cloud-services/types": "^0.0.24", + "@scalprum/core": "^0.7.0", + "@scalprum/react-core": "^0.7.0", + "classnames": "^2.2.5", + "sanitize-html": "^2.7.2" + }, + "peerDependencies": { + "@patternfly/react-core": "6.0.0-alpha.100", + "@patternfly/react-icons": "6.0.0-alpha.35", + "@patternfly/react-table": "6.0.0-alpha.101", + "lodash": "^4.17.15", + "prop-types": "^15.6.2", + "react": "^18.2.0", + "react-content-loader": "^6.2.0", + "react-dom": "^18.2.0", + "react-redux": ">=7.0.0", + "react-router-dom": "^5.0.0 || ^6.0.0" + } + }, + "node_modules/@ausuliv/frontend-components-notifications": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/@ausuliv/frontend-components-notifications/-/frontend-components-notifications-4.1.5.tgz", + "integrity": "sha512-Zm+QOT1wvJl60V6SD9KEIROYJt0uBgNsRKmtz9Q2UnhjCP/DZGVhYsSk97cNth+c59nWhdciKEjvrw1aubzsxw==", + "license": "Apache-2.0", + "dependencies": { + "@ausuliv/frontend-components": "^4.2.9", + "@ausuliv/frontend-components-utilities": "^4.0.11", + "redux-promise-middleware": "6.1.3" + }, + "peerDependencies": { + "@patternfly/react-core": "6.0.0-alpha.100", + "@patternfly/react-icons": "6.0.0-alpha.35", + "prop-types": "^15.6.2", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "react-redux": ">=7.2.9", + "redux": ">=4.2.0" + } + }, + "node_modules/@ausuliv/frontend-components-utilities": { + "version": "4.0.13", + "resolved": "https://registry.npmjs.org/@ausuliv/frontend-components-utilities/-/frontend-components-utilities-4.0.13.tgz", + "integrity": "sha512-eQWk0ATeaFunJaqWZKwldEE77+k5z+8MzBDiLI6az0IWp8mykZcZnkV72517r6YI/UPU4Nm50UtMd1Gw8q7yIA==", + "license": "Apache-2.0", + "dependencies": { + "@redhat-cloud-services/rbac-client": "^1.0.100", + "@redhat-cloud-services/types": "^0.0.24", + "@sentry/browser": "^5.30.0", + "awesome-debounce-promise": "^2.1.0", + "axios": "^0.28.1", + "commander": "^2.20.3", + "mkdirp": "^1.0.4", + "p-all": "^5.0.0", + "react-content-loader": "^6.2.0" + }, + "peerDependencies": { + "@patternfly/react-core": "6.0.0-alpha.100", + "@patternfly/react-table": "6.0.0-alpha.101", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "react-redux": ">=7.0.0", + "react-router-dom": "^5.0.0 || ^6.0.0" + } + }, + "node_modules/@ausuliv/frontend-components-utilities/node_modules/@redhat-cloud-services/rbac-client": { + "version": "1.4.5", + "resolved": "https://registry.npmjs.org/@redhat-cloud-services/rbac-client/-/rbac-client-1.4.5.tgz", + "integrity": "sha512-7kryZfzEYuw1V7c8bO5esXnfeYQO4Skz1XhluJ2whZNji8HcVbwDjBsQxy0+ndaSVirh5d86fufb00vK6fyUjw==", + "license": "Apache-2.0", + "dependencies": { + "axios": "^0.27.2", + "tslib": "^2.6.2" + } + }, + "node_modules/@ausuliv/frontend-components-utilities/node_modules/@redhat-cloud-services/rbac-client/node_modules/axios": { + "version": "0.27.2", + "resolved": "https://registry.npmjs.org/axios/-/axios-0.27.2.tgz", + "integrity": "sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ==", + "license": "MIT", + "dependencies": { + "follow-redirects": "^1.14.9", + "form-data": "^4.0.0" + } + }, + "node_modules/@ausuliv/frontend-components-utilities/node_modules/axios": { + "version": "0.28.1", + "resolved": "https://registry.npmjs.org/axios/-/axios-0.28.1.tgz", + "integrity": "sha512-iUcGA5a7p0mVb4Gm/sy+FSECNkPFT4y7wt6OM/CDpO/OnNCvSs3PoMG8ibrC9jRoGYU0gUK5pXVC4NPXq6lHRQ==", + "license": "MIT", + "dependencies": { + "follow-redirects": "^1.15.0", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/@ausuliv/frontend-components/node_modules/@patternfly/react-component-groups": { + "version": "6.0.0-alpha.12", + "resolved": "https://registry.npmjs.org/@patternfly/react-component-groups/-/react-component-groups-6.0.0-alpha.12.tgz", + "integrity": "sha512-tmR6SWEVntEYPXQvtnivZgL3xdhPb6Fa73Yiyse9wSrrEo/Vv8oBD+e1SswOImfS0ELzFc9bLby20cN0xZQAKw==", + "license": "MIT", + "dependencies": { + "@patternfly/react-core": "^6.0.0-alpha.100", + "@patternfly/react-icons": "^6.0.0-alpha.35", + "@patternfly/react-table": "^6.0.0-alpha.101", + "clsx": "^2.1.1", + "react-jss": "^10.10.0" + }, + "peerDependencies": { + "react": "^17 || ^18", + "react-dom": "^17 || ^18" + } + }, + "node_modules/@ausuliv/frontend-components/node_modules/@scalprum/react-core": { + "version": "0.7.1", + "resolved": "https://registry.npmjs.org/@scalprum/react-core/-/react-core-0.7.1.tgz", + "integrity": "sha512-CdLSwg46MYyDqCjWGuim/u0HF6GaPPGxXRD6AkWCkB4o3feBep+2zRAjzNfi3IlhNufWaiswxLpThhTLG4cgMg==", + "license": "Apache-2.0", + "dependencies": { + "@openshift/dynamic-plugin-sdk": "^5.0.1", + "@scalprum/core": "^0.7.0", + "lodash": "^4.17.0" + }, + "peerDependencies": { + "react": ">=16.8.0 || >=17.0.0 || ^18.0.0", + "react-dom": ">=16.8.0 || >=17.0.0 || ^18.0.0" + } + }, "node_modules/@babel/code-frame": { "version": "7.23.5", "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", @@ -821,6 +956,7 @@ "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.9.1.tgz", "integrity": "sha512-xIDQRsfg5hNBqHz04H1R3scSVwmI+KUbqjsQKHKQ1DAUSaUjYPReZZmS/5PNiKu1fUvzDd6H7DEDKACSEhu+TQ==", "dev": true, + "license": "MIT", "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" } @@ -2152,19 +2288,19 @@ } }, "node_modules/@patternfly/patternfly": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/@patternfly/patternfly/-/patternfly-5.4.0.tgz", - "integrity": "sha512-9B33M4N0/KDyss6NpCwAhz18za7R+sXYiFrUObhGoJ1Cmg06SeScVrEAjT4yJwAClWUlKh604Af9wE4D7IF8Lg==", + "version": "6.0.0-alpha.222", + "resolved": "https://registry.npmjs.org/@patternfly/patternfly/-/patternfly-6.0.0-alpha.222.tgz", + "integrity": "sha512-DK6hMiJAyLo3mf4KYebEqQwdOtN+AFzFCxlHhQawgPdPYS1000eBrKpNe7mAzmzubwXSffDXsSz+q7ddB6uMiw==", "license": "MIT" }, "node_modules/@patternfly/react-charts": { - "version": "7.4.0", - "resolved": "https://registry.npmjs.org/@patternfly/react-charts/-/react-charts-7.4.0.tgz", - "integrity": "sha512-2nvjoGw+ndAwiSFds041wMb4c1BnflyWLAutyC1kYTawhlKrSDGsd4heKWmquzg7GTLBzr1w6YbxKv2i2l7Z7g==", + "version": "8.0.0-alpha.38", + "resolved": "https://registry.npmjs.org/@patternfly/react-charts/-/react-charts-8.0.0-alpha.38.tgz", + "integrity": "sha512-hjNXPc98OLZbcWYei4UPEvgYxqr0Rz2db6/EjRXn5ba2VX7222180sz8/1hPIHiSTORpk7FKeIwyEq4IGNGYYA==", "license": "MIT", "dependencies": { - "@patternfly/react-styles": "^5.4.0", - "@patternfly/react-tokens": "^5.4.0", + "@patternfly/react-styles": "^6.0.0-alpha.35", + "@patternfly/react-tokens": "^6.0.0-alpha.35", "hoist-non-react-statics": "^3.3.2", "lodash": "^4.17.21", "tslib": "^2.6.3", @@ -2192,20 +2328,21 @@ } }, "node_modules/@patternfly/react-charts/node_modules/tslib": { - "version": "2.7.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.7.0.tgz", - "integrity": "sha512-gLXCKdN1/j47AiHiOkJN69hJmcbGTHI0ImLmbYLHykhgeN0jVGola9yVjFgzCUklsZQMW55o+dW7IXv3RCXDzA==", + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.3.tgz", + "integrity": "sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==", "license": "0BSD" }, "node_modules/@patternfly/react-component-groups": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@patternfly/react-component-groups/-/react-component-groups-5.2.0.tgz", - "integrity": "sha512-kb57OOVJ9L5fbY/kiil8awPWuJVops8Rz1ZNFtkEb72mF3lhmRadYNheLBeaD8T9GE1dOaVJRMMf133ZSKN87g==", + "version": "6.0.0-alpha.14", + "resolved": "https://registry.npmjs.org/@patternfly/react-component-groups/-/react-component-groups-6.0.0-alpha.14.tgz", + "integrity": "sha512-tjuuCP9x7S/mZ2eEoPLu8auHvFMxF89205Cv66XLqgSb2Mn8Bjcu0Tnhl9FFLCniRN0S3KtKDthQkerI4UObqw==", + "license": "MIT", "dependencies": { - "@patternfly/react-core": "^5.1.1", - "@patternfly/react-icons": "^5.1.1", - "@patternfly/react-table": "^5.1.1", - "clsx": "^2.0.0", + "@patternfly/react-core": "^6.0.0-alpha.101", + "@patternfly/react-icons": "^6.0.0-alpha.36", + "@patternfly/react-table": "^6.0.0-alpha.102", + "clsx": "^2.1.1", "react-jss": "^10.10.0" }, "peerDependencies": { @@ -2214,33 +2351,27 @@ } }, "node_modules/@patternfly/react-core": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/@patternfly/react-core/-/react-core-5.4.0.tgz", - "integrity": "sha512-Tz2Y9V4G2pnwrylc/4/FyxIRFvxiA8BEBIG6UBwXxrstnJmJaHgAIy6QJdJmERzVx3GVDz6/rM0PnMqa5R6auQ==", + "version": "6.0.0-alpha.102", + "resolved": "https://registry.npmjs.org/@patternfly/react-core/-/react-core-6.0.0-alpha.102.tgz", + "integrity": "sha512-NjnLhgYwJ3LuA3/DDwzM10X9dlZyR9ICAKOXI2FlxRM0kTAnAK0kLx7MuQjZ7wboIjxpRaA3lG8c9zlHDrCWdQ==", "license": "MIT", "dependencies": { - "@patternfly/react-icons": "^5.4.0", - "@patternfly/react-styles": "^5.4.0", - "@patternfly/react-tokens": "^5.4.0", + "@patternfly/react-icons": "^6.0.0-alpha.36", + "@patternfly/react-styles": "^6.0.0-alpha.35", + "@patternfly/react-tokens": "^6.0.0-alpha.35", "focus-trap": "7.5.4", "react-dropzone": "^14.2.3", - "tslib": "^2.6.3" + "tslib": "^2.6.2" }, "peerDependencies": { "react": "^17 || ^18", "react-dom": "^17 || ^18" } }, - "node_modules/@patternfly/react-core/node_modules/tslib": { - "version": "2.7.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.7.0.tgz", - "integrity": "sha512-gLXCKdN1/j47AiHiOkJN69hJmcbGTHI0ImLmbYLHykhgeN0jVGola9yVjFgzCUklsZQMW55o+dW7IXv3RCXDzA==", - "license": "0BSD" - }, "node_modules/@patternfly/react-icons": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/@patternfly/react-icons/-/react-icons-5.4.0.tgz", - "integrity": "sha512-2M3qN/naultvRHeG2laJMmoIroFCGAyfwTVrnCjSkG6/KnRoXV0+dqd+Xrh7xzpzvIJB1klvifC0oX42cEkDrA==", + "version": "6.0.0-alpha.36", + "resolved": "https://registry.npmjs.org/@patternfly/react-icons/-/react-icons-6.0.0-alpha.36.tgz", + "integrity": "sha512-9gxJr3UxqZnUKwtPfV1JrzcH76hN/5hHM5CL5HJVWnAhI6WjRm3oQ9dA/PLo91Kyo3tN6TQKV1b2x/LhPiBscw==", "license": "MIT", "peerDependencies": { "react": "^17 || ^18", @@ -2248,21 +2379,21 @@ } }, "node_modules/@patternfly/react-styles": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/@patternfly/react-styles/-/react-styles-5.4.0.tgz", - "integrity": "sha512-4ZE0s6LkX/0KsN0FOeogrDoj18m+BPA73YKnabZGB4SDRzrBNeBh2a6bSt546ZseEjkoJ+S81kOG0G8YckPQYg==", + "version": "6.0.0-alpha.35", + "resolved": "https://registry.npmjs.org/@patternfly/react-styles/-/react-styles-6.0.0-alpha.35.tgz", + "integrity": "sha512-9ddQpDJ1CXDbsuV5lYmynw8hqGncKXxnhNwvUKc+s/i50pNBAMmNO9CP5dkKhnZPcjHQj0A35aleQ7xdRgNWQw==", "license": "MIT" }, "node_modules/@patternfly/react-table": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/@patternfly/react-table/-/react-table-5.4.0.tgz", - "integrity": "sha512-HkXxVEPeI6nRVSUSHb5BungF41IfjB8W2VqaA3SX+6fGxQAW0e/Hb58ctUdPR2VJ/S2YZFcIcqCCWQtQEf+xKA==", + "version": "6.0.0-alpha.103", + "resolved": "https://registry.npmjs.org/@patternfly/react-table/-/react-table-6.0.0-alpha.103.tgz", + "integrity": "sha512-EVLLZ8R/e3/Hx0JigSyKTASqmifEPHBCtivYf6RMkp8eRRkgyrM9VRGQk354UJky7kcY1Jsp4aKMcPd/0Tc9dg==", "license": "MIT", "dependencies": { - "@patternfly/react-core": "^5.4.0", - "@patternfly/react-icons": "^5.4.0", - "@patternfly/react-styles": "^5.4.0", - "@patternfly/react-tokens": "^5.4.0", + "@patternfly/react-core": "^6.0.0-alpha.102", + "@patternfly/react-icons": "^6.0.0-alpha.36", + "@patternfly/react-styles": "^6.0.0-alpha.35", + "@patternfly/react-tokens": "^6.0.0-alpha.35", "lodash": "^4.17.21", "tslib": "^2.6.3" }, @@ -2272,15 +2403,15 @@ } }, "node_modules/@patternfly/react-table/node_modules/tslib": { - "version": "2.7.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.7.0.tgz", - "integrity": "sha512-gLXCKdN1/j47AiHiOkJN69hJmcbGTHI0ImLmbYLHykhgeN0jVGola9yVjFgzCUklsZQMW55o+dW7IXv3RCXDzA==", + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.3.tgz", + "integrity": "sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==", "license": "0BSD" }, "node_modules/@patternfly/react-tokens": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/@patternfly/react-tokens/-/react-tokens-5.4.0.tgz", - "integrity": "sha512-KONkwCVOMyklhuuaYeYgcAsGtCBQXnsBGZeolhOdSzr2Mj0RVSW0oMrQPgZuPVzhhC/kbqgClHJJl6xuG9xheA==", + "version": "6.0.0-alpha.35", + "resolved": "https://registry.npmjs.org/@patternfly/react-tokens/-/react-tokens-6.0.0-alpha.35.tgz", + "integrity": "sha512-TYLYxyx7tDVRYeso+72eGZbM/O3G90brLzHQai2JtKI66XE3T2R89N0VxPT65gbc1cnqNkiTtUKkpUUHmOK9qg==", "license": "MIT" }, "node_modules/@pkgjs/parseargs": { @@ -2665,25 +2796,6 @@ "node": ">=8" } }, - "node_modules/@redhat-cloud-services/frontend-components-notifications": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/@redhat-cloud-services/frontend-components-notifications/-/frontend-components-notifications-4.1.0.tgz", - "integrity": "sha512-bEoAeZMVY+UuSriSeruZ1pIesiPEjScrVFJQ5Wq/w3UFc79oXSYOgpRElxblPUH/LbKqp7inbzqRm2FxMcVxYg==", - "dependencies": { - "@redhat-cloud-services/frontend-components": "^4.0.9", - "@redhat-cloud-services/frontend-components-utilities": "^4.0.2", - "redux-promise-middleware": "6.1.3" - }, - "peerDependencies": { - "@patternfly/react-core": "^5.0.0", - "@patternfly/react-icons": "^5.0.0", - "prop-types": "^15.6.2", - "react": "^18.2.0", - "react-dom": "^18.2.0", - "react-redux": ">=7.2.9", - "redux": ">=4.2.0" - } - }, "node_modules/@redhat-cloud-services/frontend-components-translations": { "version": "3.2.8", "resolved": "https://registry.npmjs.org/@redhat-cloud-services/frontend-components-translations/-/frontend-components-translations-3.2.8.tgz", @@ -2727,6 +2839,23 @@ "resolved": "https://registry.npmjs.org/@redhat-cloud-services/types/-/types-1.0.9.tgz", "integrity": "sha512-dKYYSLU0cwNkOSq5kSvdKWzgwFGBk45uwAwoHGi44PMQdWkuz+tXhYLrKKAXoSXVahR6VFjBDONlaxok8Lzkcw==" }, + "node_modules/@redhat-cloud-services/frontend-components/node_modules/@patternfly/react-component-groups": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@patternfly/react-component-groups/-/react-component-groups-5.2.0.tgz", + "integrity": "sha512-kb57OOVJ9L5fbY/kiil8awPWuJVops8Rz1ZNFtkEb72mF3lhmRadYNheLBeaD8T9GE1dOaVJRMMf133ZSKN87g==", + "license": "MIT", + "dependencies": { + "@patternfly/react-core": "^5.1.1", + "@patternfly/react-icons": "^5.1.1", + "@patternfly/react-table": "^5.1.1", + "clsx": "^2.0.0", + "react-jss": "^10.10.0" + }, + "peerDependencies": { + "react": "^17 || ^18", + "react-dom": "^17 || ^18" + } + }, "node_modules/@redhat-cloud-services/frontend-components/node_modules/@redhat-cloud-services/types": { "version": "1.0.9", "resolved": "https://registry.npmjs.org/@redhat-cloud-services/types/-/types-1.0.9.tgz", @@ -2754,6 +2883,7 @@ "version": "2.2.2", "resolved": "https://registry.npmjs.org/@redhat-cloud-services/rbac-client/-/rbac-client-2.2.2.tgz", "integrity": "sha512-GsHHRyYcfh8BJaW9jdBuKLnA+n2YpfGU4kfibCS04BWQz+g8F6jF6gHhJAymHicN+lgvFo8Z1WvF4TRfI17qNg==", + "license": "Apache-2.0", "dependencies": { "@redhat-cloud-services/javascript-clients-shared": "^1.2.2", "axios": "^1.7.2", @@ -2794,6 +2924,12 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/@redhat-cloud-services/types": { + "version": "0.0.24", + "resolved": "https://registry.npmjs.org/@redhat-cloud-services/types/-/types-0.0.24.tgz", + "integrity": "sha512-P50stc+mnWLycID46/AKmD/760r5N1eoam//O6MUVriqVorUdht7xkUL78aJZU1vw8WW6xlrDHwz3F6BM148qg==", + "license": "Apache-2.0" + }, "node_modules/@reduxjs/toolkit": { "version": "2.2.7", "resolved": "https://registry.npmjs.org/@reduxjs/toolkit/-/toolkit-2.2.7.tgz", @@ -3349,6 +3485,7 @@ "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.5.0.tgz", "integrity": "sha512-xGGHpBXYSHUUr6XsKBfs85TWlYKpTc37cSBBVrXcib2MkHLboWlkClhWF37JKlDb9KEq3dHs+f2xR7XJEWGBxA==", "dev": true, + "license": "MIT", "dependencies": { "@adobe/css-tools": "^4.4.0", "aria-query": "^5.0.0", @@ -3576,26 +3713,22 @@ "node_modules/@types/d3-array": { "version": "3.2.1", "resolved": "https://registry.npmjs.org/@types/d3-array/-/d3-array-3.2.1.tgz", - "integrity": "sha512-Y2Jn2idRrLzUfAKV2LyRImR+y4oa2AntrgID95SHJxuMUrkNXmanDSed71sRNZysveJVt1hLLemQZIady0FpEg==", - "license": "MIT" + "integrity": "sha512-Y2Jn2idRrLzUfAKV2LyRImR+y4oa2AntrgID95SHJxuMUrkNXmanDSed71sRNZysveJVt1hLLemQZIady0FpEg==" }, "node_modules/@types/d3-color": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/@types/d3-color/-/d3-color-3.1.3.tgz", - "integrity": "sha512-iO90scth9WAbmgv7ogoq57O9YpKmFBbmoEoCHDB2xMBY0+/KVrqAaCDyCE16dUspeOvIxFFRI+0sEtqDqy2b4A==", - "license": "MIT" + "integrity": "sha512-iO90scth9WAbmgv7ogoq57O9YpKmFBbmoEoCHDB2xMBY0+/KVrqAaCDyCE16dUspeOvIxFFRI+0sEtqDqy2b4A==" }, "node_modules/@types/d3-ease": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/@types/d3-ease/-/d3-ease-3.0.2.tgz", - "integrity": "sha512-NcV1JjO5oDzoK26oMzbILE6HW7uVXOHLQvHshBUW4UMdZGfiY6v5BeQwh9a9tCzv+CeefZQHJt5SRgK154RtiA==", - "license": "MIT" + "integrity": "sha512-NcV1JjO5oDzoK26oMzbILE6HW7uVXOHLQvHshBUW4UMdZGfiY6v5BeQwh9a9tCzv+CeefZQHJt5SRgK154RtiA==" }, "node_modules/@types/d3-interpolate": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/@types/d3-interpolate/-/d3-interpolate-3.0.4.tgz", "integrity": "sha512-mgLPETlrpVV1YRJIglr4Ez47g7Yxjl1lj7YKsiMCb27VJH9W8NVM6Bb9d8kkpG/uAQS5AmbA48q2IAolKKo1MA==", - "license": "MIT", "dependencies": { "@types/d3-color": "*" } @@ -3603,14 +3736,12 @@ "node_modules/@types/d3-path": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/@types/d3-path/-/d3-path-3.1.0.tgz", - "integrity": "sha512-P2dlU/q51fkOc/Gfl3Ul9kicV7l+ra934qBFXCFhrZMOL6du1TM0pm1ThYvENukyOn5h9v+yMJ9Fn5JK4QozrQ==", - "license": "MIT" + "integrity": "sha512-P2dlU/q51fkOc/Gfl3Ul9kicV7l+ra934qBFXCFhrZMOL6du1TM0pm1ThYvENukyOn5h9v+yMJ9Fn5JK4QozrQ==" }, "node_modules/@types/d3-scale": { "version": "4.0.8", "resolved": "https://registry.npmjs.org/@types/d3-scale/-/d3-scale-4.0.8.tgz", "integrity": "sha512-gkK1VVTr5iNiYJ7vWDI+yUFFlszhNMtVeneJ6lUTKPjprsvLLI9/tgEGiXJOnlINJA8FyA88gfnQsHbybVZrYQ==", - "license": "MIT", "dependencies": { "@types/d3-time": "*" } @@ -3619,7 +3750,6 @@ "version": "3.1.6", "resolved": "https://registry.npmjs.org/@types/d3-shape/-/d3-shape-3.1.6.tgz", "integrity": "sha512-5KKk5aKGu2I+O6SONMYSNflgiP0WfZIQvVUMan50wHsLG1G94JlxEVnCpQARfTtzytuY0p/9PXXZb3I7giofIA==", - "license": "MIT", "dependencies": { "@types/d3-path": "*" } @@ -3627,14 +3757,12 @@ "node_modules/@types/d3-time": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/@types/d3-time/-/d3-time-3.0.3.tgz", - "integrity": "sha512-2p6olUZ4w3s+07q3Tm2dbiMZy5pCDfYwtLXXHUnVzXgQlZ/OyPtUz6OL382BkOuGlLXqfT+wqv8Fw2v8/0geBw==", - "license": "MIT" + "integrity": "sha512-2p6olUZ4w3s+07q3Tm2dbiMZy5pCDfYwtLXXHUnVzXgQlZ/OyPtUz6OL382BkOuGlLXqfT+wqv8Fw2v8/0geBw==" }, "node_modules/@types/d3-timer": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/@types/d3-timer/-/d3-timer-3.0.2.tgz", - "integrity": "sha512-Ps3T8E8dZDam6fUyNiMkekK3XUsaUEik+idO9/YjPtfj2qruF8tFBXS7XhtE4iIXBLxhmLjP3SXpLhVf21I9Lw==", - "license": "MIT" + "integrity": "sha512-Ps3T8E8dZDam6fUyNiMkekK3XUsaUEik+idO9/YjPtfj2qruF8tFBXS7XhtE4iIXBLxhmLjP3SXpLhVf21I9Lw==" }, "node_modules/@types/debounce-promise": { "version": "3.1.9", @@ -3651,6 +3779,16 @@ "@types/json-schema": "*" } }, + "node_modules/@types/eslint-scope": { + "version": "3.7.7", + "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.7.tgz", + "integrity": "sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==", + "dev": true, + "dependencies": { + "@types/eslint": "*", + "@types/estree": "*" + } + }, "node_modules/@types/estree": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", @@ -4605,10 +4743,10 @@ "acorn-walk": "^8.0.2" } }, - "node_modules/acorn-import-attributes": { - "version": "1.9.5", - "resolved": "https://registry.npmjs.org/acorn-import-attributes/-/acorn-import-attributes-1.9.5.tgz", - "integrity": "sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ==", + "node_modules/acorn-import-assertions": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.9.0.tgz", + "integrity": "sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==", "dev": true, "peerDependencies": { "acorn": "^8" @@ -5036,6 +5174,7 @@ "version": "2.2.2", "resolved": "https://registry.npmjs.org/attr-accept/-/attr-accept-2.2.2.tgz", "integrity": "sha512-7prDjvt9HmqiZ0cl5CRjtS84sEyhsHP2coDkaZKRKVfCDo9s7iw7ChVmar78Gu9pC4SoR/28wFu/G5JJhTnqEg==", + "license": "MIT", "engines": { "node": ">=4" } @@ -5105,6 +5244,7 @@ "version": "1.7.7", "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.7.tgz", "integrity": "sha512-S4kL7XrjgBmvdGut0sN3yJxqYzrDOnivkBiN0OFs6hLiUam3UPvswUo0kqGyhqUZGEOytHyumEdXsAkgCOUf3Q==", + "license": "MIT", "dependencies": { "follow-redirects": "^1.15.6", "form-data": "^4.0.0", @@ -6029,9 +6169,10 @@ } }, "node_modules/clsx": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.0.tgz", - "integrity": "sha512-m3iNNWpd9rl3jvvcBnu70ylMdrXt8Vlq4HYadnU5fwcOtvkSQWPmj7amUcDT2qYI7risszBjI5AUIUox9D16pg==", + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.1.tgz", + "integrity": "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==", + "license": "MIT", "engines": { "node": ">=6" } @@ -6793,7 +6934,6 @@ "version": "3.2.4", "resolved": "https://registry.npmjs.org/d3-array/-/d3-array-3.2.4.tgz", "integrity": "sha512-tdQAmyA18i4J7wprpYq8ClcxZy3SC31QMeByyCFyRt7BVHdREQZ5lpzoe5mFEYZUWe+oq8HBvk9JjpibyEV4Jg==", - "license": "ISC", "dependencies": { "internmap": "1 - 2" }, @@ -6805,7 +6945,6 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/d3-color/-/d3-color-3.1.0.tgz", "integrity": "sha512-zg/chbXyeBtMQ1LbD/WSoW2DpC3I0mpmPdW+ynRTj/x2DAWYrIY7qeZIHidozwV24m4iavr15lNwIwLxRmOxhA==", - "license": "ISC", "engines": { "node": ">=12" } @@ -6814,7 +6953,6 @@ "version": "3.0.1", "resolved": "https://registry.npmjs.org/d3-ease/-/d3-ease-3.0.1.tgz", "integrity": "sha512-wR/XK3D3XcLIZwpbvQwQ5fK+8Ykds1ip7A2Txe0yxncXSdq1L9skcG7blcedkOX+ZcgxGAmLX1FrRGbADwzi0w==", - "license": "BSD-3-Clause", "engines": { "node": ">=12" } @@ -6823,7 +6961,6 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/d3-format/-/d3-format-3.1.0.tgz", "integrity": "sha512-YyUI6AEuY/Wpt8KWLgZHsIU86atmikuoOmCfommt0LYHiQSPjvX2AcFc38PX0CBpr2RCyZhjex+NS/LPOv6YqA==", - "license": "ISC", "engines": { "node": ">=12" } @@ -6832,7 +6969,6 @@ "version": "3.0.1", "resolved": "https://registry.npmjs.org/d3-interpolate/-/d3-interpolate-3.0.1.tgz", "integrity": "sha512-3bYs1rOD33uo8aqJfKP3JWPAibgw8Zm2+L9vBKEHJ2Rg+viTR7o5Mmv5mZcieN+FRYaAOWX5SJATX6k1PWz72g==", - "license": "ISC", "dependencies": { "d3-color": "1 - 3" }, @@ -6844,7 +6980,6 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/d3-path/-/d3-path-3.1.0.tgz", "integrity": "sha512-p3KP5HCf/bvjBSSKuXid6Zqijx7wIfNW+J/maPs+iwR35at5JCbLUT0LzF1cnjbCHWhqzQTIN2Jpe8pRebIEFQ==", - "license": "ISC", "engines": { "node": ">=12" } @@ -6853,7 +6988,6 @@ "version": "4.0.2", "resolved": "https://registry.npmjs.org/d3-scale/-/d3-scale-4.0.2.tgz", "integrity": "sha512-GZW464g1SH7ag3Y7hXjf8RoUuAFIqklOAq3MRl4OaWabTFJY9PN/E1YklhXLh+OQ3fM9yS2nOkCoS+WLZ6kvxQ==", - "license": "ISC", "dependencies": { "d3-array": "2.10.0 - 3", "d3-format": "1 - 3", @@ -6869,7 +7003,6 @@ "version": "3.2.0", "resolved": "https://registry.npmjs.org/d3-shape/-/d3-shape-3.2.0.tgz", "integrity": "sha512-SaLBuwGm3MOViRq2ABk3eLoxwZELpH6zhl3FbAoJ7Vm1gofKx6El1Ib5z23NUEhF9AsGl7y+dzLe5Cw2AArGTA==", - "license": "ISC", "dependencies": { "d3-path": "^3.1.0" }, @@ -6881,7 +7014,6 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/d3-time/-/d3-time-3.1.0.tgz", "integrity": "sha512-VqKjzBLejbSMT4IgbmVgDjpkYrNWUYJnbCGo874u7MMKIWsILRX+OpX/gTk8MqjpT1A/c6HY2dCA77ZN0lkQ2Q==", - "license": "ISC", "dependencies": { "d3-array": "2 - 3" }, @@ -6893,7 +7025,6 @@ "version": "4.1.0", "resolved": "https://registry.npmjs.org/d3-time-format/-/d3-time-format-4.1.0.tgz", "integrity": "sha512-dJxPBlzC7NugB2PDLwo9Q8JiTR3M3e4/XANkreKSUxF8vvXKqm1Yfq4Q5dl8budlunRVlUUaDUgFt7eA8D6NLg==", - "license": "ISC", "dependencies": { "d3-time": "1 - 3" }, @@ -6905,7 +7036,6 @@ "version": "3.0.1", "resolved": "https://registry.npmjs.org/d3-timer/-/d3-timer-3.0.1.tgz", "integrity": "sha512-ndfJ/JxxMd3nw31uyKoY2naivF+r29V+Lc0svZxe1JvvIRmi8hUsrMvdOwgS1o6uBHmiz91geQ0ylPP0aj1VUA==", - "license": "ISC", "engines": { "node": ">=12" } @@ -7549,9 +7679,9 @@ } }, "node_modules/enhanced-resolve": { - "version": "5.17.1", - "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.17.1.tgz", - "integrity": "sha512-LMHl3dXhTcfv8gM4kEzIUeTQ+7fpdA0l2tUf34BddXPkz2A5xJ5L/Pchd5BL6rdccM9QGvu0sWZzK1Z1t4wwyg==", + "version": "5.16.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.16.0.tgz", + "integrity": "sha512-O+QWCviPNSSLAD9Ucn8Awv+poAkqn3T1XY5/N7kR7rQO9yfSGWkYZDwpJ+iKF7B8rxaQKWngSqACpgzeapSyoA==", "dev": true, "dependencies": { "graceful-fs": "^4.2.4", @@ -9767,6 +9897,7 @@ "version": "0.6.0", "resolved": "https://registry.npmjs.org/file-selector/-/file-selector-0.6.0.tgz", "integrity": "sha512-QlZ5yJC0VxHxQQsQhXvBaC7VRJ2uaxTf+Tfpu4Z/OcVQJVpZO+DGU0rkoVW5ce2SccxugvpBJoMvUs59iILYdw==", + "license": "MIT", "dependencies": { "tslib": "^2.4.0" }, @@ -11244,7 +11375,6 @@ "version": "2.0.3", "resolved": "https://registry.npmjs.org/internmap/-/internmap-2.0.3.tgz", "integrity": "sha512-5Hh7Y1wQbvY5ooGgPbDaL5iYLAPzMTUrjMulskHLH6wnv/A+1q5rgEaiuqEjB+oxGXIVZs1FF+R/KPN3ZSQYYg==", - "license": "ISC", "engines": { "node": ">=12" } @@ -16730,6 +16860,7 @@ "version": "14.2.3", "resolved": "https://registry.npmjs.org/react-dropzone/-/react-dropzone-14.2.3.tgz", "integrity": "sha512-O3om8I+PkFKbxCukfIR3QAGftYXDZfOE2N1mr/7qebQJHs7U+/RSL/9xomJNpRg9kM5h9soQSdf0Gc7OHF5Fug==", + "license": "MIT", "dependencies": { "attr-accept": "^2.2.2", "file-selector": "^0.6.0", @@ -18745,6 +18876,7 @@ "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-29.2.5.tgz", "integrity": "sha512-KD8zB2aAZrcKIdGk4OwpJggeLcH1FgrICqDSROWqlnJXGCXK4Mn6FcdK2B6670Xr73lHMG1kHw8R87A0ecZ+vA==", "dev": true, + "license": "MIT", "dependencies": { "bs-logger": "^0.2.6", "ejs": "^3.1.10", @@ -18793,6 +18925,7 @@ "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", "dev": true, + "license": "ISC", "bin": { "semver": "bin/semver.js" }, @@ -19520,170 +19653,86 @@ } }, "node_modules/victory-area": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-area/-/victory-area-37.1.0.tgz", - "integrity": "sha512-SfXlOl2Tg700/2+yuq4sNUP2x0VvsZeQz07QohnN4n9ag17Vj650gp8Yx5vj+CWRSZKWd77OcWiQ5FvBAZbr6A==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-area/-/victory-area-37.0.2.tgz", + "integrity": "sha512-KEuJiBg/VQq1CSQe8U1Gk1eI/sMm+Y4WGveKkx9lXvgPHqxXog2Of+j+q1ZY0bXVrb9vAlIuJHPg4Oq+UQRUYw==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0", - "victory-vendor": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-area/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2", + "victory-vendor": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-axis": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-axis/-/victory-axis-37.1.0.tgz", - "integrity": "sha512-7c0zWLEX+L7GzQ6gNUnJHnCnRkgSU57KU41w95XYfmNOpT9bsPwAGmVRfMEvZVWlhpiWshNRzaW2RQ9wSrNZPA==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-axis/-/victory-axis-37.0.2.tgz", + "integrity": "sha512-tmjq43m7hto7NblaJwPiSloilFIlmZ4UMt91yv0dBUlM8sexRTE8g/fAvnioTblVEec/t91sqQBoLta5VZnWIQ==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-axis/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-bar": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-bar/-/victory-bar-37.1.0.tgz", - "integrity": "sha512-vww8UGioxXC8+zV0dzPOVBkk6Dzd+SQcGF+SzFVg3rPyVvTDf5ALL3Hp8Qt6rIkV2rWLjSVh2H3RcEHtkffPEw==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-bar/-/victory-bar-37.0.2.tgz", + "integrity": "sha512-ofezvu4NYkxaQZuLJSnQVsgQKO+869IEYZQuIvc7EtiLrVSznNygqcDrZzLJ+0q6ZxGRIJ/1cdEgaz2dS40ukQ==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0", - "victory-vendor": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-bar/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2", + "victory-vendor": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-box-plot": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-box-plot/-/victory-box-plot-37.1.0.tgz", - "integrity": "sha512-26RRltwrvs3hU7I5x1VHF71eDdVdYpfOfWDbQlte73/sfJotkOI2s8GApkG7fxLbuoYfu4n+2eOPM6FIbFdbtA==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-box-plot/-/victory-box-plot-37.0.2.tgz", + "integrity": "sha512-NzhxPRXues5F3Ay3JRLAnDBGrSC3940KmFHtc14F0Y+KDmwMDa15c2MBME9Rhg6SOvKL/o+jGzYX8ohE3k94kA==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0", - "victory-vendor": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-box-plot/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2", + "victory-vendor": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-brush-container": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-brush-container/-/victory-brush-container-37.1.0.tgz", - "integrity": "sha512-TYw/7ujVvBNwbjzefnPWQj8K+IqyX62G4JNWw+M83ZTnetuN7yZBhch57JCHCh6tCBll9HZijzvuw4ftt8x+sA==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-brush-container/-/victory-brush-container-37.0.2.tgz", + "integrity": "sha512-eZBarKzkGw1fM3n1FSGo5MAE7o4ZM3a87aSSRuIK4aMgGxaZkxKV4y219WCIIDeYw6U4l7T+tDXSw71XbXGG3g==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", "react-fast-compare": "^3.2.0", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-brush-container/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-chart": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-chart/-/victory-chart-37.1.0.tgz", - "integrity": "sha512-3wCOLCyJ94o03Uvj2XvNyY3AiFvGfVgq/8PZDnPu649ntSOG3MRGgwiazq8BHkPy9Im9MXN0dZ+WcemhPRZfPA==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-chart/-/victory-chart-37.0.2.tgz", + "integrity": "sha512-OpNvSzypQyhyJtBYAcx+9vJZTry2HssBJVT5Yui1NrT4IcHTuw02z5Zg/RYFgADloqraA+TsVzZbJQcfD/j6MA==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", "react-fast-compare": "^3.2.0", - "victory-axis": "37.1.0", - "victory-core": "37.1.0", - "victory-polar-axis": "37.1.0", - "victory-shared-events": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-chart/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-axis": "^37.0.2", + "victory-core": "^37.0.2", + "victory-polar-axis": "^37.0.2", + "victory-shared-events": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" @@ -19693,7 +19742,6 @@ "version": "37.0.2", "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.0.2.tgz", "integrity": "sha512-B3A3yCanjskShZTFtA1Bp8BLXniaTtjzaKHOChjCkay8oRkWjGMy0aZdCL7ezfUWVHAaFUIw248PgqApMn1K/w==", - "license": "MIT", "dependencies": { "lodash": "^4.17.21", "react-fast-compare": "^3.2.0", @@ -19735,287 +19783,147 @@ } }, "node_modules/victory-group": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-group/-/victory-group-37.1.0.tgz", - "integrity": "sha512-PXR9BJEeMONej3N9kRk6xPD07o7Umes9HsSNvcm6TV4K86VuMXzLuYg5Q3PmknWnDF1eECDr1pfWZbLy1vTi/Q==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-group/-/victory-group-37.0.2.tgz", + "integrity": "sha512-uBU3PdndeOxE5E+LVoVnT3ciJNwlTj99Deh178AARJ3jKuuH3hJ7Fnw+tgQjQNMdRuKKxILJdddd9ouktLTJJA==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", "react-fast-compare": "^3.2.0", - "victory-core": "37.1.0", - "victory-shared-events": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-group/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2", + "victory-shared-events": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-legend": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-legend/-/victory-legend-37.1.0.tgz", - "integrity": "sha512-fxxvSkq6AUgEZawfgo4gJtNleFATwwICkad+6JxRii0F73YY0hzbfbkC2YrLSK920JxbnzLWf0ixMtbFzT/yew==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-legend/-/victory-legend-37.0.2.tgz", + "integrity": "sha512-mbScaQepyvLVghyRSxsccZwpf3LTz434GuWIh5aFQcP8pTrGT+9V8Wtw6N6W/4MxHBznh1sGZbI755k+IM2oNQ==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-legend/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-line": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-line/-/victory-line-37.1.0.tgz", - "integrity": "sha512-5IejHIbYrDjsOFdbftG+NhBf1mcAb9YNwrV14SGNN9PMejeCS7PN4nT+tC8BFdGF17ORS0gDP464AvVIn7jlbg==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-line/-/victory-line-37.0.2.tgz", + "integrity": "sha512-b0Jj9uYGzWhA3KCbzjvraxKfP3gB+sqzaU/r2JQdICug0isGQHnng3vW40RNveEjE6CfIEHGZdylSCAbjAFhzQ==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0", - "victory-vendor": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-line/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2", + "victory-vendor": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-pie": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-pie/-/victory-pie-37.1.0.tgz", - "integrity": "sha512-6wLs/XBrp+nq8U7L81TiEQGIqn+InTCiNMBMbABRWdsQQVviysovoZ0Q+GhEcGl5+BWhbRPe3LGMfEQTwQYX/Q==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-pie/-/victory-pie-37.0.2.tgz", + "integrity": "sha512-rdaL7Or5BU/368xLoe8FThekxx9ICgwmtaUc2Lt1w8uklt6S3SBMbAoL2lmr5IutZf55HYRX64vM3TGqWjD3+w==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0", - "victory-vendor": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-pie/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2", + "victory-vendor": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-polar-axis": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-polar-axis/-/victory-polar-axis-37.1.0.tgz", - "integrity": "sha512-NY5RPLRFqeGDWMTlZ8EZERtMS7gcviBtcO7h9lvDbUHFrrDdxBe4YwzgEgdzIdwVJpV9bSngVjBaOrDb8NPXyw==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-polar-axis/-/victory-polar-axis-37.0.2.tgz", + "integrity": "sha512-qqIk9fFYuL9G/RzHoXB/9ZI6DkKHdfdczI2vdl2rl0KdzAcfd9Eosa9EHmnTh/9ijPJvYi++1ul1WQNRWXBVSg==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-polar-axis/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-scatter": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-scatter/-/victory-scatter-37.1.0.tgz", - "integrity": "sha512-movtEagWZjFnI4Wbrn1zb2rgV5UTnCwipVnj+Rj8IEu7NUIjuA1B8ZQsdo6yJs1JzMQeslfbuN1PP3dWiJ/MvA==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-scatter/-/victory-scatter-37.0.2.tgz", + "integrity": "sha512-BY83Y+D3enHqPvHAt3HrEaT5ckmcj3vq3QJ28e1b6DhlbGWoS/DEmhf5OiHF+wCBSSDBOkAyq1uTXSbcHKyLXQ==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-scatter/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-selection-container": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-selection-container/-/victory-selection-container-37.1.0.tgz", - "integrity": "sha512-AXBWydZAlVV+Vo6Hj9IskTHijnhA/rcrjxwk1kfbhClPDFwnREtkdzO8r6BLqlFlAQlXYK5vDONBzpLR0q22FA==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-selection-container/-/victory-selection-container-37.0.2.tgz", + "integrity": "sha512-HgLmGTIZNdlpZ081ZowJAoUYE69q4p9sB0h8FBKbM7xPDXfH9Eh6MZ5RIfoen9GdB4Hz0He4vQZIU5OOK3TNDQ==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-selection-container/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-shared-events": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-shared-events/-/victory-shared-events-37.1.0.tgz", - "integrity": "sha512-j7ppVc14UeOXr3l2xZEtSxochlOcHq875MfuDjyzZUsAkpIgJ+fFwUUYVn9Inzi0iuJwghXWki/916IQjOTqvQ==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-shared-events/-/victory-shared-events-37.0.2.tgz", + "integrity": "sha512-1U1yljfsFs3fGJmoSZt1j/ZgdV4tf2hWhue2Xixn71ZEYFBlsF6hY3gXI5EzRji1QhHa3mnar17wrgr++H+CWQ==", "license": "MIT", "dependencies": { "json-stringify-safe": "^5.0.1", "lodash": "^4.17.19", "react-fast-compare": "^3.2.0", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-shared-events/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-stack": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-stack/-/victory-stack-37.1.0.tgz", - "integrity": "sha512-Mipm4Lzn7Ely1qHCTZRRC/ug4zIueNFzlgHHXObMgjt9iXz2sBAYe8eJXNkdJIDo67XTU8nTVLgzXsuiyz++eg==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-stack/-/victory-stack-37.0.2.tgz", + "integrity": "sha512-CbinJJxkN7WT6XJ8EWZLXiibqHGU++rKqyh95jo01U+FZ7QOu5l0qf7OxfEnmEWGLF3J5hcMEOSX22lrdtxl+A==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", "react-fast-compare": "^3.2.0", - "victory-core": "37.1.0", - "victory-shared-events": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-stack/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2", + "victory-shared-events": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-tooltip": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-tooltip/-/victory-tooltip-37.1.0.tgz", - "integrity": "sha512-OiXZ40dC/XTaW05oiwm8V4JJATfnedCrvuSCE/yiRp/RPysw5ZhbgAdVFDglJnT5aTxKcafRrr8NTy6nNNLgCw==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-tooltip/-/victory-tooltip-37.0.2.tgz", + "integrity": "sha512-UYne2i9in8bwxz0z6+kknvZbKVbMdfapQnISDBBWfmqWVHirsxNGJUFaSrHMqEBdNtTCXLd0vNhADJxIUKGtqA==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-tooltip/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" } }, "node_modules/victory-vendor": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-vendor/-/victory-vendor-37.1.0.tgz", - "integrity": "sha512-ecXgkii9uNdLQvEmRQgSawdGLVLT5jAbSuyIyDeS0T5O3diTEW/UcyK+JmXJxVaNb1ZHPZ+zEW/bNg2pyGraIw==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-vendor/-/victory-vendor-37.0.2.tgz", + "integrity": "sha512-Mjs+00QR256itUM/jVqGJkAw5OADpwjQj7sOEqLqJQfnj9uuf7cPto1KCjrS5d+E6lb0mE5kYwUfzBq0BrMa8Q==", "license": "MIT AND ISC", "dependencies": { "@types/d3-array": "^3.0.3", @@ -20051,27 +19959,13 @@ } }, "node_modules/victory-zoom-container": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-zoom-container/-/victory-zoom-container-37.1.0.tgz", - "integrity": "sha512-GTW15lHBj+YVDAu2ONIPteVKzPbRWt/Lhzc/9p1e+VOvkfQtL+skZLt1Pq6diYZzcqyimzk6Z+FeipXiig8AMQ==", + "version": "37.0.2", + "resolved": "https://registry.npmjs.org/victory-zoom-container/-/victory-zoom-container-37.0.2.tgz", + "integrity": "sha512-CCTm7EgCtFKBduEgJjYTokC13sy0LmLC3Eczb967n7IZUUrIaNQsyGajW3gH5wbof4zeHSpuZghRGPUB2DVQ1Q==", "license": "MIT", "dependencies": { "lodash": "^4.17.19", - "victory-core": "37.1.0" - }, - "peerDependencies": { - "react": ">=16.6.0" - } - }, - "node_modules/victory-zoom-container/node_modules/victory-core": { - "version": "37.1.0", - "resolved": "https://registry.npmjs.org/victory-core/-/victory-core-37.1.0.tgz", - "integrity": "sha512-K1PVc0AIO+p5XmmgjK1L87MXZS+UKyguohTR1dNT1Ltveerj9TR5hys8DTdMPpWhR+W7R6U9RLQeACbQSOcbnQ==", - "license": "MIT", - "dependencies": { - "lodash": "^4.17.21", - "react-fast-compare": "^3.2.0", - "victory-vendor": "37.1.0" + "victory-core": "^37.0.2" }, "peerDependencies": { "react": ">=16.6.0" @@ -20158,25 +20052,26 @@ } }, "node_modules/webpack": { - "version": "5.94.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.94.0.tgz", - "integrity": "sha512-KcsGn50VT+06JH/iunZJedYGUJS5FGjow8wb9c0v5n1Om8O1g4L6LjtfxwlXIATopoQu+vOXXa7gYisWxCoPyg==", + "version": "5.90.3", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.90.3.tgz", + "integrity": "sha512-h6uDYlWCctQRuXBs1oYpVe6sFcWedl0dpcVaTf/YF67J9bKvwJajFulMVSYKHrksMB3I/pIagRzDxwxkebuzKA==", "dev": true, "dependencies": { + "@types/eslint-scope": "^3.7.3", "@types/estree": "^1.0.5", - "@webassemblyjs/ast": "^1.12.1", - "@webassemblyjs/wasm-edit": "^1.12.1", - "@webassemblyjs/wasm-parser": "^1.12.1", + "@webassemblyjs/ast": "^1.11.5", + "@webassemblyjs/wasm-edit": "^1.11.5", + "@webassemblyjs/wasm-parser": "^1.11.5", "acorn": "^8.7.1", - "acorn-import-attributes": "^1.9.5", + "acorn-import-assertions": "^1.9.0", "browserslist": "^4.21.10", "chrome-trace-event": "^1.0.2", - "enhanced-resolve": "^5.17.1", + "enhanced-resolve": "^5.15.0", "es-module-lexer": "^1.2.1", "eslint-scope": "5.1.1", "events": "^3.2.0", "glob-to-regexp": "^0.4.1", - "graceful-fs": "^4.2.11", + "graceful-fs": "^4.2.9", "json-parse-even-better-errors": "^2.3.1", "loader-runner": "^4.2.0", "mime-types": "^2.1.27", @@ -20184,7 +20079,7 @@ "schema-utils": "^3.2.0", "tapable": "^2.1.1", "terser-webpack-plugin": "^5.3.10", - "watchpack": "^2.4.1", + "watchpack": "^2.4.0", "webpack-sources": "^3.2.3" }, "bin": { diff --git a/package.json b/package.json index e8cae8521..01f6f1f59 100644 --- a/package.json +++ b/package.json @@ -50,15 +50,15 @@ "verify": "npm-run-all build lint test" }, "dependencies": { - "@patternfly/patternfly": "5.4.0", - "@patternfly/react-charts": "7.4.0", - "@patternfly/react-component-groups": "^5.2.0", - "@patternfly/react-core": "5.4.0", - "@patternfly/react-icons": "5.4.0", - "@patternfly/react-table": "5.4.0", - "@patternfly/react-tokens": "5.4.0", + "@patternfly/patternfly": "6.0.0-alpha.222", + "@patternfly/react-charts": "8.0.0-alpha.38", + "@patternfly/react-component-groups": "6.0.0-alpha.14", + "@patternfly/react-core": "6.0.0-alpha.102", + "@patternfly/react-icons": "6.0.0-alpha.36", + "@patternfly/react-table": "6.0.0-alpha.103", + "@patternfly/react-tokens": "6.0.0-alpha.35", "@redhat-cloud-services/frontend-components": "^4.2.14", - "@redhat-cloud-services/frontend-components-notifications": "^4.1.0", + "@ausuliv/frontend-components-notifications": "^4.1.5", "@redhat-cloud-services/frontend-components-translations": "^3.2.8", "@redhat-cloud-services/frontend-components-utilities": "^4.0.17", "@redhat-cloud-services/rbac-client": "^2.2.2", @@ -136,6 +136,9 @@ "webpack-bundle-analyzer": "^4.10.2" }, "overrides": { + "@patternfly/react-core": "6.0.0-alpha.102", + "@patternfly/react-icons": "6.0.0-alpha.36", + "@patternfly/react-table": "6.0.0-alpha.103", "@typescript-eslint/eslint-plugin": "^8.4.0", "eslint": "^9.9.1", "redux": "^5.0.1" diff --git a/src/app.tsx b/src/app.tsx index fec7429a0..70872ecde 100644 --- a/src/app.tsx +++ b/src/app.tsx @@ -1,8 +1,8 @@ import './app.scss'; +import NotificationsPortal from '@ausuliv/frontend-components-notifications/NotificationPortal'; +import { notificationsReducer } from '@ausuliv/frontend-components-notifications/redux'; import { useChrome } from '@redhat-cloud-services/frontend-components/useChrome'; -import NotificationsPortal from '@redhat-cloud-services/frontend-components-notifications/NotificationPortal'; -import { notificationsReducer } from '@redhat-cloud-services/frontend-components-notifications/redux'; import { getRegistry } from '@redhat-cloud-services/frontend-components-utilities/Registry'; import React, { useEffect, useLayoutEffect } from 'react'; import { invalidateSession } from 'utils/sessionStorage'; diff --git a/src/appEntry.tsx b/src/appEntry.tsx index cc548ecbc..e17e25620 100644 --- a/src/appEntry.tsx +++ b/src/appEntry.tsx @@ -1,5 +1,4 @@ /* eslint-disable no-console */ -import NotificationsPortal from '@redhat-cloud-services/frontend-components-notifications/NotificationPortal'; import IntlProvider from '@redhat-cloud-services/frontend-components-translations/Provider'; import { getLocale } from 'components/i18n'; import React from 'react'; @@ -11,7 +10,7 @@ import App from './app'; import { configureStore } from './store'; // Todo: Uncomment for use with non-shared PatternFly packages -// require.resolve('@patternfly/patternfly/patternfly.css'); +require.resolve('@patternfly/patternfly/patternfly.css'); // Todo: revert require.resolve('@patternfly/patternfly/patternfly-addons.css'); import './styles/global.css'; @@ -28,7 +27,6 @@ const AppEntry = () => { return ( - diff --git a/src/components/drawers/commonDrawer/commonDrawer.tsx b/src/components/drawers/commonDrawer/commonDrawer.tsx index 229a4e2d7..026c1f756 100644 --- a/src/components/drawers/commonDrawer/commonDrawer.tsx +++ b/src/components/drawers/commonDrawer/commonDrawer.tsx @@ -50,7 +50,7 @@ class CommonDrawerBase extends React.Component { // https://github.com/redhat-developer/rhosak-ui/blob/main/packages/ui/src/components/KafkaInstanceDrawer/KafkaInstanceDrawer.tsx#L69-L78 return ( - + {children} diff --git a/src/components/drawers/exports/exports.styles.ts b/src/components/drawers/exports/exports.styles.ts index e0ffabf43..4846d75e0 100644 --- a/src/components/drawers/exports/exports.styles.ts +++ b/src/components/drawers/exports/exports.styles.ts @@ -1,4 +1,4 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; @@ -18,12 +18,12 @@ export const styles = { alignItems: 'center', }, pagination: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, paddingBottom: global_spacer_md.value, paddingTop: global_spacer_md.value, }, toolbarContainer: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, paddingBottom: global_spacer_md.value, paddingTop: global_spacer_md.value, }, diff --git a/src/components/drawers/exports/exportsLink.tsx b/src/components/drawers/exports/exportsLink.tsx index 82dbee0ef..90350f78e 100644 --- a/src/components/drawers/exports/exportsLink.tsx +++ b/src/components/drawers/exports/exportsLink.tsx @@ -50,7 +50,7 @@ class ExportsLinkBase extends React.Component { // @redhat-cloud-services/frontend-components-notifications does not expose PatternFly's actionLinks prop if (isActionLink) { return ( -
+
{intl.formatMessage(messages.exportsTitle)}
); diff --git a/src/components/drawers/exports/exportsTable.styles.ts b/src/components/drawers/exports/exportsTable.styles.ts index 03c215f93..2d892ab38 100644 --- a/src/components/drawers/exports/exportsTable.styles.ts +++ b/src/components/drawers/exports/exportsTable.styles.ts @@ -1,23 +1,23 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_danger_color_200 from '@patternfly/react-tokens/dist/js/global_danger_color_200'; -import global_FontSize_sm from '@patternfly/react-tokens/dist/js/global_FontSize_sm'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; +import global_color_status_danger_200 from '@patternfly/react-tokens/dist/js/global_color_status_danger_200'; +import global_font_size_sm from '@patternfly/react-tokens/dist/js/global_font_size_sm'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import global_spacer_xl from '@patternfly/react-tokens/dist/js/global_spacer_xl'; import type React from 'react'; export const styles = { emptyState: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, display: 'flex', justifyContent: 'center', paddingTop: global_spacer_xl.value, width: '100%', }, failed: { - color: global_danger_color_200.value, + color: global_color_status_danger_200.value, }, failedButton: { - fontSize: global_FontSize_sm.value, + fontSize: global_font_size_sm.value, }, failedHeader: { marginLeft: global_spacer_md.value, diff --git a/src/components/drawers/exports/exportsTable.tsx b/src/components/drawers/exports/exportsTable.tsx index 9fa0c55f8..9770d7cea 100644 --- a/src/components/drawers/exports/exportsTable.tsx +++ b/src/components/drawers/exports/exportsTable.tsx @@ -4,8 +4,6 @@ import { EmptyState, EmptyStateBody, EmptyStateFooter, - EmptyStateHeader, - EmptyStateIcon, Label, Popover, } from '@patternfly/react-core'; @@ -140,12 +138,11 @@ class ExportsTableBase extends React.Component - {intl.formatMessage(messages.noExportsStateTitle)}} - icon={} - headingLevel="h5" - /> + {intl.formatMessage(messages.noExportsStateTitle)}} + > {intl.formatMessage(messages.exportsEmptyState)}
} > + > )} > diff --git a/src/components/drawers/exports/exportsToolbar.tsx b/src/components/drawers/exports/exportsToolbar.tsx index c0302554b..479b5682c 100644 --- a/src/components/drawers/exports/exportsToolbar.tsx +++ b/src/components/drawers/exports/exportsToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import messages from 'locales/messages'; import React from 'react'; @@ -32,7 +32,7 @@ type ExportsToolbarProps = ExportsToolbarOwnProps & WrappedComponentProps; export class ExportsToolbarBase extends React.Component { - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl } = this.props; return [{ name: intl.formatMessage(messages.filterByValues, { value: 'name' }), key: 'name' }]; diff --git a/src/components/inactiveSources/inactiveSources.scss b/src/components/inactiveSources/inactiveSources.scss index b46cf0a92..d13a020fb 100644 --- a/src/components/inactiveSources/inactiveSources.scss +++ b/src/components/inactiveSources/inactiveSources.scss @@ -1,8 +1,8 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .alert { - background-color: var(--pf-v5-global--BackgroundColor--light-100); - padding-left: var(--pf-v5-global--spacer--lg); - padding-right: var(--pf-v5-global--spacer--lg); - padding-top: var(--pf-v5-global--spacer--lg); + background-color: var(--pf-t--global--background--color--primary--default); + padding-left: var(--pf-t--global--spacer--lg); + padding-right: var(--pf-t--global--spacer--lg); + padding-top: var(--pf-t--global--spacer--lg); } diff --git a/src/routes/components/charts/costExplorerChart/costExplorerChart.styles.ts b/src/routes/components/charts/costExplorerChart/costExplorerChart.styles.ts index 5494744d1..2d1cbabda 100644 --- a/src/routes/components/charts/costExplorerChart/costExplorerChart.styles.ts +++ b/src/routes/components/charts/costExplorerChart/costExplorerChart.styles.ts @@ -1,19 +1,19 @@ import { chart_color_blue_300 } from '@patternfly/react-tokens/dist/js/chart_color_blue_300'; -import { chart_color_cyan_300 } from '@patternfly/react-tokens/dist/js/chart_color_cyan_300'; -import { chart_color_gold_300 } from '@patternfly/react-tokens/dist/js/chart_color_gold_300'; import { chart_color_green_300 } from '@patternfly/react-tokens/dist/js/chart_color_green_300'; import { chart_color_orange_300 } from '@patternfly/react-tokens/dist/js/chart_color_orange_300'; import { chart_color_purple_300 } from '@patternfly/react-tokens/dist/js/chart_color_purple_300'; +import { chart_color_teal_300 } from '@patternfly/react-tokens/dist/js/chart_color_teal_300'; +import { chart_color_yellow_300 } from '@patternfly/react-tokens/dist/js/chart_color_yellow_300'; export const chartStyles = { // See: https://github.com/project-koku/koku-ui/issues/241 colorScale: [ chart_color_blue_300.value, - chart_color_gold_300.value, + chart_color_yellow_300.value, chart_color_green_300.value, chart_color_purple_300.value, chart_color_orange_300.value, - chart_color_cyan_300.value, + chart_color_teal_300.value, ], yAxis: { axisLabel: { diff --git a/src/routes/components/charts/historicalCostChart/__snapshots__/historicalCostChart.test.tsx.snap b/src/routes/components/charts/historicalCostChart/__snapshots__/historicalCostChart.test.tsx.snap index 72375b858..ec3906689 100644 --- a/src/routes/components/charts/historicalCostChart/__snapshots__/historicalCostChart.test.tsx.snap +++ b/src/routes/components/charts/historicalCostChart/__snapshots__/historicalCostChart.test.tsx.snap @@ -6,9 +6,9 @@ exports[`null previous and current reports are handled 1`] = ` class="chartOverride" >

@@ -22,7 +22,7 @@ exports[`null previous and current reports are handled 1`] = ` style="height: 100px;" >
@@ -92,7 +92,7 @@ exports[`null previous and current reports are handled 1`] = ` d="M8,25C7.8933333333333335,24.886666666666667,7.786666666666666,24.773333333333333,7.68,24.66C7.573333333333333,24.546666666666667,7.466666666666666,24.433333333333334,7.359999999999999,24.32C7.253333333333333,24.206666666666667,7.146666666666667,24.093333333333334,7.040000000000001,23.98C6.9333333333333345,23.866666666666667,6.826666666666667,23.753333333333334,6.720000000000001,23.64C6.613333333333334,23.526666666666667,6.506666666666667,23.413333333333334,6.4,23.3C6.293333333333334,23.186666666666667,6.1866666666666665,23.073333333333334,6.08,22.96C5.973333333333334,22.846666666666668,5.866666666666666,22.733333333333334,5.76,22.62C5.653333333333333,22.506666666666668,5.546666666666666,22.393333333333334,5.4399999999999995,22.28C5.333333333333333,22.166666666666668,5.2266666666666675,22.053333333333335,5.120000000000001,21.94C5.0133333333333345,21.826666666666668,4.906666666666667,21.713333333333335,4.800000000000001,21.6C4.693333333333334,21.486666666666668,4.586666666666667,21.373333333333335,4.48,21.26C4.373333333333334,21.14666666666667,4.266666666666667,21.033333333333335,4.16,20.92C4.053333333333334,20.80666666666667,3.9466666666666668,20.69333333333333,3.84,20.58C3.733333333333333,20.466666666666665,3.6266666666666665,20.353333333333335,3.5199999999999996,20.240000000000002C3.413333333333333,20.12666666666667,3.306666666666666,20.013333333333332,3.1999999999999997,19.9C3.093333333333333,19.786666666666665,2.9866666666666664,19.673333333333332,2.8799999999999994,19.56C2.773333333333333,19.446666666666665,2.666666666666667,19.33333333333333,2.5600000000000005,19.219999999999995C2.4533333333333336,19.106666666666662,2.346666666666667,18.993333333333332,2.24,18.88C2.1333333333333333,18.766666666666666,2.026666666666667,18.653333333333332,1.92,18.54C1.8133333333333332,18.426666666666666,1.7066666666666663,18.313333333333333,1.5999999999999996,18.2C1.4933333333333334,18.086666666666666,1.386666666666667,17.973333333333336,1.2800000000000007,17.860000000000003C1.173333333333334,17.74666666666667,1.066666666666667,17.633333333333336,0.9600000000000004,17.520000000000003C0.8533333333333338,17.40666666666667,0.7466666666666671,17.293333333333333,0.6400000000000006,17.18C0.533333333333334,17.066666666666666,0.42666666666666736,16.953333333333333,0.32000000000000073,16.84C0.21333333333333382,16.726666666666667,0.10666666666666691,16.613333333333333,0,16.5C-0.10666666666666676,16.386666666666667,-0.21333333333333354,16.273333333333333,-0.3200000000000003,16.16C-0.42666666666666647,16.046666666666667,-0.5333333333333327,15.933333333333334,-0.6399999999999988,15.82C-0.7466666666666661,15.706666666666665,-0.8533333333333335,15.593333333333332,-0.9600000000000009,15.479999999999999C-1.066666666666667,15.366666666666665,-1.1733333333333331,15.253333333333334,-1.2799999999999994,15.14C-1.386666666666666,15.026666666666667,-1.493333333333333,14.913333333333334,-1.5999999999999996,14.8C-1.7066666666666659,14.686666666666667,-1.813333333333332,14.573333333333334,-1.9199999999999982,14.46C-2.0266666666666655,14.346666666666668,-2.133333333333333,14.233333333333334,-2.24,14.120000000000001C-2.346666666666667,14.006666666666668,-2.4533333333333336,13.893333333333334,-2.5600000000000005,13.780000000000001C-2.6666666666666665,13.666666666666668,-2.773333333333333,13.553333333333333,-2.879999999999999,13.44C-2.986666666666666,13.326666666666664,-3.0933333333333324,13.213333333333331,-3.1999999999999993,13.099999999999998C-3.306666666666666,12.986666666666665,-3.4133333333333327,12.873333333333335,-3.5199999999999996,12.760000000000002C-3.6266666666666665,12.646666666666668,-3.733333333333333,12.533333333333333,-3.84,12.42C-3.9466666666666668,12.306666666666667,-4.053333333333334,12.193333333333333,-4.16,12.08C-4.266666666666667,11.966666666666667,-4.373333333333332,11.853333333333332,-4.479999999999999,11.739999999999998C-4.586666666666666,11.626666666666663,-4.693333333333333,11.513333333333332,-4.800000000000001,11.399999999999999C-4.906666666666667,11.286666666666665,-5.013333333333333,11.173333333333332,-5.119999999999999,11.059999999999999C-5.226666666666666,10.946666666666665,-5.333333333333333,10.833333333333334,-5.4399999999999995,10.72C-5.546666666666666,10.606666666666667,-5.653333333333333,10.493333333333334,-5.76,10.38C-5.866666666666666,10.266666666666667,-5.973333333333334,10.153333333333332,-6.08,10.04C-6.1866666666666665,9.926666666666666,-6.293333333333334,9.813333333333333,-6.4,9.7C-6.506666666666667,9.586666666666666,-6.613333333333332,9.473333333333333,-6.719999999999999,9.36C-6.826666666666665,9.246666666666666,-6.933333333333333,9.133333333333333,-7.039999999999999,9.02C-7.146666666666666,8.906666666666666,-7.253333333333331,8.793333333333333,-7.359999999999998,8.68C-7.466666666666665,8.566666666666666,-7.573333333333332,8.453333333333333,-7.68,8.34C-7.786666666666666,8.226666666666667,-7.8933333333333335,8.113333333333333,-8,8" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #38812f; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #3d7317; fill-opacity: 0.3; stroke-width: 2;" /> @@ -102,7 +102,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -139,7 +139,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -160,7 +160,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -181,7 +181,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -196,7 +196,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -234,7 +234,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -255,7 +255,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -276,7 +276,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -297,7 +297,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -318,7 +318,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -346,7 +346,7 @@ exports[`null previous and current reports are handled 1`] = ` z" role="presentation" shape-rendering="auto" - style="fill: #8bc1f7;" + style="fill: #92c5f9;" /> @@ -385,7 +385,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -417,9 +417,9 @@ exports[`reports are formatted to datums 1`] = ` class="chartOverride" >

@@ -433,7 +433,7 @@ exports[`reports are formatted to datums 1`] = ` style="height: 100px;" >
@@ -503,7 +503,7 @@ exports[`reports are formatted to datums 1`] = ` d="M8,22.95206455054681C7.822222222222222,22.771400817995907,7.644444444444445,22.590737085445003,7.466666666666667,22.410050680181378C7.288888888888889,22.229364274917753,7.111111111111112,22.0486476393705,6.933333333333334,21.867946118965058C6.7555555555555555,21.687244598559616,6.577777777777778,21.50652796301236,6.4,21.325841557748735C6.222222222222222,21.14515515248511,6.044444444444445,20.964514092646926,5.866666666666667,20.7838276873833C5.688888888888889,20.603141282119676,5.511111111111112,20.42242464657242,5.333333333333334,20.241723126166978C5.155555555555556,20.061021605761535,4.977777777777779,19.880312527785186,4.800000000000001,19.699618564950654C4.622222222222223,19.51892460211612,4.444444444444444,19.3382457544234,4.266666666666666,19.157559349159776C4.088888888888889,18.97687294389615,3.911111111111111,18.79619409620343,3.733333333333334,18.615500133368897C3.555555555555556,18.43480617053436,3.3777777777777778,18.254097092558016,3.1999999999999997,18.073395572152574C3.022222222222222,17.89269405174713,2.844444444444445,17.746810260513914,2.6666666666666674,17.53129101093625C2.4888888888888894,17.315771761358587,2.3111111111111113,17.080655730417,2.1333333333333333,16.780280074686583C1.9555555555555555,16.479904418956167,1.7777777777777775,16.078680537032096,1.5999999999999996,15.729037076553746C1.4222222222222218,15.379393616075397,1.2444444444444442,15.027566017604695,1.0666666666666664,14.682419311816485C0.8888888888888887,14.337272606028275,0.7111111111111109,14.005442340179602,0.5333333333333332,13.658156841824486C0.3555555555555555,13.310871343469369,0.17777777777777773,12.945538365786431,0,12.598706321685782C-0.17777777777777773,12.251874277585133,-0.3555555555555555,11.914519427402864,-0.5333333333333332,11.577164577220593" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #38812f; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #3d7317; fill-opacity: 0.3; stroke-width: 2;" /> @@ -513,7 +513,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -550,7 +550,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -571,7 +571,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -592,7 +592,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -607,7 +607,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -645,7 +645,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -666,7 +666,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -687,7 +687,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -715,7 +715,7 @@ exports[`reports are formatted to datums 1`] = ` z" role="presentation" shape-rendering="auto" - style="fill: #8bc1f7;" + style="fill: #92c5f9;" /> @@ -754,7 +754,7 @@ exports[`reports are formatted to datums 1`] = ` diff --git a/src/routes/components/charts/historicalTrendChart/__snapshots__/historicalTrendChart.test.tsx.snap b/src/routes/components/charts/historicalTrendChart/__snapshots__/historicalTrendChart.test.tsx.snap index f33121793..d55c73892 100644 --- a/src/routes/components/charts/historicalTrendChart/__snapshots__/historicalTrendChart.test.tsx.snap +++ b/src/routes/components/charts/historicalTrendChart/__snapshots__/historicalTrendChart.test.tsx.snap @@ -5,9 +5,9 @@ exports[`null previous and current reports are handled 1`] = ` class="chartOverride" >

@@ -21,7 +21,7 @@ exports[`null previous and current reports are handled 1`] = ` style="height: 100px;" >
@@ -91,7 +91,7 @@ exports[`null previous and current reports are handled 1`] = ` d="M8,25C7.8933333333333335,24.886666666666667,7.786666666666666,24.773333333333333,7.68,24.66C7.573333333333333,24.546666666666667,7.466666666666666,24.433333333333334,7.359999999999999,24.32C7.253333333333333,24.206666666666667,7.146666666666667,24.093333333333334,7.040000000000001,23.98C6.9333333333333345,23.866666666666667,6.826666666666667,23.753333333333334,6.720000000000001,23.64C6.613333333333334,23.526666666666667,6.506666666666667,23.413333333333334,6.4,23.3C6.293333333333334,23.186666666666667,6.1866666666666665,23.073333333333334,6.08,22.96C5.973333333333334,22.846666666666668,5.866666666666666,22.733333333333334,5.76,22.62C5.653333333333333,22.506666666666668,5.546666666666666,22.393333333333334,5.4399999999999995,22.28C5.333333333333333,22.166666666666668,5.2266666666666675,22.053333333333335,5.120000000000001,21.94C5.0133333333333345,21.826666666666668,4.906666666666667,21.713333333333335,4.800000000000001,21.6C4.693333333333334,21.486666666666668,4.586666666666667,21.373333333333335,4.48,21.26C4.373333333333334,21.14666666666667,4.266666666666667,21.033333333333335,4.16,20.92C4.053333333333334,20.80666666666667,3.9466666666666668,20.69333333333333,3.84,20.58C3.733333333333333,20.466666666666665,3.6266666666666665,20.353333333333335,3.5199999999999996,20.240000000000002C3.413333333333333,20.12666666666667,3.306666666666666,20.013333333333332,3.1999999999999997,19.9C3.093333333333333,19.786666666666665,2.9866666666666664,19.673333333333332,2.8799999999999994,19.56C2.773333333333333,19.446666666666665,2.666666666666667,19.33333333333333,2.5600000000000005,19.219999999999995C2.4533333333333336,19.106666666666662,2.346666666666667,18.993333333333332,2.24,18.88C2.1333333333333333,18.766666666666666,2.026666666666667,18.653333333333332,1.92,18.54C1.8133333333333332,18.426666666666666,1.7066666666666663,18.313333333333333,1.5999999999999996,18.2C1.4933333333333334,18.086666666666666,1.386666666666667,17.973333333333336,1.2800000000000007,17.860000000000003C1.173333333333334,17.74666666666667,1.066666666666667,17.633333333333336,0.9600000000000004,17.520000000000003C0.8533333333333338,17.40666666666667,0.7466666666666671,17.293333333333333,0.6400000000000006,17.18C0.533333333333334,17.066666666666666,0.42666666666666736,16.953333333333333,0.32000000000000073,16.84C0.21333333333333382,16.726666666666667,0.10666666666666691,16.613333333333333,0,16.5C-0.10666666666666676,16.386666666666667,-0.21333333333333354,16.273333333333333,-0.3200000000000003,16.16C-0.42666666666666647,16.046666666666667,-0.5333333333333327,15.933333333333334,-0.6399999999999988,15.82C-0.7466666666666661,15.706666666666665,-0.8533333333333335,15.593333333333332,-0.9600000000000009,15.479999999999999C-1.066666666666667,15.366666666666665,-1.1733333333333331,15.253333333333334,-1.2799999999999994,15.14C-1.386666666666666,15.026666666666667,-1.493333333333333,14.913333333333334,-1.5999999999999996,14.8C-1.7066666666666659,14.686666666666667,-1.813333333333332,14.573333333333334,-1.9199999999999982,14.46C-2.0266666666666655,14.346666666666668,-2.133333333333333,14.233333333333334,-2.24,14.120000000000001C-2.346666666666667,14.006666666666668,-2.4533333333333336,13.893333333333334,-2.5600000000000005,13.780000000000001C-2.6666666666666665,13.666666666666668,-2.773333333333333,13.553333333333333,-2.879999999999999,13.44C-2.986666666666666,13.326666666666664,-3.0933333333333324,13.213333333333331,-3.1999999999999993,13.099999999999998C-3.306666666666666,12.986666666666665,-3.4133333333333327,12.873333333333335,-3.5199999999999996,12.760000000000002C-3.6266666666666665,12.646666666666668,-3.733333333333333,12.533333333333333,-3.84,12.42C-3.9466666666666668,12.306666666666667,-4.053333333333334,12.193333333333333,-4.16,12.08C-4.266666666666667,11.966666666666667,-4.373333333333332,11.853333333333332,-4.479999999999999,11.739999999999998C-4.586666666666666,11.626666666666663,-4.693333333333333,11.513333333333332,-4.800000000000001,11.399999999999999C-4.906666666666667,11.286666666666665,-5.013333333333333,11.173333333333332,-5.119999999999999,11.059999999999999C-5.226666666666666,10.946666666666665,-5.333333333333333,10.833333333333334,-5.4399999999999995,10.72C-5.546666666666666,10.606666666666667,-5.653333333333333,10.493333333333334,-5.76,10.38C-5.866666666666666,10.266666666666667,-5.973333333333334,10.153333333333332,-6.08,10.04C-6.1866666666666665,9.926666666666666,-6.293333333333334,9.813333333333333,-6.4,9.7C-6.506666666666667,9.586666666666666,-6.613333333333332,9.473333333333333,-6.719999999999999,9.36C-6.826666666666665,9.246666666666666,-6.933333333333333,9.133333333333333,-7.039999999999999,9.02C-7.146666666666666,8.906666666666666,-7.253333333333331,8.793333333333333,-7.359999999999998,8.68C-7.466666666666665,8.566666666666666,-7.573333333333332,8.453333333333333,-7.68,8.34C-7.786666666666666,8.226666666666667,-7.8933333333333335,8.113333333333333,-8,8" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #4cb140; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #63993d; fill-opacity: 0.3; stroke-width: 2;" /> @@ -101,7 +101,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -142,7 +142,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -163,7 +163,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -178,7 +178,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -219,7 +219,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -240,7 +240,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -261,7 +261,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -282,7 +282,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -310,7 +310,7 @@ exports[`null previous and current reports are handled 1`] = ` z" role="presentation" shape-rendering="auto" - style="fill: #8bc1f7;" + style="fill: #92c5f9;" /> @@ -349,7 +349,7 @@ exports[`null previous and current reports are handled 1`] = ` @@ -379,9 +379,9 @@ exports[`reports are formatted to datums 1`] = ` class="chartOverride" >

@@ -395,7 +395,7 @@ exports[`reports are formatted to datums 1`] = ` style="height: 100px;" >
@@ -465,7 +465,7 @@ exports[`reports are formatted to datums 1`] = ` d="M8,16.5Z" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #4cb140; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #63993d; fill-opacity: 0.3; stroke-width: 2;" /> @@ -475,7 +475,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -516,7 +516,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -537,7 +537,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -552,7 +552,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -593,7 +593,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -614,7 +614,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -635,7 +635,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -656,7 +656,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -684,7 +684,7 @@ exports[`reports are formatted to datums 1`] = ` z" role="presentation" shape-rendering="auto" - style="fill: #8bc1f7;" + style="fill: #92c5f9;" /> @@ -723,7 +723,7 @@ exports[`reports are formatted to datums 1`] = ` diff --git a/src/routes/components/charts/historicalUsageChart/__snapshots__/historicalUsageChart.test.tsx.snap b/src/routes/components/charts/historicalUsageChart/__snapshots__/historicalUsageChart.test.tsx.snap index e20450b42..9e70aef15 100644 --- a/src/routes/components/charts/historicalUsageChart/__snapshots__/historicalUsageChart.test.tsx.snap +++ b/src/routes/components/charts/historicalUsageChart/__snapshots__/historicalUsageChart.test.tsx.snap @@ -5,9 +5,9 @@ exports[`reports are formatted to datums 1`] = ` class="chartOverride" >

@@ -21,7 +21,7 @@ exports[`reports are formatted to datums 1`] = ` style="height: 100px;" >
@@ -91,7 +91,7 @@ exports[`reports are formatted to datums 1`] = ` d="M0.5333333333333332,14Z" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #38812f; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #3d7317; fill-opacity: 0.3; stroke-width: 2;" /> @@ -121,7 +121,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -151,7 +151,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -183,7 +183,7 @@ exports[`reports are formatted to datums 1`] = ` d="M8,20C7.8933333333333335,19.92,7.786666666666666,19.840000000000003,7.68,19.76C7.573333333333333,19.68,7.466666666666666,19.6,7.359999999999999,19.52C7.253333333333333,19.439999999999998,7.146666666666667,19.359999999999996,7.040000000000001,19.279999999999998C6.9333333333333345,19.2,6.826666666666667,19.12,6.720000000000001,19.040000000000003C6.613333333333334,18.960000000000004,6.506666666666667,18.880000000000003,6.4,18.8C6.293333333333334,18.72,6.1866666666666665,18.64,6.08,18.560000000000002C5.973333333333334,18.480000000000004,5.866666666666666,18.4,5.76,18.32C5.653333333333333,18.240000000000002,5.546666666666666,18.16,5.4399999999999995,18.080000000000002C5.333333333333333,18.000000000000004,5.2266666666666675,17.92,5.120000000000001,17.840000000000003C5.0133333333333345,17.76,4.906666666666667,17.68,4.800000000000001,17.6C4.693333333333334,17.520000000000003,4.586666666666667,17.440000000000005,4.48,17.360000000000003C4.373333333333334,17.28,4.266666666666667,17.199999999999996,4.16,17.119999999999997C4.053333333333334,17.04,3.9466666666666668,16.96,3.84,16.880000000000003C3.733333333333333,16.800000000000004,3.6266666666666665,16.720000000000002,3.5199999999999996,16.64C3.413333333333333,16.56,3.306666666666666,16.48,3.1999999999999997,16.4C3.093333333333333,16.319999999999997,2.9866666666666664,16.239999999999995,2.8799999999999994,16.159999999999997C2.773333333333333,16.08,2.666666666666667,16,2.5600000000000005,15.92C2.4533333333333336,15.84,2.346666666666667,15.76,2.24,15.68C2.1333333333333333,15.6,2.026666666666667,15.520000000000001,1.92,15.440000000000001C1.8133333333333332,15.360000000000001,1.7066666666666663,15.28,1.5999999999999996,15.2C1.4933333333333334,15.12,1.386666666666667,15.040000000000001,1.2800000000000007,14.96C1.173333333333334,14.88,1.066666666666667,14.8,0.9600000000000004,14.72C0.8533333333333338,14.64,0.7466666666666671,14.56,0.6400000000000006,14.48C0.533333333333334,14.4,0.42666666666666736,14.32,0.32000000000000073,14.24C0.21333333333333382,14.16,0.10666666666666691,14.08,0,14C-0.10666666666666676,13.92,-0.21333333333333354,13.84,-0.3200000000000003,13.76C-0.42666666666666647,13.68,-0.5333333333333327,13.6,-0.6399999999999988,13.52C-0.7466666666666661,13.44,-0.8533333333333335,13.36,-0.9600000000000009,13.28C-1.066666666666667,13.2,-1.1733333333333331,13.12,-1.2799999999999994,13.04C-1.386666666666666,12.959999999999999,-1.493333333333333,12.88,-1.5999999999999996,12.8C-1.7066666666666659,12.72,-1.813333333333332,12.639999999999999,-1.9199999999999982,12.559999999999999C-2.0266666666666655,12.479999999999999,-2.133333333333333,12.4,-2.24,12.32C-2.346666666666667,12.24,-2.4533333333333336,12.159999999999998,-2.5600000000000005,12.079999999999998C-2.6666666666666665,11.999999999999998,-2.773333333333333,11.92,-2.879999999999999,11.84C-2.986666666666666,11.76,-3.0933333333333324,11.679999999999998,-3.1999999999999993,11.599999999999998C-3.306666666666666,11.519999999999998,-3.4133333333333327,11.44,-3.5199999999999996,11.36C-3.6266666666666665,11.28,-3.733333333333333,11.200000000000001,-3.84,11.120000000000001C-3.9466666666666668,11.040000000000001,-4.053333333333334,10.959999999999999,-4.16,10.879999999999999C-4.266666666666667,10.799999999999999,-4.373333333333332,10.72,-4.479999999999999,10.64C-4.586666666666666,10.56,-4.693333333333333,10.479999999999999,-4.800000000000001,10.399999999999999C-4.906666666666667,10.319999999999999,-5.013333333333333,10.24,-5.119999999999999,10.16C-5.226666666666666,10.08,-5.333333333333333,10,-5.4399999999999995,9.92C-5.546666666666666,9.84,-5.653333333333333,9.76,-5.76,9.68C-5.866666666666666,9.6,-5.973333333333334,9.52,-6.08,9.44C-6.1866666666666665,9.36,-6.293333333333334,9.28,-6.4,9.2C-6.506666666666667,9.12,-6.613333333333332,9.04,-6.719999999999999,8.959999999999999C-6.826666666666665,8.879999999999999,-6.933333333333333,8.799999999999999,-7.039999999999999,8.719999999999999C-7.146666666666666,8.639999999999999,-7.253333333333331,8.56,-7.359999999999998,8.48C-7.466666666666665,8.4,-7.573333333333332,8.32,-7.68,8.24C-7.786666666666666,8.16,-7.8933333333333335,8.08,-8,8" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #06c; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #0066cc; fill-opacity: 0.3; stroke-width: 2;" /> @@ -215,7 +215,7 @@ exports[`reports are formatted to datums 1`] = ` d="M8,20C7.8933333333333335,19.92,7.786666666666666,19.840000000000003,7.68,19.76C7.573333333333333,19.68,7.466666666666666,19.6,7.359999999999999,19.52C7.253333333333333,19.439999999999998,7.146666666666667,19.359999999999996,7.040000000000001,19.279999999999998C6.9333333333333345,19.2,6.826666666666667,19.12,6.720000000000001,19.040000000000003C6.613333333333334,18.960000000000004,6.506666666666667,18.880000000000003,6.4,18.8C6.293333333333334,18.72,6.1866666666666665,18.64,6.08,18.560000000000002C5.973333333333334,18.480000000000004,5.866666666666666,18.4,5.76,18.32C5.653333333333333,18.240000000000002,5.546666666666666,18.16,5.4399999999999995,18.080000000000002C5.333333333333333,18.000000000000004,5.2266666666666675,17.92,5.120000000000001,17.840000000000003C5.0133333333333345,17.76,4.906666666666667,17.68,4.800000000000001,17.6C4.693333333333334,17.520000000000003,4.586666666666667,17.440000000000005,4.48,17.360000000000003C4.373333333333334,17.28,4.266666666666667,17.199999999999996,4.16,17.119999999999997C4.053333333333334,17.04,3.9466666666666668,16.96,3.84,16.880000000000003C3.733333333333333,16.800000000000004,3.6266666666666665,16.720000000000002,3.5199999999999996,16.64C3.413333333333333,16.56,3.306666666666666,16.48,3.1999999999999997,16.4C3.093333333333333,16.319999999999997,2.9866666666666664,16.239999999999995,2.8799999999999994,16.159999999999997C2.773333333333333,16.08,2.666666666666667,16,2.5600000000000005,15.92C2.4533333333333336,15.84,2.346666666666667,15.76,2.24,15.68C2.1333333333333333,15.6,2.026666666666667,15.520000000000001,1.92,15.440000000000001C1.8133333333333332,15.360000000000001,1.7066666666666663,15.28,1.5999999999999996,15.2C1.4933333333333334,15.12,1.386666666666667,15.040000000000001,1.2800000000000007,14.96C1.173333333333334,14.88,1.066666666666667,14.8,0.9600000000000004,14.72C0.8533333333333338,14.64,0.7466666666666671,14.56,0.6400000000000006,14.48C0.533333333333334,14.4,0.42666666666666736,14.32,0.32000000000000073,14.24C0.21333333333333382,14.16,0.10666666666666691,14.08,0,14C-0.10666666666666676,13.92,-0.21333333333333354,13.84,-0.3200000000000003,13.76C-0.42666666666666647,13.68,-0.5333333333333327,13.6,-0.6399999999999988,13.52C-0.7466666666666661,13.44,-0.8533333333333335,13.36,-0.9600000000000009,13.28C-1.066666666666667,13.2,-1.1733333333333331,13.12,-1.2799999999999994,13.04C-1.386666666666666,12.959999999999999,-1.493333333333333,12.88,-1.5999999999999996,12.8C-1.7066666666666659,12.72,-1.813333333333332,12.639999999999999,-1.9199999999999982,12.559999999999999C-2.0266666666666655,12.479999999999999,-2.133333333333333,12.4,-2.24,12.32C-2.346666666666667,12.24,-2.4533333333333336,12.159999999999998,-2.5600000000000005,12.079999999999998C-2.6666666666666665,11.999999999999998,-2.773333333333333,11.92,-2.879999999999999,11.84C-2.986666666666666,11.76,-3.0933333333333324,11.679999999999998,-3.1999999999999993,11.599999999999998C-3.306666666666666,11.519999999999998,-3.4133333333333327,11.44,-3.5199999999999996,11.36C-3.6266666666666665,11.28,-3.733333333333333,11.200000000000001,-3.84,11.120000000000001C-3.9466666666666668,11.040000000000001,-4.053333333333334,10.959999999999999,-4.16,10.879999999999999C-4.266666666666667,10.799999999999999,-4.373333333333332,10.72,-4.479999999999999,10.64C-4.586666666666666,10.56,-4.693333333333333,10.479999999999999,-4.800000000000001,10.399999999999999C-4.906666666666667,10.319999999999999,-5.013333333333333,10.24,-5.119999999999999,10.16C-5.226666666666666,10.08,-5.333333333333333,10,-5.4399999999999995,9.92C-5.546666666666666,9.84,-5.653333333333333,9.76,-5.76,9.68C-5.866666666666666,9.6,-5.973333333333334,9.52,-6.08,9.44C-6.1866666666666665,9.36,-6.293333333333334,9.28,-6.4,9.2C-6.506666666666667,9.12,-6.613333333333332,9.04,-6.719999999999999,8.959999999999999C-6.826666666666665,8.879999999999999,-6.933333333333333,8.799999999999999,-7.039999999999999,8.719999999999999C-7.146666666666666,8.639999999999999,-7.253333333333331,8.56,-7.359999999999998,8.48C-7.466666666666665,8.4,-7.573333333333332,8.32,-7.68,8.24C-7.786666666666666,8.16,-7.8933333333333335,8.08,-8,8" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #7cc674; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #87bb62; fill-opacity: 0.3; stroke-width: 2;" /> @@ -225,7 +225,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -266,7 +266,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -287,7 +287,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -302,7 +302,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -343,7 +343,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -364,7 +364,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -385,7 +385,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -413,7 +413,7 @@ exports[`reports are formatted to datums 1`] = ` z" role="presentation" shape-rendering="auto" - style="fill: #8bc1f7;" + style="fill: #92c5f9;" /> @@ -512,7 +512,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -529,7 +529,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -546,7 +546,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -563,7 +563,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -580,7 +580,7 @@ exports[`reports are formatted to datums 1`] = ` diff --git a/src/routes/components/charts/trendChart/__snapshots__/trendChart.test.tsx.snap b/src/routes/components/charts/trendChart/__snapshots__/trendChart.test.tsx.snap index f5f43266a..c5bd26315 100644 --- a/src/routes/components/charts/trendChart/__snapshots__/trendChart.test.tsx.snap +++ b/src/routes/components/charts/trendChart/__snapshots__/trendChart.test.tsx.snap @@ -3,9 +3,9 @@ exports[`reports are formatted to datums 1`] = `

Example Trend Title @@ -18,7 +18,7 @@ exports[`reports are formatted to datums 1`] = ` style="height: 100px;" >
@@ -94,7 +94,7 @@ exports[`reports are formatted to datums 1`] = ` d="M0.5333333333333332,29Z" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #38812f; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #3d7317; fill-opacity: 0.3; stroke-width: 2;" /> @@ -104,7 +104,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -145,7 +145,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -166,7 +166,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -181,7 +181,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -222,7 +222,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -243,7 +243,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -264,7 +264,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -292,7 +292,7 @@ exports[`reports are formatted to datums 1`] = ` z" role="presentation" shape-rendering="auto" - style="fill: #d2d2d2;" + style="fill: #e0e0e0;" /> @@ -331,7 +331,7 @@ exports[`reports are formatted to datums 1`] = ` diff --git a/src/routes/components/charts/usageChart/__snapshots__/usageChart.test.tsx.snap b/src/routes/components/charts/usageChart/__snapshots__/usageChart.test.tsx.snap index fa66ea952..1f272aa96 100644 --- a/src/routes/components/charts/usageChart/__snapshots__/usageChart.test.tsx.snap +++ b/src/routes/components/charts/usageChart/__snapshots__/usageChart.test.tsx.snap @@ -6,7 +6,7 @@ exports[`reports are formatted to datums 1`] = ` style="height: 100px;" >
@@ -82,7 +82,7 @@ exports[`reports are formatted to datums 1`] = ` d="M0.5333333333333332,25Z" role="presentation" shape-rendering="auto" - style="fill: none; stroke: #38812f; fill-opacity: 0.3; stroke-width: 2;" + style="fill: none; stroke: #3d7317; fill-opacity: 0.3; stroke-width: 2;" /> @@ -112,7 +112,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -142,7 +142,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -152,7 +152,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -193,7 +193,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -214,7 +214,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -229,7 +229,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -270,7 +270,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -291,7 +291,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -312,7 +312,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -340,7 +340,7 @@ exports[`reports are formatted to datums 1`] = ` z" role="presentation" shape-rendering="auto" - style="fill: #d2d2d2;" + style="fill: #e0e0e0;" /> @@ -419,7 +419,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -436,7 +436,7 @@ exports[`reports are formatted to datums 1`] = ` @@ -453,7 +453,7 @@ exports[`reports are formatted to datums 1`] = ` diff --git a/src/routes/components/cluster/modal/clusterModal.scss b/src/routes/components/cluster/modal/clusterModal.scss index d247c868b..8393ee2ea 100644 --- a/src/routes/components/cluster/modal/clusterModal.scss +++ b/src/routes/components/cluster/modal/clusterModal.scss @@ -1,10 +1,10 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .modalOverride { - & .pf-v5-c-modal-box__body { - margin-top: var(--pf-v5-global--spacer--lg); + & .pf-v6-c-modal-box__body { + margin-top: var(--pf-t--global--spacer--lg); } - & .pf-v5-c-modal-box__footer { + & .pf-v6-c-modal-box__footer { display: none; } } diff --git a/src/routes/components/cluster/modal/clusterModal.tsx b/src/routes/components/cluster/modal/clusterModal.tsx index 840f31ec7..e1d8e5517 100644 --- a/src/routes/components/cluster/modal/clusterModal.tsx +++ b/src/routes/components/cluster/modal/clusterModal.tsx @@ -1,6 +1,6 @@ import './clusterModal.scss'; -import { Modal } from '@patternfly/react-core'; +import { Modal, ModalBody, ModalHeader } from '@patternfly/react-core'; import messages from 'locales/messages'; import React from 'react'; import type { WrappedComponentProps } from 'react-intl'; @@ -38,18 +38,16 @@ class ClusterModalBase extends React.Component { const { clusters, groupBy, intl, isOpen, title } = this.props; return ( - - + + + + + ); } diff --git a/src/routes/components/dataTable/dataTable.scss b/src/routes/components/dataTable/dataTable.scss index d97c63d36..e4c02450f 100644 --- a/src/routes/components/dataTable/dataTable.scss +++ b/src/routes/components/dataTable/dataTable.scss @@ -4,13 +4,13 @@ div { display: block; margin-right: 0; - margin-bottom: var(--pf-v5-global--spacer--xs); + margin-bottom: var(--pf-t--global--spacer--xs); &.iconOverride { &.decrease { - color: var(--pf-v5-global--success-color--100); + color: var(--pf-t--global--color--status--success--default); } &.increase { - color: var(--pf-v5-global--danger-color--100); + color: var(--pf-t--global--color--status--danger--default); } .fa-sort-up { margin-left: 10px; @@ -19,10 +19,10 @@ margin-left: 10px; } .fa-sort-up::before { - color: var(--pf-v5-global--danger-color--100); + color: var(--pf-t--global--color--status--danger--default); } .fa-sort-down::before { - color: var(--pf-v5-global--success-color--100); + color: var(--pf-t--global--color--status--success--default); } span { margin-right: -17px !important; @@ -32,7 +32,7 @@ } .tableOverride { - &.pf-v5-c-table tbody .pf-v5-c-table__check input { - margin-top: .40rem; + &.pf-v6-c-table tbody .pf-v6-c-table__check input { + margin-top: .26rem; } } diff --git a/src/routes/components/dataTable/dataTable.styles.ts b/src/routes/components/dataTable/dataTable.styles.ts index c18c613e3..81c3f11b1 100644 --- a/src/routes/components/dataTable/dataTable.styles.ts +++ b/src/routes/components/dataTable/dataTable.styles.ts @@ -1,6 +1,6 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_disabled_color_100 from '@patternfly/react-tokens/dist/js/global_disabled_color_100'; -import global_FontSize_xs from '@patternfly/react-tokens/dist/js/global_FontSize_xs'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; +import global_color_disabled_100 from '@patternfly/react-tokens/dist/js/global_color_disabled_100'; +import global_font_size_body_sm from '@patternfly/react-tokens/dist/js/global_font_size_body_sm'; import global_spacer_3xl from '@patternfly/react-tokens/dist/js/global_spacer_3xl'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; @@ -17,7 +17,7 @@ export const styles = { minWidth: '50px', }, emptyState: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, display: 'flex', justifyContent: 'center', paddingTop: global_spacer_3xl.value, @@ -34,8 +34,8 @@ export const styles = { bottom: global_spacer_xs.value, }, infoDescription: { - color: global_disabled_color_100.value, - fontSize: global_FontSize_xs.value, + color: global_color_disabled_100.value, + fontSize: global_font_size_body_sm.value, }, lastItem: { textAlign: 'right', diff --git a/src/routes/components/dataTable/dataTable.tsx b/src/routes/components/dataTable/dataTable.tsx index 07ae4a492..671bc7cc1 100644 --- a/src/routes/components/dataTable/dataTable.tsx +++ b/src/routes/components/dataTable/dataTable.tsx @@ -1,13 +1,6 @@ import './dataTable.scss'; -import { - Bullseye, - EmptyState, - EmptyStateBody, - EmptyStateHeader, - EmptyStateIcon, - Spinner, -} from '@patternfly/react-core'; +import { Bullseye, EmptyState, EmptyStateBody, Spinner } from '@patternfly/react-core'; import { CalculatorIcon } from '@patternfly/react-icons/dist/esm/icons/calculator-icon'; import type { ThProps } from '@patternfly/react-table'; import { SortByDirection, Table, TableVariant, Tbody, Td, Th, Thead, Tr } from '@patternfly/react-table'; @@ -54,8 +47,7 @@ class DataTable extends React.Component { return emptyState ? ( emptyState ) : ( - - } /> + {intl.formatMessage(messages.detailsEmptyState)} ); diff --git a/src/routes/components/dataTable/expandableTable.tsx b/src/routes/components/dataTable/expandableTable.tsx index 9c9c6441d..958d3023c 100644 --- a/src/routes/components/dataTable/expandableTable.tsx +++ b/src/routes/components/dataTable/expandableTable.tsx @@ -1,13 +1,6 @@ import './dataTable.scss'; -import { - Bullseye, - EmptyState, - EmptyStateBody, - EmptyStateHeader, - EmptyStateIcon, - Spinner, -} from '@patternfly/react-core'; +import { Bullseye, EmptyState, EmptyStateBody, Spinner } from '@patternfly/react-core'; import { CalculatorIcon } from '@patternfly/react-icons/dist/esm/icons/calculator-icon'; import type { ThProps } from '@patternfly/react-table'; import { SortByDirection, Table, TableVariant, Tbody, Td, Th, Thead, Tr } from '@patternfly/react-table'; @@ -60,8 +53,7 @@ class ExpandableTable extends React.Component - } /> + {intl.formatMessage(messages.detailsEmptyState)} ); diff --git a/src/routes/components/dataTable/selectableTable.tsx b/src/routes/components/dataTable/selectableTable.tsx index 2d6d21f68..91e295630 100644 --- a/src/routes/components/dataTable/selectableTable.tsx +++ b/src/routes/components/dataTable/selectableTable.tsx @@ -1,11 +1,4 @@ -import { - Bullseye, - EmptyState, - EmptyStateBody, - EmptyStateHeader, - EmptyStateIcon, - Spinner, -} from '@patternfly/react-core'; +import { Bullseye, EmptyState, EmptyStateBody, Spinner } from '@patternfly/react-core'; import { CalculatorIcon } from '@patternfly/react-icons/dist/esm/icons/calculator-icon'; import type { ThProps } from '@patternfly/react-table'; import { SortByDirection, Table, TableVariant, Tbody, Td, Th, Thead, Tr } from '@patternfly/react-table'; @@ -53,8 +46,7 @@ class SelectableTable extends React.Component { return emptyState; } return ( - - } /> + {intl.formatMessage(messages.detailsEmptyState)} ); diff --git a/src/routes/components/dataToolbar/basicToolbar.tsx b/src/routes/components/dataToolbar/basicToolbar.tsx index ed24adf3b..7cce2f181 100644 --- a/src/routes/components/dataToolbar/basicToolbar.tsx +++ b/src/routes/components/dataToolbar/basicToolbar.tsx @@ -14,7 +14,6 @@ import { isEqual } from 'routes/utils/equal'; import type { Filter } from 'routes/utils/filter'; import { createMapStateToProps } from 'store/common'; -import { styles } from './dataToolbar.styles'; import { getBulkSelect } from './utils/bulkSelect'; import { getCategoryInput, @@ -335,14 +334,14 @@ export class BasicToolbarBase extends React.Component +
- {showBulkSelect && {this.getBulkSelectComponent()}} + {showBulkSelect && {this.getBulkSelectComponent()}} {showFilter && ( }> @@ -353,7 +352,7 @@ export class BasicToolbarBase extends React.Component )} {actions && {actions}} - + {pagination} diff --git a/src/routes/components/dataToolbar/costCategoryValue.tsx b/src/routes/components/dataToolbar/costCategoryValue.tsx index 30602f1b0..fb5fd543e 100644 --- a/src/routes/components/dataToolbar/costCategoryValue.tsx +++ b/src/routes/components/dataToolbar/costCategoryValue.tsx @@ -147,13 +147,12 @@ class CostCategoryValueBase extends React.Component + > ); diff --git a/src/routes/components/dataToolbar/dataToolbar.scss b/src/routes/components/dataToolbar/dataToolbar.scss index e6d8b1bf2..45a3a07c6 100644 --- a/src/routes/components/dataToolbar/dataToolbar.scss +++ b/src/routes/components/dataToolbar/dataToolbar.scss @@ -3,15 +3,15 @@ // Workaround for https://github.com/patternfly/patternfly-react/issues/4477 // and https://github.com/patternfly/patternfly-react/issues/6371 .selectOverride { - .pf-v5-c-menu-toggle { + .pf-v6-c-menu-toggle { min-width: 250px; } } .toolbarOverride { - .pf-v5-c-button.pf-m-control::after { + .pf-v6-c-button.pf-m-control::after { border-left: none; } // Alternative workaround to overriding table sticky style - // --pf-v5-c-toolbar--ZIndex: auto; z-index: 301; + // --pf-v6-c-toolbar--ZIndex: auto; z-index: 301; } diff --git a/src/routes/components/dataToolbar/dataToolbar.styles.ts b/src/routes/components/dataToolbar/dataToolbar.styles.ts index 054c1a36f..d7d28af02 100644 --- a/src/routes/components/dataToolbar/dataToolbar.styles.ts +++ b/src/routes/components/dataToolbar/dataToolbar.styles.ts @@ -1,4 +1,3 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import type React from 'react'; @@ -6,12 +5,7 @@ export const styles = { export: { marginRight: global_spacer_md.value, }, - toolbarContainer: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, platformCosts: { - marginTop: '6px', + paddingTop: '8px', }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/components/dataToolbar/dataToolbar.tsx b/src/routes/components/dataToolbar/dataToolbar.tsx index c1a1af26f..76f37c3a7 100644 --- a/src/routes/components/dataToolbar/dataToolbar.tsx +++ b/src/routes/components/dataToolbar/dataToolbar.tsx @@ -18,7 +18,6 @@ import type { Filter } from 'routes/utils/filter'; import { createMapStateToProps } from 'store/common'; import { awsCategoryKey, orgUnitIdKey, platformCategoryKey, tagKey } from 'utils/props'; -import { styles } from './dataToolbar.styles'; import { getColumnManagement, getExportButton, getKebab, getPlatformCosts } from './utils/actions'; import { getBulkSelect } from './utils/bulkSelect'; import { @@ -748,14 +747,14 @@ export class DataToolbarBase extends React.Component +
- {showBulkSelect && {this.getBulkSelectComponent()}} + {showBulkSelect && {this.getBulkSelectComponent()}} {showFilter && ( }> @@ -774,12 +773,14 @@ export class DataToolbarBase extends React.Component )} {(showExport || showColumnManagement) && ( - - {showColumnManagement && this.getColumnManagementComponent()} - {showPlatformCosts && this.getPlatformCostsComponent()} - {showExport && this.getExportButtonComponent()} - {(showColumnManagement || showPlatformCosts) && this.getKebab()} - + <> + {showColumnManagement && this.getColumnManagementComponent()} + {showPlatformCosts && this.getPlatformCostsComponent()} + + {showExport && this.getExportButtonComponent()} + {(showColumnManagement || showPlatformCosts) && this.getKebab()} + + )} {(dateRange || datePicker) && ( @@ -787,7 +788,7 @@ export class DataToolbarBase extends React.Component )} - + {pagination} diff --git a/src/routes/components/dataToolbar/tagValue.tsx b/src/routes/components/dataToolbar/tagValue.tsx index 4515deed7..389b844f3 100644 --- a/src/routes/components/dataToolbar/tagValue.tsx +++ b/src/routes/components/dataToolbar/tagValue.tsx @@ -147,13 +147,12 @@ class TagValueBase extends React.Component { + > ); diff --git a/src/routes/components/dataToolbar/utils/actions.tsx b/src/routes/components/dataToolbar/utils/actions.tsx index 615f53948..f09599d65 100644 --- a/src/routes/components/dataToolbar/utils/actions.tsx +++ b/src/routes/components/dataToolbar/utils/actions.tsx @@ -37,18 +37,17 @@ export const getExportButton = ({ }) => { return ( + > ); }; diff --git a/src/routes/components/dataToolbar/utils/category.tsx b/src/routes/components/dataToolbar/utils/category.tsx index 6838155d4..aec866603 100644 --- a/src/routes/components/dataToolbar/utils/category.tsx +++ b/src/routes/components/dataToolbar/utils/category.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import { Button, ButtonVariant, @@ -58,8 +58,8 @@ export const getCategoryInput = ({ return ( @@ -90,13 +90,12 @@ export const getCategoryInput = ({ size={intl.formatMessage(messages.filterByPlaceholder, { value: placeholderKey }).length} /> + > )} @@ -105,7 +104,7 @@ export const getCategoryInput = ({ ); }; -export const getDefaultCategoryOptions = (): ToolbarChipGroup[] => { +export const getDefaultCategoryOptions = (): ToolbarLabelGroup[] => { return [{ name: intl.formatMessage(messages.names, { count: 1 }), key: 'name' }]; }; @@ -196,7 +195,7 @@ export const getCategorySelect = ({ isDisabled, onCategorySelect, }: { - categoryOptions?: ToolbarChipGroup[]; // Options for category menu + categoryOptions?: ToolbarLabelGroup[]; // Options for category menu currentCategory?: string; filters?: Filters; isDisabled?: boolean; @@ -224,7 +223,7 @@ export const getCategorySelect = ({ ); }; -export const getCategorySelectOptions = (categoryOptions: ToolbarChipGroup[]): SelectWrapperOption[] => { +export const getCategorySelectOptions = (categoryOptions: ToolbarLabelGroup[]): SelectWrapperOption[] => { const options: SelectWrapperOption[] = []; categoryOptions.map(option => { diff --git a/src/routes/components/dataToolbar/utils/common.ts b/src/routes/components/dataToolbar/utils/common.ts index b71d23a9c..d11fb4b32 100644 --- a/src/routes/components/dataToolbar/utils/common.ts +++ b/src/routes/components/dataToolbar/utils/common.ts @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import { intl } from 'components/i18n'; import messages from 'locales/messages'; @@ -10,12 +10,12 @@ export interface Filters { [key: string]: Filter[] | { [key: string]: Filter[] }; } -export interface ToolbarChipGroupExt extends ToolbarChipGroup { +export interface ToolbarChipGroupExt extends ToolbarLabelGroup { ariaLabelKey?: string; placeholderKey?: string; resourceKey?: string; selectClassName?: string; // A selector from routes/components/dataToolbar/dataToolbar.scss - selectOptions?: ToolbarChipGroup[]; + selectOptions?: ToolbarLabelGroup[]; } export const defaultFilters = { @@ -91,7 +91,7 @@ export const getChips = (filters: Filter[]): string[] => { return chips; }; -export const getDefaultCategory = (categoryOptions: ToolbarChipGroup[], groupBy: string, query: Query) => { +export const getDefaultCategory = (categoryOptions: ToolbarLabelGroup[], groupBy: string, query: Query) => { if (!categoryOptions) { return 'name'; } diff --git a/src/routes/components/dataToolbar/utils/costCategory.tsx b/src/routes/components/dataToolbar/utils/costCategory.tsx index 9439a52e3..9fe49360d 100644 --- a/src/routes/components/dataToolbar/utils/costCategory.tsx +++ b/src/routes/components/dataToolbar/utils/costCategory.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import { ToolbarFilter, ToolbarItem } from '@patternfly/react-core'; import type { Resource, ResourcePathsType } from 'api/resources/resource'; import { intl } from 'components/i18n'; @@ -59,7 +59,7 @@ export const getCostCategoryKeySelect = ({ export const getCostCategoryKeyOptions = ( resourceReport: Resource, isSelectWrapperOption = false -): ToolbarChipGroup[] | SelectWrapperOption[] => { +): ToolbarLabelGroup[] | SelectWrapperOption[] => { let data = []; let options = []; @@ -122,7 +122,7 @@ export const getCostCategoryValueSelect = ({ }: { currentCategory?: string; currentCostCategoryKey?: string; - costCategoryKeyOption: ToolbarChipGroup; + costCategoryKeyOption: ToolbarLabelGroup; costCategoryKeyValueInput?: string; filters?: Filters; isDisabled?: boolean; @@ -141,8 +141,8 @@ export const getCostCategoryValueSelect = ({ return ( diff --git a/src/routes/components/dataToolbar/utils/custom.tsx b/src/routes/components/dataToolbar/utils/custom.tsx index 76b37694a..e32528ebb 100644 --- a/src/routes/components/dataToolbar/utils/custom.tsx +++ b/src/routes/components/dataToolbar/utils/custom.tsx @@ -39,8 +39,8 @@ export const getCustomSelect = ({ return ( diff --git a/src/routes/components/dataToolbar/utils/orgUntits.tsx b/src/routes/components/dataToolbar/utils/orgUntits.tsx index 63e626f78..11980b509 100644 --- a/src/routes/components/dataToolbar/utils/orgUntits.tsx +++ b/src/routes/components/dataToolbar/utils/orgUntits.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import { ToolbarFilter } from '@patternfly/react-core'; import type { Org } from 'api/orgs/org'; import { intl } from 'components/i18n'; @@ -62,8 +62,8 @@ export const getOrgUnitSelect = ({ key: orgUnitIdKey, name: intl.formatMessage(messages.filterByValues, { value: 'org_unit_id' }), }} - chips={chips} - deleteChip={onDelete} + labels={chips} + deleteLabel={onDelete} key={orgUnitIdKey} showToolbarItem={currentCategory === orgUnitIdKey} > @@ -81,7 +81,7 @@ export const getOrgUnitSelect = ({ ); }; -export const getOrgUnitOptions = (orgReport: Org): ToolbarChipGroup[] => { +export const getOrgUnitOptions = (orgReport: Org): ToolbarLabelGroup[] => { let options = []; if (!orgReport?.data) { return options; diff --git a/src/routes/components/dataToolbar/utils/tags.tsx b/src/routes/components/dataToolbar/utils/tags.tsx index e32a09fe5..2bbb07116 100644 --- a/src/routes/components/dataToolbar/utils/tags.tsx +++ b/src/routes/components/dataToolbar/utils/tags.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import { ToolbarFilter, ToolbarItem } from '@patternfly/react-core'; import type { Tag, TagPathsType } from 'api/tags/tag'; import { intl } from 'components/i18n'; @@ -56,7 +56,7 @@ export const getTagKeySelect = ({ export const getTagKeyOptions = ( tagReport: Tag, isSelectWrapperOption = false -): ToolbarChipGroup[] | SelectWrapperOption[] => { +): ToolbarLabelGroup[] | SelectWrapperOption[] => { let data = []; let options = []; @@ -124,7 +124,7 @@ export const getTagValueSelect = ({ onTagValueSelect?: (event: any, selection) => void; onTagValueInput?: (event: any) => void; onTagValueInputChange?: (value: string) => void; - tagKeyOption?: ToolbarChipGroup; + tagKeyOption?: ToolbarLabelGroup; tagPathsType?: TagPathsType; tagKeyValueInput?: string; }) => { @@ -137,8 +137,8 @@ export const getTagValueSelect = ({ return ( diff --git a/src/routes/components/dropdownWrapper/dropdownWrapper.scss b/src/routes/components/dropdownWrapper/dropdownWrapper.scss index 8d940ce0a..ea02ecfcb 100644 --- a/src/routes/components/dropdownWrapper/dropdownWrapper.scss +++ b/src/routes/components/dropdownWrapper/dropdownWrapper.scss @@ -2,10 +2,10 @@ // Workaround for missing "position" property .dropdownWrapper { - .pf-v5-c-menu-toggle { + .pf-v6-c-menu-toggle { max-width: unset; } - .pf-v5-c-menu-toggle__text { + .pf-v6-c-menu-toggle__text { width: max-content; } } diff --git a/src/routes/components/export/exportModal.tsx b/src/routes/components/export/exportModal.tsx index 3faa1c1ef..f17adb78e 100644 --- a/src/routes/components/export/exportModal.tsx +++ b/src/routes/components/export/exportModal.tsx @@ -10,6 +10,10 @@ import { HelperText, HelperTextItem, Modal, + ModalBody, + ModalFooter, + ModalHeader, + ModalVariant, Radio, TextInput, } from '@patternfly/react-core'; @@ -192,13 +196,117 @@ export class ExportModalBase extends React.Component + + + {error && } +
+ {isExportsToggleEnabled ? ( + + {intl.formatMessage(messages.exportDesc, { value: {intl.formatMessage(messages.exportsTitle)} })} + + ) : ( + {intl.formatMessage(messages.exportHeading, { groupBy })} + )} +
+
+ + {isExportsToggleEnabled && ( + + + + {validated === 'error' && ( + + {intl.formatMessage(helpText)} + + )} + + + )} + {showAggregateType && ( + + + {resolutionOptions.map((option, index) => ( + + ))} + + + )} + {showTimeScope && ( + + + {timeScopeOptions.map((option, index) => ( + + ))} + + + )} + {showFormatType && isExportsToggleEnabled && ( + + + {formatTypeOptions.map((option, index) => ( + + ))} + + + )} + + +
    + {sortedItems.map((groupItem, index) => { + return
  • {groupItem.label}
  • ; + })} +
+
+
+
+
+
+ , + /> , - ]} - > - {error && } -
- {isExportsToggleEnabled ? ( - - {intl.formatMessage(messages.exportDesc, { value: {intl.formatMessage(messages.exportsTitle)} })} - - ) : ( - {intl.formatMessage(messages.exportHeading, { groupBy })} - )} -
-
- - {isExportsToggleEnabled && ( - - - - {validated === 'error' && ( - - {intl.formatMessage(helpText)} - - )} - - - )} - {showAggregateType && ( - - - {resolutionOptions.map((option, index) => ( - - ))} - - - )} - {showTimeScope && ( - - - {timeScopeOptions.map((option, index) => ( - - ))} - - - )} - {showFormatType && isExportsToggleEnabled && ( - - - {formatTypeOptions.map((option, index) => ( - - ))} - - - )} - - -
    - {sortedItems.map((groupItem, index) => { - return
  • {groupItem.label}
  • ; - })} -
-
-
-
-
+ +
); } diff --git a/src/routes/components/page/loading/loading.tsx b/src/routes/components/page/loading/loading.tsx index 99af6462d..84c4d07a9 100644 --- a/src/routes/components/page/loading/loading.tsx +++ b/src/routes/components/page/loading/loading.tsx @@ -19,7 +19,7 @@ const Loading = ({ body, heading, title }: LoadingProps) => { )} - + diff --git a/src/routes/components/page/maintenance/maintenance.tsx b/src/routes/components/page/maintenance/maintenance.tsx index df754ec94..0411c77c5 100644 --- a/src/routes/components/page/maintenance/maintenance.tsx +++ b/src/routes/components/page/maintenance/maintenance.tsx @@ -5,7 +5,7 @@ import { MaintenanceState } from './maintenanceState'; const Maintenance = () => { return ( - + ); diff --git a/src/routes/components/page/maintenance/maintenanceState.tsx b/src/routes/components/page/maintenance/maintenanceState.tsx index f64d20de7..bf144e562 100644 --- a/src/routes/components/page/maintenance/maintenanceState.tsx +++ b/src/routes/components/page/maintenance/maintenanceState.tsx @@ -28,6 +28,7 @@ class MaintenanceStateBase extends React.Component{intl.formatMessage(messages.maintenanceEmptyStateThanks)} } + titleText={undefined} /> ); } diff --git a/src/routes/components/page/noData/noData.tsx b/src/routes/components/page/noData/noData.tsx index 0fedc8d05..70bb0b695 100644 --- a/src/routes/components/page/noData/noData.tsx +++ b/src/routes/components/page/noData/noData.tsx @@ -20,7 +20,7 @@ const NoData = ({ detailsComponent, showReload, title }: NoDataProps) => { )} - + diff --git a/src/routes/components/page/noData/noDataState.tsx b/src/routes/components/page/noData/noDataState.tsx index adddbfd57..b5c4728d6 100644 --- a/src/routes/components/page/noData/noDataState.tsx +++ b/src/routes/components/page/noData/noDataState.tsx @@ -4,8 +4,6 @@ import { EmptyState, EmptyStateBody, EmptyStateFooter, - EmptyStateHeader, - EmptyStateIcon, EmptyStateVariant, } from '@patternfly/react-core'; import { PlusCircleIcon } from '@patternfly/react-icons/dist/esm/icons/plus-circle-icon'; @@ -28,12 +26,13 @@ class NoDataStateBase extends React.Component { const { detailsComponent, intl, showReload = true } = this.props; return ( - - } - headingLevel="h5" - /> + {intl.formatMessage(messages.noDataStateDesc)} {detailsComponent && {detailsComponent}} diff --git a/src/routes/components/page/noInstances/noInstances.tsx b/src/routes/components/page/noInstances/noInstances.tsx index 627d33420..fa4da40a3 100644 --- a/src/routes/components/page/noInstances/noInstances.tsx +++ b/src/routes/components/page/noInstances/noInstances.tsx @@ -18,7 +18,7 @@ const NoInstances = ({ title }: NoInstancesProps) => { )} - + diff --git a/src/routes/components/page/noInstances/noInstancesState.tsx b/src/routes/components/page/noInstances/noInstancesState.tsx index 4a242d7b3..39d790de6 100644 --- a/src/routes/components/page/noInstances/noInstancesState.tsx +++ b/src/routes/components/page/noInstances/noInstancesState.tsx @@ -1,10 +1,4 @@ -import { - EmptyState, - EmptyStateBody, - EmptyStateHeader, - EmptyStateIcon, - EmptyStateVariant, -} from '@patternfly/react-core'; +import { EmptyState, EmptyStateBody, EmptyStateVariant } from '@patternfly/react-core'; import { PlusCircleIcon } from '@patternfly/react-icons/dist/esm/icons/plus-circle-icon'; import messages from 'locales/messages'; import React from 'react'; @@ -22,12 +16,13 @@ class NoInstancesStateBase extends React.Component { const { intl } = this.props; return ( - - } - headingLevel="h1" - /> + {intl.formatMessage(messages.noInstancesDesc)} ); diff --git a/src/routes/components/page/noProviders/noProviders.tsx b/src/routes/components/page/noProviders/noProviders.tsx index 3aea1200e..79b13d32e 100644 --- a/src/routes/components/page/noProviders/noProviders.tsx +++ b/src/routes/components/page/noProviders/noProviders.tsx @@ -20,7 +20,7 @@ const NoProviders = ({ providerType, title }: NoProvidersProps) => { )} - + diff --git a/src/routes/components/page/noProviders/noProvidersState.tsx b/src/routes/components/page/noProviders/noProvidersState.tsx index 11ed24d09..5d6667352 100644 --- a/src/routes/components/page/noProviders/noProvidersState.tsx +++ b/src/routes/components/page/noProviders/noProvidersState.tsx @@ -5,8 +5,6 @@ import { EmptyState, EmptyStateBody, EmptyStateFooter, - EmptyStateHeader, - EmptyStateIcon, EmptyStateVariant, } from '@patternfly/react-core'; import { ExternalLinkAltIcon } from '@patternfly/react-icons/dist/esm/icons/external-link-alt-icon'; @@ -84,12 +82,13 @@ class NoProvidersStateBase extends React.Component { icon = CostIcon; } return ( - - } - headingLevel="h1" - /> + {intl.formatMessage(descKey)} {detailsComponent && {detailsComponent}} diff --git a/src/routes/components/page/notAuthorized/notAuthorized.tsx b/src/routes/components/page/notAuthorized/notAuthorized.tsx index 57f183a56..2ac0bb5b8 100644 --- a/src/routes/components/page/notAuthorized/notAuthorized.tsx +++ b/src/routes/components/page/notAuthorized/notAuthorized.tsx @@ -19,7 +19,7 @@ const NotAuthorized = ({ pathname, title }: NotAuthorizedProps) => { )} - + diff --git a/src/routes/components/page/notAvailable/notAvailable.tsx b/src/routes/components/page/notAvailable/notAvailable.tsx index 342b64599..5b6ced033 100644 --- a/src/routes/components/page/notAvailable/notAvailable.tsx +++ b/src/routes/components/page/notAvailable/notAvailable.tsx @@ -17,7 +17,7 @@ const NotAvailable = ({ title }: NotAvailableProps) => { )} - + diff --git a/src/routes/components/page/notFound/notFound.tsx b/src/routes/components/page/notFound/notFound.tsx index 9084e9b07..96aa8a799 100644 --- a/src/routes/components/page/notFound/notFound.tsx +++ b/src/routes/components/page/notFound/notFound.tsx @@ -4,8 +4,8 @@ import React from 'react'; const NotFound = () => { return ( - - + + ); }; diff --git a/src/routes/components/reports/reportSummary/__snapshots__/reportSummaryItems.test.tsx.snap b/src/routes/components/reports/reportSummary/__snapshots__/reportSummaryItems.test.tsx.snap index 7c07cf5a3..76dde5a04 100644 --- a/src/routes/components/reports/reportSummary/__snapshots__/reportSummaryItems.test.tsx.snap +++ b/src/routes/components/reports/reportSummary/__snapshots__/reportSummaryItems.test.tsx.snap @@ -3,35 +3,35 @@ exports[`contains skeleton readers if in progress 1`] = `
diff --git a/src/routes/components/reports/reportSummary/reportSummary.scss b/src/routes/components/reports/reportSummary/reportSummary.scss index e55656282..252e6a958 100644 --- a/src/routes/components/reports/reportSummary/reportSummary.scss +++ b/src/routes/components/reports/reportSummary/reportSummary.scss @@ -2,12 +2,12 @@ .chartSkeleton { height: 125px; - margin-bottom: var(--pf-v5-global--spacer--md); - margin-top: var(--pf-v5-global--spacer--md); + margin-bottom: var(--pf-t--global--spacer--md); + margin-top: var(--pf-t--global--spacer--md); } .legendSkeleton { - margin-top: var(--pf-v5-global--spacer--md), + margin-top: var(--pf-t--global--spacer--md), } .reportSummary { @@ -16,7 +16,7 @@ .subtitle { display: inline-block; - font-size: var(--pf-v5-global--FontSize--xs); - color: var(--pf-v5-global--Color--200); + font-size: var(--pf-t--global--font--size--xs); + color: var(--pf-t--global--text--color--200); margin-bottom: 0; } diff --git a/src/routes/components/reports/reportSummary/reportSummaryAlt.scss b/src/routes/components/reports/reportSummary/reportSummaryAlt.scss index c73fe7209..71929688f 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryAlt.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryAlt.scss @@ -2,18 +2,18 @@ .chartSkeleton { height: 175px; - margin-bottom: var(--pf-v5-global--spacer--md); - margin-top: var(--pf-v5-global--spacer--md); + margin-bottom: var(--pf-t--global--spacer--md); + margin-top: var(--pf-t--global--spacer--md); } .cost { flex-grow: 1; min-height: 470px; - margin-tight: var(--pf-v5-global--spacer--md); + margin-tight: var(--pf-t--global--spacer--md); } .legendSkeleton { - margin-top: var(--pf-v5-global--spacer--md), + margin-top: var(--pf-t--global--spacer--md), } .reportSummary { @@ -22,11 +22,11 @@ .subtitle { display: inline-block; - font-size: var(--pf-v5-global--FontSize--xs); - color: var(--pf-v5-global--Color--200); + font-size: var(--pf-t--global--font--size--xs); + color: var(--pf-t--global--text--color--200); margin-bottom: 0; } .tops { - margin-top: var(--pf-v5-global--spacer--lg), + margin-top: var(--pf-t--global--spacer--lg), } diff --git a/src/routes/components/reports/reportSummary/reportSummaryCost.scss b/src/routes/components/reports/reportSummary/reportSummaryCost.scss index 22b63d796..062359a96 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryCost.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryCost.scss @@ -1,5 +1,5 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .chart { - margin-bottom: var(--pf-v5-global--spacer--sm); + margin-bottom: var(--pf-t--global--spacer--sm); } diff --git a/src/routes/components/reports/reportSummary/reportSummaryDailyCost.scss b/src/routes/components/reports/reportSummary/reportSummaryDailyCost.scss index 22b63d796..062359a96 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryDailyCost.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryDailyCost.scss @@ -1,5 +1,5 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .chart { - margin-bottom: var(--pf-v5-global--spacer--sm); + margin-bottom: var(--pf-t--global--spacer--sm); } diff --git a/src/routes/components/reports/reportSummary/reportSummaryDailyTrend.scss b/src/routes/components/reports/reportSummary/reportSummaryDailyTrend.scss index 47363e31f..1893af627 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryDailyTrend.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryDailyTrend.scss @@ -1,5 +1,5 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .chart { - margin-nottom: var(--pf-v5-global--spacer--sm); + margin-nottom: var(--pf-t--global--spacer--sm); } diff --git a/src/routes/components/reports/reportSummary/reportSummaryDetails.scss b/src/routes/components/reports/reportSummary/reportSummaryDetails.scss index c569b949f..a85b1ef70 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryDetails.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryDetails.scss @@ -1,40 +1,40 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .reportSummaryDetails { - margin-bottom: var(--pf-v5-global--spacer--md); + margin-bottom: var(--pf-t--global--spacer--md); display: flex; align-Items: flex-end; } .text { - padding-bottom: var(--pf-v5-global--spacer--sm); - line-height: var(--pf-v5-global--LineHeight--sm); - font-size: var(--pf-v5-global--FontSize--xs); + padding-bottom: var(--pf-t--global--spacer--sm); + line-height: var(--pf-t--global--font--line-height--100); + font-size: var(--pf-t--global--font--size--xs); } .units { - padding-left: var(--pf-v5-global--spacer--xs); - padding-bottom: var(--pf-v5-global--spacer--sm); - line-height: var(--pf-v5-global--LineHeight--sm); - font-size: var(--pf-v5-global--FontSize--xs); + padding-left: var(--pf-t--global--spacer--xs); + padding-bottom: var(--pf-t--global--spacer--sm); + line-height: var(--pf-t--global--font--line-height--100); + font-size: var(--pf-t--global--font--size--xs); white-space: nowrap; } .value { - color: var(--pf-v5-global--Color--100); - margin-right: var(--pf-v5-global--spacer--sm); - font-size: var(--pf-v5-global--FontSize--2xl); + color: var(--pf-t--global--text--color--100); + margin-right: var(--pf-t--global--spacer--sm); + font-size: var(--pf-t--global--font--size--2xl); } .valueAlt { - color: var(--pf-v5-global--Color--100); - margin-right: var(--pf-v5-global--spacer--sm); - font-size: var(--pf-v5-global--FontSize--4xl); + color: var(--pf-t--global--text--color--100); + margin-right: var(--pf-t--global--spacer--sm); + font-size: var(--pf-t--global--font--size--4xl); } .valueContainer { display: inline-block; - margin-bottom: var(--pf-v5-global--spacer--md); + margin-bottom: var(--pf-t--global--spacer--md); width: 50%; word-Wrap: break-word; } diff --git a/src/routes/components/reports/reportSummary/reportSummaryItem.scss b/src/routes/components/reports/reportSummary/reportSummaryItem.scss index 7bcc047b7..3e181ec25 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryItem.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryItem.scss @@ -1,5 +1,5 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .reportSummaryItem:not(:last-child) { - margin-bottom: var(--pf-v5-global--spacer--md); + margin-bottom: var(--pf-t--global--spacer--md); } diff --git a/src/routes/components/reports/reportSummary/reportSummaryItems.scss b/src/routes/components/reports/reportSummary/reportSummaryItems.scss index b8f585f23..af491cfae 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryItems.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryItems.scss @@ -1,5 +1,5 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .skeleton { - margin-top: var(--pf-v5-global--spacer--md); + margin-top: var(--pf-t--global--spacer--md); } diff --git a/src/routes/components/reports/reportSummary/reportSummaryTrend.scss b/src/routes/components/reports/reportSummary/reportSummaryTrend.scss index 47363e31f..1893af627 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryTrend.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryTrend.scss @@ -1,5 +1,5 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .chart { - margin-nottom: var(--pf-v5-global--spacer--sm); + margin-nottom: var(--pf-t--global--spacer--sm); } diff --git a/src/routes/components/reports/reportSummary/reportSummaryUsage.scss b/src/routes/components/reports/reportSummary/reportSummaryUsage.scss index 22b63d796..062359a96 100644 --- a/src/routes/components/reports/reportSummary/reportSummaryUsage.scss +++ b/src/routes/components/reports/reportSummary/reportSummaryUsage.scss @@ -1,5 +1,5 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .chart { - margin-bottom: var(--pf-v5-global--spacer--sm); + margin-bottom: var(--pf-t--global--spacer--sm); } diff --git a/src/routes/components/resourceTypeahead/resourceFetch.tsx b/src/routes/components/resourceTypeahead/resourceFetch.tsx index 39a4c3814..4ac5c99ce 100644 --- a/src/routes/components/resourceTypeahead/resourceFetch.tsx +++ b/src/routes/components/resourceTypeahead/resourceFetch.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import { getQuery } from 'api/queries/query'; import type { Resource } from 'api/resources/resource'; @@ -58,7 +58,7 @@ const ResourceFetch: React.FC = ({ }) => { const { resource, resourceFetchStatus } = useMapToProps({ resourcePathsType, resourceType, search }); - const getOptions = (): ToolbarChipGroup[] => { + const getOptions = (): ToolbarLabelGroup[] => { let options = []; if (resource && resource.data && resource.data.length > 0 && resourceFetchStatus !== FetchStatus.inProgress) { options = resource.data.map(item => { diff --git a/src/routes/components/resourceTypeahead/resourceInput.tsx b/src/routes/components/resourceTypeahead/resourceInput.tsx index b7d22a467..868358ce3 100644 --- a/src/routes/components/resourceTypeahead/resourceInput.tsx +++ b/src/routes/components/resourceTypeahead/resourceInput.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import { Button, Divider, @@ -23,7 +23,7 @@ interface ResourceInputOwnProps { isDisabled?: boolean; onChange?: (evt: FormEvent, value: string) => void; onClear?: () => void; - options?: ToolbarChipGroup[]; + options?: ToolbarLabelGroup[]; onSelect?: (value: string) => void; placeholder?: string; search?: string; @@ -69,12 +69,11 @@ const ResourceInput: React.FC = ({ {search && search.length && ( + > )} diff --git a/src/routes/components/selectWrapper/selectTypeaheadWrapper.tsx b/src/routes/components/selectWrapper/selectTypeaheadWrapper.tsx index 593ccb4a2..8bc654c15 100644 --- a/src/routes/components/selectWrapper/selectTypeaheadWrapper.tsx +++ b/src/routes/components/selectWrapper/selectTypeaheadWrapper.tsx @@ -183,12 +183,11 @@ const SelectTypeaheadWrapper: React.FC = ({ {!!inputValue && ( + > )} diff --git a/src/routes/components/selectWrapper/selectWrapper.scss b/src/routes/components/selectWrapper/selectWrapper.scss index c89b9bbd2..7e1cf3bc6 100644 --- a/src/routes/components/selectWrapper/selectWrapper.scss +++ b/src/routes/components/selectWrapper/selectWrapper.scss @@ -2,10 +2,10 @@ // Workaround for missing "position" property .selectWrapper { - .pf-v5-c-menu-toggle { + .pf-v6-c-menu-toggle { max-width: unset; } - .pf-v5-c-menu-toggle__text { + .pf-v6-c-menu-toggle__text { width: max-content; } } diff --git a/src/routes/components/state/emptyFilterState/emptyFilterState.tsx b/src/routes/components/state/emptyFilterState/emptyFilterState.tsx index 04a61cb87..a44d47cd1 100644 --- a/src/routes/components/state/emptyFilterState/emptyFilterState.tsx +++ b/src/routes/components/state/emptyFilterState/emptyFilterState.tsx @@ -1,5 +1,5 @@ import type { MessageDescriptor } from '@formatjs/intl/src/types'; -import { Bullseye, EmptyState, EmptyStateBody, EmptyStateHeader, EmptyStateIcon } from '@patternfly/react-core'; +import { Bullseye, EmptyState, EmptyStateBody } from '@patternfly/react-core'; import { SearchIcon } from '@patternfly/react-icons/dist/esm/icons/search-icon'; import type { Query } from 'api/queries/query'; import { parseQuery } from 'api/queries/query'; @@ -112,10 +112,12 @@ const EmptyFilterStateBase: React.FC = ({ } else if (showEmptyState2) { return ; } else { - return ; + return null; } }; + const item = getItem(); + return (
= ({ ...(showMargin ? styles.containerMargin : {}), }} > - - {getItem()} - + + {item} {intl.formatMessage(subTitle)}
diff --git a/src/routes/components/state/emptyValueState/emptyValueState.scss b/src/routes/components/state/emptyValueState/emptyValueState.scss index ada261561..eb0faca03 100644 --- a/src/routes/components/state/emptyValueState/emptyValueState.scss +++ b/src/routes/components/state/emptyValueState/emptyValueState.scss @@ -1,5 +1,5 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .emptyValueContainer { - font-size: var(--pf-v5-global--FontSize--sm); + font-size: var(--pf-t--global--font--size--sm); } diff --git a/src/routes/components/state/errorState/errorState.tsx b/src/routes/components/state/errorState/errorState.tsx index fc3f60cf1..dafbc2ba0 100644 --- a/src/routes/components/state/errorState/errorState.tsx +++ b/src/routes/components/state/errorState/errorState.tsx @@ -1,10 +1,4 @@ -import { - EmptyState, - EmptyStateBody, - EmptyStateHeader, - EmptyStateIcon, - EmptyStateVariant, -} from '@patternfly/react-core'; +import { EmptyState, EmptyStateBody, EmptyStateVariant } from '@patternfly/react-core'; import { ErrorCircleOIcon } from '@patternfly/react-icons/dist/esm/icons/error-circle-o-icon'; import { LockIcon } from '@patternfly/react-icons/dist/esm/icons/lock-icon'; import type { AxiosError } from 'axios'; @@ -29,8 +23,13 @@ const ErrorStateBase: React.FC = ({ error, icon = ErrorCircleOI } return ( - - } headingLevel="h5" /> + {subTitle} ); diff --git a/src/routes/components/state/loadingState/loadingState.tsx b/src/routes/components/state/loadingState/loadingState.tsx index 0ae19d140..bb9375932 100644 --- a/src/routes/components/state/loadingState/loadingState.tsx +++ b/src/routes/components/state/loadingState/loadingState.tsx @@ -1,4 +1,4 @@ -import { EmptyState, EmptyStateBody, EmptyStateHeader, EmptyStateVariant, Spinner } from '@patternfly/react-core'; +import { EmptyState, EmptyStateBody, EmptyStateVariant, Spinner } from '@patternfly/react-core'; import { intl as defaultIntl } from 'components/i18n'; import messages from 'locales/messages'; import React from 'react'; @@ -18,9 +18,8 @@ const LoadingStateBase: React.FC = ({ heading = intl.formatMessage(messages.loadingStateTitle), }) => { return ( - + - {body} ); diff --git a/src/routes/details/awsBreakdown/instances/instances.styles.ts b/src/routes/details/awsBreakdown/instances/instances.styles.ts new file mode 100644 index 000000000..635214d62 --- /dev/null +++ b/src/routes/details/awsBreakdown/instances/instances.styles.ts @@ -0,0 +1,7 @@ +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; + +export const styles = { + paginationContainer: { + marginTop: global_spacer_sm.var, + }, +} as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/awsBreakdown/instances/instances.tsx b/src/routes/details/awsBreakdown/instances/instances.tsx index 355675279..4ade070f9 100644 --- a/src/routes/details/awsBreakdown/instances/instances.tsx +++ b/src/routes/details/awsBreakdown/instances/instances.tsx @@ -1,4 +1,4 @@ -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import { getQuery } from 'api/queries/query'; import type { Report } from 'api/reports/report'; @@ -12,12 +12,11 @@ import { useDispatch, useSelector } from 'react-redux'; import type { AnyAction } from 'redux'; import type { ThunkDispatch } from 'redux-thunk'; import { ExportModal } from 'routes/components/export'; -import { Loading } from 'routes/components/page/loading'; import { NoInstances } from 'routes/components/page/noInstances'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import type { ColumnManagementModalOption } from 'routes/details/components/columnManagement'; import { ColumnManagementModal, initHiddenColumns } from 'routes/details/components/columnManagement'; -import { styles } from 'routes/optimizations/optimizationsBreakdown/optimizationsBreakdown.styles'; import type { ComputedReportItem } from 'routes/utils/computedReport/getComputedReportItems'; import { getUnsortedComputedReportItems } from 'routes/utils/computedReport/getComputedReportItems'; import { getExcludeTagKey, getFilterByTagKey } from 'routes/utils/groupBy'; @@ -28,6 +27,7 @@ import { reportActions, reportSelectors } from 'store/reports'; import { useQueryFromRoute, useQueryState } from 'utils/hooks'; import { accountKey, logicalAndPrefix, orgUnitIdKey, regionKey, serviceKey } from 'utils/props'; +import { styles } from './instances.styles'; import { InstancesTable, InstanceTableColumnIds } from './instancesTable'; import { InstancesToolbar } from './instancesToolbar'; @@ -306,19 +306,21 @@ const Instances: React.FC = ({ currency }) => { const computedItems = getComputedItems(); return ( - <> - {getExportModal(computedItems)} - {getColumnManagementModal()} - {getToolbar(computedItems)} - {reportFetchStatus === FetchStatus.inProgress ? ( - - ) : ( - <> - {getTable()} -
{getPagination(isDisabled, true)}
- - )} - + + + {getExportModal(computedItems)} + {getColumnManagementModal()} + {getToolbar(computedItems)} + {reportFetchStatus === FetchStatus.inProgress ? ( + + ) : ( + <> + {getTable()} +
{getPagination(isDisabled, true)}
+ + )} +
+
); }; diff --git a/src/routes/details/awsBreakdown/instances/instancesToolbar.tsx b/src/routes/details/awsBreakdown/instances/instancesToolbar.tsx index 0f899d2df..f93c42af7 100644 --- a/src/routes/details/awsBreakdown/instances/instancesToolbar.tsx +++ b/src/routes/details/awsBreakdown/instances/instancesToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { AwsQuery } from 'api/queries/awsQuery'; import { getQuery } from 'api/queries/query'; import { ResourcePathsType } from 'api/resources/resource'; @@ -50,7 +50,7 @@ interface InstancesToolbarDispatchProps { } interface InstancesToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type InstancesToolbarProps = InstancesToolbarOwnProps & @@ -94,7 +94,7 @@ export class InstancesToolbarBase extends React.Component { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { hideAccount, hideRegion, hideTags, intl, tagReport } = this.props; const options = [ diff --git a/src/routes/details/awsDetails/awsDetails.styles.ts b/src/routes/details/awsDetails/awsDetails.styles.ts index e9d9bd507..a16155500 100644 --- a/src/routes/details/awsDetails/awsDetails.styles.ts +++ b/src/routes/details/awsDetails/awsDetails.styles.ts @@ -1,30 +1,11 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; +import type React from 'react'; export const styles = { - awsDetails: { - minHeight: '100%', - }, - content: { - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, + headerContainer: { + paddingBottom: 0, }, paginationContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - toolbarContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, + marginTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/awsDetails/awsDetails.tsx b/src/routes/details/awsDetails/awsDetails.tsx index 581496b2a..523cb0a4a 100644 --- a/src/routes/details/awsDetails/awsDetails.tsx +++ b/src/routes/details/awsDetails/awsDetails.tsx @@ -1,6 +1,6 @@ import 'routes/components/dataTable/dataTable.scss'; -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; import type { AwsQuery } from 'api/queries/awsQuery'; @@ -20,6 +20,7 @@ import { Loading } from 'routes/components/page/loading'; import { NoData } from 'routes/components/page/noData'; import { NoProviders } from 'routes/components/page/noProviders'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import { ProviderDetails } from 'routes/details/components/providerDetails'; import { getIdKeyForGroupBy } from 'routes/utils/computedReport/getComputedAwsReportItems'; import type { ComputedReportItem } from 'routes/utils/computedReport/getComputedReportItems'; @@ -408,31 +409,35 @@ class AwsDetails extends React.Component { } return ( -
- handleOnCostTypeSelect(query, router)} - onCurrencySelect={() => handleOnCurrencySelect(query, router)} - onGroupBySelect={this.handleOnGroupBySelect} - report={report} - /> -
-
{this.getToolbar(computedItems)}
- {this.getExportModal(computedItems)} - {reportFetchStatus === FetchStatus.inProgress ? ( - - ) : ( - <> -
{this.getTable()}
-
-
{this.getPagination(isDisabled, true)}
-
- - )} -
-
+ <> + + handleOnCostTypeSelect(query, router)} + onCurrencySelect={() => handleOnCurrencySelect(query, router)} + onGroupBySelect={this.handleOnGroupBySelect} + report={report} + /> + + + + + {this.getToolbar(computedItems)} + {this.getExportModal(computedItems)} + {reportFetchStatus === FetchStatus.inProgress ? ( + + ) : ( + <> + {this.getTable()} +
{this.getPagination(isDisabled, true)}
+ + )} +
+
+
+ ); } } diff --git a/src/routes/details/awsDetails/detailsHeader.styles.ts b/src/routes/details/awsDetails/detailsHeader.styles.ts index d55ff51cc..f28aa9b26 100644 --- a/src/routes/details/awsDetails/detailsHeader.styles.ts +++ b/src/routes/details/awsDetails/detailsHeader.styles.ts @@ -1,4 +1,3 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; @@ -15,10 +14,6 @@ export const styles = { exportContainer: { display: 'flex', }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, - }, perspective: { paddingTop: global_spacer_lg.var, marginTop: global_spacer_xs.var, diff --git a/src/routes/details/awsDetails/detailsHeader.tsx b/src/routes/details/awsDetails/detailsHeader.tsx index a7416f1d1..f82eac8fb 100644 --- a/src/routes/details/awsDetails/detailsHeader.tsx +++ b/src/routes/details/awsDetails/detailsHeader.tsx @@ -88,7 +88,7 @@ class DetailsHeaderBase extends React.Component { const hasCost = report?.meta?.total?.cost?.total; return ( -
+
diff --git a/src/routes/details/awsDetails/detailsToolbar.tsx b/src/routes/details/awsDetails/detailsToolbar.tsx index d532cad4a..28f3fdc42 100644 --- a/src/routes/details/awsDetails/detailsToolbar.tsx +++ b/src/routes/details/awsDetails/detailsToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { Org } from 'api/orgs/org'; import { OrgPathsType, OrgType } from 'api/orgs/org'; import type { AwsQuery } from 'api/queries/awsQuery'; @@ -60,7 +60,7 @@ interface DetailsToolbarDispatchProps { } interface DetailsToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type DetailsToolbarProps = DetailsToolbarOwnProps & @@ -111,7 +111,7 @@ export class DetailsToolbarBase extends React.Component<DetailsToolbarProps, Det } } - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl, orgReport, resourceReport, tagReport } = this.props; const options = [ diff --git a/src/routes/details/azureDetails/azureDetails.styles.ts b/src/routes/details/azureDetails/azureDetails.styles.ts index 805571cde..a16155500 100644 --- a/src/routes/details/azureDetails/azureDetails.styles.ts +++ b/src/routes/details/azureDetails/azureDetails.styles.ts @@ -1,31 +1,11 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { - azureDetails: { - minHeight: '100%', - }, - content: { - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, + headerContainer: { + paddingBottom: 0, }, paginationContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - toolbarContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, + marginTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/azureDetails/azureDetails.tsx b/src/routes/details/azureDetails/azureDetails.tsx index 6cda78228..0fefb0e11 100644 --- a/src/routes/details/azureDetails/azureDetails.tsx +++ b/src/routes/details/azureDetails/azureDetails.tsx @@ -1,4 +1,4 @@ -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; import type { AzureQuery } from 'api/queries/azureQuery'; @@ -18,6 +18,7 @@ import { Loading } from 'routes/components/page/loading'; import { NoData } from 'routes/components/page/noData'; import { NoProviders } from 'routes/components/page/noProviders'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import { ProviderDetails } from 'routes/details/components/providerDetails'; import { getIdKeyForGroupBy } from 'routes/utils/computedReport/getComputedAzureReportItems'; import type { ComputedReportItem } from 'routes/utils/computedReport/getComputedReportItems'; @@ -368,29 +369,33 @@ class AzureDetails extends React.Component<AzureDetailsProps, AzureDetailsState> } return ( - <div style={styles.azureDetails}> - <DetailsHeader - currency={currency} - groupBy={groupById} - onCurrencySelect={() => handleOnCurrencySelect(query, router)} - onGroupBySelect={this.handleOnGroupBySelect} - report={report} - /> - <div style={styles.content}> - <div style={styles.toolbarContainer}>{this.getToolbar(computedItems)}</div> - {this.getExportModal(computedItems)} - {reportFetchStatus === FetchStatus.inProgress ? ( - <Loading /> - ) : ( - <> - <div style={styles.tableContainer}>{this.getTable()}</div> - <div style={styles.paginationContainer}> - <div style={styles.pagination}>{this.getPagination(isDisabled, true)}</div> - </div> - </> - )} - </div> - </div> + <> + <PageSection style={styles.headerContainer}> + <DetailsHeader + currency={currency} + groupBy={groupById} + onCurrencySelect={() => handleOnCurrencySelect(query, router)} + onGroupBySelect={this.handleOnGroupBySelect} + report={report} + /> + </PageSection> + <PageSection> + <Card> + <CardBody> + {this.getToolbar(computedItems)} + {this.getExportModal(computedItems)} + {reportFetchStatus === FetchStatus.inProgress ? ( + <LoadingState /> + ) : ( + <> + {this.getTable()} + <div style={styles.paginationContainer}>{this.getPagination(isDisabled, true)}</div> + </> + )} + </CardBody> + </Card> + </PageSection> + </> ); } } diff --git a/src/routes/details/azureDetails/detailsHeader.styles.ts b/src/routes/details/azureDetails/detailsHeader.styles.ts index d55ff51cc..f28aa9b26 100644 --- a/src/routes/details/azureDetails/detailsHeader.styles.ts +++ b/src/routes/details/azureDetails/detailsHeader.styles.ts @@ -1,4 +1,3 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; @@ -15,10 +14,6 @@ export const styles = { exportContainer: { display: 'flex', }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, - }, perspective: { paddingTop: global_spacer_lg.var, marginTop: global_spacer_xs.var, diff --git a/src/routes/details/azureDetails/detailsHeader.tsx b/src/routes/details/azureDetails/detailsHeader.tsx index 911d6855c..ade1b7d3b 100644 --- a/src/routes/details/azureDetails/detailsHeader.tsx +++ b/src/routes/details/azureDetails/detailsHeader.tsx @@ -72,7 +72,7 @@ class DetailsHeaderBase extends React.Component<DetailsHeaderProps, any> { const hasCost = report?.meta?.total?.cost?.total; return ( - <header style={styles.header}> + <header> <Flex justifyContent={{ default: 'justifyContentSpaceBetween' }}> <FlexItem> <Title headingLevel="h1" style={styles.title} size={TitleSizes['2xl']}> diff --git a/src/routes/details/azureDetails/detailsToolbar.tsx b/src/routes/details/azureDetails/detailsToolbar.tsx index 71575e7ec..660acf83a 100644 --- a/src/routes/details/azureDetails/detailsToolbar.tsx +++ b/src/routes/details/azureDetails/detailsToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { AzureQuery } from 'api/queries/azureQuery'; import { getQuery } from 'api/queries/azureQuery'; import { ResourcePathsType } from 'api/resources/resource'; @@ -46,7 +46,7 @@ interface DetailsToolbarDispatchProps { } interface DetailsToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type DetailsToolbarProps = DetailsToolbarOwnProps & @@ -89,7 +89,7 @@ export class DetailsToolbarBase extends React.Component<DetailsToolbarProps, Det } } - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl, tagReport } = this.props; const options = [ diff --git a/src/routes/details/components/breakdown/breakdown.styles.ts b/src/routes/details/components/breakdown/breakdown.styles.ts index 3f3d7061e..3a513b32c 100644 --- a/src/routes/details/components/breakdown/breakdown.styles.ts +++ b/src/routes/details/components/breakdown/breakdown.styles.ts @@ -1,11 +1,7 @@ -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import type React from 'react'; export const styles = { - content: { - paddingBottom: global_spacer_lg.value, - paddingLeft: global_spacer_lg.value, - paddingRight: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, + headerContainer: { + paddingBottom: 0, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/components/breakdown/breakdownBase.tsx b/src/routes/details/components/breakdown/breakdownBase.tsx index fe3c3de85..d56ce5748 100644 --- a/src/routes/details/components/breakdown/breakdownBase.tsx +++ b/src/routes/details/components/breakdown/breakdownBase.tsx @@ -1,4 +1,4 @@ -import { Tab, TabContent, Tabs, TabTitleText } from '@patternfly/react-core'; +import { PageSection, Tab, TabContent, Tabs, TabTitleText } from '@patternfly/react-core'; import AsyncComponent from '@redhat-cloud-services/frontend-components/AsyncComponent'; import type { Providers } from 'api/providers'; import type { ProviderType } from 'api/providers'; @@ -182,17 +182,13 @@ class BreakdownBase extends React.Component<BreakdownProps, BreakdownState> { <> <TabTitleText>{this.getTabTitle(tab)}</TabTitleText> {showBadge && ( - <span> - { - <AsyncComponent - scope="costManagementMfe" - appName="cost-management-mfe" - module="./MfeOptimizationsBadge" - cluster={queryState?.filter_by?.cluster ? queryState.filter_by.cluster : undefined} - project={groupBy === 'project' ? groupByValue : undefined} - /> - } - </span> + <AsyncComponent + scope="costManagementMfe" + appName="cost-management-mfe" + module="./MfeOptimizationsBadge" + cluster={queryState?.filter_by?.cluster ? queryState.filter_by.cluster : undefined} + project={groupBy === 'project' ? groupByValue : undefined} + /> )} </> } @@ -327,34 +323,36 @@ class BreakdownBase extends React.Component<BreakdownProps, BreakdownState> { } return ( <> - <BreakdownHeader - breadcrumbLabel={breadcrumbLabel} - breadcrumbPath={ - router?.location?.state?.details?.breadcrumbPath - ? router.location.state.details.breadcrumbPath - : breadcrumbPath - } - clusterInfoComponent={clusterInfoComponent} - dataDetailsComponent={dataDetailsComponent} - costDistribution={costDistribution} - costType={costType} - currency={currency} - description={description} - detailsURL={detailsURL} - groupBy={groupBy} - onCostDistributionSelect={() => handleOnCostDistributionSelect(query, router, router.location.state)} - onCostTypeSelect={() => handleOnCostTypeSelect(query, router, router.location.state)} - onCurrencySelect={() => handleOnCurrencySelect(query, router, router.location.state)} - query={query} - report={report} - showCostDistribution={showCostDistribution && activeTabKey !== 2} - showCostType={showCostType} - showCurrency={activeTabKey !== 2} - tabs={this.getTabs(availableTabs)} - tagPathsType={tagPathsType} - title={title} - /> - <div style={styles.content}>{this.getTabContent(availableTabs)}</div> + <PageSection style={styles.headerContainer}> + <BreakdownHeader + breadcrumbLabel={breadcrumbLabel} + breadcrumbPath={ + router?.location?.state?.details?.breadcrumbPath + ? router.location.state.details.breadcrumbPath + : breadcrumbPath + } + clusterInfoComponent={clusterInfoComponent} + dataDetailsComponent={dataDetailsComponent} + costDistribution={costDistribution} + costType={costType} + currency={currency} + description={description} + detailsURL={detailsURL} + groupBy={groupBy} + onCostDistributionSelect={() => handleOnCostDistributionSelect(query, router, router.location.state)} + onCostTypeSelect={() => handleOnCostTypeSelect(query, router, router.location.state)} + onCurrencySelect={() => handleOnCurrencySelect(query, router, router.location.state)} + query={query} + report={report} + showCostDistribution={showCostDistribution && activeTabKey !== 2} + showCostType={showCostType} + showCurrency={activeTabKey !== 2} + tabs={this.getTabs(availableTabs)} + tagPathsType={tagPathsType} + title={title} + /> + </PageSection> + <PageSection>{this.getTabContent(availableTabs)}</PageSection> </> ); } diff --git a/src/routes/details/components/breakdown/breakdownHeader.scss b/src/routes/details/components/breakdown/breakdownHeader.scss index 44af56837..524f6a585 100644 --- a/src/routes/details/components/breakdown/breakdownHeader.scss +++ b/src/routes/details/components/breakdown/breakdownHeader.scss @@ -1,11 +1,11 @@ .breadcrumbOverride { - .pf-v5-c-breadcrumb__item:not(:last-child) { - margin-left: var(--pf-v5-c-breadcrumb__item--MarginRight); + .pf-v6-c-breadcrumb__item:not(:last-child) { + margin-left: var(--pf-t--global--spacer--sm); margin-right: 0; } - .pf-v5-c-breadcrumb__item-divider { + .pf-v6-c-breadcrumb__item-divider { margin-left: 0; - margin-right: var(--pf-v5-c-breadcrumb__item-divider--MarginLeft); + margin-right: var(--pf-t--global--spacer--sm); } } diff --git a/src/routes/details/components/breakdown/breakdownHeader.styles.ts b/src/routes/details/components/breakdown/breakdownHeader.styles.ts index a971ab86e..af8cb4cc4 100644 --- a/src/routes/details/components/breakdown/breakdownHeader.styles.ts +++ b/src/routes/details/components/breakdown/breakdownHeader.styles.ts @@ -1,6 +1,5 @@ -import global_BackgroundColor_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_100'; -import global_disabled_color_100 from '@patternfly/react-tokens/dist/js/global_disabled_color_100'; -import global_FontSize_xs from '@patternfly/react-tokens/dist/js/global_FontSize_xs'; +import global_color_disabled_100 from '@patternfly/react-tokens/dist/js/global_color_disabled_100'; +import global_font_size_body_sm from '@patternfly/react-tokens/dist/js/global_font_size_body_sm'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; @@ -31,8 +30,8 @@ export const styles = { paddingBottom: global_spacer_sm.var, }, description: { - color: global_disabled_color_100.value, - fontSize: global_FontSize_xs.value, + color: global_color_disabled_100.value, + fontSize: global_font_size_body_sm.value, marginBottom: 0, }, filterChip: { @@ -47,12 +46,6 @@ export const styles = { marginBottom: global_spacer_sm.var, marginTop: global_spacer_sm.var, }, - header: { - backgroundColor: global_BackgroundColor_100.var, - paddingLeft: global_spacer_lg.var, - paddingRight: global_spacer_lg.var, - paddingTop: global_spacer_lg.var, - }, headerContent: { alignItems: 'unset', minHeight: '36px', @@ -68,5 +61,6 @@ export const styles = { }, tag: { marginLeft: global_spacer_lg.var, + marginTop: global_spacer_xs.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/components/breakdown/breakdownHeader.tsx b/src/routes/details/components/breakdown/breakdownHeader.tsx index 91b755a32..2e120fab9 100644 --- a/src/routes/details/components/breakdown/breakdownHeader.tsx +++ b/src/routes/details/components/breakdown/breakdownHeader.tsx @@ -3,10 +3,10 @@ import './breakdownHeader.scss'; import { Button, ButtonVariant, - Chip, - ChipGroup, Flex, FlexItem, + Label, + LabelGroup, Popover, Title, TitleSizes, @@ -124,13 +124,13 @@ class BreakdownHeader extends React.Component<BreakdownHeaderProps, any> { const chips: any[] = getChips(filters[key]); return ( <span key={key} style={styles.filterChip}> - <ChipGroup categoryName={getLabel(key)}> + <LabelGroup categoryName={getLabel(key)}> {chips.map((chip, index) => ( - <Chip key={`${key}-${index}`} isReadOnly> + <Label variant="outline" key={`${key}-${index}`}> {chip.node} - </Chip> + </Label> ))} - </ChipGroup> + </LabelGroup> </span> ); } else { @@ -138,13 +138,13 @@ class BreakdownHeader extends React.Component<BreakdownHeaderProps, any> { const chips: any[] = getChips(filters[key][key2]); return ( <span key={key2} style={styles.filterChip}> - <ChipGroup categoryName={getLabel(key2)}> + <LabelGroup categoryName={getLabel(key2)}> {chips.map((chip, index) => ( - <Chip key={`${key2}-${index}`} isReadOnly> + <Label variant="outline" key={`${key2}-${index}`}> {chip.node} - </Chip> + </Label> ))} - </ChipGroup> + </LabelGroup> </span> ); }); @@ -162,11 +162,10 @@ class BreakdownHeader extends React.Component<BreakdownHeaderProps, any> { bodyContent={<p>{intl.formatMessage(messages.filteredByWarning)}</p>} > <Button + icon={<OutlinedQuestionCircleIcon />} aria-label={intl.formatMessage(messages.overviewInfoButtonArialLabel)} variant={ButtonVariant.plain} - > - <OutlinedQuestionCircleIcon /> - </Button> + ></Button> </Popover> </span> {filterChips} @@ -233,16 +232,16 @@ class BreakdownHeader extends React.Component<BreakdownHeaderProps, any> { : groupBy; return ( - <header style={styles.header}> + <header> <Flex justifyContent={{ default: 'justifyContentSpaceBetween' }} style={styles.headerContent}> <FlexItem> <nav aria-label={intl.formatMessage(messages.breakdownBackToDetailsAriaLabel)} className="breadcrumbOverride" > - <ol className="pf-v5-c-breadcrumb__list"> - <li className="pf-v5-c-breadcrumb__item"> - <span className="pf-v5-c-breadcrumb__item-divider"> + <ol className="pf-v6-c-breadcrumb__list"> + <li className="pf-v6-c-breadcrumb__item"> + <span className="pf-v6-c-breadcrumb__item-divider"> <AngleLeftIcon /> </span> {this.getBackToLink(groupByKey)} @@ -297,7 +296,7 @@ class BreakdownHeader extends React.Component<BreakdownHeaderProps, any> { </div> </FlexItem> </Flex> - <div> + <div className="pf-v6-c-tabs"> <div style={styles.tabs}> {tabs} <div style={styles.tag}>{showTags && <TagLink id="tags" tagPathsType={tagPathsType} />}</div> diff --git a/src/routes/details/components/columnManagement/columnManagementModal.tsx b/src/routes/details/components/columnManagement/columnManagementModal.tsx index c9ff23eb9..f01aff5ad 100644 --- a/src/routes/details/components/columnManagement/columnManagementModal.tsx +++ b/src/routes/details/components/columnManagement/columnManagementModal.tsx @@ -1,6 +1,8 @@ import { Button, ButtonVariant, + Content, + ContentVariants, DataList, DataListCell, DataListCheck, @@ -8,10 +10,10 @@ import { DataListItemCells, DataListItemRow, Modal, + ModalBody, + ModalFooter, + ModalHeader, ModalVariant, - Text, - TextContent, - TextVariants, } from '@patternfly/react-core'; import messages from 'locales/messages'; import React from 'react'; @@ -124,58 +126,57 @@ export class ColumnManagementModalBase extends React.Component<ColumnManagementM const { options, intl } = this.props; return ( - <Modal - description={ - <TextContent> - <Text component={TextVariants.p}>{intl.formatMessage(messages.manageColumnsDesc)}</Text> - <Button isInline onClick={this.selectAll} variant="link"> - {intl.formatMessage(messages.selectAll)} - </Button> - </TextContent> - } - // style={styles.modal} - isOpen={this.props.isOpen} - onClose={this.handleClose} - title={intl.formatMessage(messages.manageColumnsTitle)} - variant={ModalVariant.medium} - actions={[ + <Modal isOpen={this.props.isOpen} onClose={this.handleClose} variant={ModalVariant.medium}> + <ModalHeader + description={ + <Content> + <Content component={ContentVariants.p}>{intl.formatMessage(messages.manageColumnsDesc)}</Content> + <Button isInline onClick={this.selectAll} variant="link"> + {intl.formatMessage(messages.selectAll)} + </Button> + </Content> + } + title={intl.formatMessage(messages.manageColumnsTitle)} + /> + <ModalBody> + <DataList + aria-label={intl.formatMessage(messages.manageColumnsAriaLabel)} + id="table-column-management" + isCompact + > + {options.map(option => ( + <DataListItem aria-labelledby={option.value} key={option.value}> + <DataListItemRow> + <DataListCheck + aria-labelledby={`${option.value}Label`} + isChecked={!this.isHidden(option.value)} + name={option.value} + id={option.value} + onChange={this.handleChange} + /> + <DataListItemCells + dataListCells={[ + <DataListCell id={`${option.value}Label`} key="table-column-management-item1"> + <span>{intl.formatMessage(option.label)}</span> + </DataListCell>, + <DataListCell key="table-column-management-item2"> + {option.description && <span>{intl.formatMessage(option.description)}</span>} + </DataListCell>, + ]} + /> + </DataListItemRow> + </DataListItem> + ))} + </DataList> + </ModalBody> + <ModalFooter> <Button key="save" onClick={this.handleSave} variant={ButtonVariant.link}> {intl.formatMessage(messages.save)} - </Button>, + </Button> <Button key="cancel" onClick={this.handleClose} variant={ButtonVariant.link}> {intl.formatMessage(messages.cancel)} - </Button>, - ]} - > - <DataList - aria-label={intl.formatMessage(messages.manageColumnsAriaLabel)} - id="table-column-management" - isCompact - > - {options.map(option => ( - <DataListItem aria-labelledby={option.value} key={option.value}> - <DataListItemRow> - <DataListCheck - aria-labelledby={`${option.value}Label`} - isChecked={!this.isHidden(option.value)} - name={option.value} - id={option.value} - onChange={this.handleChange} - /> - <DataListItemCells - dataListCells={[ - <DataListCell id={`${option.value}Label`} key="table-column-management-item1"> - <span>{intl.formatMessage(option.label)}</span> - </DataListCell>, - <DataListCell key="table-column-management-item2"> - {option.description && <span>{intl.formatMessage(option.description)}</span>} - </DataListCell>, - ]} - /> - </DataListItemRow> - </DataListItem> - ))} - </DataList> + </Button> + </ModalFooter> </Modal> ); } diff --git a/src/routes/details/components/costChart/costChart.styles.ts b/src/routes/details/components/costChart/costChart.styles.ts index 6bdbf0e25..92020973a 100644 --- a/src/routes/details/components/costChart/costChart.styles.ts +++ b/src/routes/details/components/costChart/costChart.styles.ts @@ -1,4 +1,4 @@ -import global_FontWeight_bold from '@patternfly/react-tokens/dist/js/global_FontWeight_bold'; +import global_font_weight_body_bold_legacy from '@patternfly/react-tokens/dist/js/global_font_weight_body_bold_legacy'; import global_spacer_3xl from '@patternfly/react-tokens/dist/js/global_spacer_3xl'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import type React from 'react'; @@ -7,7 +7,7 @@ export const chartStyles = { chartHeight: 150, chartWidth: 475, subTitle: { - fontWeight: global_FontWeight_bold.value as any, + fontWeight: global_font_weight_body_bold_legacy.value as any, }, }; diff --git a/src/routes/details/components/costOverview/costOverviewBase.tsx b/src/routes/details/components/costOverview/costOverviewBase.tsx index 4875c98c9..fb655b995 100644 --- a/src/routes/details/components/costOverview/costOverviewBase.tsx +++ b/src/routes/details/components/costOverview/costOverviewBase.tsx @@ -112,9 +112,7 @@ class CostOverviewsBase extends React.Component<CostOverviewProps, any> { </> } > - <Button variant={ButtonVariant.plain}> - <OutlinedQuestionCircleIcon style={styles.info} /> - </Button> + <Button icon={<OutlinedQuestionCircleIcon style={styles.info} />} variant={ButtonVariant.plain}></Button> </Popover> @@ -162,9 +160,7 @@ class CostOverviewsBase extends React.Component { } > - + diff --git a/src/routes/details/components/overheadCostChart/overheadCostChart.styles.ts b/src/routes/details/components/overheadCostChart/overheadCostChart.styles.ts index b70708a55..a84b2de98 100644 --- a/src/routes/details/components/overheadCostChart/overheadCostChart.styles.ts +++ b/src/routes/details/components/overheadCostChart/overheadCostChart.styles.ts @@ -1,4 +1,4 @@ -import global_FontWeight_bold from '@patternfly/react-tokens/dist/js/global_FontWeight_bold'; +import global_font_weight_body_bold_legacy from '@patternfly/react-tokens/dist/js/global_font_weight_body_bold_legacy'; import global_spacer_3xl from '@patternfly/react-tokens/dist/js/global_spacer_3xl'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import type React from 'react'; @@ -7,7 +7,7 @@ export const chartStyles = { chartHeight: 150, chartWidth: 525, subTitle: { - fontWeight: global_FontWeight_bold.value as any, + fontWeight: global_font_weight_body_bold_legacy.value as any, }, }; diff --git a/src/routes/details/components/providerDetails/components/cloudData.tsx b/src/routes/details/components/providerDetails/components/cloudData.tsx index f8fbc4fe2..52214af6c 100644 --- a/src/routes/details/components/providerDetails/components/cloudData.tsx +++ b/src/routes/details/components/providerDetails/components/cloudData.tsx @@ -1,4 +1,4 @@ -import { ProgressStep, ProgressStepper, Text, TextContent, TextVariants } from '@patternfly/react-core'; +import { Content, ContentVariants, ProgressStep, ProgressStepper } from '@patternfly/react-core'; import type { Provider } from 'api/providers'; import messages from 'locales/messages'; import React from 'react'; @@ -26,9 +26,9 @@ const CloudData: React.FC = ({ provider }: CloudDataProps) => { return ( <> - - {intl.formatMessage(messages.dataDetailsCloudData)} - + + {intl.formatMessage(messages.dataDetailsCloudData)} + = ({ provider }: ClusterDataProps) return ( <> - - {intl.formatMessage(messages.dataDetailsClusterData)} - + + {intl.formatMessage(messages.dataDetailsClusterData)} + = ({ provider, providerType return ( <> - - {title} - + + {title} + { const { isOpen, title } = this.props; return ( - - + + + + + ); } diff --git a/src/routes/details/components/pvcChart/modal/pvcToolbar.tsx b/src/routes/details/components/pvcChart/modal/pvcToolbar.tsx index d5c352438..f95e98d98 100644 --- a/src/routes/details/components/pvcChart/modal/pvcToolbar.tsx +++ b/src/routes/details/components/pvcChart/modal/pvcToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import messages from 'locales/messages'; import React from 'react'; @@ -18,7 +18,7 @@ interface PvcToolbarOwnProps { } interface PvcToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type PvcToolbarProps = PvcToolbarOwnProps & WrappedComponentProps; @@ -33,7 +33,7 @@ class PvcToolbarBase extends React.Component { }); } - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl } = this.props; const options = [ diff --git a/src/routes/details/components/pvcChart/pvc.scss b/src/routes/details/components/pvcChart/pvc.scss index 512b84c1e..7c2b72e9a 100644 --- a/src/routes/details/components/pvcChart/pvc.scss +++ b/src/routes/details/components/pvcChart/pvc.scss @@ -1,5 +1,5 @@ .textContentOverride { - &.pf-v5-c-content dl { + &.pf-v6-c-content dl { grid-column-gap: 1rem; } } diff --git a/src/routes/details/components/pvcChart/pvcChart.styles.ts b/src/routes/details/components/pvcChart/pvcChart.styles.ts index 37316a3f7..9767f8c7c 100644 --- a/src/routes/details/components/pvcChart/pvcChart.styles.ts +++ b/src/routes/details/components/pvcChart/pvcChart.styles.ts @@ -1,4 +1,4 @@ -import global_FontWeight_bold from '@patternfly/react-tokens/dist/js/global_FontWeight_bold'; +import global_font_weight_body_bold_legacy from '@patternfly/react-tokens/dist/js/global_font_weight_body_bold_legacy'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import global_spacer_xl from '@patternfly/react-tokens/dist/js/global_spacer_xl'; @@ -12,7 +12,7 @@ export const styles = { marginBottom: global_spacer_md.value, }, capacity: { - fontWeight: global_FontWeight_bold.value as any, + fontWeight: global_font_weight_body_bold_legacy.value as any, }, description: { display: 'flex', diff --git a/src/routes/details/components/pvcChart/pvcChart.tsx b/src/routes/details/components/pvcChart/pvcChart.tsx index 2da25ae18..70eb166d9 100644 --- a/src/routes/details/components/pvcChart/pvcChart.tsx +++ b/src/routes/details/components/pvcChart/pvcChart.tsx @@ -2,15 +2,7 @@ import 'routes/components/charts/common/chart.scss'; import './pvc.scss'; import { ChartBullet } from '@patternfly/react-charts'; -import { - Divider, - Skeleton, - TextContent, - TextList, - TextListItem, - TextListItemVariants, - TextListVariants, -} from '@patternfly/react-core'; +import { Content, ContentVariants, Divider, Skeleton } from '@patternfly/react-core'; import type { OcpQuery } from 'api/queries/ocpQuery'; import { parseQuery } from 'api/queries/ocpQuery'; import type { Query } from 'api/queries/query'; @@ -221,26 +213,22 @@ class PvcChartBase extends React.Component { return (
- - - - {intl.formatMessage(messages.names, { count: 1 })} - - {item.persistent_volume_claim} - {intl.formatMessage(messages.cluster)} - {item.clusters ? item.clusters[0] : null} - - - - -   -   - {intl.formatMessage(messages.storageClass)} - - {item.storage_class ? item.storage_class[0] : null} - - - + + + {intl.formatMessage(messages.names, { count: 1 })} + {item.persistent_volume_claim} + {intl.formatMessage(messages.cluster)} + {item.clusters ? item.clusters[0] : null} + + + + +   +   + {intl.formatMessage(messages.storageClass)} + {item.storage_class ? item.storage_class[0] : null} + +
); }; diff --git a/src/routes/details/components/summary/modal/summaryModal.tsx b/src/routes/details/components/summary/modal/summaryModal.tsx index b7e9e0c4a..7d58ac830 100644 --- a/src/routes/details/components/summary/modal/summaryModal.tsx +++ b/src/routes/details/components/summary/modal/summaryModal.tsx @@ -1,4 +1,4 @@ -import { Modal } from '@patternfly/react-core'; +import { Modal, ModalBody, ModalHeader, ModalVariant } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import type { ReportPathsType } from 'api/reports/report'; import messages from 'locales/messages'; @@ -43,23 +43,22 @@ class SummaryModalBase extends React.Component { this.props; return ( - - + + + + ); } diff --git a/src/routes/details/components/tag/modal/tagContent.styles.ts b/src/routes/details/components/tag/modal/tagContent.styles.ts index 8e64e6a31..8fc33df18 100644 --- a/src/routes/details/components/tag/modal/tagContent.styles.ts +++ b/src/routes/details/components/tag/modal/tagContent.styles.ts @@ -1,10 +1,10 @@ -import global_FontWeight_bold from '@patternfly/react-tokens/dist/js/global_FontWeight_bold'; +import global_font_weight_body_bold_legacy from '@patternfly/react-tokens/dist/js/global_font_weight_body_bold_legacy'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import type React from 'react'; export const styles = { dataListHeading: { - fontWeight: global_FontWeight_bold.value as any, + fontWeight: global_font_weight_body_bold_legacy.value as any, }, groupByHeading: { marginBottom: global_spacer_lg.value, diff --git a/src/routes/details/components/tag/modal/tagModal.tsx b/src/routes/details/components/tag/modal/tagModal.tsx index 24198da29..7c9606c29 100644 --- a/src/routes/details/components/tag/modal/tagModal.tsx +++ b/src/routes/details/components/tag/modal/tagModal.tsx @@ -1,4 +1,4 @@ -import { Modal } from '@patternfly/react-core'; +import { Modal, ModalBody, ModalHeader } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import { getQuery, parseQuery } from 'api/queries/query'; import type { Tag, TagData, TagPathsType } from 'api/tags/tag'; @@ -97,18 +97,16 @@ class TagModalBase extends React.Component { const groupByValue = query && query.filter && query.filter.account ? query.filter.account : this.props.groupByValue; return ( - - + + + + + ); } diff --git a/src/routes/details/components/usageChart/usageChart.styles.ts b/src/routes/details/components/usageChart/usageChart.styles.ts index 33eebc5a6..7e0b7e3f9 100644 --- a/src/routes/details/components/usageChart/usageChart.styles.ts +++ b/src/routes/details/components/usageChart/usageChart.styles.ts @@ -1,4 +1,4 @@ -import global_FontWeight_bold from '@patternfly/react-tokens/dist/js/global_FontWeight_bold'; +import global_font_weight_body_bold_legacy from '@patternfly/react-tokens/dist/js/global_font_weight_body_bold_legacy'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import type React from 'react'; @@ -10,7 +10,7 @@ export const styles = { marginBottom: global_spacer_md.value, }, capacity: { - fontWeight: global_FontWeight_bold.value as any, + fontWeight: global_font_weight_body_bold_legacy.value as any, }, legendSkeleton: { marginTop: global_spacer_md.value, diff --git a/src/routes/details/gcpDetails/detailsHeader.styles.ts b/src/routes/details/gcpDetails/detailsHeader.styles.ts index d55ff51cc..f28aa9b26 100644 --- a/src/routes/details/gcpDetails/detailsHeader.styles.ts +++ b/src/routes/details/gcpDetails/detailsHeader.styles.ts @@ -1,4 +1,3 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; @@ -15,10 +14,6 @@ export const styles = { exportContainer: { display: 'flex', }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, - }, perspective: { paddingTop: global_spacer_lg.var, marginTop: global_spacer_xs.var, diff --git a/src/routes/details/gcpDetails/detailsHeader.tsx b/src/routes/details/gcpDetails/detailsHeader.tsx index 3b1f7baa7..1e4eeed95 100644 --- a/src/routes/details/gcpDetails/detailsHeader.tsx +++ b/src/routes/details/gcpDetails/detailsHeader.tsx @@ -73,7 +73,7 @@ class DetailsHeaderBase extends React.Component { const hasCost = report?.meta?.total?.cost?.total; return ( -
+
diff --git a/src/routes/details/gcpDetails/detailsToolbar.tsx b/src/routes/details/gcpDetails/detailsToolbar.tsx index 883ae41af..610adeca2 100644 --- a/src/routes/details/gcpDetails/detailsToolbar.tsx +++ b/src/routes/details/gcpDetails/detailsToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { GcpQuery } from 'api/queries/gcpQuery'; import { getQuery } from 'api/queries/gcpQuery'; import { ResourcePathsType } from 'api/resources/resource'; @@ -47,7 +47,7 @@ interface DetailsToolbarDispatchProps { } interface DetailsToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type DetailsToolbarProps = DetailsToolbarOwnProps & @@ -90,7 +90,7 @@ export class DetailsToolbarBase extends React.Component<DetailsToolbarProps, Det } } - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl, tagReport } = this.props; const options = [ diff --git a/src/routes/details/gcpDetails/gcpDetails.styles.ts b/src/routes/details/gcpDetails/gcpDetails.styles.ts index 7ac804174..a16155500 100644 --- a/src/routes/details/gcpDetails/gcpDetails.styles.ts +++ b/src/routes/details/gcpDetails/gcpDetails.styles.ts @@ -1,29 +1,11 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; +import type React from 'react'; export const styles = { - gcpDetails: { - minHeight: '100%', - }, - content: { - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, + headerContainer: { + paddingBottom: 0, }, paginationContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - padding: global_spacer_md.value, - }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - toolbarContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, + marginTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/gcpDetails/gcpDetails.tsx b/src/routes/details/gcpDetails/gcpDetails.tsx index f10ff25b8..514cee6e7 100644 --- a/src/routes/details/gcpDetails/gcpDetails.tsx +++ b/src/routes/details/gcpDetails/gcpDetails.tsx @@ -1,4 +1,4 @@ -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; import type { GcpQuery } from 'api/queries/gcpQuery'; @@ -18,6 +18,7 @@ import { Loading } from 'routes/components/page/loading'; import { NoData } from 'routes/components/page/noData'; import { NoProviders } from 'routes/components/page/noProviders'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import { ProviderDetails } from 'routes/details/components/providerDetails'; import { getIdKeyForGroupBy } from 'routes/utils/computedReport/getComputedGcpReportItems'; import type { ComputedReportItem } from 'routes/utils/computedReport/getComputedReportItems'; @@ -366,29 +367,33 @@ class GcpDetails extends React.Component<GcpDetailsProps, GcpDetailsState> { } return ( - <div style={styles.gcpDetails}> - <DetailsHeader - currency={currency} - groupBy={groupById} - onCurrencySelect={() => handleOnCurrencySelect(query, router)} - onGroupBySelect={this.handleOnGroupBySelect} - report={report} - /> - <div style={styles.content}> - <div style={styles.toolbarContainer}>{this.getToolbar(computedItems)}</div> - {this.getExportModal(computedItems)} - {reportFetchStatus === FetchStatus.inProgress ? ( - <Loading /> - ) : ( - <> - <div style={styles.tableContainer}>{this.getTable()}</div> - <div style={styles.paginationContainer}> - <div style={styles.pagination}>{this.getPagination(isDisabled, true)}</div> - </div> - </> - )} - </div> - </div> + <> + <PageSection style={styles.headerContainer}> + <DetailsHeader + currency={currency} + groupBy={groupById} + onCurrencySelect={() => handleOnCurrencySelect(query, router)} + onGroupBySelect={this.handleOnGroupBySelect} + report={report} + /> + </PageSection> + <PageSection> + <Card> + <CardBody> + {this.getToolbar(computedItems)} + {this.getExportModal(computedItems)} + {reportFetchStatus === FetchStatus.inProgress ? ( + <LoadingState /> + ) : ( + <> + {this.getTable()} + <div style={styles.paginationContainer}>{this.getPagination(isDisabled, true)}</div> + </> + )} + </CardBody> + </Card> + </PageSection> + </> ); } } diff --git a/src/routes/details/ibmDetails/detailsHeader.styles.ts b/src/routes/details/ibmDetails/detailsHeader.styles.ts index d55ff51cc..f28aa9b26 100644 --- a/src/routes/details/ibmDetails/detailsHeader.styles.ts +++ b/src/routes/details/ibmDetails/detailsHeader.styles.ts @@ -1,4 +1,3 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; @@ -15,10 +14,6 @@ export const styles = { exportContainer: { display: 'flex', }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, - }, perspective: { paddingTop: global_spacer_lg.var, marginTop: global_spacer_xs.var, diff --git a/src/routes/details/ibmDetails/detailsHeader.tsx b/src/routes/details/ibmDetails/detailsHeader.tsx index 9d2ea9164..bd3f32ef0 100644 --- a/src/routes/details/ibmDetails/detailsHeader.tsx +++ b/src/routes/details/ibmDetails/detailsHeader.tsx @@ -73,7 +73,7 @@ class DetailsHeaderBase extends React.Component<DetailsHeaderProps, any> { const hasCost = report?.meta?.total?.cost?.total; return ( - <header style={styles.header}> + <header> <Flex justifyContent={{ default: 'justifyContentSpaceBetween' }}> <FlexItem> <Title headingLevel="h1" style={styles.title} size={TitleSizes['2xl']}> diff --git a/src/routes/details/ibmDetails/detailsToolbar.tsx b/src/routes/details/ibmDetails/detailsToolbar.tsx index af6f37f3f..729ff3bda 100644 --- a/src/routes/details/ibmDetails/detailsToolbar.tsx +++ b/src/routes/details/ibmDetails/detailsToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { IbmQuery } from 'api/queries/ibmQuery'; import { getQuery } from 'api/queries/ibmQuery'; import { ResourcePathsType } from 'api/resources/resource'; @@ -47,7 +47,7 @@ interface DetailsToolbarDispatchProps { } interface DetailsToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type DetailsToolbarProps = DetailsToolbarOwnProps & @@ -90,7 +90,7 @@ export class DetailsToolbarBase extends React.Component<DetailsToolbarProps, Det } } - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl, tagReport } = this.props; const options = [ diff --git a/src/routes/details/ibmDetails/ibmDetails.styles.ts b/src/routes/details/ibmDetails/ibmDetails.styles.ts index c22caf82f..a16155500 100644 --- a/src/routes/details/ibmDetails/ibmDetails.styles.ts +++ b/src/routes/details/ibmDetails/ibmDetails.styles.ts @@ -1,30 +1,11 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; +import type React from 'react'; export const styles = { - gcpDetails: { - minHeight: '100%', - }, - content: { - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, + headerContainer: { + paddingBottom: 0, }, paginationContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - toolbarContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, + marginTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/ibmDetails/ibmDetails.tsx b/src/routes/details/ibmDetails/ibmDetails.tsx index 1af6f03db..bf71e5364 100644 --- a/src/routes/details/ibmDetails/ibmDetails.tsx +++ b/src/routes/details/ibmDetails/ibmDetails.tsx @@ -1,4 +1,4 @@ -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; import type { IbmQuery } from 'api/queries/ibmQuery'; @@ -18,6 +18,7 @@ import { Loading } from 'routes/components/page/loading'; import { NoData } from 'routes/components/page/noData'; import { NoProviders } from 'routes/components/page/noProviders'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import { ProviderDetails } from 'routes/details/components/providerDetails'; import { getIdKeyForGroupBy } from 'routes/utils/computedReport/getComputedIbmReportItems'; import type { ComputedReportItem } from 'routes/utils/computedReport/getComputedReportItems'; @@ -368,29 +369,33 @@ class IbmDetails extends React.Component<IbmDetailsProps, IbmDetailsState> { } return ( - <div style={styles.ibmDetails}> - <DetailsHeader - currency={currency} - groupBy={groupById} - onCurrencySelect={() => handleOnCurrencySelect(query, router)} - onGroupBySelect={this.handleOnGroupBySelect} - report={report} - /> - <div style={styles.content}> - <div style={styles.toolbarContainer}>{this.getToolbar(computedItems)}</div> - {this.getExportModal(computedItems)} - {reportFetchStatus === FetchStatus.inProgress ? ( - <Loading /> - ) : ( - <> - <div style={styles.tableContainer}>{this.getTable()}</div> - <div style={styles.paginationContainer}> - <div style={styles.pagination}>{this.getPagination(isDisabled, true)}</div> - </div> - </> - )} - </div> - </div> + <> + <PageSection style={styles.headerContainer}> + <DetailsHeader + currency={currency} + groupBy={groupById} + onCurrencySelect={() => handleOnCurrencySelect(query, router)} + onGroupBySelect={this.handleOnGroupBySelect} + report={report} + /> + </PageSection> + <PageSection> + <Card> + <CardBody> + {this.getToolbar(computedItems)} + {this.getExportModal(computedItems)} + {reportFetchStatus === FetchStatus.inProgress ? ( + <LoadingState /> + ) : ( + <> + {this.getTable()} + <div style={styles.paginationContainer}>{this.getPagination(isDisabled, true)}</div> + </> + )} + </CardBody> + </Card> + </PageSection> + </> ); } } diff --git a/src/routes/details/ociDetails/detailsHeader.styles.ts b/src/routes/details/ociDetails/detailsHeader.styles.ts index d55ff51cc..f28aa9b26 100644 --- a/src/routes/details/ociDetails/detailsHeader.styles.ts +++ b/src/routes/details/ociDetails/detailsHeader.styles.ts @@ -1,4 +1,3 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; @@ -15,10 +14,6 @@ export const styles = { exportContainer: { display: 'flex', }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, - }, perspective: { paddingTop: global_spacer_lg.var, marginTop: global_spacer_xs.var, diff --git a/src/routes/details/ociDetails/detailsHeader.tsx b/src/routes/details/ociDetails/detailsHeader.tsx index 1397f156b..f00fb620f 100644 --- a/src/routes/details/ociDetails/detailsHeader.tsx +++ b/src/routes/details/ociDetails/detailsHeader.tsx @@ -72,7 +72,7 @@ class DetailsHeaderBase extends React.Component<DetailsHeaderProps, any> { const hasCost = report?.meta?.total?.cost?.total; return ( - <header style={styles.header}> + <header> <Flex justifyContent={{ default: 'justifyContentSpaceBetween' }}> <FlexItem> <Title headingLevel="h1" style={styles.title} size={TitleSizes['2xl']}> diff --git a/src/routes/details/ociDetails/detailsToolbar.tsx b/src/routes/details/ociDetails/detailsToolbar.tsx index 5bcb25b60..696e44bff 100644 --- a/src/routes/details/ociDetails/detailsToolbar.tsx +++ b/src/routes/details/ociDetails/detailsToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { OciQuery } from 'api/queries/ociQuery'; import { getQuery } from 'api/queries/ociQuery'; import { ResourcePathsType } from 'api/resources/resource'; @@ -46,7 +46,7 @@ interface DetailsToolbarDispatchProps { } interface DetailsToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type DetailsToolbarProps = DetailsToolbarOwnProps & @@ -89,7 +89,7 @@ export class DetailsToolbarBase extends React.Component<DetailsToolbarProps, Det } } - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl, tagReport } = this.props; const options = [ diff --git a/src/routes/details/ociDetails/ociDetails.styles.ts b/src/routes/details/ociDetails/ociDetails.styles.ts index 451ce3248..a16155500 100644 --- a/src/routes/details/ociDetails/ociDetails.styles.ts +++ b/src/routes/details/ociDetails/ociDetails.styles.ts @@ -1,31 +1,11 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { - ociDetails: { - minHeight: '100%', - }, - content: { - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, + headerContainer: { + paddingBottom: 0, }, paginationContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - toolbarContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, + marginTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/ociDetails/ociDetails.tsx b/src/routes/details/ociDetails/ociDetails.tsx index 3301980ab..9a2547cb5 100644 --- a/src/routes/details/ociDetails/ociDetails.tsx +++ b/src/routes/details/ociDetails/ociDetails.tsx @@ -1,4 +1,4 @@ -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; import type { OciQuery } from 'api/queries/ociQuery'; @@ -18,6 +18,7 @@ import { Loading } from 'routes/components/page/loading'; import { NoData } from 'routes/components/page/noData'; import { NoProviders } from 'routes/components/page/noProviders'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import { ProviderDetails } from 'routes/details/components/providerDetails'; import { getIdKeyForGroupBy } from 'routes/utils/computedReport/getComputedOciReportItems'; import type { ComputedReportItem } from 'routes/utils/computedReport/getComputedReportItems'; @@ -368,29 +369,33 @@ class OciDetails extends React.Component<OciDetailsProps, OciDetailsState> { } return ( - <div style={styles.ociDetails}> - <DetailsHeader - currency={currency} - groupBy={groupById} - onCurrencySelect={() => handleOnCurrencySelect(query, router)} - onGroupBySelect={this.handleOnGroupBySelect} - report={report} - /> - <div style={styles.content}> - <div style={styles.toolbarContainer}>{this.getToolbar(computedItems)}</div> - {this.getExportModal(computedItems)} - {reportFetchStatus === FetchStatus.inProgress ? ( - <Loading /> - ) : ( - <> - <div style={styles.tableContainer}>{this.getTable()}</div> - <div style={styles.paginationContainer}> - <div style={styles.pagination}>{this.getPagination(isDisabled, true)}</div> - </div> - </> - )} - </div> - </div> + <> + <PageSection style={styles.headerContainer}> + <DetailsHeader + currency={currency} + groupBy={groupById} + onCurrencySelect={() => handleOnCurrencySelect(query, router)} + onGroupBySelect={this.handleOnGroupBySelect} + report={report} + /> + </PageSection> + <PageSection> + <Card> + <CardBody> + {this.getToolbar(computedItems)} + {this.getExportModal(computedItems)} + {reportFetchStatus === FetchStatus.inProgress ? ( + <LoadingState /> + ) : ( + <> + {this.getTable()} + <div style={styles.paginationContainer}>{this.getPagination(isDisabled, true)}</div> + </> + )} + </CardBody> + </Card> + </PageSection> + </> ); } } diff --git a/src/routes/details/ocpBreakdown/clusterInfo/clusterInfo.styles.ts b/src/routes/details/ocpBreakdown/clusterInfo/clusterInfo.styles.ts index c20bdbf4e..ce4fc8095 100644 --- a/src/routes/details/ocpBreakdown/clusterInfo/clusterInfo.styles.ts +++ b/src/routes/details/ocpBreakdown/clusterInfo/clusterInfo.styles.ts @@ -1,21 +1,21 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_FontSize_xs from '@patternfly/react-tokens/dist/js/global_FontSize_xs'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; +import global_color_status_warning_100 from '@patternfly/react-tokens/dist/js/global_color_status_warning_100'; +import global_font_size_body_sm from '@patternfly/react-tokens/dist/js/global_font_size_body_sm'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; -import global_warning_color_100 from '@patternfly/react-tokens/dist/js/global_warning_color_100'; import type React from 'react'; export const styles = { clusterInfoButton: { - fontSize: global_FontSize_xs.value, + fontSize: global_font_size_body_sm.value, }, loading: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, }, spacingRight: { marginRight: global_spacer_md.value, }, updateAvailable: { - color: global_warning_color_100.value, + color: global_color_status_warning_100.value, paddingLeft: '5px', }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoContent.scss b/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoContent.scss index 21831c538..e51e40eb2 100644 --- a/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoContent.scss +++ b/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoContent.scss @@ -1,7 +1,7 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .textContentOverride { - &.pf-v5-c-content ul { - padding-left: var(--pf-v5-global--spacer--lg); + &.pf-v6-c-content ul { + padding-left: var(--pf-t--global--spacer--lg); } } diff --git a/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoContent.tsx b/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoContent.tsx index 82ef83ed1..a050bbea6 100644 --- a/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoContent.tsx +++ b/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoContent.tsx @@ -1,6 +1,6 @@ import './clusterInfoContent.scss'; -import { Icon, Text, TextContent, TextList, TextListItem, TextVariants } from '@patternfly/react-core'; +import { Content, ContentVariants, Icon } from '@patternfly/react-core'; import { ExclamationTriangleIcon } from '@patternfly/react-icons/dist/esm/icons/exclamation-triangle-icon'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; @@ -60,17 +60,17 @@ const ClusterInfoContent: React.FC<ClusterInfoContentProps> = ({ clusterId }: Cl const release = getReleasePath(); return ( - <TextContent className="textContentOverride"> - <Text component={TextVariants.h3}>{intl.formatMessage(messages.clusterId)}</Text> - <TextList isPlain> - <TextListItem> + <Content className="textContentOverride"> + <Content component={ContentVariants.h3}>{intl.formatMessage(messages.clusterId)}</Content> + <Content component="ul" isPlainList> + <Content component="li"> <span style={styles.spacingRight}>{clusterId}</span> <a href={`${release}/openshift/details/${clusterId}`}>{intl.formatMessage(messages.ocpClusterDetails)}</a> - </TextListItem> - </TextList> - <Text component={TextVariants.h3}>{intl.formatMessage(messages.metricsOperatorVersion)}</Text> - <TextList isPlain> - <TextListItem> + </Content> + </Content> + <Content component={ContentVariants.h3}>{intl.formatMessage(messages.metricsOperatorVersion)}</Content> + <Content component="ul" isPlainList> + <Content component="li"> <span style={styles.spacingRight}>{clusterProvider?.additional_context?.operator_version}</span> {clusterProvider?.additional_context?.operator_update_available && ( <> @@ -80,17 +80,17 @@ const ClusterInfoContent: React.FC<ClusterInfoContentProps> = ({ clusterId }: Cl <span style={styles.updateAvailable}>{intl.formatMessage(messages.updateAvailable)}</span> </> )} - </TextListItem> - </TextList> + </Content> + </Content> {clusterProvider && ( <> - <Text component={TextVariants.h3}>{intl.formatMessage(messages.redHatIntegration)}</Text> - <TextList isPlain> - <TextListItem> + <Content component={ContentVariants.h3}>{intl.formatMessage(messages.redHatIntegration)}</Content> + <Content component="ul" isPlainList> + <Content component="li"> <span style={styles.spacingRight}>{intl.formatMessage(messages.source, { value: 'ocp' })}</span> <a href={`${release}/settings/integrations/detail/${clusterProvider.id}`}>{clusterProvider.name}</a> - </TextListItem> - <TextListItem> + </Content> + <Content component="li"> {clusterProvider?.cost_models?.length ? ( clusterProvider.cost_models.map((cm, index) => ( <React.Fragment key={index}> @@ -101,12 +101,12 @@ const ClusterInfoContent: React.FC<ClusterInfoContentProps> = ({ clusterId }: Cl ) : ( <a href={formatPath(routes.settings.path, true)}>{intl.formatMessage(messages.assignCostModel)}</a> )} - </TextListItem> - </TextList> + </Content> + </Content> {cloudProvider && <CloudIntegration provider={cloudProvider} />} </> )} - </TextContent> + </Content> ); }; diff --git a/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoModal.tsx b/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoModal.tsx index 01090f2d7..5fafed8ec 100644 --- a/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoModal.tsx +++ b/src/routes/details/ocpBreakdown/clusterInfo/clusterInfoModal.tsx @@ -1,5 +1,4 @@ -import { Button, ButtonVariant } from '@patternfly/react-core'; -import { Modal, ModalBody, ModalHeader, ModalVariant } from '@patternfly/react-core/next'; +import { Button, ButtonVariant, Modal, ModalBody, ModalHeader, ModalVariant } from '@patternfly/react-core'; import messages from 'locales/messages'; import React, { useState } from 'react'; import { useIntl } from 'react-intl'; diff --git a/src/routes/details/ocpBreakdown/clusterInfo/components/cloudIntegration.tsx b/src/routes/details/ocpBreakdown/clusterInfo/components/cloudIntegration.tsx index 64d35cd2b..f047a76da 100644 --- a/src/routes/details/ocpBreakdown/clusterInfo/components/cloudIntegration.tsx +++ b/src/routes/details/ocpBreakdown/clusterInfo/components/cloudIntegration.tsx @@ -1,4 +1,4 @@ -import { Text, TextList, TextListItem, TextVariants } from '@patternfly/react-core'; +import { Content, ContentVariants } from '@patternfly/react-core'; import type { Provider } from 'api/providers'; import messages from 'locales/messages'; import React from 'react'; @@ -24,12 +24,12 @@ const CloudIntegration: React.FC<CloudIntegrationProps> = ({ provider }: CloudIn return ( <> - <Text component={TextVariants.h3}>{intl.formatMessage(messages.cloudIntegration)}</Text> - <TextList isPlain> - <TextListItem> + <Content component={ContentVariants.h3}>{intl.formatMessage(messages.cloudIntegration)}</Content> + <Content component="ul" isPlainList> + <Content component="li"> <SourceLink provider={provider} /> - </TextListItem> - <TextListItem> + </Content> + <Content component="li"> {provider?.cost_models?.length ? ( provider.cost_models.map(cm => ( <> @@ -40,8 +40,8 @@ const CloudIntegration: React.FC<CloudIntegrationProps> = ({ provider }: CloudIn ) : ( <a href={formatPath(routes.settings.path, true)}>{intl.formatMessage(messages.assignCostModel)}</a> )} - </TextListItem> - </TextList> + </Content> + </Content> </> ); }; diff --git a/src/routes/details/ocpBreakdown/optimizations.tsx b/src/routes/details/ocpBreakdown/optimizations.tsx index 05e8b903d..ac5fe753c 100644 --- a/src/routes/details/ocpBreakdown/optimizations.tsx +++ b/src/routes/details/ocpBreakdown/optimizations.tsx @@ -1,3 +1,4 @@ +import { Card, CardBody } from '@patternfly/react-core'; import AsyncComponent from '@redhat-cloud-services/frontend-components/AsyncComponent'; import messages from 'locales/messages'; import React from 'react'; @@ -28,22 +29,26 @@ const Optimizations: React.FC<OptimizationsProps> = () => { const isOptimizationsPath = queryFromRoute?.optimizationsPath === 'true'; return ( - <AsyncComponent - scope="costManagementMfe" - appName="cost-management-mfe" - module="./MfeOptimizationsTable" - breadcrumbLabel={intl.formatMessage(messages.breakdownBackToOptimizationsProject, { value: groupByValue })} - breadcrumbPath={formatPath(`${routes.ocpBreakdown.path}${location.search}${otimizationsTab}`)} - cluster={clusterFilter} - hideCluster={clusterFilter !== undefined} - hideProject={groupBy === 'project'} - isOptimizationsPath={isOptimizationsPath} - linkPath={formatPath(routes.optimizationsBreakdown.path)} - linkState={{ - ...(location.state && location.state), - }} - project={groupBy === 'project' ? groupByValue : undefined} - /> + <Card> + <CardBody> + <AsyncComponent + scope="costManagementMfe" + appName="cost-management-mfe" + module="./MfeOptimizationsTable" + breadcrumbLabel={intl.formatMessage(messages.breakdownBackToOptimizationsProject, { value: groupByValue })} + breadcrumbPath={formatPath(`${routes.ocpBreakdown.path}${location.search}${otimizationsTab}`)} + cluster={clusterFilter} + hideCluster={clusterFilter !== undefined} + hideProject={groupBy === 'project'} + isOptimizationsPath={isOptimizationsPath} + linkPath={formatPath(routes.optimizationsBreakdown.path)} + linkState={{ + ...(location.state && location.state), + }} + project={groupBy === 'project' ? groupByValue : undefined} + /> + </CardBody> + </Card> ); }; diff --git a/src/routes/details/ocpDetails/detailsHeader.styles.ts b/src/routes/details/ocpDetails/detailsHeader.styles.ts index caa2a81fe..f3e8ea77a 100644 --- a/src/routes/details/ocpDetails/detailsHeader.styles.ts +++ b/src/routes/details/ocpDetails/detailsHeader.styles.ts @@ -1,5 +1,4 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_FontSize_md from '@patternfly/react-tokens/dist/js/global_FontSize_md'; +import global_font_size_md from '@patternfly/react-tokens/dist/js/global_font_size_md'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; @@ -16,10 +15,6 @@ export const styles = { exportContainer: { display: 'flex', }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, - }, perspective: { paddingTop: global_spacer_lg.var, marginTop: global_spacer_xs.var, @@ -31,7 +26,7 @@ export const styles = { verticalAlign: 'middle', }, infoIcon: { - fontSize: global_FontSize_md.value, + fontSize: global_font_size_md.value, }, infoTitle: { fontWeight: 'bold', diff --git a/src/routes/details/ocpDetails/detailsHeader.tsx b/src/routes/details/ocpDetails/detailsHeader.tsx index c7180d8ea..ccc143c13 100644 --- a/src/routes/details/ocpDetails/detailsHeader.tsx +++ b/src/routes/details/ocpDetails/detailsHeader.tsx @@ -108,7 +108,7 @@ class DetailsHeaderBase extends React.Component<DetailsHeaderProps, DetailsHeade } return ( - <header style={styles.header}> + <header> <Flex justifyContent={{ default: 'justifyContentSpaceBetween' }}> <FlexItem> <Title headingLevel="h1" style={styles.title} size={TitleSizes['2xl']}> diff --git a/src/routes/details/ocpDetails/detailsToolbar.tsx b/src/routes/details/ocpDetails/detailsToolbar.tsx index 383dae42b..fa163ed31 100644 --- a/src/routes/details/ocpDetails/detailsToolbar.tsx +++ b/src/routes/details/ocpDetails/detailsToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { OcpQuery } from 'api/queries/ocpQuery'; import { getQuery } from 'api/queries/ocpQuery'; import { ResourcePathsType } from 'api/resources/resource'; @@ -47,7 +47,7 @@ interface DetailsToolbarDispatchProps { } interface DetailsToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type DetailsToolbarProps = DetailsToolbarOwnProps & @@ -89,7 +89,7 @@ export class DetailsToolbarBase extends React.Component<DetailsToolbarProps, Det } } - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl, tagReport } = this.props; const options = [ diff --git a/src/routes/details/ocpDetails/ocpDetails.styles.ts b/src/routes/details/ocpDetails/ocpDetails.styles.ts index 1ee4315c6..a16155500 100644 --- a/src/routes/details/ocpDetails/ocpDetails.styles.ts +++ b/src/routes/details/ocpDetails/ocpDetails.styles.ts @@ -1,31 +1,11 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { - content: { - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, - }, - ocpDetails: { - minHeight: '100vh', + headerContainer: { + paddingBottom: 0, }, paginationContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - toolbarContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, + marginTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/ocpDetails/ocpDetails.tsx b/src/routes/details/ocpDetails/ocpDetails.tsx index f9f25b29c..e419b1abc 100644 --- a/src/routes/details/ocpDetails/ocpDetails.tsx +++ b/src/routes/details/ocpDetails/ocpDetails.tsx @@ -1,4 +1,4 @@ -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; import type { OcpQuery } from 'api/queries/ocpQuery'; @@ -20,6 +20,7 @@ import { Loading } from 'routes/components/page/loading'; import { NoData } from 'routes/components/page/noData'; import { NoProviders } from 'routes/components/page/noProviders'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import type { ColumnManagementModalOption } from 'routes/details/components/columnManagement'; import { ColumnManagementModal, initHiddenColumns } from 'routes/details/components/columnManagement'; import { ProviderDetails } from 'routes/details/components/providerDetails'; @@ -447,32 +448,36 @@ class OcpDetails extends React.Component<OcpDetailsProps, OcpDetailsState> { } return ( - <div style={styles.ocpDetails}> - <DetailsHeader - costDistribution={costDistribution} - currency={currency} - groupBy={groupById} - onCostDistributionSelect={() => handleOnCostDistributionSelect(query, router)} - onCurrencySelect={() => handleOnCurrencySelect(query, router)} - onGroupBySelect={this.handleOnGroupBySelect} - report={report} - /> - <div style={styles.content}> - <div style={styles.toolbarContainer}>{this.getToolbar(computedItems)}</div> - {this.getExportModal(computedItems)} - {this.getColumnManagementModal()} - {reportFetchStatus === FetchStatus.inProgress ? ( - <Loading /> - ) : ( - <> - <div style={styles.tableContainer}>{this.getTable()}</div> - <div style={styles.paginationContainer}> - <div style={styles.pagination}>{this.getPagination(isDisabled, true)}</div> - </div> - </> - )} - </div> - </div> + <> + <PageSection style={styles.headerContainer}> + <DetailsHeader + costDistribution={costDistribution} + currency={currency} + groupBy={groupById} + onCostDistributionSelect={() => handleOnCostDistributionSelect(query, router)} + onCurrencySelect={() => handleOnCurrencySelect(query, router)} + onGroupBySelect={this.handleOnGroupBySelect} + report={report} + /> + </PageSection> + <PageSection> + <Card> + <CardBody> + {this.getToolbar(computedItems)} + {this.getExportModal(computedItems)} + {this.getColumnManagementModal()} + {reportFetchStatus === FetchStatus.inProgress ? ( + <LoadingState /> + ) : ( + <> + {this.getTable()} + <div style={styles.paginationContainer}>{this.getPagination(isDisabled, true)}</div> + </> + )} + </CardBody> + </Card> + </PageSection> + </> ); } } diff --git a/src/routes/details/rhelDetails/detailsHeader.styles.ts b/src/routes/details/rhelDetails/detailsHeader.styles.ts index eab228cfa..e150f353a 100644 --- a/src/routes/details/rhelDetails/detailsHeader.styles.ts +++ b/src/routes/details/rhelDetails/detailsHeader.styles.ts @@ -1,5 +1,4 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_FontSize_md from '@patternfly/react-tokens/dist/js/global_FontSize_md'; +import global_font_size_md from '@patternfly/react-tokens/dist/js/global_font_size_md'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; @@ -16,15 +15,11 @@ export const styles = { exportContainer: { display: 'flex', }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, - }, info: { verticalAlign: 'middle', }, infoIcon: { - fontSize: global_FontSize_md.value, + fontSize: global_font_size_md.value, }, infoTitle: { fontWeight: 'bold', diff --git a/src/routes/details/rhelDetails/detailsHeader.tsx b/src/routes/details/rhelDetails/detailsHeader.tsx index b14ebcaca..cbe879e8d 100644 --- a/src/routes/details/rhelDetails/detailsHeader.tsx +++ b/src/routes/details/rhelDetails/detailsHeader.tsx @@ -98,7 +98,7 @@ class DetailsHeaderBase extends React.Component<DetailsHeaderProps> { } return ( - <header style={styles.header}> + <header> <Flex justifyContent={{ default: 'justifyContentSpaceBetween' }}> <FlexItem> <Title headingLevel="h1" style={styles.title} size={TitleSizes['2xl']}> diff --git a/src/routes/details/rhelDetails/detailsToolbar.tsx b/src/routes/details/rhelDetails/detailsToolbar.tsx index d85af1b33..76145c0ca 100644 --- a/src/routes/details/rhelDetails/detailsToolbar.tsx +++ b/src/routes/details/rhelDetails/detailsToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { OcpQuery } from 'api/queries/ocpQuery'; import { getQuery } from 'api/queries/ocpQuery'; import { ResourcePathsType } from 'api/resources/resource'; @@ -46,7 +46,7 @@ interface DetailsToolbarDispatchProps { } interface DetailsToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type DetailsToolbarProps = DetailsToolbarOwnProps & @@ -88,7 +88,7 @@ export class DetailsToolbarBase extends React.Component<DetailsToolbarProps> { } } - private getCategoryOptions = (): ToolbarChipGroup[] => { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { intl, tagReport } = this.props; const options = [ diff --git a/src/routes/details/rhelDetails/rhelDetails.styles.ts b/src/routes/details/rhelDetails/rhelDetails.styles.ts index 20be10cf3..a16155500 100644 --- a/src/routes/details/rhelDetails/rhelDetails.styles.ts +++ b/src/routes/details/rhelDetails/rhelDetails.styles.ts @@ -1,31 +1,11 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { - content: { - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, - }, - ocpDetails: { - minHeight: '100%', + headerContainer: { + paddingBottom: 0, }, paginationContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - toolbarContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, + marginTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/details/rhelDetails/rhelDetails.tsx b/src/routes/details/rhelDetails/rhelDetails.tsx index 18e5c232f..9f1ec0fc7 100644 --- a/src/routes/details/rhelDetails/rhelDetails.tsx +++ b/src/routes/details/rhelDetails/rhelDetails.tsx @@ -1,4 +1,4 @@ -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; import { getProvidersQuery } from 'api/queries/providersQuery'; @@ -19,6 +19,7 @@ import { Loading } from 'routes/components/page/loading'; import { NoData } from 'routes/components/page/noData'; import { NoProviders } from 'routes/components/page/noProviders'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import type { ColumnManagementModalOption } from 'routes/details/components/columnManagement'; import { ColumnManagementModal, initHiddenColumns } from 'routes/details/components/columnManagement'; import { ProviderDetails } from 'routes/details/components/providerDetails'; @@ -424,30 +425,34 @@ class RhelDetails extends React.Component<RhelDetailsProps, RhelDetailsState> { } return ( - <div style={styles.ocpDetails}> - <DetailsHeader - currency={currency} - groupBy={groupById} - onCurrencySelect={() => handleOnCurrencySelect(query, router)} - onGroupBySelect={this.handleOnGroupBySelect} - report={report} - /> - <div style={styles.content}> - <div style={styles.toolbarContainer}>{this.getToolbar(computedItems)}</div> - {this.getExportModal(computedItems)} - {this.getColumnManagementModal()} - {reportFetchStatus === FetchStatus.inProgress ? ( - <Loading /> - ) : ( - <> - <div style={styles.tableContainer}>{this.getTable()}</div> - <div style={styles.paginationContainer}> - <div style={styles.pagination}>{this.getPagination(isDisabled, true)}</div> - </div> - </> - )} - </div> - </div> + <> + <PageSection style={styles.headerContainer}> + <DetailsHeader + currency={currency} + groupBy={groupById} + onCurrencySelect={() => handleOnCurrencySelect(query, router)} + onGroupBySelect={this.handleOnGroupBySelect} + report={report} + /> + </PageSection> + <PageSection> + <Card> + <CardBody> + {this.getToolbar(computedItems)} + {this.getExportModal(computedItems)} + {this.getColumnManagementModal()} + {reportFetchStatus === FetchStatus.inProgress ? ( + <LoadingState /> + ) : ( + <> + {this.getTable()} + <div style={styles.paginationContainer}>{this.getPagination(isDisabled, true)}</div> + </> + )} + </CardBody> + </Card> + </PageSection> + </> ); } } diff --git a/src/routes/explorer/explorer.styles.ts b/src/routes/explorer/explorer.styles.ts index f2feb3dd9..5c127b36a 100644 --- a/src/routes/explorer/explorer.styles.ts +++ b/src/routes/explorer/explorer.styles.ts @@ -1,41 +1,15 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; +import type React from 'react'; export const styles = { - chartContainer: { - backgroundColor: global_BackgroundColor_light_100.value, - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - paddingRight: global_spacer_lg.value, - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, + dividerContainer: { + paddingTop: global_spacer_md.var, }, - chartContent: { - paddingTop: global_spacer_lg.value, - }, - explorer: { - minHeight: '100%', + headerContainer: { + paddingBottom: 0, }, paginationContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - tableContent: { - paddingBottom: global_spacer_lg.value, - paddingTop: global_spacer_lg.value, - }, - toolbarContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, + marginTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/explorer/explorer.tsx b/src/routes/explorer/explorer.tsx index d99b98f43..6c11c1d9b 100644 --- a/src/routes/explorer/explorer.tsx +++ b/src/routes/explorer/explorer.tsx @@ -1,4 +1,4 @@ -import { Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, Grid, GridItem, PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Providers } from 'api/providers'; import { ProviderType } from 'api/providers'; import { getProvidersQuery } from 'api/queries/providersQuery'; @@ -21,6 +21,7 @@ import { Loading } from 'routes/components/page/loading'; import { NoData } from 'routes/components/page/noData'; import { NoProviders } from 'routes/components/page/noProviders'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import { getIdKeyForGroupBy } from 'routes/utils/computedReport/getComputedExplorerReportItems'; import type { ComputedReportItem } from 'routes/utils/computedReport/getComputedReportItems'; import { getUnsortedComputedReportItems } from 'routes/utils/computedReport/getComputedReportItems'; @@ -506,63 +507,73 @@ class Explorer extends React.Component<ExplorerProps, ExplorerState> { } return ( - <div style={styles.explorer}> - <ExplorerHeader - costDistribution={costDistribution} - costType={costType} - currency={currency} - groupBy={ - groupByCostCategory - ? `${awsCategoryPrefix}${groupByCostCategory}` - : groupByTagKey - ? `${tagPrefix}${groupByTagKey}` - : groupById - } - onCostDistributionSelect={() => handleOnCostDistributionSelect(query, router)} - onCostTypeSelect={() => handleOnCostTypeSelect(query, router)} - onCurrencySelect={() => handleOnCurrencySelect(query, router)} - onDatePickerSelect={this.handleOnDatePickerSelect} - onFilterAdded={filter => handleOnFilterAdded(query, router, filter)} - onFilterRemoved={filter => handleOnFilterRemoved(query, router, filter)} - onGroupBySelect={this.handleOnGroupBySelect} - onPerspectiveClicked={this.handleOnPerspectiveClick} - perspective={perspective} - report={report} - /> - {itemsTotal > 0 && ( - <div style={styles.chartContent}> - <div style={styles.chartContainer}> - <ExplorerChart - costDistribution={costDistribution} - costType={costType} - currency={currency} - groupBy={ - groupByCostCategory - ? `${awsCategoryPrefix}${groupByCostCategory}` - : groupByTagKey - ? `${tagPrefix}${groupByTagKey}` - : groupById - } - perspective={perspective} - /> - </div> - </div> - )} - <div style={styles.tableContent}> - <div style={styles.toolbarContainer}>{this.getToolbar(computedItems)}</div> - {this.getExportModal(computedItems)} - {reportFetchStatus === FetchStatus.inProgress ? ( - <Loading /> - ) : ( - <> - <div style={styles.tableContainer}>{this.getTable()}</div> - <div style={styles.paginationContainer}> - <div style={styles.pagination}>{this.getPagination(isDisabled, true)}</div> - </div> - </> - )} - </div> - </div> + <> + <PageSection style={styles.headerContainer}> + <ExplorerHeader + costDistribution={costDistribution} + costType={costType} + currency={currency} + groupBy={ + groupByCostCategory + ? `${awsCategoryPrefix}${groupByCostCategory}` + : groupByTagKey + ? `${tagPrefix}${groupByTagKey}` + : groupById + } + onCostDistributionSelect={() => handleOnCostDistributionSelect(query, router)} + onCostTypeSelect={() => handleOnCostTypeSelect(query, router)} + onCurrencySelect={() => handleOnCurrencySelect(query, router)} + onDatePickerSelect={this.handleOnDatePickerSelect} + onFilterAdded={filter => handleOnFilterAdded(query, router, filter)} + onFilterRemoved={filter => handleOnFilterRemoved(query, router, filter)} + onGroupBySelect={this.handleOnGroupBySelect} + onPerspectiveClicked={this.handleOnPerspectiveClick} + perspective={perspective} + report={report} + /> + </PageSection> + <PageSection> + <Grid hasGutter> + {itemsTotal > 0 && ( + <GridItem sm={12}> + <Card> + <CardBody> + <ExplorerChart + costDistribution={costDistribution} + costType={costType} + currency={currency} + groupBy={ + groupByCostCategory + ? `${awsCategoryPrefix}${groupByCostCategory}` + : groupByTagKey + ? `${tagPrefix}${groupByTagKey}` + : groupById + } + perspective={perspective} + /> + </CardBody> + </Card> + </GridItem> + )} + <GridItem sm={12}> + <Card> + <CardBody> + {this.getToolbar(computedItems)} + {this.getExportModal(computedItems)} + {reportFetchStatus === FetchStatus.inProgress ? ( + <LoadingState /> + ) : ( + <> + {this.getTable()} + <div style={styles.paginationContainer}>{this.getPagination(isDisabled, true)}</div> + </> + )} + </CardBody> + </Card> + </GridItem> + </Grid> + </PageSection> + </> ); } } diff --git a/src/routes/explorer/explorerChart.styles.ts b/src/routes/explorer/explorerChart.styles.ts index 7d29f1f86..a093a3196 100644 --- a/src/routes/explorer/explorerChart.styles.ts +++ b/src/routes/explorer/explorerChart.styles.ts @@ -1,6 +1,5 @@ import global_spacer_2xl from '@patternfly/react-tokens/dist/js/global_spacer_2xl'; import global_spacer_3xl from '@patternfly/react-tokens/dist/js/global_spacer_3xl'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; @@ -10,9 +9,6 @@ export const chartStyles = { }; export const styles = { - chartContainer: { - marginLeft: global_spacer_2xl.value, - }, chartSkeleton: { height: '125px', marginBottom: global_spacer_md.value, @@ -20,14 +16,12 @@ export const styles = { }, costChart: { marginBottom: global_spacer_sm.value, + marginLeft: global_spacer_2xl.value, marginTop: global_spacer_sm.value, }, legendSkeleton: { marginTop: global_spacer_md.value, }, - titleContainer: { - marginLeft: global_spacer_lg.value, - }, trendChart: { marginBottom: global_spacer_sm.value, marginTop: global_spacer_sm.value, diff --git a/src/routes/explorer/explorerChart.tsx b/src/routes/explorer/explorerChart.tsx index 74f9de020..08fa5a17f 100644 --- a/src/routes/explorer/explorerChart.tsx +++ b/src/routes/explorer/explorerChart.tsx @@ -239,29 +239,25 @@ class ExplorerChartBase extends React.Component<ExplorerChartProps, ExplorerChar // Todo: get title from perspective menu return ( <> - <div style={styles.titleContainer}> - <Title headingLevel="h3" size={TitleSizes.md}> - {intl.formatMessage(messages.explorerChartTitle, { value: perspective })} - -
-
-
- {reportFetchStatus === FetchStatus.inProgress ? ( - this.getSkeleton() - ) : ( - 0 ? datums[0] : []} - top2ndData={datums.length > 1 ? datums[1] : []} - top3rdData={datums.length > 2 ? datums[2] : []} - top4thData={datums.length > 3 ? datums[3] : []} - top5thData={datums.length > 4 ? datums[4] : []} - top6thData={datums.length > 5 ? datums[5] : []} - /> - )} -
+ + {intl.formatMessage(messages.explorerChartTitle, { value: perspective })} + +
+ {reportFetchStatus === FetchStatus.inProgress ? ( + this.getSkeleton() + ) : ( + 0 ? datums[0] : []} + top2ndData={datums.length > 1 ? datums[1] : []} + top3rdData={datums.length > 2 ? datums[2] : []} + top4thData={datums.length > 3 ? datums[3] : []} + top5thData={datums.length > 4 ? datums[4] : []} + top6thData={datums.length > 5 ? datums[5] : []} + /> + )}
); diff --git a/src/routes/explorer/explorerFilter.scss b/src/routes/explorer/explorerFilter.scss index 70ce63a22..77d2fdde7 100644 --- a/src/routes/explorer/explorerFilter.scss +++ b/src/routes/explorer/explorerFilter.scss @@ -1,7 +1,10 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .explorerToolbarOverride { - .pf-v5-c-toolbar__content { + .pf-v6-c-toolbar__content { padding-left: 0; } + .pf-v6-c-toolbar { + --pf-v6-c-toolbar--PaddingBlockEnd: 0; + } } diff --git a/src/routes/explorer/explorerFilter.styles.ts b/src/routes/explorer/explorerFilter.styles.ts index 560bcf952..1ebd8237a 100644 --- a/src/routes/explorer/explorerFilter.styles.ts +++ b/src/routes/explorer/explorerFilter.styles.ts @@ -1,10 +1,10 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { toolbarContainer: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, paddingTop: global_spacer_sm.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/explorer/explorerFilter.tsx b/src/routes/explorer/explorerFilter.tsx index eb59e774a..14771eabd 100644 --- a/src/routes/explorer/explorerFilter.tsx +++ b/src/routes/explorer/explorerFilter.tsx @@ -1,6 +1,6 @@ import './explorerFilter.scss'; -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import type { Org, OrgPathsType } from 'api/orgs/org'; import { OrgType } from 'api/orgs/org'; import type { Query } from 'api/queries/query'; @@ -74,7 +74,7 @@ interface ExplorerFilterDispatchProps { } interface ExplorerFilterState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; currentDateRangeType?: string; showDatePicker?: boolean; } @@ -119,7 +119,7 @@ export class ExplorerFilterBase extends React.Component { + private getCategoryOptions = (): ToolbarLabelGroup[] => { const { orgReport, perspective, intl, resourceReport, tagReport } = this.props; const options = []; diff --git a/src/routes/explorer/explorerHeader.styles.ts b/src/routes/explorer/explorerHeader.styles.ts index 8ddf9e3f2..2d0192d0e 100644 --- a/src/routes/explorer/explorerHeader.styles.ts +++ b/src/routes/explorer/explorerHeader.styles.ts @@ -1,10 +1,8 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_Color_100 from '@patternfly/react-tokens/dist/js/global_Color_100'; -import global_Color_200 from '@patternfly/react-tokens/dist/js/global_Color_200'; -import global_FontSize_sm from '@patternfly/react-tokens/dist/js/global_FontSize_sm'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; +import global_font_size_sm from '@patternfly/react-tokens/dist/js/global_font_size_sm'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; +import global_text_color_100 from '@patternfly/react-tokens/dist/js/global_text_color_100'; +import global_text_color_200 from '@patternfly/react-tokens/dist/js/global_text_color_200'; import type React from 'react'; export const styles = { @@ -18,19 +16,12 @@ export const styles = { marginRight: global_spacer_md.var, }, costLabelUnit: { - fontSize: global_FontSize_sm.value, - color: global_Color_100.var, + fontSize: global_font_size_sm.value, + color: global_text_color_100.var, }, costLabelDate: { - fontSize: global_FontSize_sm.value, - color: global_Color_200.var, - }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - paddingBottom: global_spacer_md.var, - paddingLeft: global_spacer_lg.var, - paddingRight: global_spacer_lg.var, - paddingTop: global_spacer_lg.var, + fontSize: global_font_size_sm.value, + color: global_text_color_200.var, }, headerContent: { alignItems: 'unset', diff --git a/src/routes/explorer/explorerHeader.tsx b/src/routes/explorer/explorerHeader.tsx index 7bef85b0c..13bdf8d6b 100644 --- a/src/routes/explorer/explorerHeader.tsx +++ b/src/routes/explorer/explorerHeader.tsx @@ -285,7 +285,7 @@ class ExplorerHeaderBase extends React.Component +
diff --git a/src/routes/explorer/explorerTable.scss b/src/routes/explorer/explorerTable.scss index eec90e1a4..bb48e1908 100644 --- a/src/routes/explorer/explorerTable.scss +++ b/src/routes/explorer/explorerTable.scss @@ -1,15 +1,15 @@ @import url("~@patternfly/patternfly/base/patternfly-variables.css"); .explorerTableOverride { - &.pf-v5-c-table { - .pf-v5-c-table__sticky-column { + &.pf-v6-c-table { + .pf-v6-c-table__sticky-column { z-index: 99; } } - &.pf-v5-c-table tbody .pf-v5-c-table__check input { - margin-top: .40rem; + &.pf-v6-c-table tbody .pf-v6-c-table__check input { + margin-top: .35rem; } .stickyColumn { - --pf-v5-c-table--cell--Width: 1%; + --pf-v6-c-table--cell--Width: 1%; } } diff --git a/src/routes/explorer/explorerTable.styles.ts b/src/routes/explorer/explorerTable.styles.ts index 77e86fc7a..ed20cb05e 100644 --- a/src/routes/explorer/explorerTable.styles.ts +++ b/src/routes/explorer/explorerTable.styles.ts @@ -1,6 +1,6 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_disabled_color_100 from '@patternfly/react-tokens/dist/js/global_disabled_color_100'; -import global_FontSize_xs from '@patternfly/react-tokens/dist/js/global_FontSize_xs'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; +import global_color_disabled_100 from '@patternfly/react-tokens/dist/js/global_color_disabled_100'; +import global_font_size_body_sm from '@patternfly/react-tokens/dist/js/global_font_size_body_sm'; import global_spacer_3xl from '@patternfly/react-tokens/dist/js/global_spacer_3xl'; import global_spacer_xs from '@patternfly/react-tokens/dist/js/global_spacer_xs'; import type React from 'react'; @@ -10,7 +10,7 @@ export const styles = { minWidth: '50px', }, emptyState: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, display: 'flex', justifyContent: 'center', paddingTop: global_spacer_3xl.value, @@ -24,7 +24,7 @@ export const styles = { bottom: global_spacer_xs.value, }, infoDescription: { - color: global_disabled_color_100.value, - fontSize: global_FontSize_xs.value, + color: global_color_disabled_100.value, + fontSize: global_font_size_body_sm.value, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/explorer/explorerTable.tsx b/src/routes/explorer/explorerTable.tsx index daad735bf..1d18a5d53 100644 --- a/src/routes/explorer/explorerTable.tsx +++ b/src/routes/explorer/explorerTable.tsx @@ -1,15 +1,6 @@ import './explorerTable.scss'; -import { - Bullseye, - EmptyState, - EmptyStateBody, - EmptyStateHeader, - EmptyStateIcon, - Label, - Spinner, - Tooltip, -} from '@patternfly/react-core'; +import { Bullseye, EmptyState, EmptyStateBody, Label, Spinner, Tooltip } from '@patternfly/react-core'; import { CalculatorIcon } from '@patternfly/react-icons/dist/esm/icons/calculator-icon'; import type { ThProps } from '@patternfly/react-table'; import { @@ -385,8 +376,7 @@ class ExplorerTableBase extends React.Component<ExplorerTableProps, ExplorerTabl } } return ( - <EmptyState> - <EmptyStateHeader icon={<EmptyStateIcon icon={CalculatorIcon} />} /> + <EmptyState icon={CalculatorIcon} titleText=""> <EmptyStateBody>{intl.formatMessage(messages.detailsEmptyState)}</EmptyStateBody> </EmptyState> ); diff --git a/src/routes/explorer/explorerToolbar.tsx b/src/routes/explorer/explorerToolbar.tsx index a9805fed9..3646dab3c 100644 --- a/src/routes/explorer/explorerToolbar.tsx +++ b/src/routes/explorer/explorerToolbar.tsx @@ -1,4 +1,4 @@ -import type { ToolbarChipGroup } from '@patternfly/react-core'; +import type { ToolbarLabelGroup } from '@patternfly/react-core'; import React from 'react'; import type { WrappedComponentProps } from 'react-intl'; import { injectIntl } from 'react-intl'; @@ -33,7 +33,7 @@ interface ExplorerToolbarDispatchProps { } interface ExplorerToolbarState { - categoryOptions?: ToolbarChipGroup[]; + categoryOptions?: ToolbarLabelGroup[]; } type ExplorerToolbarProps = ExplorerToolbarOwnProps & diff --git a/src/routes/optimizations/optimizationsBreakdown/optimizationsBreakdown.styles.ts b/src/routes/optimizations/optimizationsBreakdown/optimizationsBreakdown.styles.ts deleted file mode 100644 index 696df518c..000000000 --- a/src/routes/optimizations/optimizationsBreakdown/optimizationsBreakdown.styles.ts +++ /dev/null @@ -1,24 +0,0 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; -import type React from 'react'; - -export const styles = { - alertContainer: { - marginBottom: global_spacer_lg.value, - }, - codeBlock: { - display: 'flex', - }, - container: { - minHeight: '100vh', - }, - currentActions: { - height: '36px', - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, -} as { [className: string]: React.CSSProperties }; diff --git a/src/routes/optimizations/optimizationsBreakdown/optimizationsBreakdown.tsx b/src/routes/optimizations/optimizationsBreakdown/optimizationsBreakdown.tsx index 63962ce2e..62e0dd92a 100644 --- a/src/routes/optimizations/optimizationsBreakdown/optimizationsBreakdown.tsx +++ b/src/routes/optimizations/optimizationsBreakdown/optimizationsBreakdown.tsx @@ -1,8 +1,6 @@ import AsyncComponent from '@redhat-cloud-services/frontend-components/AsyncComponent'; import React from 'react'; -import { styles } from './optimizationsBreakdown.styles'; - interface OptimizationsBreakdownOwnProps { // TBD... } @@ -11,9 +9,7 @@ type OptimizationsBreakdownProps = OptimizationsBreakdownOwnProps; const OptimizationsBreakdown: React.FC<OptimizationsBreakdownProps> = () => { return ( - <div style={styles.container}> - <AsyncComponent scope="costManagementMfe" appName="cost-management-mfe" module="./MfeOptimizationsBreakdown" /> - </div> + <AsyncComponent scope="costManagementMfe" appName="cost-management-mfe" module="./MfeOptimizationsBreakdown" /> ); }; diff --git a/src/routes/optimizations/optimizationsDetails/optimizationsDetails.styles.ts b/src/routes/optimizations/optimizationsDetails/optimizationsDetails.styles.ts deleted file mode 100644 index bcd3af1a9..000000000 --- a/src/routes/optimizations/optimizationsDetails/optimizationsDetails.styles.ts +++ /dev/null @@ -1,14 +0,0 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; -import type React from 'react'; - -export const styles = { - container: { - minHeight: '100vh', - }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - }, -} as { [className: string]: React.CSSProperties }; diff --git a/src/routes/optimizations/optimizationsDetails/optimizationsDetails.tsx b/src/routes/optimizations/optimizationsDetails/optimizationsDetails.tsx index d116c9259..4ed98c5ed 100644 --- a/src/routes/optimizations/optimizationsDetails/optimizationsDetails.tsx +++ b/src/routes/optimizations/optimizationsDetails/optimizationsDetails.tsx @@ -6,8 +6,6 @@ import { useLocation } from 'react-router-dom'; import { routes } from 'routes'; import { formatPath } from 'utils/paths'; -import { styles } from './optimizationsDetails.styles'; - interface OptimizationsDetailsOwnProps { // TBD... } @@ -19,20 +17,18 @@ const OptimizationsDetails: React.FC<OptimizationsDetailsProps> = () => { const location = useLocation(); return ( - <div style={styles.container}> - <AsyncComponent - scope="costManagementMfe" - appName="cost-management-mfe" - module="./MfeOptimizationsDetails" - breadcrumbLabel={intl.formatMessage(messages.breakdownBackToOptimizations)} - breadcrumbPath={formatPath(`${routes.optimizationsDetails.path}${location.search}`)} - linkPath={formatPath(routes.optimizationsBreakdown.path)} - linkState={{ - ...(location.state && location.state), - }} - projectPath={formatPath(routes.ocpBreakdown.path)} - /> - </div> + <AsyncComponent + scope="costManagementMfe" + appName="cost-management-mfe" + module="./MfeOptimizationsDetails" + breadcrumbLabel={intl.formatMessage(messages.breakdownBackToOptimizations)} + breadcrumbPath={formatPath(`${routes.optimizationsDetails.path}${location.search}`)} + linkPath={formatPath(routes.optimizationsBreakdown.path)} + linkState={{ + ...(location.state && location.state), + }} + projectPath={formatPath(routes.ocpBreakdown.path)} + /> ); }; diff --git a/src/routes/overview/overview.scss b/src/routes/overview/overview.scss index eb721c917..928df8865 100644 --- a/src/routes/overview/overview.scss +++ b/src/routes/overview/overview.scss @@ -1,5 +1,5 @@ .headerOverride { - &.pf-v5-c-page__main-section { - --pf-v5-c-page__main-section--PaddingBottom: 0; + &.pf-v6-c-page__main-section { + --pf-v6-c-page__main-section--PaddingBottom: 0; // Todo: PaddingBottom no longer exists? } } diff --git a/src/routes/overview/overview.styles.ts b/src/routes/overview/overview.styles.ts index 7179a46cb..0a313db2e 100644 --- a/src/routes/overview/overview.styles.ts +++ b/src/routes/overview/overview.styles.ts @@ -1,5 +1,4 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_FontSize_md from '@patternfly/react-tokens/dist/js/global_FontSize_md'; +import global_font_size_md from '@patternfly/react-tokens/dist/js/global_font_size_md'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import type React from 'react'; @@ -13,9 +12,11 @@ export const styles = { costType: { marginLeft: global_spacer_md.var, }, - header: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, + headerContainer: { + paddingBottom: 0, + }, + headerContent: { + display: 'flex', }, headerContentLeft: { display: 'flex', @@ -24,16 +25,12 @@ export const styles = { display: 'flex', }, infoIcon: { - fontSize: global_FontSize_md.value, + fontSize: global_font_size_md.value, }, infoTitle: { fontWeight: 'bold', }, - main: { - padding: global_spacer_lg.value, - }, tabs: { - backgroundColor: global_BackgroundColor_light_100.var, paddingBottom: global_spacer_lg.var, paddingTop: global_spacer_lg.var, }, diff --git a/src/routes/overview/overview.tsx b/src/routes/overview/overview.tsx index 3e99e4e2f..692c79e18 100644 --- a/src/routes/overview/overview.tsx +++ b/src/routes/overview/overview.tsx @@ -5,6 +5,7 @@ import { ButtonVariant, Flex, FlexItem, + PageSection, Popover, Tab, TabContent, @@ -728,75 +729,76 @@ class OverviewBase extends React.Component<OverviewProps, OverviewState> { } return ( <> - <header style={styles.header}> - <Flex justifyContent={{ default: 'justifyContentSpaceBetween' }}> - <FlexItem> - <Title headingLevel="h1" size={TitleSizes['2xl']}> - {title} - <span style={styles.infoIcon}> - <Popover - aria-label={intl.formatMessage(messages.overviewInfoArialLabel)} - enableFlip - bodyContent={ - <> - <p style={styles.infoTitle}>{intl.formatMessage(messages.openShiftCloudInfrastructure)}</p> - <p>{intl.formatMessage(messages.openShiftCloudInfrastructureDesc)}</p> - <br /> - <p style={styles.infoTitle}>{intl.formatMessage(messages.openShift)}</p> - <p>{intl.formatMessage(messages.openShiftDesc)}</p> - <br /> - {isFinsightsToggleEnabled && ( - <> - <p style={styles.infoTitle}>{intl.formatMessage(messages.rhel)}</p> - <p>{intl.formatMessage(messages.rhelDesc)}</p> - <br /> - </> - )} - <p style={styles.infoTitle}>{intl.formatMessage(messages.aws)}</p> - <p>{intl.formatMessage(messages.awsDesc)}</p> - <br /> - <p style={styles.infoTitle}>{intl.formatMessage(messages.gcp)}</p> - <p>{intl.formatMessage(messages.gcpDesc)}</p> - {isIbmToggleEnabled && ( - <> - <br /> - <p style={styles.infoTitle}>{intl.formatMessage(messages.ibm)}</p> - <p>{intl.formatMessage(messages.ibmDesc)}</p> - </> - )} - <br /> - <p style={styles.infoTitle}>{intl.formatMessage(messages.azure)}</p> - <p>{intl.formatMessage(messages.azureDesc)}</p> - <br /> - <p style={styles.infoTitle}>{intl.formatMessage(messages.oci)}</p> - <p>{intl.formatMessage(messages.ociDesc)}</p> - </> - } - > - <Button - aria-label={intl.formatMessage(messages.overviewInfoButtonArialLabel)} - variant={ButtonVariant.plain} + <PageSection style={styles.headerContainer}> + <header> + <Flex justifyContent={{ default: 'justifyContentSpaceBetween' }}> + <FlexItem> + <Title headingLevel="h1" size={TitleSizes['2xl']}> + {title} + <span style={styles.infoIcon}> + <Popover + aria-label={intl.formatMessage(messages.overviewInfoArialLabel)} + enableFlip + bodyContent={ + <> + <p style={styles.infoTitle}>{intl.formatMessage(messages.openShiftCloudInfrastructure)}</p> + <p>{intl.formatMessage(messages.openShiftCloudInfrastructureDesc)}</p> + <br /> + <p style={styles.infoTitle}>{intl.formatMessage(messages.openShift)}</p> + <p>{intl.formatMessage(messages.openShiftDesc)}</p> + <br /> + {isFinsightsToggleEnabled && ( + <> + <p style={styles.infoTitle}>{intl.formatMessage(messages.rhel)}</p> + <p>{intl.formatMessage(messages.rhelDesc)}</p> + <br /> + </> + )} + <p style={styles.infoTitle}>{intl.formatMessage(messages.aws)}</p> + <p>{intl.formatMessage(messages.awsDesc)}</p> + <br /> + <p style={styles.infoTitle}>{intl.formatMessage(messages.gcp)}</p> + <p>{intl.formatMessage(messages.gcpDesc)}</p> + {isIbmToggleEnabled && ( + <> + <br /> + <p style={styles.infoTitle}>{intl.formatMessage(messages.ibm)}</p> + <p>{intl.formatMessage(messages.ibmDesc)}</p> + </> + )} + <br /> + <p style={styles.infoTitle}>{intl.formatMessage(messages.azure)}</p> + <p>{intl.formatMessage(messages.azureDesc)}</p> + <br /> + <p style={styles.infoTitle}>{intl.formatMessage(messages.oci)}</p> + <p>{intl.formatMessage(messages.ociDesc)}</p> + </> + } > - <OutlinedQuestionCircleIcon /> - </Button> - </Popover> - </span> - - - -
{this.getCurrency()}
-
-
-
{this.getTabs(availableTabs)}
-
-
- {this.getPerspective()} - {this.getCostType()} + + + + + + +
{this.getCurrency()}
+
+ +
{this.getTabs(availableTabs)}
+
+
+ {this.getPerspective()} + {this.getCostType()} +
+
{getSinceDateRangeString()}
-
{getSinceDateRangeString()}
-
-
-
{this.getTabContent(availableTabs)}
+ + + {this.getTabContent(availableTabs)} ); } diff --git a/src/routes/settings/calculations/calculations.styles.ts b/src/routes/settings/calculations/calculations.styles.ts index 3b34f647c..b62b3975b 100644 --- a/src/routes/settings/calculations/calculations.styles.ts +++ b/src/routes/settings/calculations/calculations.styles.ts @@ -1,4 +1,3 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; @@ -6,28 +5,16 @@ import type React from 'react'; export const styles = { costType: { - marginBottom: global_spacer_lg.var, marginTop: global_spacer_lg.var, width: 'fit-content', }, costTypeContainer: { - backgroundColor: global_BackgroundColor_light_100.var, - paddingBottom: global_spacer_lg.var, - paddingLeft: global_spacer_lg.var, - paddingRight: global_spacer_lg.var, - paddingTop: global_spacer_lg.var, + marginTop: global_spacer_lg.var, }, currency: { marginTop: global_spacer_lg.var, width: 'fit-content', }, - currencyContainer: { - backgroundColor: global_BackgroundColor_light_100.var, - paddingBottom: global_spacer_lg.var, - paddingLeft: global_spacer_lg.var, - paddingRight: global_spacer_lg.var, - paddingTop: global_spacer_lg.var, - }, resetContainer: { display: 'inline-block', paddingLeft: global_spacer_md.var, diff --git a/src/routes/settings/calculations/calculations.tsx b/src/routes/settings/calculations/calculations.tsx index 4d3e78ecd..84acf24a8 100644 --- a/src/routes/settings/calculations/calculations.tsx +++ b/src/routes/settings/calculations/calculations.tsx @@ -1,4 +1,4 @@ -import { PageSection, Title, TitleSizes, Tooltip } from '@patternfly/react-core'; +import { Card, CardBody, Title, TitleSizes, Tooltip } from '@patternfly/react-core'; import { AccountSettingsType } from 'api/accountSettings'; import messages from 'locales/messages'; import React, { useEffect, useState } from 'react'; @@ -59,7 +59,7 @@ const Calculations: React.FC = ({ canWrite }) => { const getCurrency = () => { return ( -
+ <> {intl.formatMessage(messages.currency)} @@ -75,7 +75,7 @@ const Calculations: React.FC = ({ canWrite }) => { /> )}
-
+ ); }; @@ -105,10 +105,12 @@ const Calculations: React.FC = ({ canWrite }) => { }, [costTypeAccountSettingsUpdateStatus, currencyAccountSettingsUpdateStatus]); return ( - - {getCurrency()} - {getCostType()} - + + + {getCurrency()} + {getCostType()} + + ); }; diff --git a/src/routes/settings/costCategory/costCategory.styles.ts b/src/routes/settings/costCategory/costCategory.styles.ts index 19d3215ba..40533795e 100644 --- a/src/routes/settings/costCategory/costCategory.styles.ts +++ b/src/routes/settings/costCategory/costCategory.styles.ts @@ -1,20 +1,16 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; +import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { action: { marginLeft: global_spacer_md.var, }, - descContainer: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingLeft: global_spacer_md.value, - paddingRight: global_spacer_md.value, - paddingTop: global_spacer_md.value, + paginationContainer: { + marginTop: global_spacer_sm.var, }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, + tableContainer: { + marginTop: global_spacer_lg.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/costCategory/costCategory.tsx b/src/routes/settings/costCategory/costCategory.tsx index 03547941c..a8828d131 100644 --- a/src/routes/settings/costCategory/costCategory.tsx +++ b/src/routes/settings/costCategory/costCategory.tsx @@ -1,4 +1,4 @@ -import { PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import { getQuery } from 'api/queries/query'; import type { Settings } from 'api/settings'; @@ -11,8 +11,8 @@ import { useIntl } from 'react-intl'; import { useDispatch, useSelector } from 'react-redux'; import type { AnyAction } from 'redux'; import type { ThunkDispatch } from 'redux-thunk'; -import { Loading } from 'routes/components/page/loading'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import * as queryUtils from 'routes/utils/query'; import type { RootState } from 'store'; import { FetchStatus } from 'store/common'; @@ -216,8 +216,8 @@ const CostCategory: React.FC = ({ canWrite }) => { return ; } return ( - -
+ + {intl.formatMessage(messages.costCategoryDesc, { learnMore: ( @@ -225,17 +225,19 @@ const CostCategory: React.FC = ({ canWrite }) => { ), })} -
- {getToolbar(categories)} - {settingsStatus === FetchStatus.inProgress ? ( - - ) : ( - <> - {getTable()} -
{getPagination(isDisabled, true)}
- - )} -
+
+ {getToolbar(categories)} + {settingsStatus === FetchStatus.inProgress ? ( + + ) : ( + <> + {getTable()} +
{getPagination(isDisabled, true)}
+ + )} +
+ + ); }; diff --git a/src/routes/settings/costModels/components/__snapshots__/rateTable.test.tsx.snap b/src/routes/settings/costModels/components/__snapshots__/rateTable.test.tsx.snap index 12b6b07f3..966ad686e 100644 --- a/src/routes/settings/costModels/components/__snapshots__/rateTable.test.tsx.snap +++ b/src/routes/settings/costModels/components/__snapshots__/rateTable.test.tsx.snap @@ -3,25 +3,25 @@ exports[`rate-table sort by metric & measurement 1`] = ` [ {value, select, cpu {CPU} cluster {Cluster} memory {Memory} node {Node} persistent_volume_claims {Persistent volume claims} storage {Storage} other {}}{"value":"Node"} , {value, select, cpu {CPU} cluster {Cluster} memory {Memory} node {Node} persistent_volume_claims {Persistent volume claims} storage {Storage} other {}}{"value":"CPU"} , {value, select, cpu {CPU} cluster {Cluster} memory {Memory} node {Node} persistent_volume_claims {Persistent volume claims} storage {Storage} other {}}{"value":"CPU"} , {value, select, cpu {CPU} cluster {Cluster} memory {Memory} node {Node} persistent_volume_claims {Persistent volume claims} storage {Storage} other {}}{"value":"CPU"} diff --git a/src/routes/settings/costModels/components/__snapshots__/warningIcon.test.tsx.snap b/src/routes/settings/costModels/components/__snapshots__/warningIcon.test.tsx.snap index b2edbad87..c6e6e3638 100644 --- a/src/routes/settings/costModels/components/__snapshots__/warningIcon.test.tsx.snap +++ b/src/routes/settings/costModels/components/__snapshots__/warningIcon.test.tsx.snap @@ -3,7 +3,7 @@ exports[`warning icon 1`] = `
); }; diff --git a/src/routes/settings/costModels/components/rateForm/rateForm.tsx b/src/routes/settings/costModels/components/rateForm/rateForm.tsx index cf0f47f4b..6a1c883ee 100644 --- a/src/routes/settings/costModels/components/rateForm/rateForm.tsx +++ b/src/routes/settings/costModels/components/rateForm/rateForm.tsx @@ -226,8 +226,8 @@ const RateFormBase: React.FC = ({ currencyUnits, intl = defaultIn updateDefaultTag={updateDefaultTag} updateTag={updateTag} /> - )} diff --git a/src/routes/settings/costModels/components/rateForm/taggingRatesForm.tsx b/src/routes/settings/costModels/components/rateForm/taggingRatesForm.tsx index 8dd783b5f..e411fad5b 100644 --- a/src/routes/settings/costModels/components/rateForm/taggingRatesForm.tsx +++ b/src/routes/settings/costModels/components/rateForm/taggingRatesForm.tsx @@ -91,13 +91,12 @@ const TaggingRatesFormBase: React.FC = ({  
}> + > diff --git a/src/routes/settings/costModels/costModel/__snapshots__/dialog.test.tsx.snap b/src/routes/settings/costModels/costModel/__snapshots__/dialog.test.tsx.snap index c080cca6b..8496b4d09 100644 --- a/src/routes/settings/costModels/costModel/__snapshots__/dialog.test.tsx.snap +++ b/src/routes/settings/costModels/costModel/__snapshots__/dialog.test.tsx.snap @@ -2,7 +2,7 @@ exports[`dialog title renders correctly with icon and title text 1`] = ` Test dialog diff --git a/src/routes/settings/costModels/costModel/addRateModal.tsx b/src/routes/settings/costModels/costModel/addRateModal.tsx index 335c6de4e..5d3daa802 100644 --- a/src/routes/settings/costModels/costModel/addRateModal.tsx +++ b/src/routes/settings/costModels/costModel/addRateModal.tsx @@ -1,4 +1,14 @@ -import { Alert, Button, ButtonVariant, Form, Modal } from '@patternfly/react-core'; +import { + Alert, + Button, + ButtonVariant, + Form, + Modal, + ModalBody, + ModalFooter, + ModalHeader, + ModalVariant, +} from '@patternfly/react-core'; import type { CostModelRequest } from 'api/costModels'; import type { CostModel } from 'api/costModels'; import type { MetricHash } from 'api/metrics'; @@ -59,13 +69,15 @@ export const AddRateModalBase: React.FC = ({ }, [isOpen]); return ( - + + +
+ {updateError && } + + +
+ , + , - ]} - > -
- {updateError && } - - + +
); }; diff --git a/src/routes/settings/costModels/costModel/addSourceStep.tsx b/src/routes/settings/costModels/costModel/addSourceStep.tsx index cf2388ac0..b3c51c64f 100644 --- a/src/routes/settings/costModels/costModel/addSourceStep.tsx +++ b/src/routes/settings/costModels/costModel/addSourceStep.tsx @@ -16,6 +16,7 @@ import { createMapStateToProps } from 'store/common'; import { sourcesActions, sourcesSelectors } from 'store/sourceSettings'; import { AssignSourcesToolbar } from './assignSourcesModalToolbar'; +import { styles } from './costModelInfo.styles'; interface AddSourcesStepOwnProps extends WrappedComponentProps { checked: { [uuid: string]: { selected: boolean; meta: Provider } }; @@ -230,6 +231,7 @@ class AddSourcesStepBase extends React.Component + + + + {updateApiError && } + + + + + {intl.formatMessage(messages.names, { count: 1 })} + + + + + {this.props.costModel.name} + + + + + {intl.formatMessage(messages.sourceType)} + + + + + {this.props.costModel.source_type} + + + + + + { + this.setState({ checked: newState }); + }} + /> + + + + , + , - ]} - > - - {updateApiError && } - - - - - {intl.formatMessage(messages.names, { count: 1 })} - - - - - {this.props.costModel.name} - - - - - {intl.formatMessage(messages.sourceType)} - - - - - {this.props.costModel.source_type} - - - - - - { - this.setState({ checked: newState }); - }} - /> - - + +
); } diff --git a/src/routes/settings/costModels/costModel/assignSourcesModalToolbar.tsx b/src/routes/settings/costModels/costModel/assignSourcesModalToolbar.tsx index 6c3d80b12..8d68f85ae 100644 --- a/src/routes/settings/costModels/costModel/assignSourcesModalToolbar.tsx +++ b/src/routes/settings/costModels/costModel/assignSourcesModalToolbar.tsx @@ -70,8 +70,8 @@ export const AssignSourcesToolbarBase: React.FC = }> - - + + - - - } - headingLevel="h2" - /> - - {intl.formatMessage(messages.costModelsUUIDEmptyStateDesc, { - uuid: this.props.router.params.uuid, - })} - - - + + + {intl.formatMessage(messages.costModelsUUIDEmptyStateDesc, { + uuid: this.props.router.params.uuid, + })} + + ); } @@ -114,20 +101,18 @@ class CostModelInfo extends React.Component + <>
this.setState({ tabIndex })} /> -
+ {current.source_type === 'OpenShift Container Platform' ? ( <> ) : ( <> )} -
-
+ + ); } } diff --git a/src/routes/settings/costModels/costModel/costModelsDetails.styles.ts b/src/routes/settings/costModels/costModel/costModelsDetails.styles.ts index efd594557..0b254970c 100644 --- a/src/routes/settings/costModels/costModel/costModelsDetails.styles.ts +++ b/src/routes/settings/costModels/costModel/costModelsDetails.styles.ts @@ -1,4 +1,4 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; @@ -13,43 +13,10 @@ export const styles = { paddingTop: global_spacer_lg.value, height: '182vh', }, - costmodelsContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - paddingLeft: global_spacer_lg.value, - paddingRight: global_spacer_lg.value, - }, currency: { paddingBottom: global_spacer_md.value, paddingTop: global_spacer_lg.value, }, - tableContainer: { - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - }, - paginationContainer: { - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - paddingLeft: global_spacer_lg.value, - paddingRight: global_spacer_lg.value, - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - marginBottom: global_spacer_lg.value, - backgroundColor: global_BackgroundColor_light_100.value, - }, - toolbarContainer: { - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, - marginLeft: global_spacer_lg.value, - marginRight: global_spacer_lg.value, - backgroundColor: global_BackgroundColor_light_100.value, - }, - header: { - padding: global_spacer_lg.var, - backgroundColor: global_BackgroundColor_light_100.var, - }, headerContent: { display: 'flex', justifyContent: 'space-between', @@ -57,7 +24,7 @@ export const styles = { headerCostModel: { padding: global_spacer_lg.value, paddingBottom: 0, - backgroundColor: global_BackgroundColor_light_100.var, + backgroundColor: global_background_color_100.var, }, breadcrumb: { paddingBottom: global_spacer_md.var, diff --git a/src/routes/settings/costModels/costModel/dialog.tsx b/src/routes/settings/costModels/costModel/dialog.tsx index e0103402c..a2c6c1c5d 100644 --- a/src/routes/settings/costModels/costModel/dialog.tsx +++ b/src/routes/settings/costModels/costModel/dialog.tsx @@ -1,4 +1,4 @@ -import { Alert, Button, Modal } from '@patternfly/react-core'; +import { Alert, Button, Modal, ModalBody, ModalFooter, ModalHeader, ModalVariant } from '@patternfly/react-core'; import { intl as defaultIntl } from 'components/i18n'; import messages from 'locales/messages'; import React from 'react'; @@ -50,13 +50,14 @@ const DialogBase: React.FC = ({ aria-label={title} isOpen={isOpen} onClose={onClose} - actions={actions} - title={title} - titleIconVariant="warning" - variant={isSmall ? 'small' : 'default'} + variant={isSmall ? ModalVariant.small : ModalVariant.default} > - {error && } - {body} + + + {error && } + {body} + + {actions} ); }; diff --git a/src/routes/settings/costModels/costModel/header.tsx b/src/routes/settings/costModels/costModel/header.tsx index 270376f1d..ca92ce826 100644 --- a/src/routes/settings/costModels/costModel/header.tsx +++ b/src/routes/settings/costModels/costModel/header.tsx @@ -1,6 +1,8 @@ import { Breadcrumb, BreadcrumbItem, + Content, + ContentVariants, List, ListItem, Split, @@ -8,11 +10,6 @@ import { Tab, Tabs, TabTitleText, - TextContent, - TextList, - TextListItem, - TextListItemVariants, - TextListVariants, Title, TitleSizes, } from '@patternfly/react-core'; @@ -168,18 +165,16 @@ const Header: React.FC = ({ /> - - - - {intl.formatMessage(messages.costModelsLastUpdated)} - - {dateTime} - {intl.formatMessage(messages.currency)} - + + + {intl.formatMessage(messages.costModelsLastUpdated)} + {dateTime} + {intl.formatMessage(messages.currency)} + {intl.formatMessage(messages.currencyOptions, { units: current.currency || 'USD' })} - - - + + + {current.source_type === 'OpenShift Container Platform' ? ( onSelectTab(index)}> - - } - headingLevel="h2" - /> + {intl.formatMessage(messages.priceListEmptyRateDesc)} @@ -357,35 +343,29 @@ class PriceListTable extends React.Component - - - - - - this.setState({ - pagination: { ...this.state.pagination, page }, - }) - } - onPerPageSelect={(_evt, perPage) => - this.setState({ - pagination: { page: 1, perPage }, - }) - } - titles={{ - paginationAriaLabel: intl.formatMessage(messages.paginationTitle, { - title: intl.formatMessage(messages.priceList), - placement: 'bottom', - }), - }} - variant="bottom" - /> - - - + + this.setState({ + pagination: { ...this.state.pagination, page }, + }) + } + onPerPageSelect={(_evt, perPage) => + this.setState({ + pagination: { page: 1, perPage }, + }) + } + style={styles.pagination} + titles={{ + paginationAriaLabel: intl.formatMessage(messages.paginationTitle, { + title: intl.formatMessage(messages.priceList), + placement: 'bottom', + }), + }} + variant="bottom" + /> )} diff --git a/src/routes/settings/costModels/costModel/sourcesTable.tsx b/src/routes/settings/costModels/costModel/sourcesTable.tsx index 03b9ee65c..3f2023a40 100644 --- a/src/routes/settings/costModels/costModel/sourcesTable.tsx +++ b/src/routes/settings/costModels/costModel/sourcesTable.tsx @@ -58,14 +58,13 @@ const SourcesTable: React.FC = ({ canWrite, costModels, intl, + > diff --git a/src/routes/settings/costModels/costModel/sourcesToolbar.tsx b/src/routes/settings/costModels/costModel/sourcesToolbar.tsx index 57cbd8414..3c4d0ac70 100644 --- a/src/routes/settings/costModels/costModel/sourcesToolbar.tsx +++ b/src/routes/settings/costModels/costModel/sourcesToolbar.tsx @@ -72,10 +72,10 @@ export const SourcesToolbar: React.FC = ({ }> - + diff --git a/src/routes/settings/costModels/costModel/table.styles.ts b/src/routes/settings/costModels/costModel/table.styles.ts index 7c7b85bbf..ef279e36e 100644 --- a/src/routes/settings/costModels/costModel/table.styles.ts +++ b/src/routes/settings/costModels/costModel/table.styles.ts @@ -1,3 +1,4 @@ +import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import type React from 'react'; export const styles = { @@ -7,8 +8,6 @@ export const styles = { justifyContent: 'center', }, sourceTypeTitle: { - marginLeft: 20, - marginTop: 8, - marginBottom: 8, + marginBottom: global_spacer_md.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/costModels/costModel/table.tsx b/src/routes/settings/costModels/costModel/table.tsx index efab2048d..d2cb06acc 100644 --- a/src/routes/settings/costModels/costModel/table.tsx +++ b/src/routes/settings/costModels/costModel/table.tsx @@ -1,11 +1,4 @@ -import { - EmptyState, - EmptyStateBody, - EmptyStateHeader, - EmptyStateIcon, - Title, - TitleSizes, -} from '@patternfly/react-core'; +import { EmptyState, EmptyStateBody, Title, TitleSizes } from '@patternfly/react-core'; import { PlusCircleIcon } from '@patternfly/react-icons/dist/esm/icons/plus-circle-icon'; import type { CostModel } from 'api/costModels'; import messages from 'locales/messages'; @@ -124,12 +117,11 @@ class TableBase extends React.Component { )} {rows.length === 0 && (
- - } - headingLevel="h2" - /> + {intl.formatMessage(messages.costModelsSourceEmptyStateTitle)}
diff --git a/src/routes/settings/costModels/costModel/updateCostModel.tsx b/src/routes/settings/costModels/costModel/updateCostModel.tsx index 27a373d66..df73b92ef 100644 --- a/src/routes/settings/costModels/costModel/updateCostModel.tsx +++ b/src/routes/settings/costModels/costModel/updateCostModel.tsx @@ -1,4 +1,16 @@ -import { Alert, Button, Form, FormGroup, Modal, TextArea, TextInput } from '@patternfly/react-core'; +import { + Alert, + Button, + Form, + FormGroup, + Modal, + ModalBody, + ModalFooter, + ModalHeader, + ModalVariant, + TextArea, + TextInput, +} from '@patternfly/react-core'; import type { CostModel } from 'api/costModels'; import messages from 'locales/messages'; import { cloneDeep } from 'lodash'; @@ -76,50 +88,12 @@ class UpdateCostModelBase extends React.Component setDialogOpen({ name: 'updateCostModel', isOpen: false })} - variant="small" - actions={[ - , - , - ]} + variant={ModalVariant.small} > - <> + + {updateError && }
@@ -160,7 +134,45 @@ class UpdateCostModelBase extends React.Component
- +
+ + + + ); } diff --git a/src/routes/settings/costModels/costModel/updateDistributionDialog.tsx b/src/routes/settings/costModels/costModel/updateDistributionDialog.tsx index 8d9ff31b9..0312cd9f2 100644 --- a/src/routes/settings/costModels/costModel/updateDistributionDialog.tsx +++ b/src/routes/settings/costModels/costModel/updateDistributionDialog.tsx @@ -2,15 +2,17 @@ import { Alert, Button, Checkbox, + Content, Form, FormGroup, Modal, + ModalBody, + ModalFooter, + ModalHeader, ModalVariant, Radio, Stack, StackItem, - Text, - TextContent, Title, TitleSizes, } from '@patternfly/react-core'; @@ -103,16 +105,101 @@ class UpdateDistributionDialogBase extends React.Component< } = this.props; return ( - {intl.formatMessage(messages.learnMore)} - - } isOpen onClose={() => onClose({ name: 'updateDistribution', isOpen: false })} variant={ModalVariant.medium} - actions={[ + > + + {intl.formatMessage(messages.learnMore)} + + } + title={intl.formatMessage(messages.costDistribution)} + /> + + + {error && } + + + {intl.formatMessage(messages.distributionType)} + + + + {intl.formatMessage(messages.distributionModelDesc)} + + + + +
+ + + + +
+
+ + + {intl.formatMessage(messages.distributeCostsToProjects)} + + + +
+ + + + {isOcpCloudNetworkingToggleEnabled && ( + + )} + {isOcpProjectStorageToggleEnabled && ( + + )} + +
+
+
+
+ , + , - ]} - > - - {error && } - - - {intl.formatMessage(messages.distributionType)} - - - {intl.formatMessage(messages.distributionModelDesc)} - - - -
- - - - -
-
- - - {intl.formatMessage(messages.distributeCostsToProjects)} - - - -
- - - - {isOcpCloudNetworkingToggleEnabled && ( - - )} - {isOcpProjectStorageToggleEnabled && ( - - )} - -
-
-
+ +
); } diff --git a/src/routes/settings/costModels/costModel/updateMarkupDialog.tsx b/src/routes/settings/costModels/costModel/updateMarkupDialog.tsx index 723f642b6..632a304fd 100644 --- a/src/routes/settings/costModels/costModel/updateMarkupDialog.tsx +++ b/src/routes/settings/costModels/costModel/updateMarkupDialog.tsx @@ -1,6 +1,7 @@ import { Alert, Button, + Content, Flex, FlexItem, Form, @@ -13,12 +14,13 @@ import { List, ListItem, Modal, + ModalBody, + ModalFooter, + ModalHeader, ModalVariant, Radio, Stack, StackItem, - Text, - TextContent, TextInput, Title, TitleSizes, @@ -110,12 +112,104 @@ class UpdateMarkupDialogBase extends React.Component onClose({ name: 'updateMarkup', isOpen: false })} - variant={ModalVariant.medium} - actions={[ + onClose({ name: 'updateMarkup', isOpen: false })} variant={ModalVariant.medium}> + + + + {error && } + + + + {intl.formatMessage(messages.markupOrDiscountModalDesc)} + + + + + + + {intl.formatMessage(messages.markupOrDiscount)} + + + + + + + + + + + +
+ + + + {isDiscount + ? intl.formatMessage(messages.discountMinus) + : intl.formatMessage(messages.markupPlus)} + + + + + + {intl.formatMessage(messages.percentSymbol)} + + + {validated === 'error' && ( + + {intl.formatMessage(helpText)} + + )} + +
+
+
+
+
+ + + + + {intl.formatMessage(messages.examplesTitle)} + + + + {intl.formatMessage(messages.costModelsExamplesNoAdjust)} + {intl.formatMessage(messages.costModelsExamplesDoubleMarkup)} + {intl.formatMessage(messages.costModelsExamplesReduceZero)} + {intl.formatMessage(messages.costModelsExamplesReduceSeventyfive)} + + +
+
+ , + , - ]} - > - - {error && } - - - {intl.formatMessage(messages.markupOrDiscountModalDesc)} - - - - - - {intl.formatMessage(messages.markupOrDiscount)} - - - - - - - - - - - -
- - - - {isDiscount - ? intl.formatMessage(messages.discountMinus) - : intl.formatMessage(messages.markupPlus)} - - - - - - {intl.formatMessage(messages.percentSymbol)} - - - {validated === 'error' && ( - - {intl.formatMessage(helpText)} - - )} - -
-
-
-
-
- - - - - {intl.formatMessage(messages.examplesTitle)} - - - - {intl.formatMessage(messages.costModelsExamplesNoAdjust)} - {intl.formatMessage(messages.costModelsExamplesDoubleMarkup)} - {intl.formatMessage(messages.costModelsExamplesReduceZero)} - {intl.formatMessage(messages.costModelsExamplesReduceSeventyfive)} - - -
+ +
); } diff --git a/src/routes/settings/costModels/costModel/updateRateModel.tsx b/src/routes/settings/costModels/costModel/updateRateModel.tsx index b57dcf706..1d98214ce 100644 --- a/src/routes/settings/costModels/costModel/updateRateModel.tsx +++ b/src/routes/settings/costModels/costModel/updateRateModel.tsx @@ -1,4 +1,14 @@ -import { Alert, Button, Modal, Stack, StackItem } from '@patternfly/react-core'; +import { + Alert, + Button, + Modal, + ModalBody, + ModalFooter, + ModalHeader, + ModalVariant, + Stack, + StackItem, +} from '@patternfly/react-core'; import type { CostModelRequest } from 'api/costModels'; import type { MetricHash } from 'api/metrics'; import { intl as defaultIntl } from 'components/i18n'; @@ -101,13 +111,23 @@ const UpdateRateModalBase: React.FC = ({ }, [isOpen]); return ( - + + + + {updateError && ( + + + + )} + +
+ + +
+
+
+ , + , - ]} - > - - {updateError && ( - - - - )} - -
- - -
-
+ +
); }; diff --git a/src/routes/settings/costModels/costModelWizard/assignSourcesToolbar.tsx b/src/routes/settings/costModels/costModelWizard/assignSourcesToolbar.tsx index 3d49c4940..dec9d0b2e 100644 --- a/src/routes/settings/costModels/costModelWizard/assignSourcesToolbar.tsx +++ b/src/routes/settings/costModels/costModelWizard/assignSourcesToolbar.tsx @@ -70,8 +70,8 @@ export const AssignSourcesToolbarBase: React.FC = }> - - + + = ({ // Todo: Remove key={newSteps.length} workaround -- see https://github.com/patternfly/patternfly-react/issues/9752 return ( - + + <Icon status="warning"> <ExclamationTriangleIcon /> </Icon>{' '} {intl.formatMessage(messages.createCostModelExit)} - } - onClose={closeConfirmDialog} - actions={[OkButton, CancelButton]} - variant="small" - > - {intl.formatMessage(messages.createCostModelConfirmMsg)} + + {intl.formatMessage(messages.createCostModelConfirmMsg)} + + {OkButton} + {CancelButton} + ); diff --git a/src/routes/settings/costModels/costModelWizard/distribution.tsx b/src/routes/settings/costModels/costModelWizard/distribution.tsx index d99749ee1..5fdcb1069 100644 --- a/src/routes/settings/costModels/costModelWizard/distribution.tsx +++ b/src/routes/settings/costModels/costModelWizard/distribution.tsx @@ -1,14 +1,4 @@ -import { - Checkbox, - FormGroup, - Radio, - Stack, - StackItem, - Text, - TextContent, - Title, - TitleSizes, -} from '@patternfly/react-core'; +import { Checkbox, Content, FormGroup, Radio, Stack, StackItem, Title, TitleSizes } from '@patternfly/react-core'; import messages from 'locales/messages'; import React from 'react'; import type { WrappedComponentProps } from 'react-intl'; @@ -64,11 +54,13 @@ class DistributionBase extends React.Component {intl.formatMessage(messages.distributionType)} - - {intl.formatMessage(messages.distributionModelDesc)} - + + + {intl.formatMessage(messages.distributionModelDesc)} + + - +
- + {intl.formatMessage(messages.markupOrDiscount)} - - {intl.formatMessage(messages.markupOrDiscountModalDesc)} - + + {intl.formatMessage(messages.markupOrDiscountModalDesc)} + @@ -155,9 +154,9 @@ class MarkupWithDistributionBase extends React.Component
- - {intl.formatMessage(messages.examplesTitle)} - + + {intl.formatMessage(messages.examplesTitle)} + {intl.formatMessage(messages.costModelsExamplesNoAdjust)} {intl.formatMessage(messages.costModelsExamplesDoubleMarkup)} diff --git a/src/routes/settings/costModels/costModelWizard/priceListTable.tsx b/src/routes/settings/costModels/costModelWizard/priceListTable.tsx index cd75a9422..3792e0ecc 100644 --- a/src/routes/settings/costModels/costModelWizard/priceListTable.tsx +++ b/src/routes/settings/costModels/costModelWizard/priceListTable.tsx @@ -1,15 +1,12 @@ import { Bullseye, Button, + Content, EmptyState, EmptyStateBody, - EmptyStateHeader, - EmptyStateIcon, Pagination, Stack, StackItem, - Text, - TextContent, Title, TitleSizes, } from '@patternfly/react-core'; @@ -92,12 +89,11 @@ class PriceListTable extends React.Component ( - - } - headingLevel="h2" - /> + {intl.formatMessage(messages.costModelsWizardEmptyStateSkipStep, { value: {intl.formatMessage(messages.next)}, @@ -120,9 +116,9 @@ class PriceListTable extends React.Component - - {intl.formatMessage(messages.costModelsWizardSubTitleTable)} - + + {intl.formatMessage(messages.costModelsWizardSubTitleTable)} + = ({ intl }) => ( {({ onClose, name }) => ( - - - - - } - headingLevel="h2" - /> + {intl.formatMessage(messages.costModelsWizardReviewStatusSubTitle, { value: name })} @@ -108,99 +91,87 @@ const ReviewDetailsBase: React.FC = ({ - - + + {intl.formatMessage(messages.costModelsWizardReviewStatusSubDetails, { create: {intl.formatMessage(messages.create)}, back: {intl.formatMessage(messages.back)}, })} - - + + - - - - {intl.formatMessage(messages.names, { count: 1 })} - - {name} - - {intl.formatMessage(messages.description)} - - {description} - - {intl.formatMessage(messages.currency)} - - + + + {intl.formatMessage(messages.names, { count: 1 })} + {name} + {intl.formatMessage(messages.description)} + {description} + {intl.formatMessage(messages.currency)} + {intl.formatMessage(messages.currencyOptions, { units: currencyUnits })} - + {type === 'OCP' && ( <> - - {intl.formatMessage(messages.priceList)} - - + {intl.formatMessage(messages.priceList)} + {tiers.length > 0 ? ( ) : ( intl.formatMessage(messages.costModelsWizardNoRatesAdded) )} - + )} - + {intl.formatMessage(messages.costModelsWizardReviewMarkDiscount)} - - + + {intl.formatMessage(messages.percent, { value: isDiscount ? '-' + markup : markup })} - + {type === 'OCP' && ( <> - - {intl.formatMessage(messages.costDistribution)} - - + {intl.formatMessage(messages.costDistribution)} + {intl.formatMessage(messages.distributionTypeDesc, { type: distribution })} - - + + {intl.formatMessage(messages.distributePlatformCosts, { value: distributePlatformUnallocated, })} - - + + {intl.formatMessage(messages.distributeUnallocatedCapacity, { value: distributeWorkerUnallocated, })} - + {isOcpCloudNetworkingToggleEnabled && ( - + {intl.formatMessage(messages.distributeCosts, { value: distributeNetwork, type: 'network', })} - + )} {isOcpProjectStorageToggleEnabled && ( - + {intl.formatMessage(messages.distributeCosts, { value: distributeStorage, type: 'storage', })} - + )} )} - + {intl.formatMessage(messages.costModelsAssignSources, { count: 2 })}{' '} {selectedSources.find(src => Boolean(src.costmodel)) && ( )} - - - {selectedSources.map(r => r.name).join(', ')} - - - + + {selectedSources.map(r => r.name).join(', ')} + + diff --git a/src/routes/settings/costModels/costModelWizard/table.tsx b/src/routes/settings/costModels/costModelWizard/table.tsx index 492b23904..2ca05567c 100644 --- a/src/routes/settings/costModels/costModelWizard/table.tsx +++ b/src/routes/settings/costModels/costModelWizard/table.tsx @@ -1,4 +1,4 @@ -import { Checkbox, Stack, StackItem, Text, TextContent, TextVariants, Title, TitleSizes } from '@patternfly/react-core'; +import { Checkbox, Content, ContentVariants, Stack, StackItem, Title, TitleSizes } from '@patternfly/react-core'; import { Table, TableVariant, Tbody, Td, Th, Thead, Tr } from '@patternfly/react-table'; import messages from 'locales/messages'; import React from 'react'; @@ -38,18 +38,18 @@ const SourcesTable: React.FC = ({ intl }) => { - - {intl.formatMessage(messages.costModelsWizardSourceSubtitle)} - + + {intl.formatMessage(messages.costModelsWizardSourceSubtitle)} + - - + + {intl.formatMessage(messages.costModelsWizardSourceCaption, { value: type.toLowerCase(), })} - - + + = props => { onPerPageSelect, } = props; return ( - - - - - - - + ); }; diff --git a/src/routes/settings/costModels/costModelsDetails/costModelsDetails.styles.ts b/src/routes/settings/costModels/costModelsDetails/costModelsDetails.styles.ts index c6af422cc..803d7498e 100644 --- a/src/routes/settings/costModels/costModelsDetails/costModelsDetails.styles.ts +++ b/src/routes/settings/costModels/costModelsDetails/costModelsDetails.styles.ts @@ -1,10 +1,12 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { - descContainer: { - backgroundColor: global_BackgroundColor_light_100.value, - padding: global_spacer_md.value, + paginationContainer: { + marginTop: global_spacer_sm.var, + }, + tableContainer: { + marginTop: global_spacer_lg.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/costModels/costModelsDetails/costModelsDetails.tsx b/src/routes/settings/costModels/costModelsDetails/costModelsDetails.tsx index 09576a786..011725287 100644 --- a/src/routes/settings/costModels/costModelsDetails/costModelsDetails.tsx +++ b/src/routes/settings/costModels/costModelsDetails/costModelsDetails.tsx @@ -1,4 +1,4 @@ -import { PageSection } from '@patternfly/react-core'; +import { Card, CardBody } from '@patternfly/react-core'; import messages from 'locales/messages'; import { parse, stringify } from 'qs'; import React from 'react'; @@ -48,8 +48,8 @@ class CostModelsDetailsBase extends React.Component const { intl } = this.props; return ( - -
+ + {intl.formatMessage(messages.costModelsDesc, { learnMore: ( @@ -57,13 +57,17 @@ class CostModelsDetailsBase extends React.Component ), })} -
- - - - - -
+ + +
+ + +
+ +
+
+ + ); } } diff --git a/src/routes/settings/costModels/costModelsDetails/dialog.tsx b/src/routes/settings/costModels/costModelsDetails/dialog.tsx index 0fd7c1981..293999122 100644 --- a/src/routes/settings/costModels/costModelsDetails/dialog.tsx +++ b/src/routes/settings/costModels/costModelsDetails/dialog.tsx @@ -1,7 +1,7 @@ -import type { ModalProps } from '@patternfly/react-core'; -import { Modal, ModalVariant } from '@patternfly/react-core'; +import { Modal, ModalBody, ModalFooter, ModalHeader, ModalVariant } from '@patternfly/react-core'; import { intl as defaultIntl } from 'components/i18n'; import messages from 'locales/messages'; +import React from 'react'; import type { WrappedComponentProps } from 'react-intl'; import { injectIntl } from 'react-intl'; import { connect } from 'react-redux'; @@ -11,6 +11,34 @@ import { costModelsActions, costModelsSelectors } from 'store/costModels'; import { DeleteDialogActions, DeleteDialogBody, getDialogStateName } from './utils/dialog'; +export interface ReportSummaryProps extends WrappedComponentProps { + actions?: React.ReactNode; + ariaLabel?: string; + children?: React.ReactNode; + isOpen?: boolean; + onClose?: () => void; + title?: string; + titleIconVariant?: 'warning'; + variant?: ModalVariant; +} + +const DeleteDialogBase: React.FC = ({ + actions, + ariaLabel: ariaLabel, + children, + isOpen, + onClose, + title, + titleIconVariant, + variant, +}) => ( + + + {children} + {actions} + +); + const mapStateToProps = (state: RootState) => { return { isOpen: costModelsSelectors.isDialogOpen(state)('costmodel').deleteCostModel, @@ -61,14 +89,14 @@ const mergeProps = ( actions, isOpen: stateName !== 'close', variant: ModalVariant.small, - 'aria-label': intl.formatMessage(messages.costModelsDelete), + ariaLabel: intl.formatMessage(messages.costModelsDelete), title: intl.formatMessage(messages.costModelsDelete), titleIconVariant: 'warning', onClose: dispatchProps.closeDialog, children, - } as ModalProps; + }; }; -const DeleteDialog = injectIntl(connect(mapStateToProps, mapDispatchToProps, mergeProps)(Modal)); +const DeleteDialog = injectIntl(connect(mapStateToProps, mapDispatchToProps, mergeProps)(DeleteDialogBase)); export default DeleteDialog; diff --git a/src/routes/settings/costModels/costModelsDetails/emptyStateBase.tsx b/src/routes/settings/costModels/costModelsDetails/emptyStateBase.tsx index 45f032b9d..b684cd76c 100644 --- a/src/routes/settings/costModels/costModelsDetails/emptyStateBase.tsx +++ b/src/routes/settings/costModels/costModelsDetails/emptyStateBase.tsx @@ -1,4 +1,4 @@ -import { EmptyState, EmptyStateBody, EmptyStateFooter, EmptyStateHeader, EmptyStateIcon } from '@patternfly/react-core'; +import { EmptyState, EmptyStateBody, EmptyStateFooter } from '@patternfly/react-core'; import React from 'react'; interface EmptyStateBaseProps { @@ -10,8 +10,7 @@ interface EmptyStateBaseProps { function EmptyStateBase(props: EmptyStateBaseProps): JSX.Element { return ( - - } headingLevel="h2" /> + {props.description} {props.actions ? props.actions : null} diff --git a/src/routes/settings/costModels/costModelsDetails/table.tsx b/src/routes/settings/costModels/costModelsDetails/table.tsx index 153985077..dd24a67f4 100644 --- a/src/routes/settings/costModels/costModelsDetails/table.tsx +++ b/src/routes/settings/costModels/costModelsDetails/table.tsx @@ -137,14 +137,13 @@ class CostModelsTableBase extends React.Component + > )} diff --git a/src/routes/settings/costModels/costModelsDetails/utils/dialog.tsx b/src/routes/settings/costModels/costModelsDetails/utils/dialog.tsx index d932b12e8..12be2b3cb 100644 --- a/src/routes/settings/costModels/costModelsDetails/utils/dialog.tsx +++ b/src/routes/settings/costModels/costModelsDetails/utils/dialog.tsx @@ -3,13 +3,10 @@ import { AlertVariant, Button, ButtonVariant, + Content, + ContentVariants, Stack, StackItem, - Text, - TextContent, - TextList, - TextListItem, - TextListVariants, } from '@patternfly/react-core'; import React from 'react'; @@ -62,19 +59,21 @@ function CannotDeleteContent({ head, body, sources }: CannotDeleteContentProps): return ( - - {head} - + + {head} + - - {body} - + + {body} + {sources.map(source => ( - {source} + + {source} + ))} - - + + ); diff --git a/src/routes/settings/costModels/costModelsDetails/utils/filters.tsx b/src/routes/settings/costModels/costModelsDetails/utils/filters.tsx index 989c343d1..b2d39c6a7 100644 --- a/src/routes/settings/costModels/costModelsDetails/utils/filters.tsx +++ b/src/routes/settings/costModels/costModelsDetails/utils/filters.tsx @@ -143,7 +143,12 @@ const DescriptionFilterBase: React.FC = ({ /> ) : null; return ( - + {children} ); @@ -218,7 +223,12 @@ const NameFilterBase: React.FC = ({ /> ) : null; return ( - + {children} ); @@ -310,7 +320,12 @@ const SourceTypeFilterBase: React.FC = ({ /> ) : null; return ( - + {children} ); diff --git a/src/routes/settings/platformProjects/platformProjects.scss b/src/routes/settings/platformProjects/platformProjects.scss index 31a1a9a99..0006032db 100644 --- a/src/routes/settings/platformProjects/platformProjects.scss +++ b/src/routes/settings/platformProjects/platformProjects.scss @@ -1,5 +1,5 @@ @media only screen and (min-width: 1450px) { - .pf-v5-c-table__td { + .pf-v6-c-table__td { &.defaultColumn { width: 70%; } diff --git a/src/routes/settings/platformProjects/platformProjects.styles.ts b/src/routes/settings/platformProjects/platformProjects.styles.ts index 19d3215ba..40533795e 100644 --- a/src/routes/settings/platformProjects/platformProjects.styles.ts +++ b/src/routes/settings/platformProjects/platformProjects.styles.ts @@ -1,20 +1,16 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; +import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { action: { marginLeft: global_spacer_md.var, }, - descContainer: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingLeft: global_spacer_md.value, - paddingRight: global_spacer_md.value, - paddingTop: global_spacer_md.value, + paginationContainer: { + marginTop: global_spacer_sm.var, }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, - paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, + tableContainer: { + marginTop: global_spacer_lg.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/platformProjects/platformProjects.tsx b/src/routes/settings/platformProjects/platformProjects.tsx index 7eed9e24f..c62ed45ad 100644 --- a/src/routes/settings/platformProjects/platformProjects.tsx +++ b/src/routes/settings/platformProjects/platformProjects.tsx @@ -1,4 +1,4 @@ -import { PageSection, Pagination, PaginationVariant } from '@patternfly/react-core'; +import { Card, CardBody, Pagination, PaginationVariant } from '@patternfly/react-core'; import type { Query } from 'api/queries/query'; import { getQuery } from 'api/queries/query'; import type { Settings } from 'api/settings'; @@ -11,8 +11,8 @@ import { useIntl } from 'react-intl'; import { useDispatch, useSelector } from 'react-redux'; import type { AnyAction } from 'redux'; import type { ThunkDispatch } from 'redux-thunk'; -import { Loading } from 'routes/components/page/loading'; import { NotAvailable } from 'routes/components/page/notAvailable'; +import { LoadingState } from 'routes/components/state/loadingState'; import * as queryUtils from 'routes/utils/query'; import type { RootState } from 'store'; import { FetchStatus } from 'store/common'; @@ -221,8 +221,8 @@ const PlatformProjects: React.FC = ({ canWrite }) => { return ; } return ( - -
+ + {intl.formatMessage(messages.platformProjectsDesc, { learnMore: ( @@ -230,17 +230,19 @@ const PlatformProjects: React.FC = ({ canWrite }) => { ), })} -
- {getToolbar(categories)} - {settingsStatus === FetchStatus.inProgress ? ( - - ) : ( - <> - {getTable()} -
{getPagination(isDisabled, true)}
- - )} -
+
+ {getToolbar(categories)} + {settingsStatus === FetchStatus.inProgress ? ( + + ) : ( + <> + {getTable()} +
{getPagination(isDisabled, true)}
+ + )} +
+ + ); }; diff --git a/src/routes/settings/settings.scss b/src/routes/settings/settings.scss deleted file mode 100644 index 41f95abea..000000000 --- a/src/routes/settings/settings.scss +++ /dev/null @@ -1,5 +0,0 @@ -.tabsOverride { - .pf-v5-c-tabs { - --pf-v5-c-tabs--before--border-width--base: 0px; - } -} diff --git a/src/routes/settings/settings.styles.ts b/src/routes/settings/settings.styles.ts index a27259da9..51b51283b 100644 --- a/src/routes/settings/settings.styles.ts +++ b/src/routes/settings/settings.styles.ts @@ -1,20 +1,15 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import type React from 'react'; export const styles = { - header: { - backgroundColor: global_BackgroundColor_light_100.var, - paddingLeft: global_spacer_lg.var, - paddingRight: global_spacer_lg.var, - paddingTop: global_spacer_lg.var, + headerContainer: { + paddingBottom: 0, }, headerContent: { display: 'flex', justifyContent: 'space-between', }, tabs: { - backgroundColor: global_BackgroundColor_light_100.var, paddingTop: global_spacer_lg.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/settings.tsx b/src/routes/settings/settings.tsx index 18d9b3af9..cf6210d9a 100644 --- a/src/routes/settings/settings.tsx +++ b/src/routes/settings/settings.tsx @@ -1,6 +1,4 @@ -import './settings.scss'; - -import { Tab, TabContent, Tabs, TabTitleText, Title, TitleSizes } from '@patternfly/react-core'; +import { PageSection, Tab, TabContent, Tabs, TabTitleText, Title, TitleSizes } from '@patternfly/react-core'; import { getUserAccessQuery } from 'api/queries/userAccessQuery'; import type { UserAccess } from 'api/userAccess'; import { UserAccessType } from 'api/userAccess'; @@ -11,8 +9,8 @@ import React, { useState } from 'react'; import { useIntl } from 'react-intl'; import { useSelector } from 'react-redux'; import { routes } from 'routes'; -import { Loading } from 'routes/components/page/loading'; import { NotAuthorized } from 'routes/components/page/notAuthorized'; +import { LoadingState } from 'routes/components/state/loadingState'; import { Calculations } from 'routes/settings/calculations'; import { CostModelsDetails } from 'routes/settings/costModels'; import { PlatformProjects } from 'routes/settings/platformProjects'; @@ -199,6 +197,7 @@ const Settings: React.FC = () => { const availableTabs = getAvailableTabs(); return ( +<<<<<<< HEAD
@@ -214,6 +213,25 @@ const Settings: React.FC = () => {
{getTabContent(availableTabs)}
.
+======= + <> + +
+
+ + {intl.formatMessage(messages.settingsTitle)} + +
+ {userAccessFetchStatus === FetchStatus.inProgress ? ( + + ) : ( +
{getTabs(availableTabs)}
+ )} +
+
+ {getTabContent(availableTabs)} + +>>>>>>> 44d19466a (PatternFly v6 milestone) ); }; diff --git a/src/routes/settings/tagLabels/tagLabels.styles.ts b/src/routes/settings/tagLabels/tagLabels.styles.ts deleted file mode 100644 index 10204ce96..000000000 --- a/src/routes/settings/tagLabels/tagLabels.styles.ts +++ /dev/null @@ -1,10 +0,0 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; -import type React from 'react'; - -export const styles = { - container: { - backgroundColor: global_BackgroundColor_light_100.var, - padding: global_spacer_lg.var, - }, -} as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/tagLabels/tagLabels.tsx b/src/routes/settings/tagLabels/tagLabels.tsx index ccec295d9..48a676230 100644 --- a/src/routes/settings/tagLabels/tagLabels.tsx +++ b/src/routes/settings/tagLabels/tagLabels.tsx @@ -1,9 +1,8 @@ -import { Accordion, AccordionContent, AccordionItem, AccordionToggle, PageSection } from '@patternfly/react-core'; +import { Accordion, AccordionContent, AccordionItem, AccordionToggle } from '@patternfly/react-core'; import messages from 'locales/messages'; import React, { useState } from 'react'; import { useIntl } from 'react-intl'; -import { styles } from './tagLabels.styles'; import TagMapping from './tagMapping/tagMapping'; import { Tags } from './tags'; @@ -80,17 +79,16 @@ const TagLabels: React.FC = ({ canWrite }) => { return availableItems.map((val, index) => { const isExpanded = activeKey === index; return ( - + { handleOnToggle(_evt, index); }} > {val.label} - {getAccordionContent(val.item, index)} + {getAccordionContent(val.item, index)} ); }); @@ -98,13 +96,7 @@ const TagLabels: React.FC = ({ canWrite }) => { const availableItems = getAvailableItems(); - return ( - -
- {getAccordionItem(availableItems)} -
-
- ); + return {getAccordionItem(availableItems)}; }; export default TagLabels; diff --git a/src/routes/settings/tagLabels/tagMapping/components/childTagMapping/childTagMapping.tsx b/src/routes/settings/tagLabels/tagMapping/components/childTagMapping/childTagMapping.tsx index 0c4c946ca..4d39cee6d 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/childTagMapping/childTagMapping.tsx +++ b/src/routes/settings/tagLabels/tagMapping/components/childTagMapping/childTagMapping.tsx @@ -1,5 +1,4 @@ -import { Alert, Button } from '@patternfly/react-core'; -import { Modal, ModalBody, ModalFooter, ModalHeader, ModalVariant } from '@patternfly/react-core/next'; +import { Alert, Button, Modal, ModalBody, ModalFooter, ModalHeader, ModalVariant } from '@patternfly/react-core'; import type { SettingsData } from 'api/settings'; import { SettingsType } from 'api/settings'; import type { AxiosError } from 'axios'; diff --git a/src/routes/settings/tagLabels/tagMapping/components/childTags/childTagsTable.styles.ts b/src/routes/settings/tagLabels/tagMapping/components/childTags/childTagsTable.styles.ts index 95218da16..6d3680746 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/childTags/childTagsTable.styles.ts +++ b/src/routes/settings/tagLabels/tagMapping/components/childTags/childTagsTable.styles.ts @@ -1,14 +1,14 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import type React from 'react'; export const styles = { loading: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, minHeight: '520px', }, pagination: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, paddingBottom: global_spacer_md.value, paddingTop: global_spacer_md.value, }, diff --git a/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMapping.scss b/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMapping.scss index 563ac152c..730d28c97 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMapping.scss +++ b/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMapping.scss @@ -1,5 +1,5 @@ .iconOverride { - .pf-v5-c-modal-box__title-icon { - color: var(--pf-v5-global--warning-color--100); + .pf-v6-c-modal-box__title-icon { + color: var(--pf-t--global--color--status--warning--default); } } diff --git a/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMapping.tsx b/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMapping.tsx index 32985f805..e7890aa4a 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMapping.tsx +++ b/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMapping.tsx @@ -1,7 +1,6 @@ import './deleteTagMapping.scss'; -import { Button } from '@patternfly/react-core'; -import { Modal, ModalBody, ModalFooter, ModalHeader, ModalVariant } from '@patternfly/react-core/next'; +import { Button, Modal, ModalBody, ModalFooter, ModalHeader, ModalVariant } from '@patternfly/react-core'; import type { SettingsData } from 'api/settings'; import type { SettingsType } from 'api/settings'; import type { AxiosError } from 'axios'; diff --git a/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMappingAction.tsx b/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMappingAction.tsx index c4e54fb0a..44b9bf315 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMappingAction.tsx +++ b/src/routes/settings/tagLabels/tagMapping/components/deleteTagMapping/deleteTagMappingAction.tsx @@ -31,14 +31,13 @@ const DeleteTagMappingAction: React.FC = ({ canWrit return getTooltip( + > ); }; diff --git a/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMapping.styles.ts b/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMapping.styles.ts index 81737fd94..ae4444d3d 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMapping.styles.ts +++ b/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMapping.styles.ts @@ -1,31 +1,31 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_FontSize_md from '@patternfly/react-tokens/dist/js/global_FontSize_md'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; +import global_font_size_md from '@patternfly/react-tokens/dist/js/global_font_size_md'; import type React from 'react'; export const styles = { alert: { - marginBottom: global_FontSize_md.value, + marginBottom: global_font_size_md.value, }, descContainer: { - marginTop: global_FontSize_md.value, + marginTop: global_font_size_md.value, }, emptyState: { - margin: global_FontSize_md.value, + margin: global_font_size_md.value, }, icon: { - margin: global_FontSize_md.value, + margin: global_font_size_md.value, }, loading: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, minHeight: '520px', }, reviewDescContainer: { - marginBottom: global_FontSize_md.value, + marginBottom: global_font_size_md.value, }, reviewTable: { marginTop: '-10px', }, spacing: { - marginRight: global_FontSize_md.value, + marginRight: global_font_size_md.value, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMapping.tsx b/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMapping.tsx index f46ced598..23977f37d 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMapping.tsx +++ b/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMapping.tsx @@ -1,6 +1,8 @@ import { Button, ButtonVariant, + Modal, + ModalVariant, Title, TitleSizes, Tooltip, @@ -8,7 +10,6 @@ import { WizardHeader, WizardStep, } from '@patternfly/react-core'; -import { Modal, ModalVariant } from '@patternfly/react-core/next'; import type { SettingsData } from 'api/settings'; import { SettingsType } from 'api/settings'; import type { AxiosError } from 'axios'; @@ -75,7 +76,7 @@ const ParentTagMapping: React.FC = ({ const getSuccessEmptyState = () => { return ( -
+
= ({ const intl = useIntl(); return ( - - - - - } - headingLevel="h5" - /> + {intl.formatMessage(messages.tagMappingWizardSuccessDesc, { learnMore: ( diff --git a/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMappingReview.tsx b/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMappingReview.tsx index 31d3fdd3a..dcb6dd4c1 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMappingReview.tsx +++ b/src/routes/settings/tagLabels/tagMapping/components/parentTagMapping/parentTagMappingReview.tsx @@ -1,16 +1,4 @@ -import { - Alert, - Stack, - StackItem, - Text, - TextContent, - TextList, - TextListItem, - TextListItemVariants, - TextListVariants, - Title, - TitleSizes, -} from '@patternfly/react-core'; +import { Alert, Content, ContentVariants, Stack, StackItem, Title, TitleSizes } from '@patternfly/react-core'; import { Table, TableVariant, Tbody, Td, Th, Thead, Tr } from '@patternfly/react-table'; import type { SettingsData } from 'api/settings'; import type { AxiosError } from 'axios'; @@ -51,34 +39,28 @@ const ParentTagMappingReview: React.FC = ({ - - + + {intl.formatMessage(messages.tagMappingWizardReviewDesc, { create: {intl.formatMessage(messages.create)}, back: {intl.formatMessage(messages.back)}, })} - - + + - - - - {intl.formatMessage(messages.tagKeyParent)} - - {parentTags.map(item => item.key)} - - {intl.formatMessage(messages.tagKeyParentSource)} - - + + + {intl.formatMessage(messages.tagKeyParent)} + {parentTags.map(item => item.key)} + {intl.formatMessage(messages.tagKeyParentSource)} + {parentTags.map(item => intl.formatMessage(messages.sourceTypes, { value: item?.source_type?.toLowerCase() }) )} - - - {intl.formatMessage(messages.tagKeyChild)} - - + + {intl.formatMessage(messages.tagKeyChild)} +
= ({
-
-
-
+ + +
diff --git a/src/routes/settings/tagLabels/tagMapping/components/parentTags/parentTagsTable.styles.ts b/src/routes/settings/tagLabels/tagMapping/components/parentTags/parentTagsTable.styles.ts index 95218da16..6d3680746 100644 --- a/src/routes/settings/tagLabels/tagMapping/components/parentTags/parentTagsTable.styles.ts +++ b/src/routes/settings/tagLabels/tagMapping/components/parentTags/parentTagsTable.styles.ts @@ -1,14 +1,14 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; import type React from 'react'; export const styles = { loading: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, minHeight: '520px', }, pagination: { - backgroundColor: global_BackgroundColor_light_100.value, + backgroundColor: global_background_color_100.value, paddingBottom: global_spacer_md.value, paddingTop: global_spacer_md.value, }, diff --git a/src/routes/settings/tagLabels/tagMapping/tagMapping.styles.ts b/src/routes/settings/tagLabels/tagMapping/tagMapping.styles.ts index fd7b8a0a8..f0cf6a466 100644 --- a/src/routes/settings/tagLabels/tagMapping/tagMapping.styles.ts +++ b/src/routes/settings/tagLabels/tagMapping/tagMapping.styles.ts @@ -1,4 +1,3 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; import global_spacer_2xl from '@patternfly/react-tokens/dist/js/global_spacer_2xl'; import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; @@ -21,9 +20,11 @@ export const styles = { emptyStateContainer: { paddingTop: global_spacer_md.value, }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, + paginationContainer: { paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, + paddingTop: global_spacer_sm.value, + }, + tableContainer: { + marginTop: global_spacer_lg.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/tagLabels/tagMapping/tagMapping.tsx b/src/routes/settings/tagLabels/tagMapping/tagMapping.tsx index 160b28076..2d45975b5 100644 --- a/src/routes/settings/tagLabels/tagMapping/tagMapping.tsx +++ b/src/routes/settings/tagLabels/tagMapping/tagMapping.tsx @@ -181,19 +181,21 @@ const TagMapping: React.FC = ({ canWrite }) => { warning: {intl.formatMessage(messages.tagMappingWarning)}, })}
- {hasMappings && getToolbar(mappings)} - {settingsStatus === FetchStatus.inProgress ? ( - - ) : hasMappings ? ( - <> - {getTable()} -
{getPagination(isDisabled, true)}
- - ) : ( -
- -
- )} +
+ {hasMappings && getToolbar(mappings)} + {settingsStatus === FetchStatus.inProgress ? ( + + ) : hasMappings ? ( + <> + {getTable()} +
{getPagination(isDisabled, true)}
+ + ) : ( +
+ +
+ )} +
); }; diff --git a/src/routes/settings/tagLabels/tagMapping/tagMappingEmptyState.tsx b/src/routes/settings/tagLabels/tagMapping/tagMappingEmptyState.tsx index c5964cb81..97c4dd66f 100644 --- a/src/routes/settings/tagLabels/tagMapping/tagMappingEmptyState.tsx +++ b/src/routes/settings/tagLabels/tagMapping/tagMappingEmptyState.tsx @@ -3,8 +3,6 @@ import { EmptyStateActions, EmptyStateBody, EmptyStateFooter, - EmptyStateHeader, - EmptyStateIcon, EmptyStateVariant, } from '@patternfly/react-core'; import { PlusCircleIcon } from '@patternfly/react-icons/dist/esm/icons/plus-circle-icon'; @@ -29,12 +27,13 @@ const TagMappingEmptyState: React.FC = ({ const intl = useIntl(); return ( - - } - headingLevel="h5" - /> + {intl.formatMessage(messages.noMappedTagsDesc, { learnMore: ( diff --git a/src/routes/settings/tagLabels/tags/tags.styles.ts b/src/routes/settings/tagLabels/tags/tags.styles.ts index 690536658..9f7dfaa75 100644 --- a/src/routes/settings/tagLabels/tags/tags.styles.ts +++ b/src/routes/settings/tagLabels/tags/tags.styles.ts @@ -1,14 +1,17 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; +import global_spacer_lg from '@patternfly/react-tokens/dist/js/global_spacer_lg'; import global_spacer_md from '@patternfly/react-tokens/dist/js/global_spacer_md'; +import global_spacer_sm from '@patternfly/react-tokens/dist/js/global_spacer_sm'; import type React from 'react'; export const styles = { action: { marginLeft: global_spacer_md.var, }, - pagination: { - backgroundColor: global_BackgroundColor_light_100.value, + paginationContainer: { paddingBottom: global_spacer_md.value, - paddingTop: global_spacer_md.value, + paddingTop: global_spacer_sm.value, + }, + tableContainer: { + marginTop: global_spacer_lg.var, }, } as { [className: string]: React.CSSProperties }; diff --git a/src/routes/settings/tagLabels/tags/tags.tsx b/src/routes/settings/tagLabels/tags/tags.tsx index 805b19d55..7650a1ad3 100644 --- a/src/routes/settings/tagLabels/tags/tags.tsx +++ b/src/routes/settings/tagLabels/tags/tags.tsx @@ -222,25 +222,25 @@ const Tags: React.FC = ({ canWrite }) => { return ( <> -
- {intl.formatMessage(messages.tagDesc, { - count: enabledTagsLimit, - learnMore: ( - - {intl.formatMessage(messages.learnMore)} - - ), - })} + {intl.formatMessage(messages.tagDesc, { + count: enabledTagsLimit, + learnMore: ( + + {intl.formatMessage(messages.learnMore)} + + ), + })} +
+ {getToolbar(tags)} + {settingsStatus === FetchStatus.inProgress ? ( + + ) : ( + <> + {getTable()} +
{getPagination(isDisabled, true)}
+ + )}
- {getToolbar(tags)} - {settingsStatus === FetchStatus.inProgress ? ( - - ) : ( - <> - {getTable()} -
{getPagination(isDisabled, true)}
- - )} ); }; diff --git a/src/store/accountSettings/accountSettingsActions.ts b/src/store/accountSettings/accountSettingsActions.ts index f0afacc48..e6c288123 100644 --- a/src/store/accountSettings/accountSettingsActions.ts +++ b/src/store/accountSettings/accountSettingsActions.ts @@ -1,5 +1,5 @@ +import { addNotification } from '@ausuliv/frontend-components-notifications/redux'; import { AlertVariant } from '@patternfly/react-core'; -import { addNotification } from '@redhat-cloud-services/frontend-components-notifications/redux'; import type { AccountSettings, AccountSettingsPayload, AccountSettingsType } from 'api/accountSettings'; import { fetchAccountSettings as apiFetchAccountSettings, diff --git a/src/store/costModels/actions.ts b/src/store/costModels/actions.ts index 642a58dab..ddb477697 100644 --- a/src/store/costModels/actions.ts +++ b/src/store/costModels/actions.ts @@ -1,5 +1,5 @@ +import { addNotification } from '@ausuliv/frontend-components-notifications/redux'; import { AlertVariant } from '@patternfly/react-core'; -import { addNotification } from '@redhat-cloud-services/frontend-components-notifications/redux'; import type { CostModel, CostModelRequest, CostModels } from 'api/costModels'; import { deleteCostModel as apiDeleteCostModel, diff --git a/src/store/export/exportActions.tsx b/src/store/export/exportActions.tsx index 12bead39d..b6c5a0ce8 100644 --- a/src/store/export/exportActions.tsx +++ b/src/store/export/exportActions.tsx @@ -1,5 +1,5 @@ +import { addNotification, removeNotification } from '@ausuliv/frontend-components-notifications/redux'; import { AlertVariant } from '@patternfly/react-core'; -import { addNotification, removeNotification } from '@redhat-cloud-services/frontend-components-notifications/redux'; import type { Export } from 'api/export/export'; import { runExport } from 'api/export/exportUtils'; import type { ReportPathsType, ReportType } from 'api/reports/report'; diff --git a/src/store/rbac/actions.ts b/src/store/rbac/actions.ts index ca49a5620..8be137236 100644 --- a/src/store/rbac/actions.ts +++ b/src/store/rbac/actions.ts @@ -1,5 +1,5 @@ +import { addNotification } from '@ausuliv/frontend-components-notifications/redux'; import { AlertVariant } from '@patternfly/react-core'; -import { addNotification } from '@redhat-cloud-services/frontend-components-notifications/redux'; import type { RBAC } from 'api/rbac'; import { getRBAC } from 'api/rbac'; import { intl } from 'components/i18n'; diff --git a/src/store/rootReducer.ts b/src/store/rootReducer.ts index 299b9991e..c41dc0ed4 100644 --- a/src/store/rootReducer.ts +++ b/src/store/rootReducer.ts @@ -1,4 +1,4 @@ -import { notificationsReducer } from '@redhat-cloud-services/frontend-components-notifications/redux'; +import { notificationsReducer } from '@ausuliv/frontend-components-notifications/redux'; import { combineReducers } from 'redux'; import { accountSettingsReducer, accountSettingsStateKey } from 'store/accountSettings'; import { awsCostOverviewReducer, awsCostOverviewStateKey } from 'store/breakdown/costOverview/awsCostOverview'; diff --git a/src/store/settings/settingsActions.ts b/src/store/settings/settingsActions.ts index 8f7609ee8..b47b2d8d9 100644 --- a/src/store/settings/settingsActions.ts +++ b/src/store/settings/settingsActions.ts @@ -1,5 +1,5 @@ +import { addNotification } from '@ausuliv/frontend-components-notifications/redux'; import { AlertVariant } from '@patternfly/react-core'; -import { addNotification } from '@redhat-cloud-services/frontend-components-notifications/redux'; import type { Settings, SettingsPayload } from 'api/settings'; import { fetchSettings as apiFetchSettings, SettingsType, updateSettings as apiUpdateSettings } from 'api/settings'; import type { AxiosError } from 'axios'; diff --git a/src/store/store.ts b/src/store/store.ts index a7bdcbf94..e6187ed45 100644 --- a/src/store/store.ts +++ b/src/store/store.ts @@ -1,4 +1,4 @@ -import { notificationsMiddleware } from '@redhat-cloud-services/frontend-components-notifications/notificationsMiddleware'; +import { notificationsMiddleware } from '@ausuliv/frontend-components-notifications/notificationsMiddleware'; import { configureStore as createStore } from '@reduxjs/toolkit'; import { axiosInstance } from 'api'; diff --git a/src/styles/global.css b/src/styles/global.css index 1eff2a250..abdef9012 100644 --- a/src/styles/global.css +++ b/src/styles/global.css @@ -8,8 +8,8 @@ body { display: flex; } -.pf-v5-l-grid > *, -.pf-v5-l-grid .pf-v5-l-grid__item { +.pf-v6-l-grid > *, +.pf-v6-l-grid .pf-v6-l-grid__item { min-height: 0; min-width: 0; } diff --git a/src/styles/revert.css b/src/styles/revert.css index 4f16bad4e..95151f85f 100644 --- a/src/styles/revert.css +++ b/src/styles/revert.css @@ -1,10 +1,10 @@ /* For testing only */ /* https://developer.mozilla.org/en-US/docs/Web/CSS/revert */ -[class*="pf-v5-c"], -[class*="pf-v5-c"] *, -[class*="pf-v5-l"], -[class*="pf-v5-l"] *, -[class*="pf-v5-u"], -[class*="pf-v5-u"] * { +[class*="pf-v6-c"], +[class*="pf-v6-c"] *, +[class*="pf-v6-l"], +[class*="pf-v6-l"] *, +[class*="pf-v6-u"], +[class*="pf-v6-u"] * { all: revert; } diff --git a/src/styles/theme.ts b/src/styles/theme.ts index 01dbc9f07..93443b09d 100644 --- a/src/styles/theme.ts +++ b/src/styles/theme.ts @@ -1,11 +1,10 @@ -import global_BackgroundColor_light_100 from '@patternfly/react-tokens/dist/js/global_BackgroundColor_light_100'; -import global_BoxShadow_sm_right from '@patternfly/react-tokens/dist/js/global_BoxShadow_sm_right'; +import global_background_color_100 from '@patternfly/react-tokens/dist/js/global_background_color_100'; +import global_box_shadow_sm_right from '@patternfly/react-tokens/dist/js/global_box_shadow_sm_right'; import global_breakpoint_lg from '@patternfly/react-tokens/dist/js/global_breakpoint_lg'; import global_breakpoint_md from '@patternfly/react-tokens/dist/js/global_breakpoint_md'; import global_breakpoint_sm from '@patternfly/react-tokens/dist/js/global_breakpoint_sm'; import global_breakpoint_xl from '@patternfly/react-tokens/dist/js/global_breakpoint_xl'; import global_breakpoint_xs from '@patternfly/react-tokens/dist/js/global_breakpoint_xs'; -import global_Color_dark_100 from '@patternfly/react-tokens/dist/js/global_Color_dark_100'; const createBreakpoint = (size: string) => `@media (min-width: ${size})`; @@ -21,9 +20,7 @@ export const theme = { breakpoints, page_breakpoint: breakpoints.md, page_masthead_height: 70, - page_sidebar_background: global_BackgroundColor_light_100.value, - page_sidebar_boxShadow: global_BoxShadow_sm_right.value, + page_sidebar_background: global_background_color_100.value, + page_sidebar_boxShadow: global_box_shadow_sm_right.value, page_sidebar_width: 300, - verticalNav_color: global_Color_dark_100.value, - verticalNav_link_color: global_Color_dark_100.value, };