diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/package.json b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/package.json
index 89be809f267..92328d98bba 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/package.json
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/package.json
@@ -26,7 +26,8 @@
"react-router-dom": "latest",
"react-scripts": "2.1.8",
"redux-thunk": "^2.3.0",
- "storm-react-diagrams": "^5.2.1"
+ "storm-react-diagrams": "^5.2.1",
+ "react-star-ratings": "^2.3.0"
},
"devDependencies": {
"@babel/core": "^7.0.0",
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/public/conf/config.json b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/public/conf/config.json
index c2e66dda140..47b11b05c19 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/public/conf/config.json
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/public/conf/config.json
@@ -9,10 +9,19 @@
"invokerUri": "/api/application-mgt-handler/v1.0/invoke",
"loginUri": "/api/application-mgt-handler/v1.0/login"
},
- "serverUrl" : "https://localhost:9443",
+ "serverUrl": "https://localhost:9443",
"defaultPlatformIcons": {
- "default": "http://www.newdesignfile.com/postpic/2015/08/square-app-icon-blue_77131.png",
- "android": "",
- "ios" : ""
+ "default": {
+ "icon": "mobile",
+ "color": "#535c68"
+ },
+ "android": {
+ "icon": "android",
+ "color": "#7db343"
+ },
+ "ios": {
+ "icon": "apple",
+ "color": "#535c68"
+ }
}
}
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/detailed-rating/DetailedRating.css b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/detailed-rating/DetailedRating.css
new file mode 100644
index 00000000000..9e7f3bc5794
--- /dev/null
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/detailed-rating/DetailedRating.css
@@ -0,0 +1,72 @@
+.d-rating .numeric-data{
+ box-sizing: border-box;
+ display: inline-block;
+ padding: 20px 0 20px 0;
+ vertical-align: top;
+ text-align: center;
+ width: 30%;
+}
+
+.d-rating .bar-containers{
+ box-sizing: border-box;
+ display: inline-block;
+ padding: 20px 20px 20px 30px;
+ vertical-align: top;
+ width: 70%;
+}
+
+.d-rating .bar-containers .bar-container{
+ color: #737373;
+ font-weight: 400;
+ height: 20px;
+ margin-bottom: 4px;
+ position: relative;
+ width: 100%;
+}
+
+.d-rating .bar-containers .bar-container .number{
+ font-size: 11px;
+ left: -16px;
+ letter-spacing: 1px;
+ position: absolute;
+}
+
+.d-rating .bar-containers .bar-container .bar{
+ transition: width .25s ease;
+ display: inline-block;
+ height: 100%;
+ opacity: .8;
+ border-radius: 5px;
+}
+
+.bar-container .rate-5{
+ background: #57bb8a;
+}
+
+.bar-container .rate-4{
+ background: #9ace6a;
+}
+
+.bar-container .rate-3{
+ background: #ffcf02;
+}
+
+.bar-container .rate-2{
+ background: #ff9f02;
+}
+
+.bar-container .rate-1{
+ background: #ff6f31;
+}
+
+.d-rating .numeric-data .rate{
+ color: #333;
+ font-size: 64px;
+ font-weight: 100;
+ line-height: 64px;
+ padding-bottom: 6px;
+}
+
+.d-rating .numeric-data .people-count{
+ padding-top: 6px;
+}
\ No newline at end of file
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/detailed-rating/DetailedRating.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/detailed-rating/DetailedRating.js
new file mode 100644
index 00000000000..5d764c99ea1
--- /dev/null
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/detailed-rating/DetailedRating.js
@@ -0,0 +1,122 @@
+import React from "react";
+import {Row, Typography, Icon} from "antd";
+import StarRatings from "react-star-ratings";
+import "./DetailedRating.css";
+import config from "../../../../public/conf/config.json";
+import axios from "axios";
+
+const { Text } = Typography;
+
+
+class DetailedRating extends React.Component{
+
+ constructor(props){
+ super(props);
+ this.state={
+ detailedRating: null
+ }
+ }
+
+ componentDidMount() {
+ this.getData(this.props.uuid);
+ }
+
+ componentDidUpdate(nextProps) {
+ if (nextProps !== this.props) {
+ this.getData(this.props.uuid);
+ }
+ }
+
+ getData = (uuid)=>{
+ const request = "method=get&content-type=application/json&payload={}&api-endpoint=/application-mgt-store/v1.0/reviews/"+uuid+"/rating";
+
+ return axios.post('https://' + config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invokerUri, request
+ ).then(res => {
+ if (res.status === 200) {
+ let detailedRating = res.data.data;
+ this.setState({
+ detailedRating
+ })
+ }
+
+ }).catch(function (error) {
+ if (error.response.status === 401) {
+ window.location.href = 'https://localhost:9443/store/login';
+ }
+ });
+ };
+
+ render() {
+ const detailedRating = this.state.detailedRating;
+
+ console.log(detailedRating);
+
+ if(detailedRating ==null){
+ return null;
+ }
+
+ const totalCount = detailedRating.noOfUsers;
+ const ratingVariety = detailedRating.ratingVariety;
+
+ const ratingArray = [];
+
+ for (let [key, value] of Object.entries(ratingVariety)) {
+ ratingArray.push(value);
+ }
+
+ const maximumRating = Math.max(...ratingArray);
+
+ const ratingBarPercentages = [0,0,0,0,0];
+
+ if(maximumRating>0){
+ for(let i = 0; i<5; i++){
+ ratingBarPercentages[i] = (ratingVariety[(i+1).toString()])/maximumRating*100;
+ }
+ }
+
+ console.log(ratingBarPercentages);
+
+ return (
+
+