<link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" rel="stylesheet" id="bootstrap-css">
<script src="//netdna.bootstrapcdn.com/bootstrap/3.0.0/js/bootstrap.min.js"></script>
<script src="//code.jquery.com/jquery-1.11.1.min.js"></script>
<!------ Include the above in your HEAD tag ---------->
<!DOCTYPE html><html lang='en' class=''>
<head><script src='//production-assets.codepen.io/assets/editor/live/console_runner-079c09a0e3b9ff743e39ee2d5637b9216b3545af0de366d4b9aad9dc87e26bfd.js'></script><script src='//production-assets.codepen.io/assets/editor/live/events_runner-73716630c22bbc8cff4bd0f07b135f00a0bdc5d14629260c3ec49e5606f98fdd.js'></script><script src='//production-assets.codepen.io/assets/editor/live/css_live_reload_init-2c0dc5167d60a5af3ee189d570b1835129687ea2a61bee3513dee3a50c115a77.js'></script><meta charset='UTF-8'><meta name="robots" content="noindex"><link rel="shortcut icon" type="image/x-icon" href="//production-assets.codepen.io/assets/favicon/favicon-8ea04875e70c4b0bb41da869e81236e54394d63638a1ef12fa558a4a835f1164.ico" /><link rel="mask-icon" type="" href="//production-assets.codepen.io/assets/favicon/logo-pin-f2d2b6d2c61838f7e76325261b7195c27224080bc099486ddd6dccb469b8e8e6.svg" color="#111" /><link rel="canonical" href="https://codepen.io/kharrop/pen/ZOwOgL?limit=all&page=15&q=app" />
<link rel='stylesheet prefetch' href='https://maxcdn.bootstrapcdn.com/font-awesome/4.5.0/css/font-awesome.min.css'><link rel='stylesheet prefetch' href='//netdna.bootstrapcdn.com/bootstrap/3.1.1/css/bootstrap.min.css'>
<style class="cp-pen-styles">@import url(https://fonts.googleapis.com/css?family=Lato:400,300,700);
@import url(https://fonts.googleapis.com/css?family=Lato:400,300,700);
body {
  -webkit-text-size-adjust: 100%;
  font-family: 'Lato', sans-serif;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
input {
  -webkit-appearance: none;
}
*, *:after, *:before {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0;
  padding: 0;
}
a {
  text-decoration: none;
}
.pen-description {
  margin: 60px 0;
  text-align: center;
}
.pen-description .summary {
  margin-bottom: 10px;
}
.pen-description .note {
  color: #555;
  font-size: .85rem;
}
html, body {
  min-height: 100%;
}
html {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: initial;
}
/* boostrap overrides */
a, a:hover, a:visited {
  text-decoration: none;
}
p {
  margin: 0;
}
label {
  display: initial;
}
/*******************/
body {
  background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjEuMCIgeDI9IjEuMCIgeTI9IjAuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzIyNmE5NiIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iIzk5ZDVlOCIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA==');
  background-size: 100%;
  background-image: -webkit-gradient(linear, left bottom, right top, from(#226a96), to(#99d5e8));
  background-image: linear-gradient(to right top, #226a96 0%, #99d5e8 100%);
  font-family: 'Lato';
  background-color: #eee;
  color: #555;
  min-width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-perspective: 8000px;
          perspective: 8000px;
}
* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0;
  padding: 0;
}
#app {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
ul {
  list-style: none;
  margin: auto;
  padding: 0;
}
.card-container {
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
}
li {
  cursor: -webkit-grab;
  cursor: grab;
  position: relative;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  float: left;
}
li[draggable=false] {
  cursor: default;
}
li[draggable=false] figure.front,
li[draggable=false] figure.back {
  -webkit-box-shadow: none;
          box-shadow: none;
}
li .card-container {
  pointer-events: none;
}
li input[type="text"],
li input[type="number"] {
  border: 0 none;
  border-bottom: 1px solid #eee;
  pointer-events: initial;
  width: 100%;
  height: 40px;
  margin-bottom: 20px;
  outline: 0 none;
  font-size: 1rem;
  -webkit-transition: border-bottom 0.2s ease-in-out;
  transition: border-bottom 0.2s ease-in-out;
}
li input[type="text"]:focus,
li input[type="number"]:focus {
  border-bottom: 1px solid #3a8bbb;
}
li.placeholder {
  background: rgba(255, 255, 255, 0.2);
  height: 494px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 330px;
  border-radius: 5px;
}
.modal {
  overflow-y: auto;
}
.modal-dialog {
  width: 400px;
}
.modal .fund-container {
  border: 1px solid #ddd;
  border-radius: 3px;
  height: 40px;
  margin-left: 5px;
  margin-top: 20px;
  margin-bottom: 10px;
  padding: 10px 0;
  width: 125px;
  text-align: right;
}
.modal label {
  display: inline-block;
  width: 48%;
}
.modal .data {
  width: 50%;
  text-align: right;
  margin-left: 5px;
  display: inline-block;
}
.modal .smallprint {
  font-size: .7rem;
  text-align: right;
}
.modal .pre-money {
  opacity: .7;
}
h1, h2, h3, h4, h5 {
  margin: 0;
}
.modal-container {
  position: relative;
}
.modal-container .modal, .modal-container .modal-backdrop {
  position: absolute;
}
button {
  pointer-events: initial;
}
.card-title {
  text-align: center;
  margin-bottom: 20px;
  font-size: 1rem;
}
.back-arrow {
  pointer-events: initial;
  display: table;
  position: absolute;
  padding: 20px;
  margin: -20px;
  font-size: 1.2rem;
}
.back-arrow:hover .fa {
  color: #777777;
}
.edit-money {
  display: table;
  position: absolute;
  margin-top: 10px;
  opacity: .7;
}
.edit-money + input {
  padding-left: 15px;
}
.delete {
  color: #777;
  pointer-events: initial;
  text-align: center;
  font-size: .8rem;
  margin: 0 auto;
  margin-top: 10px;
  padding: 10px;
  display: table;
  -webkit-transition: color 0.2s ease-in-out;
  transition: color 0.2s ease-in-out;
}
.delete:hover {
  color: #e54b4b;
}
figure {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
figure.front {
  background: #fff;
  -webkit-transform: rotateY(0deg);
          transform: rotateY(0deg);
  overflow: hidden;
  pointer-events: intial;
  border-radius: 5px;
  padding: 20px;
  margin: 10px;
  width: 330px;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  -webkit-box-shadow: 0 10px 20px 0 rgba(13, 59, 86, 0.5);
          box-shadow: 0 10px 20px 0 rgba(13, 59, 86, 0.5);
}
figure.back {
  background-color: #fff;
  -webkit-transform: rotateY(180deg);
          transform: rotateY(180deg);
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: absolute;
  left: 0;
  margin: 10px;
  margin-top: 0;
  padding: 20px;
  width: 330px;
  height: 100%;
  top: 0;
  border-radius: 5px;
  opacity: 0;
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out;
}
figure .input-container {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.flipped figure.back {
  opacity: 1;
}
.flipped {
  transform: rotateY(180deg);
  -webkit-transform: rotateY(180deg);
}
.goal__name {
  color: #777;
  font-size: .75rem;
  text-align: center;
  width: 80%;
  margin: 10px auto;
  text-transform: uppercase;
  letter-spacing: 3px;
}
.goal--progress {
  color: #222;
  font-size: 1.7rem;
  margin-bottom: 10px;
  text-align: center;
}
.goal--remain {
  color: #222;
}
.goal--amount {
  color: #777;
  font-size: .8rem;
  text-align: center;
}
.goal--top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  height: 375px;
}
.goal--top__container {
  margin: auto;
  position: relative;
}
.edit {
  pointer-events: initial;
  padding: 20px;
  position: absolute;
  right: 0;
  margin: -20px;
  top: 0;
  margin-top: -13px;
}
.edit:hover .fa {
  color: #777777;
}
.edit .fa {
  font-size: 1.2rem;
}
.money:before {
  content: "$";
}
.right {
  float: right;
  margin-left: 5px;
}
.percent {
  color: #777;
}
.descriptor {
  font-size: .8rem;
  margin-bottom: 20px;
}
.dropdown-wrapper {
  margin-top: 10px;
  pointer-events: initial;
  border: 1px solid #eee;
  border-radius: 5px;
  position: relative;
  cursor: pointer;
  width: 100%;
  -webkit-transition: border 0.2s ease-in-out;
  transition: border 0.2s ease-in-out;
}
.dropdown-wrapper:hover {
  border: 1px solid #d5d5d5;
}
.dropdown-wrapper:after {
  font-family: 'FontAwesome';
  content: "\f107";
  color: #3FB8AF;
  position: absolute;
  right: 10px;
  top: 7px;
}
.dropdown-wrapper.outline {
  border: 1px solid rgba(63, 184, 175, 0.5);
  -webkit-box-shadow: 0 0 10px rgba(63, 184, 175, 0.2);
          box-shadow: 0 0 10px rgba(63, 184, 175, 0.2);
}
select {
  cursor: pointer;
  pointer-events: initial;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: 0 none;
  font-size: .8em;
  padding: 10px;
  outline: 0;
  width: 100%;
  display: block;
}
.button {
  background: #3a8bbb;
  border: 0 none;
  color: #fff;
  margin-bottom: auto;
  cursor: pointer;
  border-radius: 5px;
  pointer-events: initial;
  height: 44px;
  text-transform: uppercase;
  text-align: center;
  font-size: .7rem;
  letter-spacing: 2px;
  padding: 15px;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  width: 100%;
}
.button:hover {
  background: #347da8;
}
.fa {
  font-family: 'FontAwesome';
  display: block;
  text-align: center;
}
.fa.category {
  left: 0;
  right: 0;
  top: -40px;
  margin: auto;
  position: absolute;
}
.fa.fa-plane {
  color: #3FB8AF;
}
.fa.fa-car {
  color: #e54b4b;
}
.fa.fa-pencil-square-o, .fa.fa-angle-left {
  color: #aaa;
  -webkit-transition: color 0.2s ease-in-out;
  transition: color 0.2s ease-in-out;
}
/** svg **/
.svg-container {
  display: inline-block;
  position: relative;
  width: 100%;
  height: 100%;
  vertical-align: middle;
  overflow: hidden;
}
.svg-content {
  display: inline-block;
  margin: 0 auto;
  margin-top: 20px;
  width: 100%;
}
.animated {
  -webkit-animation: dash 1s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
          animation: dash 1s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
}
.box {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  position: absolute;
  left: 0;
  right: 0;
}
svg {
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}
text {
  text-anchor: middle;
}
circle {
  stroke-linecap: round;
}
.shadow {
  opacity: .6;
}
@-webkit-keyframes dash {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes dash {
  to {
    stroke-dashoffset: 0;
  }
}
</style></head><body>
<div id="app"></div>
<script src='//production-assets.codepen.io/assets/common/stopExecutionOnTimeout-b2a7b3fe212eaa732349046d8416e00a9dec26eb7fd347590fbced3ab38af52e.js'></script><script src='https://fb.me/react-with-addons-15.0.0.min.js'></script><script src='https://npmcdn.com/react-dom@15.3.0/dist/react-dom.min.js'></script><script src='https://cdnjs.cloudflare.com/ajax/libs/react-bootstrap/0.29.5/react-bootstrap.min.js'></script><script src='https://npmcdn.com/react-dnd@2.1.4/dist/ReactDnD.js'></script><script src='https://npmcdn.com/react-dnd-html5-backend@2.1.2/dist/ReactDnDHTML5Backend.min.js'></script>
<script >//var ReactCSSTransitionGroup = React.addons.CSSTransitionGroup;
'use strict';
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) {if (window.CP.shouldStopExecution(1)){break;}if (window.CP.shouldStopExecution(1)){break;} var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); }
window.CP.exitedLoop(1);
window.CP.exitedLoop(1);
 } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var placeholder = document.createElement("li");
placeholder.className = "placeholder";
var Button = ReactBootstrap.Button;
var Modal = ReactBootstrap.Modal;
var OverlayTrigger = ReactBootstrap.OverlayTrigger;
var Pie = function (_React$Component) {
	_inherits(Pie, _React$Component);
	function Pie() {
		_classCallCheck(this, Pie);
		return _possibleConstructorReturn(this, (Pie.__proto__ || Object.getPrototypeOf(Pie)).apply(this, arguments));
	}
	_createClass(Pie, [{
		key: "render",
		value: function render() {
			var _props = this.props,
			    color = _props.color,
			    width = _props.width,
			    progress = _props.progress;
			var pi = 3.14159265359;
			var r = 400 / 2;
			var c = 2 * pi * r;
			var realProgress = c * progress;
			return React.createElement(
				"div",
				{ className: "svg-container" },
				React.createElement(
					"div",
					{
						className: "svg-content"
					},
					React.createElement(
						"svg",
						{
							viewBox: "0 0 500 500",
							preserveAspectRatio: "xMinYMin meet"
						},
						React.createElement(
							"filter",
							{ id: "shadow" },
							React.createElement("feGaussianBlur", { "in": "SourceGraphic", stdDeviation: "15" }),
							React.createElement("feOffset", { dx: "-5", dy: "-4" })
						),
						React.createElement("circle", {
							className: "animated",
							cx: "250",
							cy: "250",
							r: "200",
							stroke: "",
							fillOpacity: "0",
							strokeWidth: width + 10,
							strokeDasharray: [realProgress, c],
							strokeDashoffset: c * progress
						}),
						React.createElement("circle", {
							filter: "url(#shadow)",
							className: "animated shadow",
							cx: "250",
							cy: "250",
							r: "200",
							stroke: color,
							fillOpacity: "0",
							strokeWidth: width,
							strokeDasharray: [realProgress, c],
							strokeDashoffset: c * progress
						}),
						React.createElement("circle", {
							className: "animated fill",
							cx: "250",
							cy: "250",
							r: "200",
							stroke: color,
							fillOpacity: "0",
							strokeWidth: width,
							strokeDasharray: [realProgress, c],
							strokeDashoffset: c * progress
						}),
						React.createElement("circle", {
							cx: "250",
							cy: "250",
							r: "200",
							stroke: color,
							fillOpacity: "0",
							strokeWidth: "5",
							strokeDasharray: [c, c],
							strokeOpacity: "0.1"
						})
					)
				)
			);
		}
	}]);
	return Pie;
}(React.Component);
var Application = function (_React$Component2) {
	_inherits(Application, _React$Component2);
	function Application() {
		_classCallCheck(this, Application);
		return _possibleConstructorReturn(this, (Application.__proto__ || Object.getPrototypeOf(Application)).apply(this, arguments));
	}
	_createClass(Application, [{
		key: "render",
		value: function render() {
			var percent = this.props.percent;
			var colorChart = this.props.colorChart;
			return React.createElement(
				"div",
				null,
				React.createElement(
					"div",
					{ className: "box" },
					React.createElement(Pie, {
						color: colorChart,
						width: 15,
						progress: percent
					})
				)
			);
		}
	}]);
	return Application;
}(React.Component);
var progressUpdate;
var goals = [{
	category: 'car',
	name: 'Car',
	amount: 20000,
	progress: 6593,
	flipped: false,
	dragStatus: true
}, {
	category: 'plane',
	name: 'Vacation',
	amount: 3500,
	progress: 2984,
	flipped: false,
	dragStatus: true
}];
var dragStatus = true;
var GoalCard = function (_React$Component3) {
	_inherits(GoalCard, _React$Component3);
	function GoalCard(props) {
		_classCallCheck(this, GoalCard);
		var _this3 = _possibleConstructorReturn(this, (GoalCard.__proto__ || Object.getPrototypeOf(GoalCard)).call(this, props));
		_this3.state = { condition: false,
			progress: _this3.props.item.progress,
			input1: _this3.props.item.name,
			input2: _this3.props.item.amount,
			input3: _this3.props.item.progress,
			selectValue: _this3.props.item.category
		};
		return _this3;
	}
	_createClass(GoalCard, [{
		key: "addMoney",
		value: function addMoney() {
			var addFunds = prompt('Add funds for: ' + this.props.item.name, "0");
			this.props.item.progress += Number(addFunds);
			this.setState({
				item: this.props.item
			});
		}
	}, {
		key: "onSave",
		value: function onSave() {
			this.props.item.progress = progressUpdate;
			this.setState({
				item: this.props.item
			});
		}
	}, {
		key: "editGoal",
		value: function editGoal(index) {
			this.props.onFlip(index);
			this.setState({
				condition: !this.state.condition,
				input1: this.props.item.name,
				input2: this.props.item.amount,
				input3: this.props.item.progress,
				selectValue: this.props.item.category
			});
		}
	}, {
		key: "deleteGoal",
		value: function deleteGoal(index) {
			this.props.onDelete(index);
			this.setState({ condition: !this.state.condition,
				input1: this.props.item.name,
				input2: this.props.item.amount,
				input3: this.props.item.progress,
				selectValue: this.props.item.category,
				flipped: false,
				dragStatus: true
			});
		}
	}, {
		key: "cancelEdit",
		value: function cancelEdit(index) {
			this.props.onFlip(index);
			this.setState({ condition: !this.state.condition,
				input1: this.props.item.name,
				input2: this.props.item.amount,
				input3: this.props.item.progress,
				selectValue: this.props.item.category });
		}
	}, {
		key: "saveGoal",
		value: function saveGoal(index) {
			this.props.onFlip(index);
			this.setState({ condition: !this.state.condition });
			this.props.item.name = this.state.input1;
			this.props.item.amount = Number(this.state.input2);
			this.props.item.progress = Number(this.state.input3);
			this.props.item.category = this.state.selectValue;
		}
	}, {
		key: "handleChange",
		value: function handleChange(name, e) {
			var change = {};
			change[name] = e.target.value;
			this.setState(change);
		}
	}, {
		key: "handleDropdown",
		value: function handleDropdown(e) {
			this.setState({ selectValue: e.target.value });
		}
	}, {
		key: "render",
		value: function render() {
			var message;
			var strokeColor;
			var status;
			var remaining;
			var percentRemaining;
			if (this.props.item.progress / this.props.item.amount < 1) {
				strokeColor = "#01579B";
				status = "Remaining";
				remaining = (this.props.item.amount - this.props.item.progress).toLocaleString();
				percentRemaining = "(" + ((this.props.item.amount - this.props.item.progress) / this.props.item.amount * 100).toFixed(0) + "%)";
			} else {
				strokeColor = "#7dbf69";
				status = "Exceeded";
				remaining = Math.abs(this.props.item.amount - this.props.item.progress).toLocaleString();
				percentRemaining = "(" + Math.abs((this.props.item.amount - this.props.item.progress) / this.props.item.amount * 100).toFixed(0) + "%)";
			}
			return React.createElement(
				"div",
				{ className: this.state.condition ? "flipped card-container" : "card-container" },
				React.createElement(
					"figure",
					{ className: "front" },
					React.createElement(
						"div",
						{ className: "goal--top" },
						React.createElement(
							"a",
							{ href: "#", className: "edit", onClick: this.editGoal.bind(this, this.props.item.index) },
							React.createElement("i", { className: "fa fa-pencil-square-o" })
						),
						React.createElement(
							"div",
							{ className: "goal__name" },
							this.props.item.name
						),
						React.createElement(Application, { percent: this.props.item.progress / this.props.item.amount, colorChart: strokeColor }),
						React.createElement(
							"div",
							{ className: "goal--top__container" },
							React.createElement("i", { className: 'category fa fa-' + this.props.item.category, "aria-hidden": "true" }),
							React.createElement(
								"div",
								{ className: "goal--progress" },
								React.createElement(
									"span",
									{ className: "money" },
									this.props.item.progress.toLocaleString()
								)
							),
							React.createElement(
								"div",
								{ className: "goal--amount" },
								"of ",
								React.createElement(
									"span",
									{ className: "money" },
									this.props.item.amount.toLocaleString()
								)
							)
						)
					),
					React.createElement(
						"div",
						{ className: "goal--bottom" },
						React.createElement(
							"div",
							{ className: "descriptor" },
							status,
							React.createElement(
								"span",
								{ className: "money right goal--remain" },
								remaining
							),
							React.createElement(
								"span",
								{ className: "percent right" },
								percentRemaining
							)
						),
						React.createElement(Example, {
							name: this.props.item.name,
							progress: this.props.item.progress,
							amount: this.props.item.amount,
							onSave: this.onSave.bind(this)
						})
					)
				),
				React.createElement(
					"figure",
					{ className: "back" },
					React.createElement(
						"a",
						{ href: "#", className: "back-arrow", onClick: this.cancelEdit.bind(this, this.props.item.index) },
						React.createElement("i", { className: "fa fa-angle-left" })
					),
					React.createElement(
						"h3",
						{ className: "card-title" },
						"Goal Details"
					),
					React.createElement(
						"div",
						{ className: "input-container" },
						React.createElement(
							"label",
							{ name: "name", className: "descriptor" },
							"Name"
						),
						React.createElement("input", { type: "text", placeholder: "Goal Name", value: this.state.input1, onChange: this.handleChange.bind(this, 'input1') }),
						React.createElement(
							"label",
							{ name: "amount", className: "descriptor" },
							"Goal"
						),
						React.createElement(
							"span",
							{ className: "edit-money" },
							"$"
						),
						React.createElement("input", { type: "number", placeholder: "Amount", value: this.state.input2, onChange: this.handleChange.bind(this, 'input2') }),
						React.createElement(
							"label",
							{ name: "progress", className: "descriptor" },
							"Progress"
						),
						React.createElement(
							"span",
							{ className: "edit-money" },
							"$"
						),
						" ",
						React.createElement("input", { type: "number", placeholder: "Progress", value: this.state.input3, onChange: this.handleChange.bind(this, 'input3') }),
						"         ",
						React.createElement(
							"label",
							{ name: "icon", className: "descriptor" },
							"Icon"
						),
						React.createElement(
							"div",
							{ className: "dropdown-wrapper" },
							React.createElement(
								"select",
								{ value: this.state.selectValue,
									onChange: this.handleDropdown.bind(this)
								},
								React.createElement(
									"option",
									{ value: "car" },
									"Car"
								),
								React.createElement(
									"option",
									{ value: "plane" },
									"Plane"
								),
								React.createElement(
									"option",
									{ value: "" },
									"None"
								)
							)
						)
					),
					React.createElement("input", { type: "button", className: "button", value: "Save Changes", onClick: this.saveGoal.bind(this, this.props.item.index) }),
					React.createElement(
						"a",
						{ href: "#", className: "delete", onClick: this.deleteGoal.bind(this, this.props.item.index) },
						"Delete Goal"
					)
				)
			);
		}
	}]);
	return GoalCard;
}(React.Component);
var Example = React.createClass({
	displayName: "Example",
	getInitialState: function getInitialState() {
		return { showModal: false,
			progress: this.props.progress,
			input1: "",
			sum: ""
		};
	},
	close: function close() {
		this.setState({ showModal: false });
	},
	submit: function submit(e) {
		if (e.key === 'Enter') {
			progressUpdate = this.state.sum;
			this.props.onSave();
			this.setState({
				showModal: false
			});
		}
	},
	save: function save() {
		progressUpdate = this.state.sum;
		this.props.onSave();
		this.setState({
			showModal: false
		});
	},
	open: function open() {
		this.setState({ showModal: true,
			sum: this.props.progress,
			input1: "" });
	},
	handleChange: function handleChange(name, e) {
		var change = {};
		change[name] = e.target.value;
		this.setState(change);
		this.setState({
			sum: Number(this.props.progress) + Number(change[name])
		});
	},
	render: function render() {
		return React.createElement(
			"div",
			null,
			React.createElement(
				Button,
				{
					bsStyle: "primary",
					bsSize: "large",
					onClick: this.open,
					className: "button"
				},
				"Add funds"
			),
			React.createElement(
				Modal,
				{ show: this.state.showModal, onHide: this.close },
				React.createElement(
					Modal.Header,
					{ closeButton: true },
					React.createElement(
						Modal.Title,
						null,
						"Add Funds for ",
						this.props.name
					)
				),
				React.createElement(
					Modal.Body,
					null,
					React.createElement(
						"label",
						null,
						"Current progress:"
					),
					React.createElement(
						"div",
						{ className: "data" },
						"$",
						this.props.progress.toLocaleString()
					),
					React.createElement(
						"label",
						null,
						"Add amount:"
					),
					React.createElement(
						"div",
						{ className: "data" },
						React.createElement(
							"span",
							{ className: "pre-money" },
							"$"
						),
						" ",
						React.createElement("input", { type: "number", className: "fund-container", defaultValue: "", onKeyPress: this.submit.bind(this), onChange: this.handleChange.bind(this, 'input1'), autoFocus: true })
					),
					React.createElement(
						"p",
						{ className: "smallprint" },
						" Total Progress: ",
						React.createElement(
							"span",
							{ className: "pre-money" },
							"$"
						),
						this.state.sum.toLocaleString()
					)
				),
				React.createElement(
					Modal.Footer,
					null,
					React.createElement(
						Button,
						{ onClick: this.close },
						"Close"
					),
					React.createElement(
						Button,
						{ type: "button", className: "btn-primary", onClick: this.save.bind(this, this.props) },
						"Update Progress"
					)
				)
			)
		);
	}
});
var GoalList = React.createClass({
	displayName: "GoalList",
	getInitialState: function getInitialState() {
		return {
			data: this.props.data
		};
	},
	dragStart: function dragStart(e) {
		//this.refs['update'].updateGoal();
		this.dragged = e.currentTarget;
		e.dataTransfer.effectAllowed = 'move';
		e.dataTransfer.setData("text/html", e.currentTarget);
	},
	dragEnd: function dragEnd(e) {
		this.dragged.style.display = "block";
		placeholder.remove();
		// Update data
		var data = this.state.data;
		var from = Number(this.dragged.dataset.id);
		var to = Number(this.over.dataset.id);
		if (from < to) to--;
		if (this.nodePlacement == "after") to++;
		data.splice(to, 0, data.splice(from, 1)[0]);
		this.setState({
			data: data
		});
	},
	dragOver: function dragOver(e) {
		e.preventDefault();
		this.dragged.style.display = "none";
		if (e.target.className == "placeholder") return;
		this.over = e.target;
		// Inside the dragOver method
		var relY = e.pageY - this.over.offsetTop;
		var height = this.over.offsetHeight / 2;
		var relX = e.pageX - this.over.offsetLeft;
		var width = this.over.offsetWidth / 2;
		var parent = e.target.parentNode;
		if (relX >= width) {
			this.nodePlacement = "after";
			parent.insertBefore(placeholder, e.target.nextElementSibling);
		} else {
			this.nodePlacement = "before";
			parent.insertBefore(placeholder, e.target);
		}
		this.setState({
			data: this.props.data
		});
	},
	onFlip: function onFlip(i) {
		var data = this.state.data;
		data[i].flipped = !data[i].flipped;
		this.setState({
			data: data });
		if (data[i].flipped) {
			var data = this.props.data;
			//	data[i].dragStatus = false;
			dragStatus = false;
		} else {
			//	data[i].dragStatus= true;
			dragStatus = true;
		}
	},
	onDelete: function onDelete(i) {
		var data = this.props.data;
		var newData = this.state.data.slice(); //copy array
		newData.splice(i, 1); //remove element
		this.setState({ data: newData }); //update state
		this.props = newData;
		//var data = this.props.data;
		data[i].flipped = !data[i].flipped;
		if (data[i].flipped) {
			//	data[i].dragStatus = false;
			dragStatus = false;
		} else {
			//	data[i].dragStatus= true;
			dragStatus = true;
		}
		data = newData;
		//data.splice(i, 1);
		//	this.setState({ data: data});
	},
	render: function render() {
		return React.createElement(
			"ul",
			{ className: "goal__list", onDragOver: this.dragOver },
			this.state.data.map(function (item, i) {
				return React.createElement(
					"li",
					{ "data-id": i,
						key: i
						// draggable={goals[i].dragStatus}
						, draggable: dragStatus,
						onDragEnd: this.dragEnd.bind(this),
						onDragStart: this.dragStart.bind(this)
					},
					React.createElement(GoalCard, { item: item,
						onFlip: this.onFlip.bind(this, i),
						cancelEdit: this.onFlip.bind(this, i),
						saveGoal: this.onFlip.bind(this, i),
						onDelete: this.onDelete.bind(this, i)
					})
				);
			}, this)
		);
	}
});
ReactDOM.render(React.createElement(GoalList, { data: goals }), document.getElementById('app'));
//# sourceURL=pen.js
</script>
</body></html>