-
-
-
-
-
-
-
-
-
-
-
- {this.state.platforms.length > 0 ? this.state.platforms.map(platform => {
- return (
-
- )
- }) : }
-
-
+
);
}
}
-Step1.propTypes = {
+Step1.prototypes = {
handleNext: PropTypes.func,
+ handlePrev: PropTypes.func,
setData: PropTypes.func,
removeData: PropTypes.func
};
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Create/CreateSteps/Step2.jsx b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Create/CreateSteps/Step2.jsx
index ad024b18295..31e26693fad 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Create/CreateSteps/Step2.jsx
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Create/CreateSteps/Step2.jsx
@@ -18,299 +18,148 @@
import PropTypes from 'prop-types';
import React, {Component} from 'react';
-import {Badge, FormGroup, Input, Label} from 'reactstrap';
+import AuthHandler from "../../../../api/authHandler";
+import PlatformMgtApi from "../../../../api/platformMgtApi";
+import {FormGroup, Input, Label} from 'reactstrap';
/**
- * The Second step of application create wizard.
- * This contains following components.
- * * App Title
- * * Short Description
- * * Application Description
- * * Application Visibility
- * * Application Tags : {Used Material UI Chip component}
- * * Application Category.
- * * Platform Specific properties.
+ * The first step of the application creation wizard.
+ * This contains following components:
+ * * Application Title
+ * * Store Type
+ * * Application Platform
*
* Parent Component: Create
* Props:
- * * handleNext : {type: function, Invokes handleNext function in Parent.}
- * * handlePrev : {type: function, Invokes handlePrev function in Parent}
- * * setData : {type: function, Invokes setStepData function in Parent}
- * * removeData : {type: Invokes removeStepData function in Parent}
+ * 1. handleNext: {type: function, Invokes handleNext function of parent component}
+ * 2. setData : {type: function, Sets current form data to the state of the parent component}
+ * 3. removeData: {type: function, Invokes the removeStepData function click of parent}
* */
class Step2 extends Component {
constructor() {
super();
+ this.setPlatforms = this.setPlatforms.bind(this);
+ this.setStepData = this.setStepData.bind(this);
+ this.cancel = this.cancel.bind(this);
+ this.platforms = [];
this.state = {
- tags: [],
- icon: [],
+ finished: false,
+ stepIndex: 0,
+ store: 1,
+ platformSelectedIndex: 0,
+ platform: "",
+ platforms: [],
+ stepData: [],
title: "",
- errors: {},
- banner: [],
- defValue: "",
- category: 0,
- visibility: 0,
- description: "",
- screenshots: [],
- identifier: "",
- shortDescription: ""
+ titleError: ""
};
- this.scriptId = "application-create-step2";
+ this.scriptId = "application-create-step1";
}
- /**
- * Create a tag on Enter key press and set it to the state.
- * Clears the tags text field.
- * Chip gets two parameters: Key and value.
- * */
- addTags(event) {
- let tags = this.state.tags;
- if (event.charCode === 13) {
- event.preventDefault();
- tags.push({key: Math.floor(Math.random() * 1000), value: event.target.value});
- this.setState({tags, defValue: ""}, console.log(tags));
- }
+ componentDidMount() {
+ //Get the list of available platforms and set to the state.
+ PlatformMgtApi.getPlatforms().then(response => {
+ console.log(response);
+ this.setPlatforms(response.data);
+ }).catch(err => {
+ AuthHandler.unauthorizedErrorHandler(err);
+ })
}
/**
- * Set the value for tag.
+ * Extract the platforms from the response data and populate the state.
+ * @param platforms: The array returned as the response.
* */
- handleTagChange(event) {
- let defaultValue = this.state.defValue;
- defaultValue = event.target.value;
- this.setState({defValue: defaultValue})
- }
-
- /**
- * Invokes the handleNext function in Create component.
- * */
- handleNext() {
- let fields = [{name: "Title", value: this.state.title},
- {name: "Short Description", value: this.state.shortDescription},
- {name: "Description", value: this.state.description},
- {name: "Banner", value: this.state.banner},
- {name: "Screenshots", value: this.state.screenshots},
- {name: "Identifier", value: this.state.identifier},
- {name: "Icon", value: this.state.icon}];
- this.validate(fields);
+ setPlatforms(platforms) {
+ let tmpPlatforms = [];
+ for (let index in platforms) {
+ let platform = {};
+ platform = platforms[index];
+ tmpPlatforms.push(platform);
+ }
+ this.setState({platforms: tmpPlatforms, platformSelectedIndex: 0, platform: tmpPlatforms[0].name})
}
/**
- * Invokes the handlePrev function in Create component.
+ * Persist the current form data to the state.
* */
- handlePrev() {
- this.props.handlePrev();
+ setStepData() {
+ console.log("Platforms", this.state.platforms);
+ let step = {
+ store: this.state.store,
+ platform: this.state.platforms[this.state.platformSelectedIndex]
+ };
+ console.log(step);
+ this.props.setData("step1", {step: step});
}
- /**
- * Handles Chip delete function.
- * Removes the tag from state.tags
- * */
- handleRequestDelete(event) {
- this.chipData = this.state.tags;
- console.log(event.target);
- const chipToDelete = this.chipData.map((chip) => chip.value).indexOf(event.target.value);
- this.chipData.splice(chipToDelete, 1);
- this.setState({tags: this.chipData});
- };
-
- /**
- * Validate the form.
- * */
- validate(fields) {
- let errors = {};
- let errorsPresent = false;
- fields.forEach(function (field) {
- switch (field.name) {
- case 'Title': {
- if (field.value === "") {
- errors[field.name] = field.name + " is required!";
- errorsPresent = true;
- } else {
- errorsPresent = false;
- }
- break;
- }
- case 'Identifier': {
- if (field.value === "") {
- errors[field.name] = field.name + " is required!";
- errorsPresent = true;
- } else {
- errorsPresent = false;
- }
- break;
- }
- case 'Short Description': {
- if (field.value === "") {
- errors[field.name] = field.name + " is required!";
- errorsPresent = true;
- } else {
- errorsPresent = false;
- }
- break;
- }
- case 'Description': {
- if (field.value === "") {
- errors[field.name] = field.name + " is required!";
- errorsPresent = true;
- } else {
- errorsPresent = false;
- }
- break;
- }
- case 'Banner': {
- if (field.value.length === 0) {
- errors[field.name] = field.name + " is required!";
- errorsPresent = true;
- } else {
- errorsPresent = false;
- }
- break;
- }
- case 'Icon': {
- if (field.value.length === 0) {
- errors[field.name] = field.name + " is required!";
- errorsPresent = true;
- } else {
- errorsPresent = false;
- }
- break;
- }
- case 'Screenshots': {
- if (field.value.length < 3) {
- errors[field.name] = "3 " + field.name + " are required!";
- errorsPresent = true;
- } else {
- errorsPresent = false;
- }
- break;
- }
- }
- });
+ cancel() {
- if (!errorsPresent) {
- this.setStepData();
- } else {
- this.setState({errors: errors}, console.log(errors));
- }
}
/**
- * Creates an object with the current step data and persist in the parent.
+ * Triggers when changing the Platform selection.
* */
- setStepData() {
- let stepData = {};
+ onChangePlatform(event) {
+ console.log(event.target.value, this.state.platforms);
+ let id = event.target.value;
+ let selectedPlatform = this.state.platforms.filter((platform) => {
+ return platform.identifier === id;
+ });
+ console.log(selectedPlatform);
- this.props.setData("step2", {step: stepData});
+ this.setState({platform: selectedPlatform});
};
/**
- * Set text field values to state.
+ * Triggers when changing the Store selection.
* */
- onTextFieldChange(event, value) {
- let field = event.target.id;
- switch (field) {
- case "name": {
- this.setState({name: value});
- break;
- }
- case "shortDescription": {
- this.setState({shortDescription: value});
- break;
- }
- case "description": {
- this.setState({description: value});
- break;
- }
- case "identifier": {
- this.setState({identifier: value});
- break;
- }
- }
+ onChangeStore(event) {
+ console.log(event.target.value);
+ this.setState({store: event.target.value});
};
render() {
- console.log(this.state.visibilityComponent);
return (
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+ {this.state.platforms.length > 0 ? this.state.platforms.map(platform => {
+ return (
+
+ )
+ }) : }
+
+
);
}
}
-Step2.prototypes = {
+Step2.propTypes = {
handleNext: PropTypes.func,
- handlePrev: PropTypes.func,
setData: PropTypes.func,
removeData: PropTypes.func
};
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Create/CreateSteps/Step3.jsx b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Create/CreateSteps/Step3.jsx
index e60a9d4e935..124844c739c 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Create/CreateSteps/Step3.jsx
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Create/CreateSteps/Step3.jsx
@@ -25,7 +25,6 @@ import SelectField from 'material-ui/SelectField';
import {FormGroup, Label} from 'reactstrap';
import AppImage from "../../../UIComponents/AppImage/AppImage";
-
/**
* The Third step of application create wizard.
* This contains following components.
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/Base/ApplicationEditBaseLayout.jsx b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/Base/ApplicationEditBaseLayout.jsx
index 731b23ef107..aba70453beb 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/Base/ApplicationEditBaseLayout.jsx
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/Base/ApplicationEditBaseLayout.jsx
@@ -19,7 +19,7 @@
import './baseLayout.css';
import {Col, Row} from "reactstrap";
import React, {Component} from 'react';
-import GeneralInfo from "../GeneralInfo";
+import GeneralInfo from "../GenenralInfo/GeneralInfo";
import ReleaseManager from '../../Release/ReleaseMgtBase/ReleaseManager';
class ApplicationEdit extends Component {
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/Base/baseLayout.css b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/Base/baseLayout.css
index 0c5b460a9d5..a93f84a9b22 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/Base/baseLayout.css
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/Base/baseLayout.css
@@ -22,6 +22,7 @@
width: 100%;
margin: 0;
font-size: 20px;
+ border-bottom: solid 1px #d8d8d8;
}
.application-header-text {
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/GeneralInfo.jsx b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/GenenralInfo/GeneralInfo.jsx
similarity index 100%
rename from components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/GeneralInfo.jsx
rename to components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/GenenralInfo/GeneralInfo.jsx
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/generalInfo.css b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/GenenralInfo/generalInfo.css
similarity index 100%
rename from components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/generalInfo.css
rename to components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/Application/Edit/GenenralInfo/generalInfo.css
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/UIComponents/Drawer/drawer.css b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/UIComponents/Drawer/drawer.css
index aa7e71f8563..eea79c5b694 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/UIComponents/Drawer/drawer.css
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/UIComponents/Drawer/drawer.css
@@ -21,7 +21,7 @@
width: 0; /* 0 width - change this with JavaScript */
position: fixed; /* Stay in place */
z-index: 1; /* Stay on top */
- top: 5%;
+ top: 8%;
right: 0%;
background-color: #ffffff;
overflow-x: hidden; /* Disable horizontal scroll */
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/UIComponents/FloatingButton/floatingButton.css b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/UIComponents/FloatingButton/floatingButton.css
index a4257ac2cda..5cc8756320f 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/UIComponents/FloatingButton/floatingButton.css
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/components/UIComponents/FloatingButton/floatingButton.css
@@ -42,6 +42,7 @@
.btn-circle:hover {
cursor: pointer;
+ background-color: rgb(255, 93, 2);
}
.primary {
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/index.css b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/index.css
index 7e4a275863c..f8673ceb90d 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/index.css
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/src/index.css
@@ -18,7 +18,7 @@
body {
width: 100%;
- font-family: sans-serif;
+ font-family: Roboto sans-serif;
}
#userName {
@@ -48,10 +48,11 @@ body {
#container {
background-color: #ffffff;
+ padding: 0;
}
#header-content {
- height: 100px;
+ height: 125px;
width: 100%;
margin: 0 10px 0 0;
background-color: #3b33bd;
@@ -61,6 +62,12 @@ body {
box-shadow: -2px 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}
+#header {
+ margin: 16px 16px 20px 16px;
+ height: 100%;
+ position: relative;
+}
+
#application-content {
height: auto;
width: 80%;
@@ -69,24 +76,14 @@ body {
padding: 10px 10px 10px 10px;
}
-.add-btn {
+#add-btn-container {
position: absolute;
- left:12%;
- top: 35px;
-}
-
-.add-btn.div {
- position: relative;
- margin-top: 20px;
- margin-left: 20px;
-}
-
-#fw-api:before {
- content: '\e601';
+ left: 12%;
+ top: 100px;
}
.btn-header {
- margin-top: 10px;
+ margin-top: 15px;
margin-right: 20px;
color: white;
}
@@ -113,8 +110,9 @@ body {
color: #a8a8a8;
position: relative;
float: right;
- top: 35px;
- margin-right: 10px;
+ top: 75px;
+ left: 80px;
+ margin-right: 16px;
}
#search {
@@ -175,7 +173,6 @@ body {
margin: 70px 40px 40px 150px;
}
-
.applicationCreateScreenshotDropZone {
width: 150px;
height: 150px;
diff --git a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/webpack.config.js b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/webpack.config.js
index 2cd24bd2ac9..2437370729e 100644
--- a/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/webpack.config.js
+++ b/components/application-mgt/org.wso2.carbon.device.application.mgt.publisher.ui/src/main/resources/publisher/webpack.config.js
@@ -48,6 +48,10 @@ const config = {
test: /\.css$/,
use: [ 'style-loader', 'css-loader' ]
},
+ {
+ test: /\.scss$/,
+ use: [ 'style-loader', 'scss-loader' ]
+ },
{
test: /\.less$/,
use: [{