aboutsummaryrefslogtreecommitdiff
path: root/src/static
diff options
context:
space:
mode:
authorMark Powers <markppowers0@gmail.com>2020-10-11 21:47:02 -0500
committerMark Powers <markppowers0@gmail.com>2020-10-11 21:47:02 -0500
commit292048edaf0e2d4c4d591cfec1d923cb6d845991 (patch)
tree7fe5a80a5e5805c8f9d66542a3f397e6802331f5 /src/static
parente242733deb546c2b7f00d302a96bee0c0e609a2e (diff)
Add edit ledger
Diffstat (limited to 'src/static')
-rw-r--r--src/static/main.js222
1 files changed, 7 insertions, 215 deletions
diff --git a/src/static/main.js b/src/static/main.js
index 0a381b0..1bcf5e5 100644
--- a/src/static/main.js
+++ b/src/static/main.js
@@ -1,216 +1,8 @@
-window.onload = function () {
- var transactionData = new Vue({
- el: '#data',
- data: {
- activeTab: "ledger",
- transactions: [],
- summary: {username : ""},
- selTodoType: "all",
- total_to_allocate: 0,
- goals: [],
- expected: []
- },
- methods: {
- setTab: function (value) {
- this.activeTab = value;
- },
- clearData: function () {
- this.m = {
- when: new Date().toLocaleDateString(),
- where: "",
- amount: "",
- category: "",
- subcategory: "",
- }
- this.em = {
- when: new Date().toLocaleDateString(),
- where: "",
- amount: "",
- category: "",
- subcategory: "",
- }
- this.ng = {
- name: "",
- total: "",
- amount: 0
- }
- this.e = {
- name: "",
- total: "",
- days: 7
- }
- this.na = {
- selected: "",
- amount: ""
- }
- },
- requestThenUpdate: function (request, app, field) {
- fetch(request)
- .then(response => response.json())
- .then(response => {
- app[field] = response
- });
- },
- post: function (obj, path, save_to) {
- console.log(obj);
- console.log(path);
- this.requestThenUpdate(new Request(path, {
- method: 'POST',
- headers: {
- 'Accept': 'application/json',
- 'Content-Type': 'application/json'
- },
- body: JSON.stringify(obj)
- }), this, save_to);
- this.clearData();
- },
- remove: function (obj, save_to) {
- if (confirm(`Delete transaction?`)) {
- this.requestThenUpdate(new Request("/transaction", {
- method: 'delete',
- headers: {
- 'Accept': 'application/json',
- 'Content-Type': 'application/json'
- },
- body: JSON.stringify(obj)
- }), this, save_to)
- }
- },
- prepareEntryEdit: function(transaction){
- this.em.id=transaction.id;
- this.em.where=transaction.where;
- this.em.when=transaction.when;
- this.em.amount=transaction.amount;
- this.em.category=transaction.category;
- this.em.subcategory=transaction.subcategory;
- this.activeTab='ledger-edit';
- },
- updateMany: function (obj, save_to) {
- update = {}
- update = obj;
- this.requestThenUpdate(new Request("/transaction", {
- method: 'put',
- headers: {
- 'Accept': 'application/json',
- 'Content-Type': 'application/json'
- },
- body: JSON.stringify({ id: obj.id, update: update })
- }), this, save_to)
- },
- },
- created() {
- this.clearData();
- fetch(new Request(`/expected`)).then(response => response.json())
- .then(response => this.expected = response);
- fetch(new Request(`/goals`)).then(response => response.json())
- .then(response => this.goals = response);
- fetch(new Request(`/transaction`)).then(response => response.json())
- .then(response => this.transactions = response);
- fetch(new Request(`/summary`)).then(response => response.json())
- .then(response => {
- var findOrCreateWeek = function(t, el){
- var item = t.summary.week.find( el2 => {
- return el.y == el2.y && el.w == el2.w
- })
- if(!item){
- item = {y : el.y, w : el.w, in: 0, out: 0, net: 0}
- t.summary.week.push(item);
- }
- return item
- }
- var findOrCreateMonth = function(t, el){
- var item = t.summary.month.find( el2 => {
- return el.y == el2.y && el.m == el2.m
- })
- if(!item){
- item = {y : el.y, m : el.m, in: 0, out: 0, net: 0}
- t.summary.month.push(item);
- }
- return item
- }
- var findOrCreateYear = function(t, el){
- var item = t.summary.year.find( el2 => {
- return el.y == el2.y
- })
- if(!item){
- item = {y : el.y, in: 0, out: 0, net: 0}
- t.summary.year.push(item);
- }
- return item
- }
-
- this.summary.week = [];
- this.summary.month = [];
- this.summary.year = [];
-
- response.week.in.forEach(el => {
- findOrCreateWeek(this, el).in = Math.abs(el.s)
- })
- response.week.out.forEach(el => {
- findOrCreateWeek(this, el).out = Math.abs(el.s)
- })
- response.week.net.forEach(el => {
- var item = findOrCreateWeek(this, el);
- item.net = el.s
- // Note we flip these since income is negative
- item.negative = el.s > 0
- item.positive = el.s < 0
- })
-
- response.month.in.forEach(el => {
- findOrCreateMonth(this, el).in = Math.abs(el.s)
- })
- response.month.out.forEach(el => {
- findOrCreateMonth(this, el).out = Math.abs(el.s)
- })
- response.month.net.forEach(el => {
- var item = findOrCreateMonth(this, el);
- item.net = el.s
- // Note we flip these since income is negative
- item.negative = el.s > 0
- item.positive = el.s < 0
- })
-
- response.year.in.forEach(el => {
- findOrCreateYear(this, el).in = Math.abs(el.s)
- })
- response.year.out.forEach(el => {
- findOrCreateYear(this, el).out = Math.abs(el.s)
- })
- response.year.net.forEach(el => {
- var item = findOrCreateYear(this, el);
- item.net = el.s
- // Note we flip these since income is negative
- item.negative = el.s > 0
- item.positive = el.s < 0
-
- // -= since its flipped
- this.total_to_allocate -= item.net
- })
- this.goals.forEach(el => {
- this.total_to_allocate -= el.amount
- })
-
- this.summary.week.sort(function(a, b){
- if ( a.y == b.y ){ return a.w - b.w; }
- return a.y-b.y;
- })
- this.summary.month.sort(function(a, b){
- if ( a.y == b.y ){ return a.m - b.m; }
- return a.y-b.y;
- })
- this.summary.year.sort(function(a, b){
- return a.y-b.y;
- })
-
- seriesX = this.summary.month.map(el => el.y)
-
-
- this.summary.username = response.username
- });
- },
- computed: {
-
- }
- });
+function remove(id){
+ if (confirm(`Delete transaction?`)) {
+ let request = new Request(`/ledger/${id}`, {
+ method: 'delete',
+ })
+ fetch(request).then(r => window.location = "/ledger");
+ }
} \ No newline at end of file