'use strict'
var app = angular.module('plunker', []);
app.factory('localdb', localdb);
app.controller('MainCtrl',MainCtrl);
function MainCtrl($scope, localdb) {
var vm = this;
vm.name = '';
vm.data = localdb.select('sample');
vm.eid=0;
vm.enableEdit=false;
vm.submit = submit;
vm.remove = remove;
vm.update = updateName;
vm.editClick=editClik;
function submit(name) {
console.log('Submit is called');
localdb.insert('sample', {
name: name,
_id: parseInt(Math.random() * 1000)
});
vm.name='';
vm.data = localdb.select('sample');
}
function editClik(name,id){
console.log(name,id);
vm.name=name;
vm.eid=id;
vm.enableEdit=true;
}
function remove(id) {
var result = localdb.delete('sample', id);
if (result) {
vm.data = localdb.select('sample');
}
}
function updateName(id, name) {
console.log(id,name);
var result = localdb.update('sample', id, {
name: name
});
if(result){
vm.name='';
vm.eid=0;
vm.enableEdit=false;
vm.data = localdb.select('sample');
}
else{
alert('update failed');
}
}
}
function localdb() {
return {
insert: insert,
select: getLDB,
delete: removeItem,
update: update,
};
function setCookie(cname, cvalue, exdays) {
var d = new Date();
d.setTime(d.getTime() + (exdays * 24 * 60 * 60 * 1000));
var expires = "expires=" + d.toUTCString();
document.cookie = cname + "=" + cvalue + "; " + expires;
}
function getCookie(cname) {
var name = cname + "=";
var ca = document.cookie.split(';');
for (var i = 0; i < ca.length; i++) {
var c = ca[i];
while (c.charAt(0) == ' ') c = c.substring(1);
if (c.indexOf(name) == 0) return c.substring(name.length, c.length);
}
return "";
}
function createLDB(collection, data) {
if (typeof(Storage) !== "undefined") {
// Code for localStorage/sessionStorage.
console.log('insertion', JSON.stringify(data));
localStorage.setItem(collection, JSON.stringify(data));
} else {
console.log('no localstorage support')
}
}
function getLDB(collection, mode) {
if (typeof(Storage) !== "undefined") {
var data = JSON.parse(localStorage.getItem(collection));
if (data) {
if (typeof mode != 'undefined' && mode == 'native') {
return data;
}
var result = [];
//console.log(data);
Object.keys(data).forEach(function(key) {
result.push(data[key]);
});
return result;
} else {
return false;
}
} else {
return false;
}
}
function retriveLDB(collection, id) {
if (typeof id != 'undefined' && typeof collection != 'undefined') {
if (getLDB(collection)[id] != 'undefined') {
return getLDB(collection)[id];
} else {
return {};
}
} else return null;
}
function insert(collection, item) {
var data = getLDB(collection, 'native');
console.log(data);
if (data) {
console.log('if working');
if (typeof item._id == 'undefined') {
item._id = 'uid'
data['uid'] = item;
} else {
console.log('if fata', data);
data[item._id] = item;
}
console.log('data found', data);
createLDB(collection, data);
} else {
console.log('else working');
data = {};
if (typeof item._id == 'undefined') {
item._id = 'uid';
data['uid'] = item;
} else {
data[item._id] = item;
}
createLDB(collection, data);
}
}
function update(collection, id, item) {
console.log(collection, id, item);
if (typeof collection != 'undefined' && typeof id != 'undefined' && typeof item != 'undefined') {
var data = getLDB(collection, 'native');
if (data && data[id]) {
Object.keys(item).forEach(function(element) {
data[id][element] = item[element];
});
console.log(data);
createLDB(collection, data);
return data;
} else {
return false;
}
}
}
function removeItem(collection, id) {
console.log('remove data working');
if (typeof collection != 'undefined' && typeof id != 'undefined') {
var data = getLDB(collection, 'native');
console.log(data);
if (data[id]) {
delete data[id];
createLDB(collection, data)
return true;
} else {
return false;
}
} else return false;
}
}
<!DOCTYPE html>
<html ng-app="plunker">
<head>
<meta charset="utf-8" />
<title>AngularJS Plunker</title>
<script>
document.write('<base href="' + document.location + '" />');
</script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" />
<link rel="stylesheet" href="style.css" />
<script data-require="angular.js@1.4.x" src="https://code.angularjs.org/1.4.8/angular.js" data-semver="1.4.8"></script>
<script data-require="lodash.js@*" data-semver="3.10.0" src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/3.10.0/lodash.js"></script>
<script src="app.js"></script>
</head>
<body ng-controller="MainCtrl as main">
<div class="container">
<div class="form-group" ng-if="!main.enableEdit">
<h2>What to do</h2>
<form ng-submit="main.submit(main.name)">
<div class="input-group">
<input type="text" class="form-control" ng-model="main.name" placeholder="Search for..." required>
<span class="input-group-btn">
<button class="btn btn-default" type="submit" ng-click="">Add</button>
</span>
</div>
</form>
</div>
<ul class="list-group" ng-hide="main.enableEdit">
<li class="list-group-item" ng-repeat="item in main.data">
<a><h4>{{item.name}}</h4></a>
<button type="button" class="btn btn-primary btn-xs" ng-click="main.editClick(item.name,item._id)">edit</button>
<button type="button" class="btn btn-danger btn-xs" ng-click="main.remove(item._id)">delete</button>
</li>
</ul>
<div class="form-group" ng-if="main.enableEdit">
<h1>Edit Data</h1>
<input class="form-control" type="text" ng-model="main.name">
<input class="btn btn-primary" type="button" value="update" ng-click="main.update(main.eid,main.name)">
</div>
</div>
</body>
</html>
/* Put your css in here */