diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/release/LifeCycle.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/release/LifeCycle.js
deleted file mode 100644
index 485ff30e29b..00000000000
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/release/LifeCycle.js
+++ /dev/null
@@ -1,56 +0,0 @@
-import React from "react";
-import LifeCycleGraph from "./LifeCycleGraph";
-import {connect} from "react-redux";
-import {getLifecycle, openLifecycleModal} from "../../../js/actions";
-import {Button} from "antd";
-import LifecycleModal from "./LifecycleModal";
-
-const mapDispatchToProps = dispatch => ({
- getLifecycle: () => dispatch(getLifecycle()),
- openLifecycleModal: (nextState) => dispatch(openLifecycleModal(nextState))
-});
-
-const mapStateToProps = state => {
- return {
- lifecycle: state.lifecycle,
- currentStatus : state.release.currentStatus.toUpperCase(),
- uuid : state.release.uuid
- };
-};
-
-class ConnectedLifeCycle extends React.Component {
-
- constructor(props){
- super(props);
-
- this.openModal = this.openModal.bind(this);
- }
-
- componentDidMount() {
- this.props.getLifecycle();
- }
-
- openModal() {
- this.props.openLifecycleModal("IN_REVIEW");
- }
-
- render() {
- const lifecycle = this.props.lifecycle;
- if (lifecycle != null) {
- return (
-
-
-
-
-
- );
-
- } else {
- return null;
- }
- }
-}
-
-const LifeCycle = connect(mapStateToProps, mapDispatchToProps)(ConnectedLifeCycle);
-
-export default LifeCycle;
\ 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/release/LifeCycleGraph.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/release/LifeCycleGraph.js
deleted file mode 100644
index dd22c00eb48..00000000000
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/release/LifeCycleGraph.js
+++ /dev/null
@@ -1,117 +0,0 @@
-import React from "react";
-import {Graph} from 'react-d3-graph';
-import {connect} from "react-redux";
-import {getLifecycle, openLifecycleModal} from "../../../js/actions";
-
-const mapDispatchToProps = dispatch => ({
- openLifecycleModal: (nextState) => dispatch(openLifecycleModal(nextState))
-});
-
-// the graph configuration, you only need to pass down properties
-// that you want to override, otherwise default ones will be used
-const myConfig = {
- nodeHighlightBehavior: true,
- directed: true,
- height: 400,
- d3: {
- alphaTarget: 0.05,
- gravity: -200,
- linkLength: 200,
- linkStrength: 1
- },
- node: {
- color: "#d3d3d3",
- fontColor: "black",
- fontSize: 12,
- fontWeight: "normal",
- highlightFontSize: 12,
- highlightFontWeight: "bold",
- highlightStrokeColor: "SAME",
- highlightStrokeWidth: 1.5,
- labelProperty: "id",
- mouseCursor: "pointer",
- opacity: 1,
- strokeColor: "none",
- strokeWidth: 1.5,
- svg: "",
- symbolType: "circle",
- },
- link: {
- highlightColor: 'lightblue'
- }
-};
-
-
-
-class ConnectedLifeCycleGraph extends React.Component {
-
-
- constructor(props){
- super(props);
- this.nextStates = null;
- this.onClickNode = this.onClickNode.bind(this);
- }
-
- onClickNode = function(nodeId) {
- const nextStates = this.nextStates;
- if(nextStates.includes(nodeId)){
- this.props.openLifecycleModal(nodeId);
- }
- };
-
- render() {
-// graph payload (with minimalist structure)
-
- const lifecycle = this.props.lifecycle;
- const nodes = [];
- const links = [];
- this.nextStates = lifecycle[this.props.currentStatus].proceedingStates;
-
-
- Object.keys(lifecycle).forEach((stateName) => {
- const state = lifecycle[stateName];
- let color = "rgb(83, 92, 104)";
- if (stateName === this.props.currentStatus) {
- color = "rgb(39, 174, 96)";
- } else if (this.nextStates.includes(stateName)) {
- color = "rgb(0,192,255)";
- }
- let node = {
- id: stateName,
- color: color
- };
- nodes.push(node);
-
- //todo: remove checking property
- if (state.hasOwnProperty("proceedingStates")) {
- state.proceedingStates.forEach((proceedingState) => {
- let link = {
- source: stateName,
- target: proceedingState
- };
- links.push(link);
- });
- }
- });
-
- const data = {
- nodes: nodes,
- links: links
- };
-
-
- return (
-
-
-
- );
- }
-}
-
-const LifeCycleGraph = connect(null,mapDispatchToProps)(ConnectedLifeCycleGraph);
-export default LifeCycleGraph;
\ 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/release/LifecycleModal.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/release/LifecycleModal.js
deleted file mode 100644
index df239546e3e..00000000000
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/react-app/src/components/apps/release/LifecycleModal.js
+++ /dev/null
@@ -1,111 +0,0 @@
-import React from "react";
-import {Modal, Typography, Icon, Input, Form, Checkbox, Button} from 'antd';
-import {connect} from 'react-redux';
-import {closeLifecycleModal, updateLifecycleState} from "../../../js/actions";
-
-const { TextArea } = Input;
-const { Title } = Typography;
-
-// connecting state.releaseView with the component
-const mapStateToProps = state => {
- return {
- nextState: state.lifecycleModal.nextState,
- visible: state.lifecycleModal.visible
- }
-};
-
-const mapDispatchToProps = dispatch => ({
- closeLifecycleModal : () => dispatch(closeLifecycleModal()),
- updateLifecycleState : (uuid, nextState, reason) => dispatch(updateLifecycleState(uuid, nextState, reason))
-});
-
-const Text = Typography;
-
-class ConnectedLifecycleModal extends React.Component {
- constructor(props) {
- super(props);
- this.state = {
- loading: false,
- visible: false
- };
- }
-
- componentWillReceiveProps(nextProps) {
- if (nextProps !== this.props) {
- this.setState({
- visible: nextProps.visible,
- loading: false
- })
- }
- }
-
- showModal = () => {
- this.setState({
- visible: true,
- });
- };
-
- handleOk = (e) => {
- this.setState({
- visible: false,
- });
- this.props.closeLifecycleModal();
- };
-
- handleCancel = (e) => {
- this.setState({
- visible: false,
- loading: false
- });
- this.props.closeLifecycleModal();
- };
- handleSubmit = event => {
- this.setState({ loading: true });
- event.preventDefault();
- this.props.updateLifecycleState(this.props.uuid, this.props.nextState, this.reason.state.value)
- };
-
- render() {
- if (this.props.nextState != null) {
- const nextState = this.props.nextState;
- return (
-
-
- {this.props.currentStatus} {nextState}
-
-
-
- this.reason = input}/>
-
- {/**/}
- {/**/}
- ,
-
-
-
-
- );
- } else {
- return null;
- }
- }
-}
-
-const LifecycleModal = connect(mapStateToProps, mapDispatchToProps)(ConnectedLifecycleModal);
-
-export default LifecycleModal;
\ No newline at end of file
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/package.json b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/package.json
index 6b4aba3fbd5..24acd03ce48 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/package.json
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/package.json
@@ -30,6 +30,7 @@
"react-router-dom": "latest",
"react-scripts": "2.1.8",
"react-star-ratings": "^2.3.0",
+ "react-twemoji": "^0.2.3",
"react-virtualized": "^9.21.1",
"reqwest": "^2.0.5",
"storm-react-diagrams": "^5.2.1"
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/public/conf/config.json b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/public/conf/config.json
index 642b3fdf38c..87f1691530d 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/public/conf/config.json
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/public/conf/config.json
@@ -12,7 +12,8 @@
"uri": "/ui-request-handler/invoke",
"publisher": "/application-mgt-publisher/v1.0",
"store": "/application-mgt-store/v1.0",
- "admin" : ""
+ "admin" : "",
+ "deviceMgt" : "/device-mgt/v1.0"
},
"loginUri": "/ui-request-handler/login",
"platform": "store"
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/ReleaseView.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/ReleaseView.js
index e52ddff1928..367dfd7a31f 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/ReleaseView.js
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/ReleaseView.js
@@ -22,21 +22,19 @@ class ReleaseView extends React.Component {
}
installApp = (type, payload) => {
- const {uuid} = this.props.release;
+ const release = this.props.app.applicationReleases[0];
+ const {uuid} = release;
- const parameters = {
- method: "post",
- 'content-type': "application/json",
- payload: JSON.stringify(payload),
- 'api-endpoint': "/application-mgt-store/v1.0/subscription/install/" + uuid + "/" + type + "/install"
- };
-
- const request = Object.keys(parameters).map(key => key + '=' + parameters[key]).join('&');
this.setState({
loading: true,
});
-
- axios.post(config.serverConfig.protocol + "://" + config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.store, request
+ const url = config.serverConfig.protocol + "://" + config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.store + "/subscription/install/" + uuid + "/" + type + "/install";
+ axios.post(
+ url,
+ payload,
+ {
+ headers: {'X-Platform': config.serverConfig.platform}
+ }
).then(res => {
if (res.status === 201) {
this.setState({
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/DeviceInstall.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/DeviceInstall.js
index 4f4b7be7fee..d89eba8f1cf 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/DeviceInstall.js
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/DeviceInstall.js
@@ -138,7 +138,11 @@ class DeviceInstall extends React.Component {
const request = Object.keys(parameters).map(key => key + '=' + parameters[key]).join('&');
//send request to the invoker
- axios.post(config.serverConfig.protocol + "://" + config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.store, request
+ axios.get(
+ config.serverConfig.protocol + "://"+config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.deviceMgt+"devices?" + encodedExtraParams,
+ {
+ headers: { 'X-Platform': config.serverConfig.platform }
+ }
).then(res => {
if (res.status === 200) {
const pagination = {...this.state.pagination};
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/GroupInstall.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/GroupInstall.js
index 82e2de759cb..25bf7486949 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/GroupInstall.js
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/GroupInstall.js
@@ -27,15 +27,11 @@ class GroupInstall extends React.Component {
const fetchId = this.lastFetchId;
this.setState({data: [], fetching: true});
-
- const parameters = {
- method: "get",
- 'content-type': "application/json",
- payload: "{}",
- 'api-endpoint': "/device-mgt/v1.0/admin/groups?name=" + value
- };
-
- axios.post(config.serverConfig.protocol + "://" + config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.store, request
+ axios.post(
+ config.serverConfig.protocol + "://"+config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.deviceMgt+"/groups?name=" + value,
+ {
+ headers: { 'X-Platform': config.serverConfig.platform }
+ }
).then(res => {
if (res.status === 200) {
if (fetchId !== this.lastFetchId) {
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/RoleInstall.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/RoleInstall.js
index 3f058e0825a..851d506e407 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/RoleInstall.js
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/RoleInstall.js
@@ -27,15 +27,11 @@ class RoleInstall extends React.Component {
const fetchId = this.lastFetchId;
this.setState({data: [], fetching: true});
-
- const parameters = {
- method: "get",
- 'content-type': "application/json",
- payload: "{}",
- 'api-endpoint': "/device-mgt/v1.0/roles?filter=" + value
- };
-
- axios.post(config.serverConfig.protocol + "://" + config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.store, request
+ axios.get(
+ config.serverConfig.protocol + "://"+config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.deviceMgt+"/roles?filter=" + value,
+ {
+ headers: { 'X-Platform': config.serverConfig.platform }
+ }
).then(res => {
if (res.status === 200) {
if (fetchId !== this.lastFetchId) {
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/UserInstall.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/UserInstall.js
index 57d87492424..8d38b9287f4 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/UserInstall.js
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/install/UserInstall.js
@@ -30,7 +30,7 @@ class UserInstall extends React.Component {
//send request to the invoker
axios.get(
- config.serverConfig.protocol + "://"+config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.store+"/device-mgt/v1.0/users/search?username=" + value,
+ config.serverConfig.protocol + "://"+config.serverConfig.hostname + ':' + config.serverConfig.httpsPort + config.serverConfig.invoker.uri + config.serverConfig.invoker.deviceMgt+"/users/search?username=" + value,
{
headers: { 'X-Platform': config.serverConfig.platform }
}
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/review/Reviews.css b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/review/Reviews.css
index 8678c638919..f77c5a31376 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/review/Reviews.css
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/review/Reviews.css
@@ -13,4 +13,11 @@
position: absolute;
bottom: -40px;
left: 50%;
+}
+
+img.twemoji {
+ height: 1em;
+ width: 1em;
+ margin: 0 .05em 0 .1em;
+ vertical-align: -0.1em;
}
\ No newline at end of file
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/review/SingleReview.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/review/SingleReview.js
index 3834b3ff2e3..d76bb00ed26 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/review/SingleReview.js
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.store.ui/react-app/src/components/apps/release/review/SingleReview.js
@@ -1,10 +1,12 @@
import React from "react";
import {Avatar} from "antd";
-import {List,Typography} from "antd";
+import {List, Typography} from "antd";
import StarRatings from "react-star-ratings";
+import Twemoji from "react-twemoji";
+import "./Reviews.css";
const {Text, Paragraph} = Typography;
-const colorList = ['#f0932b','#badc58','#6ab04c','#eb4d4b','#0abde3', '#9b59b6','#3498db','#22a6b3'];
+const colorList = ['#f0932b', '#badc58', '#6ab04c', '#eb4d4b', '#0abde3', '#9b59b6', '#3498db', '#22a6b3'];
class SingleReview extends React.Component {
@@ -17,13 +19,17 @@ class SingleReview extends React.Component {
{review.createdAt}
- {review.content}
+
+
+ {review.content}
+
+
);
@@ -31,7 +37,7 @@ class SingleReview extends React.Component {