# coding=utf-8
#
-# Copyright 2013 Thadeu Lima de Souza Cascardo <cascardo@cascardo.info>
+# Copyright 2013-2014 Thadeu Lima de Souza Cascardo <cascardo@cascardo.info>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
import xml.dom.minidom
import dirs
import os
+import form
+import ocupacoes
+
+class OcupacaoForm(form.OptionsForm):
+ def __init__(self, ocupacoes, contribuinte):
+ g = ocupacoes.groups()
+ l = []
+ for i in sorted(g):
+ l.extend(g[i])
+ o = map(lambda x: (x[0], x[3]), l)
+ form.OptionsForm.__init__(self, u"Ocupações", o, contribuinte.get_campo_contribuinte("ocupacaoPrincipal"))
+ self.ocupacoes = ocupacoes
+ self.contribuinte = contribuinte
+ def set_value(self, value):
+ form.OptionsForm.set_value(self, value)
+ self.contribuinte.set_campo_contribuinte("ocupacaoPrincipal", value)
+
+class ContribuinteForm(form.StringForm):
+ def __init__(self, name, attr, contribuinte):
+ self.contribuinte = contribuinte
+ self.attr = attr
+ form.StringForm.__init__(self, name, self.contribuinte.get_campo_contribuinte(self.attr))
+ def set_value(self, value):
+ form.StringForm.set_value(self, value)
+ self.contribuinte.set_campo_contribuinte(self.attr, value)
class Contribuinte:
def __init__(self, cpf):
raise RuntimeError("Invalid CPF: " + self.cpf)
if not os.path.exists(irpf_dir.get_resource_dir()):
- raise RuntimeError("O caminho para o resource não existe: " + \
+ raise RuntimeError("O caminho para o resource não existe: " + \
irpf_dir.get_resource_dir())
if not os.path.exists(irpf_dir.get_userdata_dir()):
- raise RuntimeError("O caminho para os dados não existe: " + \
+ raise RuntimeError("O caminho para os dados não existe: " + \
irpf_dir.get_userdata_dir())
self.cpf_file = irpf_dir.get_userdata_file("%s/%s.xml" % (self.cpf, self.cpf))
def _find_id(self):
cpf = self._normalize_cpf(self.cpf)
self.declaracoes = xml.dom.minidom.parse(self.iddecl_file)
- for i in self.declaracoes.childNodes[0].childNodes:
+ for i in self.declaracoes.getElementsByTagName("item"):
if "cpf" in i.attributes.keys():
if i.attributes["cpf"].nodeValue == cpf:
return i
else:
self._set_attr(self.contribuinte, attr, val)
+ def form(self):
+ form = []
+ ocup = ocupacoes.Ocupacoes()
+ form.append(ContribuinteForm("Nome", "nome", self))
+ form.append(OcupacaoForm(ocup, self))
+ for i in contribuinte_attributes:
+ form.append(ContribuinteForm(i, i, self))
+ return form
+
contribuinte_attributes = [
"nome",
"dataNascimento",