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
86
87
88
89
90
91
92
93
94
95
96
|
from odoo import api, fields, models, _
import time
import csv
from odoo.modules import get_modules, get_module_path
from odoo.exceptions import UserError
import copy
import logging
from io import StringIO
import base64
_logger = logging.getLogger(__name__)
class efaktur_partner_wizard(models.TransientModel):
_name = 'vit.efaktur_partner'
export_file = fields.Binary(string="Export File", )
export_filename = fields.Char(string="Export File", )
# @api.multi
def confirm_button(self):
"""
export partner yang is_efaktur_exported = False
update setelah export
:return:
"""
cr = self.env.cr
headers = [
'LT',
'NPWP',
'NAMA',
'JALAN',
'BLOK',
'NOMOR',
'RT',
'RW',
'KECAMATAN',
'KELURAHAN',
'KABUPATEN',
'PROPINSI',
'KODE_POS',
'NOMOR_TELEPON'
]
mpath = get_module_path('vit_efaktur')
# csvfile = open(mpath + '/static/partner.csv', 'wb')
csvfile = StringIO()
csvwriter = csv.writer(csvfile, delimiter=',')
csvwriter.writerow([h.upper() for h in headers])
partner = self.env['res.partner']
partners = partner.search([('is_efaktur_exported','=',False),
('npwp','!=',False)])
i=0
for part in partners:
npwp = part.npwp.replace(".","").replace("-","")
data = {
'LT' : 'LT',
'NPWP' : npwp,
'NAMA' : part.name,
'JALAN' : part.street or '',
'BLOK' : part.blok or '',
'NOMOR' : part.nomor or '',
'RT' : part.rt or '',
'RW' : part.rw or '',
'KECAMATAN' : part.kecamatan_id.name or '',
'KELURAHAN' : part.kelurahan_id.name or '',
'KABUPATEN' : part.kecamatan_id.kota_id.name or '',
'PROPINSI' : part.state_id.name or '',
'KODE_POS' : part.zip or '',
'NOMOR_TELEPON': part.phone or ''
}
csvwriter.writerow([data[v] for v in headers])
part.is_efaktur_exported=True
part.date_efaktur_exported=time.strftime("%Y-%m-%d %H:%M:%S")
i+=1
cr.commit()
# csvfile.close()
# raise UserError("Export %s record(s) Done!" % i)
self.export_file = base64.b64encode(csvfile.getvalue().encode())
self.export_filename = 'Export-%s.csv' % time.strftime("%Y%m%d_%H%M%S")
return {
'name': "Export E-Faktur Complete, total %s records" % i,
'type': 'ir.actions.act_window',
'res_model': 'vit.efaktur_partner',
'view_mode': 'form',
'res_id': self.id,
'views': [(False, 'form')],
'target': 'new',
}
|