forked from halloffame/ynab-csv
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.coffee
85 lines (68 loc) · 2.76 KB
/
app.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# see http://stackoverflow.com/questions/2897619/using-html5-javascript-to-generate-and-save-a-file
# see http://stackoverflow.com/questions/18662404/download-lengthy-data-as-a-csv-file
angular.element(document).ready ->
angular.module('app', [])
angular.module("app").directive "fileread", [->
scope:
fileread: "="
link: (scope, element, attributes) ->
element.bind "change", (changeEvent) ->
reader = new FileReader()
reader.onload = (loadEvent) ->
scope.$apply ->
scope.fileread = loadEvent.target.result
reader.readAsText(changeEvent.target.files[0], 'windows-1252')
]
angular.module("app").directive "dropzone", [->
transclude: true
replace: true
template: '<div class="dropzone"><div ng-transclude></div></div>'
scope:
dropzone: "="
link: (scope, element, attributes) ->
element.bind 'dragenter', (event) ->
element.addClass('dragging')
event.preventDefault()
element.bind 'dragover', (event) ->
element.addClass('dragging')
event.preventDefault()
efct = event.dataTransfer.effectAllowed
event.dataTransfer.dropEffect = if 'move' == efct or 'linkMove' == efct then 'move' else 'copy'
element.bind 'dragleave', (event) ->
element.removeClass('dragging')
event.preventDefault()
element.bind 'drop', (event) ->
element.removeClass('dragging')
event.preventDefault()
event.stopPropagation()
reader = new FileReader()
reader.onload = (loadEvent) ->
scope.$apply ->
scope.dropzone = loadEvent.target.result
reader.readAsText(event.dataTransfer.files[0], 'windows-1252')
]
# Application code
angular.module('app').controller 'ParseController', ($scope) ->
$scope.angular_loaded = true
$scope.ynab_cols = ['Date','Payee','Category','Memo','Outflow','Inflow']
$scope.data = {}
$scope.ynab_map =
Date: 'Bogf¿rt'
Payee: 'Tekst'
Category: 'Category'
Memo: 'Saldo'
Outflow: 'Bel¿b'
Inflow: 'Bel¿b'
$scope.data_object = new DataObject()
$scope.$watch 'data.source', (newValue, oldValue) ->
$scope.data_object.parse_csv(newValue) if newValue && newValue.length > 0
$scope.export = (limit) -> $scope.data_object.converted_json(limit, $scope.ynab_map)
$scope.csvString = -> $scope.data_object.converted_csv(null, $scope.ynab_map)
$scope.downloadFile = ->
a = document.createElement('a')
a.href = 'data:attachment/csv;base64,' + btoa(unescape(encodeURIComponent($scope.csvString())))
a.target = '_blank'
a.download = 'ynab_data.csv'
document.body.appendChild(a)
a.click()
angular.bootstrap document, ['app']