diff --git a/.circleci/config.yml b/.circleci/config.yml
index 6c085b4..6613ea6 100644
--- a/.circleci/config.yml
+++ b/.circleci/config.yml
@@ -38,15 +38,7 @@ jobs:
- run:
name: Run tests, save a coverage report, and save coverage percentage
command: |
- pytest --cov=. --cov-report=xml --cov-report=html --cov-report=term || EXIT_CODE=$?
- if [ $EXIT_CODE == "0" ]; then
- echo "Tests ran successfully"
- elif [ $EXIT_CODE == "5" ]; then
- echo "No tests found. Continuing."
- else
- echo "Unit test errors. pytest exited with $EXIT_CODE."
- exit 1
- fi
+ PYTHONPATH=. pytest --cov=. --cov-report=xml --cov-report=html --cov-report=term
- store_artifacts:
path: htmlcov
@@ -85,6 +77,9 @@ jobs:
key: v1-sonarcloud-scanner-4.6.2.2472
paths: /tmp/cache/scanner
+ - run:
+ name: flake8 lint tests
+ command: flake8 --config .flake8
dependency-check:
docker:
- image: cimg/python:3.8
@@ -116,9 +111,34 @@ jobs:
echo "----------------------------------------------------"
eval $command
+ deploy:
+
+ docker:
+ - image: cimg/python:3.7
+
+ steps:
+ - checkout
+
+ - python/install-packages:
+ pkg-manager: pip
+ pip-dependency-file: requirements.txt
+
+ - run:
+ name: Installs for deploy
+ command: |
+ mkdir -p $HOME/bin
+ export PATH=$HOME/bin:$PATH
+ curl -L "https://cli.run.pivotal.io/stable?release=linux64-binary&version=7.1.0" | tar xzv -C $HOME/bin
+ - deploy:
+ name: Deploy API
+ command: |
+ export PATH=$HOME/bin:$PATH
+ invoke deploy --branch $CIRCLE_BRANCH --login
+
# See: https://circleci.com/docs/2.0/configuration-reference/#workflows
workflows:
test:
jobs:
- test
- - dependency-check
\ No newline at end of file
+ - dependency-check
+ - deploy
diff --git a/.flake8 b/.flake8
new file mode 100644
index 0000000..cf9260e
--- /dev/null
+++ b/.flake8
@@ -0,0 +1,4 @@
+[flake8]
+max-line-length = 160
+ignore =
+ W503 # line break before binary operator
diff --git a/.gitignore b/.gitignore
index 9cc0678..7187611 100644
--- a/.gitignore
+++ b/.gitignore
@@ -58,11 +58,12 @@ testem.log
*.bower-registry
*.bower-tmp
-
-
# System Files
.DS_Store
Thumbs.db
.vscode/settings.json
front-end/.vscode/launch.json
*pycache*
+
+# cloud foundry
+.cfmeta
diff --git a/Procfile b/Procfile
new file mode 100644
index 0000000..cf5ff02
--- /dev/null
+++ b/Procfile
@@ -0,0 +1 @@
+web: bin/run.sh
diff --git a/bin/run.sh b/bin/run.sh
new file mode 100755
index 0000000..5693c27
--- /dev/null
+++ b/bin/run.sh
@@ -0,0 +1 @@
+gunicorn --bind 0.0.0.0:8080 wsgi:APP -w 5 -t 200
diff --git a/bin/update-licence-report.sh b/bin/update-licence-report.sh
new file mode 100755
index 0000000..410b65a
--- /dev/null
+++ b/bin/update-licence-report.sh
@@ -0,0 +1,39 @@
+#!/bin/bash
+
+CURRENT_DIR=${PWD##*/}
+OUTFILE="./docs/license_report.md"
+
+echo "Saving report as a markdown formatted file in ${OUTFILE}"
+
+if [ "$CURRENT_DIR" != "fecfile-image-generator" ]; then
+ echo "Run this script from the root directory of the fecfile-image-generator repository:"
+fi;
+
+mkdir -p docs
+
+echo "The following dependencies are used by this application:" > "$OUTFILE"
+echo "" >> "$OUTFILE"
+echo "" >> "$OUTFILE"
+echo "| Package | Version | License |" >> "$OUTFILE"
+echo "| --- | --- | --- |" >> "$OUTFILE"
+
+liccheck |
+ grep ": " |
+ sed "s/://" |
+ sed "s/\[//" |
+ sed "s/\]//" |
+ sed "s/'//g" |
+ awk '{
+ gsub(/\(/, "", $2)
+ gsub(/\)/, "", $2)
+ printf "| %s | %s | ", $1, $2
+ for (i=3; i <= NF; i++) printf "%s ", $i
+ printf "|\n"
+ }' >> "$OUTFILE"
+
+ echo "" >> "$OUTFILE"
+
+
+
+
+
diff --git a/config.py b/config.py
index 0adf3e6..dde821f 100644
--- a/config.py
+++ b/config.py
@@ -16,10 +16,10 @@
ALLOWED_HOSTS = ["*"]
-FORM_TEMPLATES_LOCATION = 'templates/forms/{}.pdf'
-HTML_FORM_TEMPLATES_LOCATION = 'templates/forms/F99/{}.html'
-FORMS_LOCATION = 'templates/forms/{}'
-REQUEST_FILE_LOCATION = 'temp/json/{}.json'
+FORM_TEMPLATES_LOCATION = "templates/forms/{}.pdf"
+HTML_FORM_TEMPLATES_LOCATION = "templates/forms/F99/{}.html"
+FORMS_LOCATION = "templates/forms/{}"
+REQUEST_FILE_LOCATION = "temp/json/{}.json"
# OUTPUT_FILE_LOCATION = 'output/pdf/{}.pdf'
OUTPUT_DIR_LOCATION = "output/pdf/{}/"
@@ -33,16 +33,14 @@
# AWS_SECRET_ACCESS_KEY = os.environ.get('SECRET_KEY', None)
# AWS_HOST_NAME = 'us-east-1'
# AWS_REGION = 'us-east-1'
-AWS_SES_AUTO_THROTTLE = (
- 0.5
-) # (default; safety factor applied to rate limit, turn off automatic throttling, set this to None)
+AWS_SES_AUTO_THROTTLE = 0.5 # (default; safety factor applied to rate limit, turn off automatic throttling, set this to None)
# AWS FECFile components bucket name
-AWS_FECFILE_OUTPUT_DIRECTORY = os.environ.get('OUTPUT_DIRECTORY', 'output')
+AWS_FECFILE_OUTPUT_DIRECTORY = os.environ.get("OUTPUT_DIRECTORY", "output")
AWS_FECFILE_COMPONENTS_BUCKET_NAME = "fecfile-dev-components"
-AWS_FECFILE_TEMP_BUCKET_NAME = os.environ.get('TEMP_BUCKET', 'dev-efile-repo')
-AWS_FECFILE_PDF_BUCKET_NAME = os.environ.get('PERM_BUCKET', 'fecfile-pdf')
+AWS_FECFILE_TEMP_BUCKET_NAME = os.environ.get("TEMP_BUCKET", "dev-efile-repo")
+AWS_FECFILE_PDF_BUCKET_NAME = os.environ.get("PERM_BUCKET", "fecfile-pdf")
# if False it will create unique file names for every uploaded file
@@ -56,28 +54,40 @@
"%s.s3.amazonaws.com" % AWS_FECFILE_TEMP_BUCKET_NAME
)
-S3_FILE_URL = "https://%s/%s/" % (AWS_S3_FECFILE_COMPONENTS_DOMAIN, AWS_FECFILE_OUTPUT_DIRECTORY)
+S3_FILE_URL = "https://%s/%s/" % (
+ AWS_S3_FECFILE_COMPONENTS_DOMAIN,
+ AWS_FECFILE_OUTPUT_DIRECTORY,
+)
# the sub-directories of temp and output files
# TEMP_FILES_LOCATION = 'temp'
# OUTPUT_FILE_FOLDER = 'output'
# TEMP_FILES_URL = "https://%s/%s/{}" % (AWS_S3_FECFILE_COMPONENTS_DOMAIN, TEMP_FILES_LOCATION)
-PRINT_OUTPUT_FILE_URL = "https://%s/%s" % (AWS_S3_FECFILE_COMPONENTS_DOMAIN, OUTPUT_DIR_LOCATION)
+PRINT_OUTPUT_FILE_URL = "https://%s/%s" % (
+ AWS_S3_FECFILE_COMPONENTS_DOMAIN,
+ OUTPUT_DIR_LOCATION,
+)
-FECFILE_UTIL_PRINT_API_URL = os.environ.get('FECFILE_UTIL_URL', 'https://dev-efile-api.efdev.fec.gov/printpdf')
+FECFILE_UTIL_PRINT_API_URL = os.environ.get(
+ "FECFILE_UTIL_URL", "https://dev-efile-api.efdev.fec.gov/printpdf"
+)
FECFILE_UTIL_API_VERSION = "/v1/fecfileutil"
-NXG_FEC_PARSER_API_URL = os.environ.get('PARSER_URL', 'https://dev-efile-api.efdev.fec.gov/receiver')
+NXG_FEC_PARSER_API_URL = os.environ.get(
+ "PARSER_URL", "https://dev-efile-api.efdev.fec.gov/receiver"
+)
# NXG_FEC_PARSER_API_URL = os.environ.get('PARSER_URL', 'http://localhost:8090')
NXG_FEC_PARSER_API_VERSION = "/v1"
# SQS Details
-DATA_RECEIVER_SQS_QUEUE = os.environ.get('DATA_RECEIVER_SQS_QUEUE', 'datareceiver-dev')
-VALIDATION_SQS_QUEUE = os.environ.get('VALIDATION_SQS_QUEUE', 'validator-dev')
-IMAGE_NUMBER_SQS_QUEUE = os.environ.get('IMAGE_NUMBER_SQS_QUEUE', 'imaging')
+DATA_RECEIVER_SQS_QUEUE = os.environ.get("DATA_RECEIVER_SQS_QUEUE", "datareceiver-dev")
+VALIDATION_SQS_QUEUE = os.environ.get("VALIDATION_SQS_QUEUE", "validator-dev")
+IMAGE_NUMBER_SQS_QUEUE = os.environ.get("IMAGE_NUMBER_SQS_QUEUE", "imaging")
# IMAGE_NUMBER_SQS_QUEUE = os.environ.get('IMAGE_NUMBER_SQS_QUEUE', 'validator-dev')
-IMAGE_GENERATOR_SQS_QUEUE = os.environ.get('IMAGE_GENERATOR_SQS_QUEUE', 'imaging-generator')
+IMAGE_GENERATOR_SQS_QUEUE = os.environ.get(
+ "IMAGE_GENERATOR_SQS_QUEUE", "imaging-generator"
+)
# Timeout for the message in queue, after the set time interval other process will see it
MESSAGE_VISIBILITY_TIMEOUT = 30 # setting it to 0 for testing
diff --git a/liccheck.ini b/liccheck.ini
new file mode 100644
index 0000000..c057c76
--- /dev/null
+++ b/liccheck.ini
@@ -0,0 +1,7 @@
+# Authorized and unauthorized licenses in LOWER CASE
+[Licenses]
+authorized_licenses:
+
+unauthorized_licenses:
+
+
diff --git a/manifest-dev.yml b/manifest-dev.yml
new file mode 100644
index 0000000..5af78ba
--- /dev/null
+++ b/manifest-dev.yml
@@ -0,0 +1,9 @@
+---
+applications:
+- name: fecfile-image-generator
+ routes:
+ - route: fecfile-image-generator-dev.app.cloud.gov
+ stack: cflinuxfs3
+ buildpacks:
+ - python_buildpack
+ memory: 512M
diff --git a/manifest-prod.yml b/manifest-prod.yml
new file mode 100644
index 0000000..777e98a
--- /dev/null
+++ b/manifest-prod.yml
@@ -0,0 +1,9 @@
+---
+applications:
+- name: fecfile-image-generator
+ routes:
+ - route: fecfile-image-generator-prod.app.cloud.gov
+ stack: cflinuxfs3
+ buildpacks:
+ - python_buildpack
+ memory: 512M
diff --git a/manifest-stage.yml b/manifest-stage.yml
new file mode 100644
index 0000000..9b8d0b7
--- /dev/null
+++ b/manifest-stage.yml
@@ -0,0 +1,9 @@
+---
+applications:
+- name: fecfile-image-generator
+ routes:
+ - route: fecfile-image-generator-stage.app.cloud.gov
+ stack: cflinuxfs3
+ buildpacks:
+ - python_buildpack
+ memory: 512M
diff --git a/requirements-test.txt b/requirements-test.txt
index 2df6a92..d9fc8ae 100644
--- a/requirements-test.txt
+++ b/requirements-test.txt
@@ -1,3 +1,5 @@
pytest==6.2.5
pytest-cov==3.0.0
-safety==1.10.3
\ No newline at end of file
+safety==1.10.3
+flake8==4.0.1
+liccheck
diff --git a/requirements.txt b/requirements.txt
index 9aa9272..7b47756 100644
--- a/requirements.txt
+++ b/requirements.txt
@@ -1,30 +1,27 @@
-BeautifulSoup4==4.7.1
+beautifulsoup4==4.7.1
+boto3==1.21.2
certifi==2018.10.15
+cfenv==0.5.2
chardet==3.0.4
-Click==7.0
-cx-Oracle==7.0.0
-Flask==1.0.2
+Flask==2.0.2
+Flask-API==3.0.post1
Flask-Cors==3.0.9
Flask-HTTPAuth==3.2.4
+Flask==2.0.2
+GitPython==3.1.0
+gunicorn==19.10.0
idna==2.7
-itsdangerous==0.24
-Jinja2==2.11.3
-MarkupSafe==1.1.1
+invoke==0.15.0
+ipdb==0.12.3
+itsdangerous==2.1.0
+Jinja2==3.0
+MarkupSafe==2.0.1
passlib==1.7.1
+pdfkit==0.6.1
+PyPDF2==1.26.0
+pypdftk==0.4
python-json-logger==0.1.9
-requests==2.22.0
+requests==2.27.1
six==1.11.0
-urllib3==1.25.3
-Werkzeug==2.0.2
+urllib3==1.26.8
WeasyPrint==47
-ipdb==0.12.3
-pypdftk==0.4
-boto3==1.14.60
-botocore==1.17.60
-Flask-API==1.1
-PyPDF2==1.26.0
-pdfkit==0.6.1
-beautifulsoup4==4.7.1
-
-gunicorn==19.10.0
-flake8==3.6.0
diff --git a/routes/src/common.py b/routes/src/common.py
index aad9260..a4adc1e 100644
--- a/routes/src/common.py
+++ b/routes/src/common.py
@@ -49,8 +49,8 @@ def check_response_and_return_or_log(response, url):
return True, response_text.get("data")
except Exception as e:
LOGGER.error(
- u'Exception "%s" raised when trying to read '
- u"response.text as json" % str(e)
+ 'Exception "%s" raised when trying to read '
+ "response.text as json" % str(e)
)
# if response.text does not indicate failure assume
# success = True
@@ -61,13 +61,13 @@ def check_response_and_return_or_log(response, url):
elif 400 <= response.status_code < 500:
LOGGER.error(
- u"%s Bouncer Service Error: %s for url: %s"
+ "%s Bouncer Service Error: %s for url: %s"
% (response.status_code, response.text, url)
)
elif 500 <= response.status_code < 600:
LOGGER.error(
- u"%s Server Error: %s for url: %s"
+ "%s Server Error: %s for url: %s"
% (response.status_code, response.text, url)
)
diff --git a/routes/src/controllers.py b/routes/src/controllers.py
index e9e1f78..d9a5f16 100644
--- a/routes/src/controllers.py
+++ b/routes/src/controllers.py
@@ -19,6 +19,12 @@
CORS(app)
+@app.route("/", methods=["GET"])
+@app.route("/app-name", methods=["GET"])
+def index():
+ return "fecfile-image-generator"
+
+
@app.route("/print", methods=["POST"])
def print_pdf():
"""
@@ -359,7 +365,7 @@ def image_number_data(next_imaging=None):
"submissionId": submission_id,
"totalPages": total_pages,
}
- ## data_obj = json.dumps(data_obj)
+ # data_obj = json.dumps(data_obj)
begin_image_number_object = requests.post(
cfg.NXG_FEC_PARSER_API_URL
+ cfg.NXG_FEC_PARSER_API_VERSION
@@ -487,7 +493,7 @@ def image_generator_data(next_image_generator=None):
json_file_name = next_image_generator["fileName"]
begin_image_number = next_image_generator["beginImageNumber"]
filing_timestamp = next_image_generator["receivedTime"]
- rep_id = json_file_name[0 : json_file_name.index(".json")]
+ rep_id = json_file_name[0:json_file_name.index(".json")]
# rep_id = '8'
# print(rep_id)
diff --git a/routes/src/f3x/form3x.py b/routes/src/f3x/form3x.py
index 7d40f4f..d7f0f89 100644
--- a/routes/src/f3x/form3x.py
+++ b/routes/src/f3x/form3x.py
@@ -1,23 +1,24 @@
import flask
import boto3
-import re
import os
import os.path
import pypdftk
import shutil
import sys
import traceback
-import urllib.request
from collections import OrderedDict
from os import path
from flask import json
from flask import request, current_app
from flask_api import status
-from PyPDF2 import PdfFileWriter, PdfFileReader, PdfFileMerger
-from PyPDF2.generic import BooleanObject, NameObject, IndirectObject
-from routes.src import tmoflask, utils, common, form
-from routes.src.utils import md5_for_text, md5_for_file, directory_files, merge, error, delete_directory
+from routes.src import common
+from routes.src.utils import (
+ md5_for_text,
+ md5_for_file,
+ error,
+ delete_directory,
+)
from routes.src.f3x.helper import (
calculate_page_count,
calculate_sh3_page_count,
@@ -460,13 +461,18 @@ def print_pdftk(
extraArgs = {"ContentType": "application/pdf", "ACL": "public-read"}
if silent_print:
- response["pdf_url"] = current_app.config['S3_FILE_URL'] + rep_id + '.pdf'
+ response["pdf_url"] = (
+ current_app.config["S3_FILE_URL"] + rep_id + ".pdf"
+ )
s3.upload_file(
- md5_directory + 'all_pages.pdf',
- current_app.config['AWS_FECFILE_COMPONENTS_BUCKET_NAME'],
- current_app.config['AWS_FECFILE_OUTPUT_DIRECTORY'] + '/' +
- str(rep_id) + '.pdf',
- ExtraArgs=extraArgs)
+ md5_directory + "all_pages.pdf",
+ current_app.config["AWS_FECFILE_COMPONENTS_BUCKET_NAME"],
+ current_app.config["AWS_FECFILE_OUTPUT_DIRECTORY"]
+ + "/"
+ + str(rep_id)
+ + ".pdf",
+ ExtraArgs=extraArgs,
+ )
s3.upload_file(
md5_directory + "all_pages.pdf",
@@ -1559,7 +1565,7 @@ def process_schedules_pages(
for rec in values:
if (
rec[0].get("designatingCommitteeName")
- and rec[0].get("coordinateExpenditure") is "Y"
+ and rec[0].get("coordinateExpenditure") == "Y"
):
cord_name = "designatingCommittee"
elif (
@@ -1569,7 +1575,7 @@ def process_schedules_pages(
cord_name = "designatingNamewithoutEXP"
elif (
rec[0].get("subordinateCommitteeName")
- and rec[0].get("coordinateExpenditure") is "N"
+ and rec[0].get("coordinateExpenditure") == "N"
):
cord_name = "subCommittee"
elif (
@@ -1580,7 +1586,7 @@ def process_schedules_pages(
elif (
rec[0].get("subordinateCommitteeName") == ""
- and rec[0].get("coordinateExpenditure") is "N"
+ and rec[0].get("coordinateExpenditure") == "N"
):
cord_name = "withsubCommittee"
diff --git a/routes/src/f3x/helper.py b/routes/src/f3x/helper.py
index 1006181..72f0e2b 100644
--- a/routes/src/f3x/helper.py
+++ b/routes/src/f3x/helper.py
@@ -127,25 +127,27 @@ def make_sh3_dict(schedules):
schedule_dict = {}
for schedule in schedules:
- hash_check = schedule.get("accountName") + '@@' + schedule.get("receiptDate")
+ hash_check = schedule.get("accountName") + "@@" + schedule.get("receiptDate")
if hash_check in schedule_dict:
- event_type = schedule.get('activityEventType')
+ event_type = schedule.get("activityEventType")
if event_type in schedule_dict[hash_check]:
- schedule_dict[hash_check][event_type] = schedule_dict[hash_check][event_type] + [schedule]
+ schedule_dict[hash_check][event_type] = schedule_dict[hash_check][
+ event_type
+ ] + [schedule]
else:
- schedule_dict[hash_check][event_type] = [schedule]
+ schedule_dict[hash_check][event_type] = [schedule]
else:
- schedule_dict[hash_check] = {}
- event_type = schedule.get('activityEventType')
+ schedule_dict[hash_check] = {}
+ event_type = schedule.get("activityEventType")
schedule_dict[hash_check][event_type] = [schedule]
-
+
return schedule_dict
def get_sh3_page_count(schedule_list):
count = 0
for event, event_list in schedule_list.items():
- if event not in ['DC', 'DF']:
+ if event not in ["DC", "DF"]:
if len(event_list) > count:
count = len(event_list)
else:
@@ -157,7 +159,7 @@ def get_sh3_page_count(schedule_list):
def calculate_sh3_page_count(schedules):
schedule_dict = make_sh3_dict(schedules)
page_count = 0
- for item in schedule_dict.values():
+ for item in schedule_dict.values():
page_count += get_sh3_page_count(item)
return page_count
@@ -265,7 +267,6 @@ def map_txn_img_num(schedules, num, txn_img_json, image_num):
return txn_img_json
-
def map_sh3_txn_img_num(schedules, txn_img_json, image_num):
sh3_dict = make_sh3_dict(schedules)
@@ -273,12 +274,12 @@ def map_sh3_txn_img_num(schedules, txn_img_json, image_num):
total_pages = get_sh3_page_count(item_value)
event_type_dict = {
- 'AD': {'current_index': 0},
- 'GV': {'current_index': 0},
- 'EA': {'current_index': 0},
- 'DC': {'current_index': 0},
- 'DF': {'current_index': 0},
- 'PC': {'current_index': 0}
+ "AD": {"current_index": 0},
+ "GV": {"current_index": 0},
+ "EA": {"current_index": 0},
+ "DC": {"current_index": 0},
+ "DF": {"current_index": 0},
+ "PC": {"current_index": 0},
}
while total_pages:
@@ -286,18 +287,18 @@ def map_sh3_txn_img_num(schedules, txn_img_json, image_num):
total_pages -= 1
for event_type, value_list in item_value.items():
- current_index = event_type_dict[event_type]['current_index']
+ current_index = event_type_dict[event_type]["current_index"]
if current_index < len(value_list):
- txn_img_json[value_list[current_index][
- "transactionId"
- ]] = image_num
+ txn_img_json[value_list[current_index]["transactionId"]] = image_num
- event_type_dict[event_type]['current_index'] += 1
+ event_type_dict[event_type]["current_index"] += 1
- if event_type in ['DC', 'DF'] and current_index + 1 < len(value_list):
+ if event_type in ["DC", "DF"] and current_index + 1 < len(
+ value_list
+ ):
current_index += 1
- txn_img_json[value_list[current_index][
- "transactionId"
- ]] = image_num
- event_type_dict[event_type]['current_index'] += 1
\ No newline at end of file
+ txn_img_json[
+ value_list[current_index]["transactionId"]
+ ] = image_num
+ event_type_dict[event_type]["current_index"] += 1
diff --git a/routes/src/form1m.py b/routes/src/form1m.py
index dda214f..9eeac7c 100644
--- a/routes/src/form1m.py
+++ b/routes/src/form1m.py
@@ -1,13 +1,10 @@
import flask
import boto3
-import re
import os
import os.path
import pypdftk
import shutil
-import urllib.request
-from os import path
from flask import json
from flask import request, current_app
from flask_api import status
@@ -256,9 +253,9 @@ def paginate(file_content=None, begin_image_num=None):
"summary": {
"committeeId": data.get("committeeId", None),
"begin_image_num": begin_image_num,
- "end_image_num": begin_image_num
- }
+ "end_image_num": begin_image_num,
}
+ }
total_no_of_pages = 1
# return True, {"total_pages": total_no_of_pages, "txn_img_json": txn_img_json}
diff --git a/routes/src/form24.py b/routes/src/form24.py
index b5c7e53..006eb70 100644
--- a/routes/src/form24.py
+++ b/routes/src/form24.py
@@ -1,11 +1,9 @@
import flask
import boto3
-import re
import os
import os.path
import pypdftk
import shutil
-import urllib.request
from os import path
from flask import json
diff --git a/routes/src/form3l.py b/routes/src/form3l.py
index ccec9e9..812379d 100644
--- a/routes/src/form3l.py
+++ b/routes/src/form3l.py
@@ -1,6 +1,5 @@
import flask
import boto3
-import re
import os
import os.path
import pypdftk
@@ -10,11 +9,9 @@
from flask import json
from flask import request, current_app
from flask_api import status
-from routes.src import tmoflask, utils, common, form
-from PyPDF2 import PdfFileWriter, PdfFileReader, PdfFileMerger
-from PyPDF2.generic import BooleanObject, NameObject, IndirectObject
+from routes.src import utils, common
-from routes.src.form3x import calculate_page_count, calculate_memo_page_count
+from routes.src.form3x import calculate_memo_page_count
def directory_files(directory):
@@ -34,9 +31,7 @@ def merge(dict1, dict2):
# Error handling
def error(msg):
if flask.request.method == "POST":
- envelope = common.get_return_envelope(
- 'false', msg
- )
+ envelope = common.get_return_envelope("false", msg)
status_code = status.HTTP_400_BAD_REQUEST
return flask.jsonify(**envelope), status_code
@@ -44,189 +39,244 @@ def error(msg):
# stamp_print is a flag that will be passed at the time of submitting a report.
def get_summary_detail(f3l_summary, f3l_data, f3l_data_summary):
# check if semmianual start and end date is there set row 5 and row 6 of summary page
- if f3l_data['semi_annual_start_date'] and len(f3l_data['semi_annual_start_date']) > 0:
- semi_annual_start_date_array = f3l_data['semi_annual_start_date'].split("-")
- f3l_data['semiAnnualStartDateMonth'] = semi_annual_start_date_array[0]
- f3l_data['semiAnnualStartDateDay'] = semi_annual_start_date_array[1]
- f3l_data['semiAnnualStartDateYear'] = semi_annual_start_date_array[2]
-
- semi_annual_end_date_array = f3l_data['semi_annual_end_date'].split("-")
- f3l_data['semiAnnualEndDateMonth'] = semi_annual_end_date_array[0]
- f3l_data['semiAnnualEndDateDay'] = semi_annual_end_date_array[1]
- f3l_data['semiAnnualEndDateYear'] = semi_annual_end_date_array[2]
+ if (
+ f3l_data["semi_annual_start_date"]
+ and len(f3l_data["semi_annual_start_date"]) > 0
+ ):
+ semi_annual_start_date_array = f3l_data["semi_annual_start_date"].split("-")
+ f3l_data["semiAnnualStartDateMonth"] = semi_annual_start_date_array[0]
+ f3l_data["semiAnnualStartDateDay"] = semi_annual_start_date_array[1]
+ f3l_data["semiAnnualStartDateYear"] = semi_annual_start_date_array[2]
+
+ semi_annual_end_date_array = f3l_data["semi_annual_end_date"].split("-")
+ f3l_data["semiAnnualEndDateMonth"] = semi_annual_end_date_array[0]
+ f3l_data["semiAnnualEndDateDay"] = semi_annual_end_date_array[1]
+ f3l_data["semiAnnualEndDateYear"] = semi_annual_end_date_array[2]
if int(semi_annual_start_date_array[1]) < 6:
- f3l_data_summary['semiAnnualPeriod_6b_H1'] = 'X'
+ f3l_data_summary["semiAnnualPeriod_6b_H1"] = "X"
else:
- f3l_data_summary['semiAnnualPeriod_6b_H2'] = 'X'
+ f3l_data_summary["semiAnnualPeriod_6b_H2"] = "X"
- f3l_data_summary['amendmentIndicator'] = f3l_data['amend_indicator']
- f3l_data_summary['reportCode'] = f3l_data['reportcode']
+ f3l_data_summary["amendmentIndicator"] = f3l_data["amend_indicator"]
+ f3l_data_summary["reportCode"] = f3l_data["reportcode"]
- if f3l_summary['contribute_amount_query'] and len(f3l_summary['contribute_amount_query']) > 0:
- f3l_amount = f3l_summary['contribute_amount_query']
- f3l_data_summary['quarterly_monthly_total'] = f3l_amount['quarterly_monthly_total']
- f3l_data_summary['semi_annual_total'] = f3l_amount['semi_annual_total']
+ if (
+ f3l_summary["contribute_amount_query"]
+ and len(f3l_summary["contribute_amount_query"]) > 0
+ ):
+ f3l_amount = f3l_summary["contribute_amount_query"]
+ f3l_data_summary["quarterly_monthly_total"] = f3l_amount[
+ "quarterly_monthly_total"
+ ]
+ f3l_data_summary["semi_annual_total"] = f3l_amount["semi_annual_total"]
def print_pdftk(stamp_print):
# check if json_file is in the request
# try:
- if 'json_file' in request.files:
+ if "json_file" in request.files:
total_no_of_pages = 0
page_no = 1
has_sa_schedules = has_sb_schedules = False
- json_file = request.files.get('json_file')
+ json_file = request.files.get("json_file")
# generate md5 for json file
# FIXME: check if PDF already exist with md5, if exist return pdf instead of re-generating PDF file.
json_file_md5 = utils.md5_for_file(json_file)
json_file.stream.seek(0)
- md5_directory = current_app.config['OUTPUT_DIR_LOCATION'].format(json_file_md5)
+ md5_directory = current_app.config["OUTPUT_DIR_LOCATION"].format(json_file_md5)
os.makedirs(md5_directory, exist_ok=True)
- infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('F3L')
+ infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("F3L")
# save json file as md5 file name
- json_file.save(current_app.config['REQUEST_FILE_LOCATION'].format(json_file_md5))
- outfile = md5_directory + json_file_md5 + '_temp.pdf'
+ json_file.save(
+ current_app.config["REQUEST_FILE_LOCATION"].format(json_file_md5)
+ )
+ outfile = md5_directory + json_file_md5 + "_temp.pdf"
# load json file
- f3l_json = json.load(open(current_app.config['REQUEST_FILE_LOCATION'].format(json_file_md5)))
+ f3l_json = json.load(
+ open(current_app.config["REQUEST_FILE_LOCATION"].format(json_file_md5))
+ )
# setting timestamp and imgno to empty as these needs to show up after submission
output = {}
- if stamp_print != 'stamp':
- output['FILING_TIMESTAMP'] = ''
- output['IMGNO'] = ''
+ if stamp_print != "stamp":
+ output["FILING_TIMESTAMP"] = ""
+ output["IMGNO"] = ""
# read data from json file
- f3l_data = f3l_json['data']
+ f3l_data = f3l_json["data"]
# check if summary is present in fecDataFile
f3l_summary = []
- if 'summary' in f3l_data:
- f3l_summary = f3l_data['summary']
+ if "summary" in f3l_data:
+ f3l_summary = f3l_data["summary"]
# split coverage start date and coverage end date to set month, day, and year
- if f3l_data['coverageStartDate'] and len(f3l_data['coverageStartDate']) > 0:
- coverage_start_date_array = f3l_data['coverageStartDate'].split("/")
- f3l_data['coverageStartDateMonth'] = coverage_start_date_array[0]
- f3l_data['coverageStartDateDay'] = coverage_start_date_array[1]
- f3l_data['coverageStartDateYear'] = coverage_start_date_array[2]
-
- if f3l_data['coverageEndDate'] and len(f3l_data['coverageEndDate']) > 0:
- coverage_end_date_array = f3l_data['coverageEndDate'].split("/")
- f3l_data['coverageEndDateMonth'] = coverage_end_date_array[0]
- f3l_data['coverageEndDateDay'] = coverage_end_date_array[1]
- f3l_data['coverageEndDateYear'] = coverage_end_date_array[2]
+ if f3l_data["coverageStartDate"] and len(f3l_data["coverageStartDate"]) > 0:
+ coverage_start_date_array = f3l_data["coverageStartDate"].split("/")
+ f3l_data["coverageStartDateMonth"] = coverage_start_date_array[0]
+ f3l_data["coverageStartDateDay"] = coverage_start_date_array[1]
+ f3l_data["coverageStartDateYear"] = coverage_start_date_array[2]
+
+ if f3l_data["coverageEndDate"] and len(f3l_data["coverageEndDate"]) > 0:
+ coverage_end_date_array = f3l_data["coverageEndDate"].split("/")
+ f3l_data["coverageEndDateMonth"] = coverage_end_date_array[0]
+ f3l_data["coverageEndDateDay"] = coverage_end_date_array[1]
+ f3l_data["coverageEndDateYear"] = coverage_end_date_array[2]
# checking for signed date, it is only available for submitted reports
- if f3l_data['date_signed'] and len(f3l_data['date_signed']) > 0:
- date_signed_array = f3l_data['date_signed'].split("-")
- f3l_data['dateSignedMonth'] = date_signed_array[0]
- f3l_data['dateSignedDay'] = date_signed_array[1]
- f3l_data['dateSignedYear'] = date_signed_array[2]
+ if f3l_data["date_signed"] and len(f3l_data["date_signed"]) > 0:
+ date_signed_array = f3l_data["date_signed"].split("-")
+ f3l_data["dateSignedMonth"] = date_signed_array[0]
+ f3l_data["dateSignedDay"] = date_signed_array[1]
+ f3l_data["dateSignedYear"] = date_signed_array[2]
# build treasurer name to map it to PDF template
treasurer_full_name = []
- treasurer_full_name.append(f3l_data['treasurerLastName'])
- treasurer_full_name.append(f3l_data['treasurerFirstName'])
- treasurer_full_name.append(f3l_data['treasurerMiddleName'])
- treasurer_full_name.append(f3l_data['treasurerPrefix'])
- treasurer_full_name.append(f3l_data['treasurerSuffix'])
- f3l_data['treasurerFullName'] = ",".join(map(str, treasurer_full_name))
- f3l_data['treasurerName'] = f3l_data['treasurerLastName'] + "," + f3l_data['treasurerFirstName']
- f3l_data['efStamp'] = '[Electronically Filed]'
+ treasurer_full_name.append(f3l_data["treasurerLastName"])
+ treasurer_full_name.append(f3l_data["treasurerFirstName"])
+ treasurer_full_name.append(f3l_data["treasurerMiddleName"])
+ treasurer_full_name.append(f3l_data["treasurerPrefix"])
+ treasurer_full_name.append(f3l_data["treasurerSuffix"])
+ f3l_data["treasurerFullName"] = ",".join(map(str, treasurer_full_name))
+ f3l_data["treasurerName"] = (
+ f3l_data["treasurerLastName"] + "," + f3l_data["treasurerFirstName"]
+ )
+ f3l_data["efStamp"] = "[Electronically Filed]"
# checking if json contains summary details, for individual transactions print there wouldn't be summary
if len(f3l_summary) > 0:
total_no_of_pages = 1
f3l_data_summary_array = [f3l_data, f3l_summary]
- if 'memoText' in f3l_data and f3l_data['memoText']:
+ if "memoText" in f3l_data and f3l_data["memoText"]:
total_no_of_pages += 1
else:
f3l_data_summary_array = [f3l_data]
f3l_data_summary = {i: j for x in f3l_data_summary_array for i, j in x.items()}
# process all schedules and build the PDF's
- process_output, total_no_of_pages = process_schedules(f3l_data, md5_directory, total_no_of_pages)
+ process_output, total_no_of_pages = process_schedules(
+ f3l_data, md5_directory, total_no_of_pages
+ )
- has_sa_schedules = process_output.get('has_sa_schedules')
- has_sb_schedules = process_output.get('has_sb_schedules')
+ has_sa_schedules = process_output.get("has_sa_schedules")
+ has_sb_schedules = process_output.get("has_sb_schedules")
if len(f3l_summary) > 0:
get_summary_detail(f3l_summary, f3l_data, f3l_data_summary)
- f3l_data_summary['PAGESTR'] = "PAGE " + str(page_no) + " / " + str(total_no_of_pages)
+ f3l_data_summary["PAGESTR"] = (
+ "PAGE " + str(page_no) + " / " + str(total_no_of_pages)
+ )
pypdftk.fill_form(infile, f3l_data_summary, outfile)
- shutil.copy(outfile, md5_directory + 'F3L_Summary.pdf')
- os.remove(md5_directory + json_file_md5 + '_temp.pdf')
+ shutil.copy(outfile, md5_directory + "F3L_Summary.pdf")
+ os.remove(md5_directory + json_file_md5 + "_temp.pdf")
# Memo text changes
- if 'memoText' in f3l_data_summary and f3l_data_summary['memoText']:
+ if "memoText" in f3l_data_summary and f3l_data_summary["memoText"]:
memo_dict = {}
- temp_memo_outfile = md5_directory + 'F3L_Summary_memo.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_dict['scheduleName_1'] = 'F3L' + f3l_data_summary['amendmentIndicator']
- memo_dict['memoDescription_1'] = f3l_data_summary['memoText']
- memo_dict['PAGESTR'] = "PAGE " + str(2) + " / " + str(total_no_of_pages)
+ temp_memo_outfile = md5_directory + "F3L_Summary_memo.pdf"
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_dict["scheduleName_1"] = (
+ "F3L" + f3l_data_summary["amendmentIndicator"]
+ )
+ memo_dict["memoDescription_1"] = f3l_data_summary["memoText"]
+ memo_dict["PAGESTR"] = "PAGE " + str(2) + " / " + str(total_no_of_pages)
pypdftk.fill_form(memo_infile, memo_dict, temp_memo_outfile)
- pypdftk.concat([md5_directory + 'F3L_Summary.pdf', temp_memo_outfile], md5_directory +
- json_file_md5 + '_temp.pdf')
- shutil.copy(md5_directory + json_file_md5 + '_temp.pdf', md5_directory + 'F3L_Summary.pdf')
- os.remove(md5_directory + json_file_md5 + '_temp.pdf')
+ pypdftk.concat(
+ [md5_directory + "F3L_Summary.pdf", temp_memo_outfile],
+ md5_directory + json_file_md5 + "_temp.pdf",
+ )
+ shutil.copy(
+ md5_directory + json_file_md5 + "_temp.pdf",
+ md5_directory + "F3L_Summary.pdf",
+ )
+ os.remove(md5_directory + json_file_md5 + "_temp.pdf")
# check if all_pages already exsits
- if os.path.exists(md5_directory + 'all_pages.pdf'):
- os.remove(md5_directory + 'all_pages.pdf')
+ if os.path.exists(md5_directory + "all_pages.pdf"):
+ os.remove(md5_directory + "all_pages.pdf")
# checking for sa transactions
if has_sa_schedules:
- pypdftk.concat([md5_directory + 'F3L_Summary.pdf', md5_directory + 'SA/all_pages.pdf'],
- md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SA/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SA')
+ pypdftk.concat(
+ [
+ md5_directory + "F3L_Summary.pdf",
+ md5_directory + "SA/all_pages.pdf",
+ ],
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SA/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SA")
else:
- shutil.copy(md5_directory + 'F3L_Summary.pdf', md5_directory + 'all_pages.pdf')
+ shutil.copy(
+ md5_directory + "F3L_Summary.pdf", md5_directory + "all_pages.pdf"
+ )
# checking for sb transactions
if has_sb_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SB/all_pages.pdf'],
- md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SB/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SB')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SB/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SB/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SB")
else:
# no summary, expecting it to be from individual transactions
if has_sa_schedules:
- if os.path.exists(md5_directory + 'all_pages.pdf'):
- os.remove(md5_directory + 'all_pages.pdf')
- shutil.move(md5_directory + 'SA/all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if os.path.exists(md5_directory + "all_pages.pdf"):
+ os.remove(md5_directory + "all_pages.pdf")
+ shutil.move(
+ md5_directory + "SA/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SA/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SA')
+ shutil.move(
+ md5_directory + "SA/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SA")
if has_sb_schedules:
- if os.path.exists(md5_directory + 'all_pages.pdf'):
- os.remove(md5_directory + 'all_pages.pdf')
- shutil.move(md5_directory + 'SB/all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if os.path.exists(md5_directory + "all_pages.pdf"):
+ os.remove(md5_directory + "all_pages.pdf")
+ shutil.move(
+ md5_directory + "SB/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SB/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SB')
+ shutil.move(
+ md5_directory + "SB/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SB")
# push output file to AWS
- s3 = boto3.client('s3')
- s3.upload_file(md5_directory + 'all_pages.pdf',
- current_app.config['AWS_FECFILE_COMPONENTS_BUCKET_NAME'],
- md5_directory + 'all_pages.pdf',
- ExtraArgs={'ContentType': "application/pdf", 'ACL': "public-read"})
+ s3 = boto3.client("s3")
+ s3.upload_file(
+ md5_directory + "all_pages.pdf",
+ current_app.config["AWS_FECFILE_COMPONENTS_BUCKET_NAME"],
+ md5_directory + "all_pages.pdf",
+ ExtraArgs={"ContentType": "application/pdf", "ACL": "public-read"},
+ )
response = {
# 'file_name': '{}.pdf'.format(json_file_md5),
- 'pdf_url': current_app.config['PRINT_OUTPUT_FILE_URL'].format(json_file_md5) + 'all_pages.pdf'
+ "pdf_url": current_app.config["PRINT_OUTPUT_FILE_URL"].format(json_file_md5)
+ + "all_pages.pdf"
}
# return response
if flask.request.method == "POST":
- envelope = common.get_return_envelope(
- data=response
- )
+ envelope = common.get_return_envelope(data=response)
status_code = status.HTTP_201_CREATED
return flask.jsonify(**envelope), status_code
@@ -234,7 +284,7 @@ def print_pdftk(stamp_print):
if flask.request.method == "POST":
envelope = common.get_return_envelope(
- 'false', 'JSON file is missing from your request'
+ "false", "JSON file is missing from your request"
)
status_code = status.HTTP_400_BAD_REQUEST
return flask.jsonify(**envelope), status_code
@@ -242,7 +292,7 @@ def print_pdftk(stamp_print):
def process_schedules(f3l_data, md5_directory, total_no_of_pages):
# Calculate total number of pages for schedules
- sb_line_numbers = ['21B', '22', '23', '26', '27', '28A', '28B', '28C', '29', '30B']
+ sb_line_numbers = ["21B", "22", "23", "26", "27", "28A", "28B", "28C", "29", "30B"]
sa_line_numbers = []
sa_schedules = []
sb_schedules = []
@@ -252,18 +302,18 @@ def process_schedules(f3l_data, md5_directory, total_no_of_pages):
sa_schedules_cnt = sb_schedules_cnt = 0
# check if schedules exist in data file
- if 'schedules' in f3l_data:
- schedules = f3l_data['schedules']
+ if "schedules" in f3l_data:
+ schedules = f3l_data["schedules"]
- if 'SA' in schedules:
+ if "SA" in schedules:
sa_start_page = total_no_of_pages
- sa_schedules = schedules.get('SA')
+ sa_schedules = schedules.get("SA")
sa_schedules_cnt = len(sa_schedules)
# if sa_schedules_cnt > 0:
if sa_schedules:
has_sa_schedules = True
- os.makedirs(md5_directory + 'SA', exist_ok=True)
+ os.makedirs(md5_directory + "SA", exist_ok=True)
# building array for all SA line numbers
sa_11a = []
sa_11a_memo = []
@@ -279,22 +329,27 @@ def process_schedules(f3l_data, md5_directory, total_no_of_pages):
# calculate number of pages for SA line numbers
sa_11a_page_cnt, sa_11a_last_page_cnt = calculate_sa_page_count(sa_11a)
- sa_11a_memo_page_cnt, sa_11a_memo_last_page_cnt = calculate_memo_page_count(sa_11a_memo)
+ (
+ sa_11a_memo_page_cnt,
+ sa_11a_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_11a_memo)
# calculate total number of pages
- total_no_of_pages = (total_no_of_pages + sa_11a_page_cnt + sa_11a_memo_page_cnt)
+ total_no_of_pages = (
+ total_no_of_pages + sa_11a_page_cnt + sa_11a_memo_page_cnt
+ )
sb_start_page = total_no_of_pages
# checking for SB transactions
- if 'SB' in schedules:
+ if "SB" in schedules:
sb_start_page = total_no_of_pages
- sb_schedules.extend(schedules['SB'])
+ sb_schedules.extend(schedules["SB"])
sb_schedules_cnt = len(sb_schedules)
if sb_schedules_cnt > 0:
has_sb_schedules = True
- os.makedirs(md5_directory + 'SB', exist_ok=True)
+ os.makedirs(md5_directory + "SB", exist_ok=True)
# building array for all SB line numbers
sb_17 = []
sb_17_memo = []
@@ -308,26 +363,47 @@ def process_schedules(f3l_data, md5_directory, total_no_of_pages):
process_sb_line_numbers(sb_17, sb_17_memo, sb_schedules[sb_count])
sb_17_page_cnt, sb_17_last_page_cnt = calculate_sb_page_count(sb_17)
- sb_17_memo_page_cnt, sb_17_memo_last_page_cnt = calculate_memo_page_count(sb_17_memo)
+ (
+ sb_17_memo_page_cnt,
+ sb_17_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_17_memo)
- total_no_of_pages = (total_no_of_pages + sb_17_page_cnt + sb_17_memo_page_cnt)
+ total_no_of_pages = (
+ total_no_of_pages + sb_17_page_cnt + sb_17_memo_page_cnt
+ )
if sa_schedules_cnt > 0:
# process Schedule 11AI
sa_11a_start_page = sa_start_page
- process_sa_line(f3l_data, md5_directory, '3L', sa_11a, sa_11a_page_cnt, sa_11a_start_page,
- sa_11a_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3l_data,
+ md5_directory,
+ "3L",
+ sa_11a,
+ sa_11a_page_cnt,
+ sa_11a_start_page,
+ sa_11a_last_page_cnt,
+ total_no_of_pages,
+ )
sa_11a_memo_start_page = sa_11a_start_page + sa_11a_page_cnt
if sb_schedules_cnt > 0:
# process Schedule 21B
sb_17_start_page = sb_start_page
- process_sb_line(f3l_data, md5_directory, '3L', sb_17, sb_17_page_cnt, sb_17_start_page,
- sb_17_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3l_data,
+ md5_directory,
+ "3L",
+ sb_17,
+ sb_17_page_cnt,
+ sb_17_start_page,
+ sb_17_last_page_cnt,
+ total_no_of_pages,
+ )
output_data = {
- 'has_sa_schedules': has_sa_schedules,
- 'has_sb_schedules': has_sb_schedules
+ "has_sa_schedules": has_sa_schedules,
+ "has_sb_schedules": has_sb_schedules,
}
return output_data, total_no_of_pages
@@ -337,14 +413,22 @@ def process_schedules(f3l_data, md5_directory, total_no_of_pages):
# return error('Error generating print preview, error message: ' + str(e))
# This method is invoked for each SB line number, it builds PDF for line numbers
-def process_sb_line(f3x_data, md5_directory, line_number, sb_line, sb_line_page_cnt, sb_line_start_page,
- sb_line_last_page_cnt, total_no_of_pages):
+def process_sb_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ sb_line,
+ sb_line_page_cnt,
+ sb_line_start_page,
+ sb_line_last_page_cnt,
+ total_no_of_pages,
+):
has_sb_schedules = False
if len(sb_line) > 0:
schedule_total = 0.00
schedule_aggregate_total = 0.00
- os.makedirs(md5_directory + 'SB/' + line_number, exist_ok=True)
- sb_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SB3L')
+ os.makedirs(md5_directory + "SB/" + line_number, exist_ok=True)
+ sb_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SB3L")
if sb_line_page_cnt > 0:
sb_line_start_page += 1
for sb_page_no in range(sb_line_page_cnt):
@@ -352,40 +436,69 @@ def process_sb_line(f3x_data, md5_directory, line_number, sb_line, sb_line_page_
memo_array = []
last_page = False
sb_schedule_page_dict = {}
- sb_schedule_page_dict['lineNumber'] = line_number
- sb_schedule_page_dict['pageNo'] = sb_line_start_page + sb_page_no
- sb_schedule_page_dict['totalPages'] = total_no_of_pages
+ sb_schedule_page_dict["lineNumber"] = line_number
+ sb_schedule_page_dict["pageNo"] = sb_line_start_page + sb_page_no
+ sb_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sb_page_no * 5
- if ((sb_page_no + 1) == sb_line_page_cnt):
+ if (sb_page_no + 1) == sb_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sb_schedule_dict = build_sb_per_page_schedule_dict(last_page, sb_line_last_page_cnt,
- page_start_index, sb_schedule_page_dict,
- sb_line, memo_array)
-
- page_subtotal = float(sb_schedule_page_dict['pageSubtotal'])
- page_aggregate_total = float(sb_schedule_page_dict['pageAggSubtotal'])
+ sb_schedule_dict = build_sb_per_page_schedule_dict(
+ last_page,
+ sb_line_last_page_cnt,
+ page_start_index,
+ sb_schedule_page_dict,
+ sb_line,
+ memo_array,
+ )
+
+ page_subtotal = float(sb_schedule_page_dict["pageSubtotal"])
+ page_aggregate_total = float(sb_schedule_page_dict["pageAggSubtotal"])
schedule_total += page_subtotal
schedule_aggregate_total += page_aggregate_total
if sb_line_page_cnt == (sb_page_no + 1):
- sb_schedule_page_dict['scheduleTotal'] = '{0:.2f}'.format(schedule_total)
- sb_schedule_page_dict['scheduleAggTotal'] = '{0:.2f}'.format(schedule_aggregate_total)
- sb_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sb_outfile = md5_directory + 'SB/' + line_number + '/page_' + str(sb_page_no) + '.pdf'
+ sb_schedule_page_dict["scheduleTotal"] = "{0:.2f}".format(
+ schedule_total
+ )
+ sb_schedule_page_dict["scheduleAggTotal"] = "{0:.2f}".format(
+ schedule_aggregate_total
+ )
+ sb_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sb_outfile = (
+ md5_directory
+ + "SB/"
+ + line_number
+ + "/page_"
+ + str(sb_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sb_infile, sb_schedule_page_dict, sb_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SB/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SB/' + line_number + '/page_memo_' + str(sb_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SB/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SB/"
+ + line_number
+ + "/page_memo_"
+ + str(sb_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sb_outfile, memo_outfile], temp_memo_outfile)
@@ -395,14 +508,27 @@ def process_sb_line(f3x_data, md5_directory, line_number, sb_line, sb_line_page_
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SB/' + line_number + '/page_memo_' + str(sb_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[2]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[2]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[2]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SB/"
+ + line_number
+ + "/page_memo_"
+ + str(sb_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[2]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[2][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[2]["transactionId"]
if len(memo_array) >= 4:
- memo_dict['scheduleName_2'] = memo_array[3]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[3]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[3]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[3]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[3][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[3][
+ "transactionId"
+ ]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sb_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
@@ -411,29 +537,57 @@ def process_sb_line(f3x_data, md5_directory, line_number, sb_line, sb_line_page_
if len(memo_array) >= 5:
memo_dict = {}
- memo_outfile = md5_directory + 'SB/' + line_number + '/page_memo_' + str(sb_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[4]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[4]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[4]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SB/"
+ + line_number
+ + "/page_memo_"
+ + str(sb_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[4]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[4][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[4]["transactionId"]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sb_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sb_outfile)
sb_line_start_page += 1
- pypdftk.concat(directory_files(md5_directory + 'SB/' + line_number + '/'), md5_directory + 'SB/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SB/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SB/all_pages.pdf', md5_directory + 'SB/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SB/temp_all_pages.pdf')
- os.rename(md5_directory + 'SB/temp_all_pages.pdf', md5_directory + 'SB/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SB/" + line_number + "/"),
+ md5_directory + "SB/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SB/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SB/all_pages.pdf",
+ md5_directory + "SB/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SB/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SB/temp_all_pages.pdf",
+ md5_directory + "SB/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SB/' + line_number + '/all_pages.pdf', md5_directory + 'SB/all_pages.pdf')
+ os.rename(
+ md5_directory + "SB/" + line_number + "/all_pages.pdf",
+ md5_directory + "SB/all_pages.pdf",
+ )
return has_sb_schedules
# This method builds data for individual SB page
-def build_sb_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sb_schedule_page_dict,
- sb_schedules, memo_array):
+def build_sb_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sb_schedule_page_dict,
+ sb_schedules,
+ memo_array,
+):
page_subtotal = 0.00
page_arg_subtotal = 0.00
if not last_page:
@@ -441,107 +595,172 @@ def build_sb_per_page_schedule_dict(last_page, transactions_in_page, page_start_
if transactions_in_page == 1:
for i in range(1):
- page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sb_schedule_page_dict, sb_schedules,
- page_subtotal)
+ page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sb_schedule_page_dict,
+ sb_schedules,
+ page_subtotal,
+ )
elif transactions_in_page == 2:
for i in range(2):
- page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sb_schedule_page_dict, sb_schedules,
- page_subtotal)
+ page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sb_schedule_page_dict,
+ sb_schedules,
+ page_subtotal,
+ )
elif transactions_in_page == 3:
for i in range(3):
- page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sb_schedule_page_dict, sb_schedules,
- page_subtotal)
+ page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sb_schedule_page_dict,
+ sb_schedules,
+ page_subtotal,
+ )
elif transactions_in_page == 4:
for i in range(4):
- page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sb_schedule_page_dict, sb_schedules,
- page_subtotal)
+ page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sb_schedule_page_dict,
+ sb_schedules,
+ page_subtotal,
+ )
elif transactions_in_page == 5:
for i in range(5):
- page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sb_schedule_page_dict, sb_schedules,
- page_subtotal)
- sb_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
- sb_schedule_page_dict['pageAggSubtotal'] = '{0:.2f}'.format(page_arg_subtotal)
+ page_arg_subtotal, page_subtotal, sb_schedule_dict = building_sb_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sb_schedule_page_dict,
+ sb_schedules,
+ page_subtotal,
+ )
+ sb_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
+ sb_schedule_page_dict["pageAggSubtotal"] = "{0:.2f}".format(page_arg_subtotal)
return sb_schedule_dict
-def building_sb_index(i, memo_array, page_start_index, page_arg_subtotal, sb_schedule_page_dict, sb_schedules,
- page_subtotal):
+def building_sb_index(
+ i,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sb_schedule_page_dict,
+ sb_schedules,
+ page_subtotal,
+):
index = i
sb_schedule_dict = sb_schedules[page_start_index + i - 1]
- process_memo_text(sb_schedule_dict, 'SB', memo_array)
- if sb_schedule_dict['expenditureAggregate'] != '':
- page_arg_subtotal += sb_schedule_dict['expenditureAggregate']
- if sb_schedule_dict['expenditureAmount'] != '':
- page_subtotal += sb_schedule_dict['expenditureAmount']
- build_payee_name_date_dict(index, page_start_index, sb_schedule_dict, sb_schedule_page_dict)
+ process_memo_text(sb_schedule_dict, "SB", memo_array)
+ if sb_schedule_dict["expenditureAggregate"] != "":
+ page_arg_subtotal += sb_schedule_dict["expenditureAggregate"]
+ if sb_schedule_dict["expenditureAmount"] != "":
+ page_subtotal += sb_schedule_dict["expenditureAmount"]
+ build_payee_name_date_dict(
+ index, page_start_index, sb_schedule_dict, sb_schedule_page_dict
+ )
return page_arg_subtotal, page_subtotal, sb_schedule_dict
def build_payee_name_date_dict(index, key, sb_schedule_dict, sb_schedule_page_dict):
try:
- if 'payeeLastName' in sb_schedule_dict and sb_schedule_dict['payeeLastName']:
- sb_schedule_page_dict['payeeName_' + str(index)] = (sb_schedule_dict['payeeLastName'] + ','
- + sb_schedule_dict['payeeFirstName'] + ','
- + sb_schedule_dict['payeeMiddleName'] + ','
- + sb_schedule_dict['payeePrefix'] + ','
- + sb_schedule_dict['payeeSuffix'])
- elif 'payeeOrganizationName' in sb_schedule_dict:
- sb_schedule_page_dict["payeeName_" + str(index)] = sb_schedule_dict['payeeOrganizationName']
-
- if 'beneficiaryCandidateLastName' in sb_schedule_dict and sb_schedule_dict['beneficiaryCandidateLastName']:
- sb_schedule_page_dict['beneficiaryName_' + str(index)] = (
- sb_schedule_dict['beneficiaryCandidateLastName'] + ','
- + sb_schedule_dict['beneficiaryCandidateFirstName'] + ','
- + sb_schedule_dict['beneficiaryCandidateMiddleName'] + ','
- + sb_schedule_dict['beneficiaryCandidatePrefix'] + ','
- + sb_schedule_dict['beneficiaryCandidateSuffix'])
-
- if 'expenditureAmount' in sb_schedule_dict:
- if sb_schedule_dict['expenditureAmount'] == '':
- sb_schedule_dict['expenditureAmount'] = 0.0
- sb_schedule_page_dict['expenditureAmount_' + str(index)] = '{0:.2f}'.format(
- sb_schedule_dict['expenditureAmount'])
- del sb_schedule_dict['expenditureAmount']
-
- if 'expenditureAggregate' in sb_schedule_dict:
- if sb_schedule_dict['expenditureAggregate'] == '':
- sb_schedule_dict['expenditureAggregate'] = 0.0
- sb_schedule_page_dict['expenditureAggregate_' + str(index)] = '{0:.2f}'.format(
- sb_schedule_dict['expenditureAggregate'])
- del sb_schedule_dict['expenditureAggregate']
+ if "payeeLastName" in sb_schedule_dict and sb_schedule_dict["payeeLastName"]:
+ sb_schedule_page_dict["payeeName_" + str(index)] = (
+ sb_schedule_dict["payeeLastName"]
+ + ","
+ + sb_schedule_dict["payeeFirstName"]
+ + ","
+ + sb_schedule_dict["payeeMiddleName"]
+ + ","
+ + sb_schedule_dict["payeePrefix"]
+ + ","
+ + sb_schedule_dict["payeeSuffix"]
+ )
+ elif "payeeOrganizationName" in sb_schedule_dict:
+ sb_schedule_page_dict["payeeName_" + str(index)] = sb_schedule_dict[
+ "payeeOrganizationName"
+ ]
+
+ if (
+ "beneficiaryCandidateLastName" in sb_schedule_dict
+ and sb_schedule_dict["beneficiaryCandidateLastName"]
+ ):
+ sb_schedule_page_dict["beneficiaryName_" + str(index)] = (
+ sb_schedule_dict["beneficiaryCandidateLastName"]
+ + ","
+ + sb_schedule_dict["beneficiaryCandidateFirstName"]
+ + ","
+ + sb_schedule_dict["beneficiaryCandidateMiddleName"]
+ + ","
+ + sb_schedule_dict["beneficiaryCandidatePrefix"]
+ + ","
+ + sb_schedule_dict["beneficiaryCandidateSuffix"]
+ )
+
+ if "expenditureAmount" in sb_schedule_dict:
+ if sb_schedule_dict["expenditureAmount"] == "":
+ sb_schedule_dict["expenditureAmount"] = 0.0
+ sb_schedule_page_dict["expenditureAmount_" + str(index)] = "{0:.2f}".format(
+ sb_schedule_dict["expenditureAmount"]
+ )
+ del sb_schedule_dict["expenditureAmount"]
+
+ if "expenditureAggregate" in sb_schedule_dict:
+ if sb_schedule_dict["expenditureAggregate"] == "":
+ sb_schedule_dict["expenditureAggregate"] = 0.0
+ sb_schedule_page_dict[
+ "expenditureAggregate_" + str(index)
+ ] = "{0:.2f}".format(sb_schedule_dict["expenditureAggregate"])
+ del sb_schedule_dict["expenditureAggregate"]
for key in sb_schedule_dict:
- if key != 'lineNumber':
- sb_schedule_page_dict[key + '_' + str(index)] = sb_schedule_dict[key]
+ if key != "lineNumber":
+ sb_schedule_page_dict[key + "_" + str(index)] = sb_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule A transaction: ' + str(sb_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule A transaction: "
+ + str(sb_schedule_dict)
+ )
raise e
# This method is invoked for each SA line number, it builds PDF for line numbers
-def process_sa_line(f3l_data, md5_directory, line_number, sa_line, sa_line_page_cnt, sa_line_start_page,
- sa_line_last_page_cnt, total_no_of_pages):
+def process_sa_line(
+ f3l_data,
+ md5_directory,
+ line_number,
+ sa_line,
+ sa_line_page_cnt,
+ sa_line_start_page,
+ sa_line_last_page_cnt,
+ total_no_of_pages,
+):
has_sa_schedules = False
if len(sa_line) > 0:
sa_line_start_page += 1
has_sa_schedules = True
schedule_total = 0.00
schedule_aggregate_total = 0.00
- os.makedirs(md5_directory + 'SA/' + line_number, exist_ok=True)
- sa_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SA3L')
+ os.makedirs(md5_directory + "SA/" + line_number, exist_ok=True)
+ sa_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SA3L")
if sa_line_page_cnt > 0:
for sa_page_no in range(sa_line_page_cnt):
@@ -552,41 +771,70 @@ def process_sa_line(f3l_data, md5_directory, line_number, sa_line, sa_line_page_
memo_array = []
last_page = False
sa_schedule_page_dict = {}
- sa_schedule_page_dict['lineNumber'] = line_number
- sa_schedule_page_dict['pageNo'] = sa_line_start_page + sa_page_no
- sa_schedule_page_dict['totalPages'] = total_no_of_pages
+ sa_schedule_page_dict["lineNumber"] = line_number
+ sa_schedule_page_dict["pageNo"] = sa_line_start_page + sa_page_no
+ sa_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sa_page_no * 4
- if ((sa_page_no + 1) == sa_line_page_cnt):
+ if (sa_page_no + 1) == sa_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sa_schedule_dict = build_sa_per_page_schedule_dict(last_page, sa_line_last_page_cnt,
- page_start_index, sa_schedule_page_dict,
- sa_line, memo_array)
-
- page_subtotal = float(sa_schedule_page_dict['pageSubtotal'])
- page_aggregate_total = float(sa_schedule_page_dict['pageAggSubtotal'])
+ sa_schedule_dict = build_sa_per_page_schedule_dict(
+ last_page,
+ sa_line_last_page_cnt,
+ page_start_index,
+ sa_schedule_page_dict,
+ sa_line,
+ memo_array,
+ )
+
+ page_subtotal = float(sa_schedule_page_dict["pageSubtotal"])
+ page_aggregate_total = float(sa_schedule_page_dict["pageAggSubtotal"])
schedule_total += page_subtotal
schedule_aggregate_total += page_aggregate_total
if sa_line_page_cnt == (sa_page_no + 1):
- sa_schedule_page_dict['scheduleTotal'] = '{0:.2f}'.format(schedule_total)
- sa_schedule_page_dict['scheduleAggTotal'] = '{0:.2f}'.format(page_aggregate_total)
- sa_schedule_page_dict['committeeName'] = f3l_data['committeeName']
- sa_outfile = md5_directory + 'SA/' + line_number + '/page_' + str(sa_page_no) + '.pdf'
+ sa_schedule_page_dict["scheduleTotal"] = "{0:.2f}".format(
+ schedule_total
+ )
+ sa_schedule_page_dict["scheduleAggTotal"] = "{0:.2f}".format(
+ page_aggregate_total
+ )
+ sa_schedule_page_dict["committeeName"] = f3l_data["committeeName"]
+ sa_outfile = (
+ md5_directory
+ + "SA/"
+ + line_number
+ + "/page_"
+ + str(sa_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sa_infile, sa_schedule_page_dict, sa_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SA/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SA/' + line_number + '/page_memo_' + str(sa_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SA/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SA/"
+ + line_number
+ + "/page_memo_"
+ + str(sa_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sa_outfile, memo_outfile], temp_memo_outfile)
@@ -596,40 +844,72 @@ def process_sa_line(f3l_data, md5_directory, line_number, sa_line, sa_line_page_
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SA/' + line_number + '/page_memo_' + str(sa_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[2]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[2]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[2]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SA/"
+ + line_number
+ + "/page_memo_"
+ + str(sa_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[2]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[2][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[2]["transactionId"]
if len(memo_array) >= 4:
- memo_dict['scheduleName_2'] = memo_array[3]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[3]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[3]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[3]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[3][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[3][
+ "transactionId"
+ ]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sa_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sa_outfile)
sa_line_start_page += 1
- pypdftk.concat(directory_files(md5_directory + 'SA/' + line_number + '/'), md5_directory + 'SA/' + line_number
- + '/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SA/" + line_number + "/"),
+ md5_directory + "SA/" + line_number + "/all_pages.pdf",
+ )
# if len(sa_memo) > 0:
# for sa_memo_obj in range(sa_memo):
# sa_outfile = md5_directory + 'SA/' + line_number + '/page_' + str(sa_page_no) + '.pdf'
# pypdftk.fill_form(sa_infile, sa_schedule_page_dict, sa_outfile)
# if all_pages.pdf exists in SA folder, concatenate line number pdf to all_pages.pdf
- if path.isfile(md5_directory + 'SA/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SA/all_pages.pdf', md5_directory + 'SA/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SA/temp_all_pages.pdf')
- os.rename(md5_directory + 'SA/temp_all_pages.pdf', md5_directory + 'SA/all_pages.pdf')
+ if path.isfile(md5_directory + "SA/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SA/all_pages.pdf",
+ md5_directory + "SA/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SA/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SA/temp_all_pages.pdf",
+ md5_directory + "SA/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SA/' + line_number + '/all_pages.pdf', md5_directory + 'SA/all_pages.pdf')
+ os.rename(
+ md5_directory + "SA/" + line_number + "/all_pages.pdf",
+ md5_directory + "SA/all_pages.pdf",
+ )
return has_sa_schedules
# This method builds data for individual SA page
-def build_sa_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sa_schedule_page_dict,
- sa_schedules, memo_array):
+def build_sa_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sa_schedule_page_dict,
+ sa_schedules,
+ memo_array,
+):
page_arg_subtotal = 0.00
page_subtotal = 0.00
if not last_page:
@@ -637,92 +917,144 @@ def build_sa_per_page_schedule_dict(last_page, transactions_in_page, page_start_
if transactions_in_page == 1:
for i in range(1):
- page_arg_subtotal, sa_schedule_dict, page_subtotal = building_sa_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sa_schedule_page_dict, sa_schedules,
- page_subtotal)
+ page_arg_subtotal, sa_schedule_dict, page_subtotal = building_sa_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sa_schedule_page_dict,
+ sa_schedules,
+ page_subtotal,
+ )
elif transactions_in_page == 2:
for i in range(2):
- page_arg_subtotal, sa_schedule_dict, page_subtotal = building_sa_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sa_schedule_page_dict, sa_schedules,
- page_subtotal)
+ page_arg_subtotal, sa_schedule_dict, page_subtotal = building_sa_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sa_schedule_page_dict,
+ sa_schedules,
+ page_subtotal,
+ )
elif transactions_in_page == 3:
for i in range(3):
- page_arg_subtotal, sa_schedule_dict, page_subtotal = building_sa_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sa_schedule_page_dict, sa_schedules,
- page_subtotal)
+ page_arg_subtotal, sa_schedule_dict, page_subtotal = building_sa_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sa_schedule_page_dict,
+ sa_schedules,
+ page_subtotal,
+ )
elif transactions_in_page == 4:
for i in range(4):
- page_arg_subtotal, sa_schedule_dict, page_subtotal = building_sa_index(i + 1, memo_array, page_start_index,
- page_arg_subtotal,
- sa_schedule_page_dict, sa_schedules,
- page_subtotal)
- sa_schedule_page_dict['pageAggSubtotal'] = '{0:.2f}'.format(page_arg_subtotal)
- sa_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
+ page_arg_subtotal, sa_schedule_dict, page_subtotal = building_sa_index(
+ i + 1,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sa_schedule_page_dict,
+ sa_schedules,
+ page_subtotal,
+ )
+ sa_schedule_page_dict["pageAggSubtotal"] = "{0:.2f}".format(page_arg_subtotal)
+ sa_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
return sa_schedule_dict
-def building_sa_index(i, memo_array, page_start_index, page_arg_subtotal, sa_schedule_page_dict, sa_schedules,
- page_subtotal):
+def building_sa_index(
+ i,
+ memo_array,
+ page_start_index,
+ page_arg_subtotal,
+ sa_schedule_page_dict,
+ sa_schedules,
+ page_subtotal,
+):
index = i
sa_schedule_dict = sa_schedules[page_start_index + i - 1]
- process_memo_text(sa_schedule_dict, 'SA', memo_array)
- if sa_schedule_dict['contributionAggregate'] != '':
- page_arg_subtotal += sa_schedule_dict['contributionAggregate']
- if sa_schedule_dict['contributionAmount'] != '':
- page_subtotal += sa_schedule_dict['contributionAmount']
- build_contributor_name_date_dict(index, page_start_index, sa_schedule_dict, sa_schedule_page_dict)
+ process_memo_text(sa_schedule_dict, "SA", memo_array)
+ if sa_schedule_dict["contributionAggregate"] != "":
+ page_arg_subtotal += sa_schedule_dict["contributionAggregate"]
+ if sa_schedule_dict["contributionAmount"] != "":
+ page_subtotal += sa_schedule_dict["contributionAmount"]
+ build_contributor_name_date_dict(
+ index, page_start_index, sa_schedule_dict, sa_schedule_page_dict
+ )
return page_arg_subtotal, sa_schedule_dict, page_subtotal
# This method filters data and message data to render PDF
-def build_contributor_name_date_dict(index, key, sa_schedule_dict, sa_schedule_page_dict):
+def build_contributor_name_date_dict(
+ index, key, sa_schedule_dict, sa_schedule_page_dict
+):
try:
- if 'contributorLastName' in sa_schedule_dict and sa_schedule_dict['contributorLastName']:
- sa_schedule_page_dict['contributorName_' + str(index)] = (sa_schedule_dict['contributorLastName'] + ','
- + sa_schedule_dict['contributorFirstName'] + ','
- + sa_schedule_dict['contributorMiddleName'] + ','
- + sa_schedule_dict['contributorPrefix'] + ','
- + sa_schedule_dict['contributorSuffix'])
- del sa_schedule_dict['contributorLastName']
- del sa_schedule_dict['contributorFirstName']
- del sa_schedule_dict['contributorMiddleName']
- del sa_schedule_dict['contributorPrefix']
- del sa_schedule_dict['contributorSuffix']
- elif 'contributorOrgName' in sa_schedule_dict:
- sa_schedule_page_dict["contributorName_" + str(index)] = sa_schedule_dict['contributorOrgName']
- del sa_schedule_dict['contributorOrgName']
-
- if 'contributionAmount' in sa_schedule_dict:
- if sa_schedule_dict['contributionAmount'] == '':
- sa_schedule_dict['contributionAmount'] = 0.0
- sa_schedule_page_dict['contributionAmount_' + str(index)] = '{0:.2f}'.format(
- sa_schedule_dict['contributionAmount'])
- del sa_schedule_dict['contributionAmount']
-
- if 'contributionAggregate' in sa_schedule_dict:
- if sa_schedule_dict['contributionAggregate'] == '':
- sa_schedule_dict['contributionAggregate'] = 0.0
- sa_schedule_page_dict['contributionAggregate_' + str(index)] = '{0:.2f}'.format(
- sa_schedule_dict['contributionAggregate'])
- del sa_schedule_dict['contributionAggregate']
+ if (
+ "contributorLastName" in sa_schedule_dict
+ and sa_schedule_dict["contributorLastName"]
+ ):
+ sa_schedule_page_dict["contributorName_" + str(index)] = (
+ sa_schedule_dict["contributorLastName"]
+ + ","
+ + sa_schedule_dict["contributorFirstName"]
+ + ","
+ + sa_schedule_dict["contributorMiddleName"]
+ + ","
+ + sa_schedule_dict["contributorPrefix"]
+ + ","
+ + sa_schedule_dict["contributorSuffix"]
+ )
+ del sa_schedule_dict["contributorLastName"]
+ del sa_schedule_dict["contributorFirstName"]
+ del sa_schedule_dict["contributorMiddleName"]
+ del sa_schedule_dict["contributorPrefix"]
+ del sa_schedule_dict["contributorSuffix"]
+ elif "contributorOrgName" in sa_schedule_dict:
+ sa_schedule_page_dict["contributorName_" + str(index)] = sa_schedule_dict[
+ "contributorOrgName"
+ ]
+ del sa_schedule_dict["contributorOrgName"]
+
+ if "contributionAmount" in sa_schedule_dict:
+ if sa_schedule_dict["contributionAmount"] == "":
+ sa_schedule_dict["contributionAmount"] = 0.0
+ sa_schedule_page_dict[
+ "contributionAmount_" + str(index)
+ ] = "{0:.2f}".format(sa_schedule_dict["contributionAmount"])
+ del sa_schedule_dict["contributionAmount"]
+
+ if "contributionAggregate" in sa_schedule_dict:
+ if sa_schedule_dict["contributionAggregate"] == "":
+ sa_schedule_dict["contributionAggregate"] = 0.0
+ sa_schedule_page_dict[
+ "contributionAggregate_" + str(index)
+ ] = "{0:.2f}".format(sa_schedule_dict["contributionAggregate"])
+ del sa_schedule_dict["contributionAggregate"]
for key in sa_schedule_dict:
- if key != 'lineNumber':
- sa_schedule_page_dict[key + '_' + str(index)] = sa_schedule_dict[key]
+ if key != "lineNumber":
+ sa_schedule_page_dict[key + "_" + str(index)] = sa_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule A transaction: ' + str(sa_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule A transaction: "
+ + str(sa_schedule_dict)
+ )
raise e
def process_memo_text(schedule_dict, schedule, memo_array):
- if 'memoDescription' in schedule_dict and schedule_dict['memoDescription']:
+ if "memoDescription" in schedule_dict and schedule_dict["memoDescription"]:
memo_array.append(
- {'scheduleName': schedule + schedule_dict['lineNumber'],
- 'memoDescription': schedule_dict['memoDescription'],
- 'transactionId': schedule_dict['transactionId']})
+ {
+ "scheduleName": schedule + schedule_dict["lineNumber"],
+ "memoDescription": schedule_dict["memoDescription"],
+ "transactionId": schedule_dict["transactionId"],
+ }
+ )
def calculate_sa_page_count(schedules):
@@ -748,42 +1080,54 @@ def calculate_sb_page_count(schedules):
def process_sa_line_numbers(sa_11a, sa_11a_memo, sa_obj):
- if sa_obj['lineNumber'] == '3L':
+ if sa_obj["lineNumber"] == "3L":
sa_11a.append(sa_obj)
- if sa_obj['memoDescription']:
+ if sa_obj["memoDescription"]:
sa_11a_memo.append(
- {'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
def process_sb_line_numbers(sb_17, sa_17_memo, sb_obj):
- if sb_obj['lineNumber'] == '3L':
+ if sb_obj["lineNumber"] == "3L":
sb_17.append(sb_obj)
- if sb_obj['memoDescription']:
+ if sb_obj["memoDescription"]:
sa_17_memo.append(
- {'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
def print_f24(print_dict, page_index, reportId, json_file_md5):
try:
- md5_directory = current_app.config['OUTPUT_DIR_LOCATION'].format(json_file_md5)
- infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('F24')
- outfile = md5_directory + json_file_md5 + '_temp.pdf'
+ md5_directory = current_app.config["OUTPUT_DIR_LOCATION"].format(json_file_md5)
+ infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("F24")
+ outfile = md5_directory + json_file_md5 + "_temp.pdf"
pypdftk.fill_form(infile, print_dict, outfile)
- shutil.copy(outfile, md5_directory + reportId + '/F24_{}.pdf'.format(page_index))
+ shutil.copy(
+ outfile, md5_directory + reportId + "/F24_{}.pdf".format(page_index)
+ )
os.remove(outfile)
except Exception as e:
- return error('print_f24 error, error message: ' + str(e))
+ return error("print_f24 error, error message: " + str(e))
def print_summ(print_dict, page_index, reportId, json_file_md5):
try:
- md5_directory = current_app.config['OUTPUT_DIR_LOCATION'].format(json_file_md5)
- infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- outfile = md5_directory + json_file_md5 + '_temp.pdf'
+ md5_directory = current_app.config["OUTPUT_DIR_LOCATION"].format(json_file_md5)
+ infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("TEXT")
+ outfile = md5_directory + json_file_md5 + "_temp.pdf"
pypdftk.fill_form(infile, print_dict, outfile)
- shutil.copy(outfile, md5_directory + reportId + '/F24_{}.pdf'.format(page_index))
+ shutil.copy(
+ outfile, md5_directory + reportId + "/F24_{}.pdf".format(page_index)
+ )
os.remove(outfile)
except Exception as e:
- return error('print_f24_summ error, error message: ' + str(e))
+ return error("print_f24_summ error, error message: " + str(e))
diff --git a/routes/src/form3x.py b/routes/src/form3x.py
index 6f6419a..2200483 100644
--- a/routes/src/form3x.py
+++ b/routes/src/form3x.py
@@ -1,6 +1,5 @@
import flask
import boto3
-import re
import os
import os.path
import pypdftk
@@ -10,9 +9,7 @@
from flask import json
from flask import request, current_app
from flask_api import status
-from routes.src import tmoflask, utils, common, form
-from PyPDF2 import PdfFileWriter, PdfFileReader, PdfFileMerger
-from PyPDF2.generic import BooleanObject, NameObject, IndirectObject
+from routes.src import utils, common
# return the list of files in a directory
@@ -33,9 +30,7 @@ def merge(dict1, dict2):
# Error handling
def error(msg):
if flask.request.method == "POST":
- envelope = common.get_return_envelope(
- 'false', msg
- )
+ envelope = common.get_return_envelope("false", msg)
status_code = status.HTTP_400_BAD_REQUEST
return flask.jsonify(**envelope), status_code
@@ -44,21 +39,33 @@ def error(msg):
def print_pdftk(stamp_print):
# check if json_file is in the request
try:
- if 'json_file' in request.files:
+ if "json_file" in request.files:
total_no_of_pages = 0
page_no = 1
- has_sa_schedules = has_sb_schedules = has_la_schedules = has_slb_schedules = has_sl_summary = False
-
- has_sh6_schedules = has_sh4_schedules = has_sh5_schedules = has_sh3_schedules =has_sh1_schedules=has_sh2_schedules =has_sf_schedules = has_se_schedules =False
-
- json_file = request.files.get('json_file')
+ has_sa_schedules = (
+ has_sb_schedules
+ ) = has_la_schedules = has_slb_schedules = has_sl_summary = False
+
+ has_sh6_schedules = (
+ has_sh4_schedules
+ ) = (
+ has_sh5_schedules
+ ) = (
+ has_sh3_schedules
+ ) = (
+ has_sh1_schedules
+ ) = has_sh2_schedules = has_sf_schedules = has_se_schedules = False
+
+ json_file = request.files.get("json_file")
# generate md5 for json file
# FIXME: check if PDF already exist with md5, if exist return pdf instead of re-generating PDF file.
json_file_md5 = utils.md5_for_file(json_file)
json_file.stream.seek(0)
- md5_directory = current_app.config['OUTPUT_DIR_LOCATION'].format(json_file_md5)
+ md5_directory = current_app.config["OUTPUT_DIR_LOCATION"].format(
+ json_file_md5
+ )
# checking if server has already generated pdf for same json file
# if os.path.isdir(md5_directory) and path.isfile(md5_directory + 'all_pages.pdf'):
# # push output file to AWS
@@ -80,350 +87,675 @@ def print_pdftk(stamp_print):
# return flask.jsonify(**envelope), status_code
#
os.makedirs(md5_directory, exist_ok=True)
- infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('F3X')
+ infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("F3X")
# save json file as md5 file name
- json_file.save(current_app.config['REQUEST_FILE_LOCATION'].format(json_file_md5))
- outfile = md5_directory + json_file_md5 + '_temp.pdf'
+ json_file.save(
+ current_app.config["REQUEST_FILE_LOCATION"].format(json_file_md5)
+ )
+ outfile = md5_directory + json_file_md5 + "_temp.pdf"
# load json file
- f3x_json = json.load(open(current_app.config['REQUEST_FILE_LOCATION'].format(json_file_md5)))
+ f3x_json = json.load(
+ open(current_app.config["REQUEST_FILE_LOCATION"].format(json_file_md5))
+ )
# setting timestamp and imgno to empty as these needs to show up after submission
- if stamp_print != 'stamp':
- f3x_json['FILING_TIMESTAMP'] = ''
- f3x_json['IMGNO'] = ''
+ if stamp_print != "stamp":
+ f3x_json["FILING_TIMESTAMP"] = ""
+ f3x_json["IMGNO"] = ""
# read data from json file
- f3x_data = f3x_json['data']
+ f3x_data = f3x_json["data"]
# check if summary is present in fecDataFile
f3x_summary = []
- if 'summary' in f3x_data:
- f3x_summary_temp = f3x_data['summary']
- f3x_summary = {'cashOnHandYear': f3x_summary_temp['cashOnHandYear']}
+ if "summary" in f3x_data:
+ f3x_summary_temp = f3x_data["summary"]
+ f3x_summary = {"cashOnHandYear": f3x_summary_temp["cashOnHandYear"]}
# building colA_ and colB_ mapping data for PDF
- f3x_col_a = f3x_summary_temp['colA']
- f3x_col_b = f3x_summary_temp['colB']
+ f3x_col_a = f3x_summary_temp["colA"]
+ f3x_col_b = f3x_summary_temp["colB"]
for key in f3x_col_a:
- f3x_summary['colA_' + key] = '{0:.2f}'.format(f3x_col_a[key])
+ f3x_summary["colA_" + key] = "{0:.2f}".format(f3x_col_a[key])
for key in f3x_col_b:
- f3x_summary['colB_' + key] = '{0:.2f}'.format(f3x_col_b[key])
+ f3x_summary["colB_" + key] = "{0:.2f}".format(f3x_col_b[key])
# split coverage start date and coverage end date to set month, day, and year
- coverage_start_date_array = f3x_data['coverageStartDate'].split("/")
- f3x_data['coverageStartDateMonth'] = coverage_start_date_array[0]
- f3x_data['coverageStartDateDay'] = coverage_start_date_array[1]
- f3x_data['coverageStartDateYear'] = coverage_start_date_array[2]
+ coverage_start_date_array = f3x_data["coverageStartDate"].split("/")
+ f3x_data["coverageStartDateMonth"] = coverage_start_date_array[0]
+ f3x_data["coverageStartDateDay"] = coverage_start_date_array[1]
+ f3x_data["coverageStartDateYear"] = coverage_start_date_array[2]
- coverage_end_date_array = f3x_data['coverageEndDate'].split("/")
- f3x_data['coverageEndDateMonth'] = coverage_end_date_array[0]
- f3x_data['coverageEndDateDay'] = coverage_end_date_array[1]
- f3x_data['coverageEndDateYear'] = coverage_end_date_array[2]
+ coverage_end_date_array = f3x_data["coverageEndDate"].split("/")
+ f3x_data["coverageEndDateMonth"] = coverage_end_date_array[0]
+ f3x_data["coverageEndDateDay"] = coverage_end_date_array[1]
+ f3x_data["coverageEndDateYear"] = coverage_end_date_array[2]
# checking for signed date, it is only available for submitted reports
- if len(f3x_data['dateSigned']) > 0:
- date_signed_array = f3x_data['dateSigned'].split("/")
- f3x_data['dateSignedMonth'] = date_signed_array[0]
- f3x_data['dateSignedDay'] = date_signed_array[1]
- f3x_data['dateSignedYear'] = date_signed_array[2]
+ if len(f3x_data["dateSigned"]) > 0:
+ date_signed_array = f3x_data["dateSigned"].split("/")
+ f3x_data["dateSignedMonth"] = date_signed_array[0]
+ f3x_data["dateSignedDay"] = date_signed_array[1]
+ f3x_data["dateSignedYear"] = date_signed_array[2]
# build treasurer name to map it to PDF template
treasurer_full_name = []
- treasurer_full_name.append(f3x_data['treasurerLastName'])
- treasurer_full_name.append(f3x_data['treasurerFirstName'])
- treasurer_full_name.append(f3x_data['treasurerMiddleName'])
- treasurer_full_name.append(f3x_data['treasurerPrefix'])
- treasurer_full_name.append(f3x_data['treasurerSuffix'])
- f3x_data['treasurerFullName'] = ",".join(map(str, treasurer_full_name))
- f3x_data['treasurerName'] = f3x_data['treasurerLastName'] + "," + f3x_data['treasurerFirstName']
- f3x_data['efStamp'] = '[Electronically Filed]'
+ treasurer_full_name.append(f3x_data["treasurerLastName"])
+ treasurer_full_name.append(f3x_data["treasurerFirstName"])
+ treasurer_full_name.append(f3x_data["treasurerMiddleName"])
+ treasurer_full_name.append(f3x_data["treasurerPrefix"])
+ treasurer_full_name.append(f3x_data["treasurerSuffix"])
+ f3x_data["treasurerFullName"] = ",".join(map(str, treasurer_full_name))
+ f3x_data["treasurerName"] = (
+ f3x_data["treasurerLastName"] + "," + f3x_data["treasurerFirstName"]
+ )
+ f3x_data["efStamp"] = "[Electronically Filed]"
# checking if json contains summary details, for individual transactions print there wouldn't be summary
if len(f3x_summary) > 0:
total_no_of_pages = 5
f3x_data_summary_array = [f3x_data, f3x_summary]
- if 'memoText' in f3x_data and f3x_data['memoText']:
+ if "memoText" in f3x_data and f3x_data["memoText"]:
total_no_of_pages += 1
else:
f3x_data_summary_array = [f3x_data]
- f3x_data_summary = {i: j for x in f3x_data_summary_array for i, j in x.items()}
-
+ f3x_data_summary = {
+ i: j for x in f3x_data_summary_array for i, j in x.items()
+ }
# process all schedules and build the PDF's
- process_output, total_no_of_pages = process_schedules(f3x_data, md5_directory,total_no_of_pages)
-
-
- has_sa_schedules = process_output.get('has_sa_schedules')
- has_sb_schedules = process_output.get('has_sb_schedules')
- has_sc_schedules = process_output.get('has_sc_schedules')
- has_sd_schedules = process_output.get('has_sd_schedules')
- has_la_schedules = process_output.get('has_la_schedules')
- has_sh6_schedules = process_output.get('has_sh6_schedules')
- has_sh4_schedules = process_output.get('has_sh4_schedules')
- has_sh5_schedules = process_output.get('has_sh5_schedules')
- has_sh3_schedules = process_output.get('has_sh3_schedules')
- has_sh2_schedules = process_output.get('has_sh2_schedules')
- has_sh1_schedules = process_output.get('has_sh1_schedules')
- has_slb_schedules= process_output.get('has_slb_schedules')
- has_sf_schedules = process_output.get('has_sf_schedules')
- has_se_schedules = process_output.get('has_se_schedules')
- has_sl_summary= process_output.get('has_sl_summary')
+ process_output, total_no_of_pages = process_schedules(
+ f3x_data, md5_directory, total_no_of_pages
+ )
+
+ has_sa_schedules = process_output.get("has_sa_schedules")
+ has_sb_schedules = process_output.get("has_sb_schedules")
+ has_sc_schedules = process_output.get("has_sc_schedules")
+ has_sd_schedules = process_output.get("has_sd_schedules")
+ has_la_schedules = process_output.get("has_la_schedules")
+ has_sh6_schedules = process_output.get("has_sh6_schedules")
+ has_sh4_schedules = process_output.get("has_sh4_schedules")
+ has_sh5_schedules = process_output.get("has_sh5_schedules")
+ has_sh3_schedules = process_output.get("has_sh3_schedules")
+ has_sh2_schedules = process_output.get("has_sh2_schedules")
+ has_sh1_schedules = process_output.get("has_sh1_schedules")
+ has_slb_schedules = process_output.get("has_slb_schedules")
+ has_sf_schedules = process_output.get("has_sf_schedules")
+ has_se_schedules = process_output.get("has_se_schedules")
+ has_sl_summary = process_output.get("has_sl_summary")
if len(f3x_summary) > 0:
- f3x_data_summary['PAGESTR'] = "PAGE " + str(page_no) + " / " + str(total_no_of_pages)
+ f3x_data_summary["PAGESTR"] = (
+ "PAGE " + str(page_no) + " / " + str(total_no_of_pages)
+ )
pypdftk.fill_form(infile, f3x_data_summary, outfile)
- shutil.copy(outfile, md5_directory + 'F3X_Summary.pdf')
- os.remove(md5_directory + json_file_md5 + '_temp.pdf')
+ shutil.copy(outfile, md5_directory + "F3X_Summary.pdf")
+ os.remove(md5_directory + json_file_md5 + "_temp.pdf")
# Memo text changes
- if 'memoText' in f3x_data_summary and f3x_data_summary['memoText']:
+ if "memoText" in f3x_data_summary and f3x_data_summary["memoText"]:
memo_dict = {}
- temp_memo_outfile = md5_directory + 'F3X_Summary_memo.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_dict['scheduleName_1'] = 'F3X' + f3x_data_summary['amendmentIndicator']
- memo_dict['memoDescription_1'] = f3x_data_summary['memoText']
- memo_dict['PAGESTR'] = "PAGE " + str(6) + " / " + str(total_no_of_pages)
+ temp_memo_outfile = md5_directory + "F3X_Summary_memo.pdf"
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_dict["scheduleName_1"] = (
+ "F3X" + f3x_data_summary["amendmentIndicator"]
+ )
+ memo_dict["memoDescription_1"] = f3x_data_summary["memoText"]
+ memo_dict["PAGESTR"] = (
+ "PAGE " + str(6) + " / " + str(total_no_of_pages)
+ )
pypdftk.fill_form(memo_infile, memo_dict, temp_memo_outfile)
- pypdftk.concat([md5_directory + 'F3X_Summary.pdf', temp_memo_outfile], md5_directory +
- json_file_md5 + '_temp.pdf')
- shutil.copy(md5_directory + json_file_md5 + '_temp.pdf', md5_directory + 'F3X_Summary.pdf')
- os.remove(md5_directory + json_file_md5 + '_temp.pdf')
+ pypdftk.concat(
+ [md5_directory + "F3X_Summary.pdf", temp_memo_outfile],
+ md5_directory + json_file_md5 + "_temp.pdf",
+ )
+ shutil.copy(
+ md5_directory + json_file_md5 + "_temp.pdf",
+ md5_directory + "F3X_Summary.pdf",
+ )
+ os.remove(md5_directory + json_file_md5 + "_temp.pdf")
# checking for sa transactions
if has_sa_schedules:
- pypdftk.concat([md5_directory + 'F3X_Summary.pdf', md5_directory + 'SA/all_pages.pdf'], md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SA/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SA')
+ pypdftk.concat(
+ [
+ md5_directory + "F3X_Summary.pdf",
+ md5_directory + "SA/all_pages.pdf",
+ ],
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SA/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SA")
else:
- shutil.copy(md5_directory + 'F3X_Summary.pdf', md5_directory + 'all_pages.pdf')
+ shutil.copy(
+ md5_directory + "F3X_Summary.pdf",
+ md5_directory + "all_pages.pdf",
+ )
# checking for sb transactions
if has_sb_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SB/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SB/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SB')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SB/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SB/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SB")
# checking for sc transactions
if has_sc_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SC/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SC/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SC')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SC/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SC/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SC")
# checking for sd transactions
if has_sd_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SD/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SD/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SD')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SD/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SD/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SD")
if has_se_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SE/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SE/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SE')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SE/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SE/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SE")
if has_sf_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SF/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SF/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SF')
-
- if has_sh1_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH1/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SH1/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH1')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SF/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SF/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SF")
+ if has_sh1_schedules:
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH1/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SH1/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SH1")
if has_sh2_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH2/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SH2/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH2')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH2/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SH2/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SH2")
if has_sh3_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH3/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SH3/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH3')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH3/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SH3/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SH3")
if has_sh4_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH4/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SH4/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH4')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH4/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SH4/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SH4")
if has_sh5_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH5/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SH5/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH5')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH5/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SH5/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SH5")
if has_sh6_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH6/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SH6/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH6')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH6/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SH6/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SH6")
if has_sl_summary:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SL/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SL/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SL')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SL/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SL/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SL")
if has_la_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SL-A/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SL-A/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SL-A')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SL-A/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SL-A/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SL-A")
if has_slb_schedules:
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SL-B/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SL-B/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SL-B')
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SL-B/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SL-B/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SL-B")
-
else:
# no summary, expecting it to be from individual transactions
if has_sa_schedules:
- shutil.move(md5_directory + 'SA/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SA')
+ shutil.move(
+ md5_directory + "SA/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SA")
if has_sb_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SB/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SB/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SB/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SB')
+ shutil.move(
+ md5_directory + "SB/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SB")
if has_sc_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SC/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SC/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SC/all_pages.pdf', md5_directory + 'all_pages.pdf')
- os.remove(md5_directory + 'SC/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SC')
+ shutil.move(
+ md5_directory + "SC/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ os.remove(md5_directory + "SC/all_pages.pdf")
+ shutil.rmtree(md5_directory + "SC")
# checking for sd transactions
if has_sd_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SD/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SD/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SD/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SD')
-
+ shutil.move(
+ md5_directory + "SD/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SD")
if has_se_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SE/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SE/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SE/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SE')
+ shutil.move(
+ md5_directory + "SE/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SE")
if has_sf_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SF/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SF/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SF/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SF')
+ shutil.move(
+ md5_directory + "SF/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SF")
if has_sh1_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH1/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH1/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SH1/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH1')
+ shutil.move(
+ md5_directory + "SH1/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SH1")
if has_sh2_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH2/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH2/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SH2/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH2')
+ shutil.move(
+ md5_directory + "SH2/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SH2")
if has_sh3_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH3/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH3/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SH3/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH3')
+ shutil.move(
+ md5_directory + "SH3/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SH3")
if has_sh4_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH4/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH4/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SH4/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH4')
+ shutil.move(
+ md5_directory + "SH4/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SH4")
if has_sh5_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH5/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH5/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SH5/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH5')
+ shutil.move(
+ md5_directory + "SH5/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SH5")
if has_sh6_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SH6/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SH6/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SH6/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SH6')
+ shutil.move(
+ md5_directory + "SH6/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SH6")
if has_sl_summary:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SL/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SL/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SL/all_pages.pdf', md5_directory + 'all_pages.pdf')
- shutil.rmtree(md5_directory + 'SL')
+ shutil.move(
+ md5_directory + "SL/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ shutil.rmtree(md5_directory + "SL")
if has_la_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SL-A/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SL-A/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SL-A/all_pages.pdf', md5_directory + 'all_pages.pdf')
- #os.remove(md5_directory + 'SL-A/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SL-A')
+ shutil.move(
+ md5_directory + "SL-A/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ # os.remove(md5_directory + 'SL-A/all_pages.pdf')
+ shutil.rmtree(md5_directory + "SL-A")
if has_slb_schedules:
- if path.exists(md5_directory + 'all_pages.pdf'):
- pypdftk.concat([md5_directory + 'all_pages.pdf', md5_directory + 'SL-B/all_pages.pdf'], md5_directory + 'temp_all_pages.pdf')
- shutil.move(md5_directory + 'temp_all_pages.pdf', md5_directory + 'all_pages.pdf')
+ if path.exists(md5_directory + "all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "all_pages.pdf",
+ md5_directory + "SL-B/all_pages.pdf",
+ ],
+ md5_directory + "temp_all_pages.pdf",
+ )
+ shutil.move(
+ md5_directory + "temp_all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
else:
- shutil.move(md5_directory + 'SL-B/all_pages.pdf', md5_directory + 'all_pages.pdf')
- #os.remove(md5_directory + 'SL-B/all_pages.pdf')
- shutil.rmtree(md5_directory + 'SL-B')
+ shutil.move(
+ md5_directory + "SL-B/all_pages.pdf",
+ md5_directory + "all_pages.pdf",
+ )
+ # os.remove(md5_directory + 'SL-B/all_pages.pdf')
+ shutil.rmtree(md5_directory + "SL-B")
-
-
-
# push output file to AWS
- s3 = boto3.client('s3')
- s3.upload_file(md5_directory + 'all_pages.pdf', current_app.config['AWS_FECFILE_COMPONENTS_BUCKET_NAME'],
- md5_directory + 'all_pages.pdf',
- ExtraArgs={'ContentType': "application/pdf", 'ACL': "public-read"})
+ s3 = boto3.client("s3")
+ s3.upload_file(
+ md5_directory + "all_pages.pdf",
+ current_app.config["AWS_FECFILE_COMPONENTS_BUCKET_NAME"],
+ md5_directory + "all_pages.pdf",
+ ExtraArgs={"ContentType": "application/pdf", "ACL": "public-read"},
+ )
response = {
# 'file_name': '{}.pdf'.format(json_file_md5),
- 'pdf_url': current_app.config['PRINT_OUTPUT_FILE_URL'].format(json_file_md5) + 'all_pages.pdf'
+ "pdf_url": current_app.config["PRINT_OUTPUT_FILE_URL"].format(
+ json_file_md5
+ )
+ + "all_pages.pdf"
}
# return response
if flask.request.method == "POST":
- envelope = common.get_return_envelope(
- data=response
- )
+ envelope = common.get_return_envelope(data=response)
status_code = status.HTTP_201_CREATED
return flask.jsonify(**envelope), status_code
@@ -431,20 +763,19 @@ def print_pdftk(stamp_print):
if flask.request.method == "POST":
envelope = common.get_return_envelope(
- 'false', 'JSON file is missing from your request'
+ "false", "JSON file is missing from your request"
)
status_code = status.HTTP_400_BAD_REQUEST
return flask.jsonify(**envelope), status_code
except Exception as e:
- return error('Error generating print preview, error message: ' + str(e))
+ return error("Error generating print preview, error message: " + str(e))
def process_schedules(f3x_data, md5_directory, total_no_of_pages):
# Calculate total number of pages for schedules
- sb_line_numbers = ['21B', '22', '23', '26', '27', '28A', '28B', '28C', '29', '30B']
- slb_line_numbers = []
- sc_sa_line_numbers = ['13', '14']
- sc_sb_line_numbers = ['26', '27']
+ sb_line_numbers = ["21B", "22", "23", "26", "27", "28A", "28B", "28C", "29", "30B"]
+ sc_sa_line_numbers = ["13", "14"]
+ sc_sb_line_numbers = ["26", "27"]
sa_schedules = []
sb_schedules = []
la_schedules = []
@@ -453,91 +784,138 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
sh_schedules = []
sf_schedules = []
se_schedules = []
- se_line_numbers=['24']
+ se_line_numbers = ["24"]
# sf_line_numbers=[]
- has_sc_schedules = has_sa_schedules = has_sb_schedules = has_sd_schedules = has_sl_summary= has_la_schedules = has_slb_schedules = has_sf_schedules= has_se_schedules = False
-
- has_sh6_schedules = has_sh4_schedules = has_sh5_schedules = has_sh3_schedules= has_sh1_schedules = has_sh2_schedules = False
- sa_schedules_cnt = sb_schedules_cnt = sh_schedules_cnt = sh4_schedules_cnt = sh6_schedules_cnt = sh5_schedules_cnt=sh3_schedules_cnt= sh1_schedules_cnt = sh2_schedules_cnt = sf_schedules_cnt= se_schedules_cnt= 0
+ has_sc_schedules = (
+ has_sa_schedules
+ ) = (
+ has_sb_schedules
+ ) = (
+ has_sd_schedules
+ ) = (
+ has_sl_summary
+ ) = (
+ has_la_schedules
+ ) = has_slb_schedules = has_sf_schedules = has_se_schedules = False
+
+ has_sh6_schedules = (
+ has_sh4_schedules
+ ) = (
+ has_sh5_schedules
+ ) = has_sh3_schedules = has_sh1_schedules = has_sh2_schedules = False
+ sa_schedules_cnt = (
+ sb_schedules_cnt
+ ) = (
+ sh_schedules_cnt
+ ) = (
+ sh4_schedules_cnt
+ ) = (
+ sh6_schedules_cnt
+ ) = (
+ sh5_schedules_cnt
+ ) = (
+ sh3_schedules_cnt
+ ) = sh1_schedules_cnt = sh2_schedules_cnt = sf_schedules_cnt = se_schedules_cnt = 0
la_schedules_cnt = slb_schedules_cnt = sl_summary_cnt = 0
total_sc_pages = 0
total_sd_pages = 0
- totalOutstandingLoans = '0.00'
+ totalOutstandingLoans = "0.00"
# check if schedules exist in data file
- if 'schedules' in f3x_data:
- schedules = f3x_data['schedules']
-
+ if "schedules" in f3x_data:
+ schedules = f3x_data["schedules"]
# Checking SC first as it has SA and SB transactions in it
- if 'SC' in schedules:
- sc_schedules = schedules.get('SC')
+ if "SC" in schedules:
+ sc_schedules = schedules.get("SC")
sc_schedules_cnt = len(sc_schedules)
sc1_schedules_cnt = 0
additional_sc_pg_cnt = 0
if sc_schedules_cnt > 0:
has_sc_schedules = True
- os.makedirs(md5_directory + 'SC', exist_ok=True)
+ os.makedirs(md5_directory + "SC", exist_ok=True)
for sc_count in range(sc_schedules_cnt):
- if 'child' in sc_schedules[sc_count]:
- sc_child_schedules = sc_schedules[sc_count]['child']
+ if "child" in sc_schedules[sc_count]:
+ sc_child_schedules = sc_schedules[sc_count]["child"]
sc_child_schedules_count = len(sc_child_schedules)
sc2_schedules_cnt = 0
for sc_child_count in range(sc_child_schedules_count):
- if sc_schedules[sc_count].get('child')[sc_child_count].get('lineNumber') in sc_sa_line_numbers:
- if 'SA' not in schedules:
- schedules['SA'] = []
- schedules['SA'].append(sc_schedules[sc_count]['child'][sc_child_count])
- elif sc_schedules[sc_count]['child'][sc_child_count]['lineNumber'] in sc_sb_line_numbers:
- if 'SB' not in schedules:
- schedules['SB'] = []
- schedules['SB'].append(sc_schedules[sc_count]['child'][sc_child_count])
- elif sc_schedules[sc_count]['child'][sc_child_count]['transactionTypeIdentifier'] in ['SC1']:
+ if (
+ sc_schedules[sc_count]
+ .get("child")[sc_child_count]
+ .get("lineNumber")
+ in sc_sa_line_numbers
+ ):
+ if "SA" not in schedules:
+ schedules["SA"] = []
+ schedules["SA"].append(
+ sc_schedules[sc_count]["child"][sc_child_count]
+ )
+ elif (
+ sc_schedules[sc_count]["child"][sc_child_count][
+ "lineNumber"
+ ]
+ in sc_sb_line_numbers
+ ):
+ if "SB" not in schedules:
+ schedules["SB"] = []
+ schedules["SB"].append(
+ sc_schedules[sc_count]["child"][sc_child_count]
+ )
+ elif sc_schedules[sc_count]["child"][sc_child_count][
+ "transactionTypeIdentifier"
+ ] in ["SC1"]:
sc1_schedules_cnt += 1
- elif sc_schedules[sc_count]['child'][sc_child_count]['transactionTypeIdentifier'] in ['SC2']:
+ elif sc_schedules[sc_count]["child"][sc_child_count][
+ "transactionTypeIdentifier"
+ ] in ["SC2"]:
sc2_schedules_cnt += 1
if sc2_schedules_cnt > 4:
- additional_sc_pg_cnt += int(sc2_schedules_cnt/4)
+ additional_sc_pg_cnt += int(sc2_schedules_cnt / 4)
total_sc_pages = sc_schedules_cnt + sc1_schedules_cnt + additional_sc_pg_cnt
- #checking SD before SA and SB as SD has SB transactions as childs
- if 'SD' in schedules:
- sd_schedules = schedules.get('SD')
+ # checking SD before SA and SB as SD has SB transactions as childs
+ if "SD" in schedules:
+ sd_schedules = schedules.get("SD")
sd_schedules_cnt = len(sd_schedules)
total_sd_pages = 0
line_9_list = []
line_10_list = []
if sd_schedules_cnt > 0:
has_sd_schedules = True
- os.makedirs(md5_directory + 'SD', exist_ok=True)
+ os.makedirs(md5_directory + "SD", exist_ok=True)
for sd in sd_schedules:
- if sd.get('lineNumber') == '9':
+ if sd.get("lineNumber") == "9":
line_9_list.append(sd)
else:
line_10_list.append(sd)
- if 'child' in sd:
- sd_children = sd.get('child')
+ if "child" in sd:
+ sd_children = sd.get("child")
for sd_child in sd_children:
- if sd_child.get('transactionTypeIdentifier') in ['OPEXP_DEBT', 'FEA_100PCT_DEBT_PAY', 'OTH_DISB_DEBT']:
- if 'SB' not in schedules:
- schedules['SB'] = []
- schedules['SB'].append(sd_child)
+ if sd_child.get("transactionTypeIdentifier") in [
+ "OPEXP_DEBT",
+ "FEA_100PCT_DEBT_PAY",
+ "OTH_DISB_DEBT",
+ ]:
+ if "SB" not in schedules:
+ schedules["SB"] = []
+ schedules["SB"].append(sd_child)
if line_9_list:
- total_sd_pages += int(len(line_9_list)/3) + 1
+ total_sd_pages += int(len(line_9_list) / 3) + 1
if line_10_list:
- total_sd_pages += int(len(line_10_list)/3) + 1
- sd_dict = { '9': line_9_list, '10': line_10_list}
+ total_sd_pages += int(len(line_10_list) / 3) + 1
+ sd_dict = {"9": line_9_list, "10": line_10_list}
- if 'SA' in schedules:
+ if "SA" in schedules:
sa_start_page = total_no_of_pages
- sa_schedules.extend(schedules.get('SA'))
+ sa_schedules.extend(schedules.get("SA"))
sa_schedules_cnt = len(sa_schedules)
# if sa_schedules_cnt > 0:
if sa_schedules:
has_sa_schedules = True
- os.makedirs(md5_directory + 'SA', exist_ok=True)
+ os.makedirs(md5_directory + "SA", exist_ok=True)
# building array for all SA line numbers
sa_11a = []
sa_11b = []
@@ -558,40 +936,80 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
sa_16_memo = []
sa_17_memo = []
- sa_11a_last_page_cnt = sa_11b_last_page_cnt = sa_11c_last_page_cnt = sa_12_last_page_cnt = 3
- sa_13_last_page_cnt = sa_14_last_page_cnt = sa_15_last_page_cnt = sa_16_last_page_cnt = 3
+ sa_11a_last_page_cnt = (
+ sa_11b_last_page_cnt
+ ) = sa_11c_last_page_cnt = sa_12_last_page_cnt = 3
+ sa_13_last_page_cnt = (
+ sa_14_last_page_cnt
+ ) = sa_15_last_page_cnt = sa_16_last_page_cnt = 3
sa_17_last_page_cnt = 3
- sa_11a_memo_last_page_cnt = sa_11b_memo_last_page_cnt = sa_11c_memo_last_page_cnt = sa_12_memo_last_page_cnt = 2
- sa_13_memo_last_page_cnt = sa_14_memo_last_page_cnt = sa_15_memo_last_page_cnt = sa_16_memo_last_page_cnt = 2
+ sa_11a_memo_last_page_cnt = (
+ sa_11b_memo_last_page_cnt
+ ) = sa_11c_memo_last_page_cnt = sa_12_memo_last_page_cnt = 2
+ sa_13_memo_last_page_cnt = (
+ sa_14_memo_last_page_cnt
+ ) = sa_15_memo_last_page_cnt = sa_16_memo_last_page_cnt = 2
sa_17_memo_last_page_cnt = 2
sa_11a_page_cnt = sa_11b_page_cnt = sa_11c_page_cnt = sa_12_page_cnt = 0
sa_13_page_cnt = sa_14_page_cnt = sa_15_page_cnt = sa_16_page_cnt = 0
- sa_17_page_cnt = sa_11a_memo_page_cnt = sa_11b_memo_page_cnt = sa_11c_memo_page_cnt = sa_12_memo_page_cnt = 0
- sa_13_memo_page_cnt = sa_14_memo_page_cnt = sa_15_memo_page_cnt = sa_16_memo_page_cnt = 0
+ sa_17_page_cnt = (
+ sa_11a_memo_page_cnt
+ ) = (
+ sa_11b_memo_page_cnt
+ ) = sa_11c_memo_page_cnt = sa_12_memo_page_cnt = 0
+ sa_13_memo_page_cnt = (
+ sa_14_memo_page_cnt
+ ) = sa_15_memo_page_cnt = sa_16_memo_page_cnt = 0
sa_17_memo_page_cnt = 0
# process for each Schedule A
for sa_count in range(sa_schedules_cnt):
- if 'child' in sa_schedules[sa_count]:
- sa_child_schedules = sa_schedules[sa_count]['child']
+ if "child" in sa_schedules[sa_count]:
+ sa_child_schedules = sa_schedules[sa_count]["child"]
sa_child_schedules_count = len(sa_child_schedules)
for sa_child_count in range(sa_child_schedules_count):
- if sa_schedules[sa_count]['child'][sa_child_count]['lineNumber'] in sb_line_numbers:
- sb_schedules.append(sa_schedules[sa_count]['child'][sa_child_count])
+ if (
+ sa_schedules[sa_count]["child"][sa_child_count][
+ "lineNumber"
+ ]
+ in sb_line_numbers
+ ):
+ sb_schedules.append(
+ sa_schedules[sa_count]["child"][sa_child_count]
+ )
else:
- sa_schedules.append(sa_schedules[sa_count]['child'][sa_child_count])
+ sa_schedules.append(
+ sa_schedules[sa_count]["child"][sa_child_count]
+ )
# process_sa_line_numbers(sa_11a, sa_11b, sa_11c, sa_12, sa_13, sa_14, sa_15, sa_16,
# sa_17,
# sa_schedules[sa_count]['child'][sa_child_count])
sa_schedules_cnt = len(sa_schedules)
for sa_count in range(sa_schedules_cnt):
- process_sa_line_numbers(sa_11a, sa_11b, sa_11c, sa_12, sa_13, sa_14, sa_15, sa_16, sa_17,
- sa_11a_memo, sa_11b_memo, sa_11c_memo, sa_12_memo, sa_13_memo, sa_14_memo,
- sa_15_memo, sa_16_memo, sa_17_memo, sa_schedules[sa_count])
-
+ process_sa_line_numbers(
+ sa_11a,
+ sa_11b,
+ sa_11c,
+ sa_12,
+ sa_13,
+ sa_14,
+ sa_15,
+ sa_16,
+ sa_17,
+ sa_11a_memo,
+ sa_11b_memo,
+ sa_11c_memo,
+ sa_12_memo,
+ sa_13_memo,
+ sa_14_memo,
+ sa_15_memo,
+ sa_16_memo,
+ sa_17_memo,
+ sa_schedules[sa_count],
+ )
# calculate number of pages for SA line numbers
sa_11a_page_cnt, sa_11a_last_page_cnt = calculate_page_count(sa_11a)
@@ -603,35 +1021,77 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
sa_15_page_cnt, sa_15_last_page_cnt = calculate_page_count(sa_15)
sa_16_page_cnt, sa_16_last_page_cnt = calculate_page_count(sa_16)
sa_17_page_cnt, sa_17_last_page_cnt = calculate_page_count(sa_17)
- sa_11a_memo_page_cnt, sa_11a_memo_last_page_cnt = calculate_memo_page_count(sa_11a_memo)
- sa_11b_memo_page_cnt, sa_11b_memo_last_page_cnt = calculate_memo_page_count(sa_11b_memo)
- sa_11c_memo_page_cnt, sa_11c_memo_last_page_cnt = calculate_memo_page_count(sa_11c_memo)
- sa_12_memo_page_cnt, sa_12_memo_last_page_cnt = calculate_memo_page_count(sa_12_memo)
- sa_13_memo_page_cnt, sa_13_memo_last_page_cnt = calculate_memo_page_count(sa_13_memo)
- sa_14_memo_page_cnt, sa_14_memo_last_page_cnt = calculate_memo_page_count(sa_14_memo)
- sa_15_memo_page_cnt, sa_15_memo_last_page_cnt = calculate_memo_page_count(sa_15_memo)
- sa_16_memo_page_cnt, sa_16_memo_last_page_cnt = calculate_memo_page_count(sa_16_memo)
- sa_17_memo_page_cnt, sa_17_memo_last_page_cnt = calculate_memo_page_count(sa_17_memo)
+ (
+ sa_11a_memo_page_cnt,
+ sa_11a_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_11a_memo)
+ (
+ sa_11b_memo_page_cnt,
+ sa_11b_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_11b_memo)
+ (
+ sa_11c_memo_page_cnt,
+ sa_11c_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_11c_memo)
+ (
+ sa_12_memo_page_cnt,
+ sa_12_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_12_memo)
+ (
+ sa_13_memo_page_cnt,
+ sa_13_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_13_memo)
+ (
+ sa_14_memo_page_cnt,
+ sa_14_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_14_memo)
+ (
+ sa_15_memo_page_cnt,
+ sa_15_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_15_memo)
+ (
+ sa_16_memo_page_cnt,
+ sa_16_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_16_memo)
+ (
+ sa_17_memo_page_cnt,
+ sa_17_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sa_17_memo)
# calculate total number of pages
- total_no_of_pages = (total_no_of_pages + sa_11a_page_cnt + sa_11b_page_cnt + sa_11c_page_cnt
- + sa_12_page_cnt + sa_13_page_cnt + sa_14_page_cnt + sa_15_page_cnt
- + sa_16_page_cnt + sa_17_page_cnt + sa_11a_memo_page_cnt + sa_11b_memo_page_cnt
- + sa_11c_memo_page_cnt + sa_12_memo_page_cnt + sa_13_memo_page_cnt
- + sa_14_memo_page_cnt + sa_15_memo_page_cnt + sa_16_memo_page_cnt
- + sa_17_memo_page_cnt)
+ total_no_of_pages = (
+ total_no_of_pages
+ + sa_11a_page_cnt
+ + sa_11b_page_cnt
+ + sa_11c_page_cnt
+ + sa_12_page_cnt
+ + sa_13_page_cnt
+ + sa_14_page_cnt
+ + sa_15_page_cnt
+ + sa_16_page_cnt
+ + sa_17_page_cnt
+ + sa_11a_memo_page_cnt
+ + sa_11b_memo_page_cnt
+ + sa_11c_memo_page_cnt
+ + sa_12_memo_page_cnt
+ + sa_13_memo_page_cnt
+ + sa_14_memo_page_cnt
+ + sa_15_memo_page_cnt
+ + sa_16_memo_page_cnt
+ + sa_17_memo_page_cnt
+ )
sb_start_page = total_no_of_pages
# checking for SB transactions
- if 'SB' in schedules or len(sb_schedules) > 0:
+ if "SB" in schedules or len(sb_schedules) > 0:
sb_start_page = total_no_of_pages
- if 'SB' in schedules:
- sb_schedules.extend(schedules['SB'])
+ if "SB" in schedules:
+ sb_schedules.extend(schedules["SB"])
sb_schedules_cnt = len(sb_schedules)
if sb_schedules_cnt > 0:
has_sb_schedules = True
- os.makedirs(md5_directory + 'SB', exist_ok=True)
+ os.makedirs(md5_directory + "SB", exist_ok=True)
# building array for all SB line numbers
sb_21b = []
sb_22 = []
@@ -654,38 +1114,93 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
sb_29_memo = []
sb_30b_memo = []
- sb_21b_last_page_cnt = sb_22_last_page_cnt = sb_23_last_page_cnt = sb_26_last_page_cnt = 3
- sb_27_last_page_cnt = sb_28a_last_page_cnt = sb_28b_last_page_cnt = sb_28c_last_page_cnt = 3
+ sb_21b_last_page_cnt = (
+ sb_22_last_page_cnt
+ ) = sb_23_last_page_cnt = sb_26_last_page_cnt = 3
+ sb_27_last_page_cnt = (
+ sb_28a_last_page_cnt
+ ) = sb_28b_last_page_cnt = sb_28c_last_page_cnt = 3
sb_29_last_page_cnt = sb_30b_last_page_cnt = 3
- sb_21b_memo_last_page_cnt = sb_22_memo_last_page_cnt = sb_23_memo_last_page_cnt = sb_26_memo_last_page_cnt = 2
- sb_27_memo_last_page_cnt = sb_28a_memo_last_page_cnt = sb_28b_memo_last_page_cnt = sb_28c_memo_last_page_cnt = 2
+ sb_21b_memo_last_page_cnt = (
+ sb_22_memo_last_page_cnt
+ ) = sb_23_memo_last_page_cnt = sb_26_memo_last_page_cnt = 2
+ sb_27_memo_last_page_cnt = (
+ sb_28a_memo_last_page_cnt
+ ) = sb_28b_memo_last_page_cnt = sb_28c_memo_last_page_cnt = 2
sb_29_memo_last_page_cnt = sb_30b_memo_last_page_cnt = 2
sb_21b_page_cnt = sb_22_page_cnt = sb_23_page_cnt = sb_26_page_cnt = 0
sb_27_page_cnt = sb_28a_page_cnt = sb_28b_page_cnt = sb_28c_page_cnt = 0
sb_29_page_cnt = sb_30b_page_cnt = 0
- sb_21b_memo_page_cnt = sb_22_memo_page_cnt = sb_23_memo_page_cnt = sb_26_memo_page_cnt = 0
- sb_27_memo_page_cnt = sb_28a_memo_page_cnt = sb_28b_memo_page_cnt = sb_28c_memo_page_cnt = 0
+ sb_21b_memo_page_cnt = (
+ sb_22_memo_page_cnt
+ ) = sb_23_memo_page_cnt = sb_26_memo_page_cnt = 0
+ sb_27_memo_page_cnt = (
+ sb_28a_memo_page_cnt
+ ) = sb_28b_memo_page_cnt = sb_28c_memo_page_cnt = 0
sb_29_memo_page_cnt = sb_30b_memo_page_cnt = 0
# process for each Schedule B
for sb_count in range(sb_schedules_cnt):
- process_sb_line_numbers(sb_21b, sb_22, sb_23, sb_26, sb_27, sb_28a, sb_28b, sb_28c, sb_29,
- sb_30b, sb_21b_memo, sb_22_memo, sb_23_memo, sb_26_memo, sb_27_memo,
- sb_28a_memo, sb_28b_memo, sb_28c_memo, sb_29_memo, sb_30b_memo,
- sb_schedules[sb_count])
-
- if 'child' in sb_schedules[sb_count]:
- sb_child_schedules = sb_schedules[sb_count]['child']
+ process_sb_line_numbers(
+ sb_21b,
+ sb_22,
+ sb_23,
+ sb_26,
+ sb_27,
+ sb_28a,
+ sb_28b,
+ sb_28c,
+ sb_29,
+ sb_30b,
+ sb_21b_memo,
+ sb_22_memo,
+ sb_23_memo,
+ sb_26_memo,
+ sb_27_memo,
+ sb_28a_memo,
+ sb_28b_memo,
+ sb_28c_memo,
+ sb_29_memo,
+ sb_30b_memo,
+ sb_schedules[sb_count],
+ )
+
+ if "child" in sb_schedules[sb_count]:
+ sb_child_schedules = sb_schedules[sb_count]["child"]
sb_child_schedules_count = len(sb_child_schedules)
for sb_child_count in range(sb_child_schedules_count):
- if sb_schedules[sb_count]['child'][sb_child_count]['lineNumber'] in sb_line_numbers:
- process_sb_line_numbers(sb_21b, sb_22, sb_23, sb_26, sb_27, sb_28a, sb_28b, sb_28c,
- sb_29, sb_30b, sb_21b_memo, sb_22_memo, sb_23_memo, sb_26_memo,
- sb_27_memo, sb_28a_memo, sb_28b_memo, sb_28c_memo,
- sb_29_memo, sb_30b_memo, sb_schedules[sb_count]['child'][sb_child_count])
+ if (
+ sb_schedules[sb_count]["child"][sb_child_count][
+ "lineNumber"
+ ]
+ in sb_line_numbers
+ ):
+ process_sb_line_numbers(
+ sb_21b,
+ sb_22,
+ sb_23,
+ sb_26,
+ sb_27,
+ sb_28a,
+ sb_28b,
+ sb_28c,
+ sb_29,
+ sb_30b,
+ sb_21b_memo,
+ sb_22_memo,
+ sb_23_memo,
+ sb_26_memo,
+ sb_27_memo,
+ sb_28a_memo,
+ sb_28b_memo,
+ sb_28c_memo,
+ sb_29_memo,
+ sb_30b_memo,
+ sb_schedules[sb_count]["child"][sb_child_count],
+ )
sb_21b_page_cnt, sb_21b_last_page_cnt = calculate_page_count(sb_21b)
sb_22_page_cnt, sb_22_last_page_cnt = calculate_page_count(sb_22)
@@ -697,32 +1212,79 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
sb_28c_page_cnt, sb_28c_last_page_cnt = calculate_page_count(sb_28c)
sb_29_page_cnt, sb_29_last_page_cnt = calculate_page_count(sb_29)
sb_30b_page_cnt, sb_30b_last_page_cnt = calculate_page_count(sb_30b)
- sb_21b_memo_page_cnt, sb_21b_memo_last_page_cnt = calculate_memo_page_count(sb_21b_memo)
- sb_22_memo_page_cnt, sb_22_memo_last_page_cnt = calculate_memo_page_count(sb_22_memo)
- sb_23_memo_page_cnt, sb_23_memo_last_page_cnt = calculate_memo_page_count(sb_23_memo)
- sb_26_memo_page_cnt, sb_26_memo_last_page_cnt = calculate_memo_page_count(sb_26_memo)
- sb_27_memo_page_cnt, sb_27_memo_last_page_cnt = calculate_memo_page_count(sb_27_memo)
- sb_28a_memo_page_cnt, sb_28a_memo_last_page_cnt = calculate_memo_page_count(sb_28a_memo)
- sb_28b_memo_page_cnt, sb_28b_memo_last_page_cnt = calculate_memo_page_count(sb_28b_memo)
- sb_28c_memo_page_cnt, sb_28c_memo_last_page_cnt = calculate_memo_page_count(sb_28c_memo)
- sb_29_memo_page_cnt, sb_29_memo_last_page_cnt = calculate_memo_page_count(sb_29_memo)
- sb_30b_memo_page_cnt, sb_30b_memo_last_page_cnt = calculate_memo_page_count(sb_30b_memo)
-
- total_no_of_pages = (total_no_of_pages + sb_21b_page_cnt + sb_22_page_cnt + sb_23_page_cnt
- + sb_26_page_cnt + sb_27_page_cnt + sb_28a_page_cnt + sb_28b_page_cnt
- + sb_28c_page_cnt + sb_29_page_cnt + sb_30b_page_cnt + sb_21b_memo_page_cnt
- + sb_22_memo_page_cnt + sb_23_memo_page_cnt + sb_26_memo_page_cnt + sb_27_memo_page_cnt
- + sb_28a_memo_page_cnt + sb_28b_memo_page_cnt
- + sb_28c_memo_page_cnt + sb_29_memo_page_cnt + sb_30b_memo_page_cnt)
-
- if 'SE' in schedules or len(se_schedules) > 0:
+ (
+ sb_21b_memo_page_cnt,
+ sb_21b_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_21b_memo)
+ (
+ sb_22_memo_page_cnt,
+ sb_22_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_22_memo)
+ (
+ sb_23_memo_page_cnt,
+ sb_23_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_23_memo)
+ (
+ sb_26_memo_page_cnt,
+ sb_26_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_26_memo)
+ (
+ sb_27_memo_page_cnt,
+ sb_27_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_27_memo)
+ (
+ sb_28a_memo_page_cnt,
+ sb_28a_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_28a_memo)
+ (
+ sb_28b_memo_page_cnt,
+ sb_28b_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_28b_memo)
+ (
+ sb_28c_memo_page_cnt,
+ sb_28c_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_28c_memo)
+ (
+ sb_29_memo_page_cnt,
+ sb_29_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_29_memo)
+ (
+ sb_30b_memo_page_cnt,
+ sb_30b_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sb_30b_memo)
+
+ total_no_of_pages = (
+ total_no_of_pages
+ + sb_21b_page_cnt
+ + sb_22_page_cnt
+ + sb_23_page_cnt
+ + sb_26_page_cnt
+ + sb_27_page_cnt
+ + sb_28a_page_cnt
+ + sb_28b_page_cnt
+ + sb_28c_page_cnt
+ + sb_29_page_cnt
+ + sb_30b_page_cnt
+ + sb_21b_memo_page_cnt
+ + sb_22_memo_page_cnt
+ + sb_23_memo_page_cnt
+ + sb_26_memo_page_cnt
+ + sb_27_memo_page_cnt
+ + sb_28a_memo_page_cnt
+ + sb_28b_memo_page_cnt
+ + sb_28c_memo_page_cnt
+ + sb_29_memo_page_cnt
+ + sb_30b_memo_page_cnt
+ )
+
+ if "SE" in schedules or len(se_schedules) > 0:
se_start_page = total_no_of_pages
- if 'SE' in schedules:
- se_schedules.extend(schedules['SE'])
+ if "SE" in schedules:
+ se_schedules.extend(schedules["SE"])
se_schedules_cnt = len(se_schedules)
if se_schedules_cnt > 0:
has_se_schedules = True
- os.makedirs(md5_directory + 'SE', exist_ok=True)
+ os.makedirs(md5_directory + "SE", exist_ok=True)
se_24 = []
se_24_memo = []
@@ -732,28 +1294,41 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
for se_count in range(se_schedules_cnt):
process_se_line_numbers(se_24, se_24_memo, se_schedules[se_count])
- if 'child' in se_schedules[se_count]:
- se_child_schedules = se_schedules[se_count]['child']
+ if "child" in se_schedules[se_count]:
+ se_child_schedules = se_schedules[se_count]["child"]
se_child_schedules_count = len(se_child_schedules)
for se_child_count in range(se_child_schedules_count):
- if se_schedules[se_count]['child'][se_child_count]['lineNumber'] in se_line_numbers:
- process_se_line_numbers(se_24, se_24_memo, se_schedules[se_count]['child'][se_child_count])
+ if (
+ se_schedules[se_count]["child"][se_child_count][
+ "lineNumber"
+ ]
+ in se_line_numbers
+ ):
+ process_se_line_numbers(
+ se_24,
+ se_24_memo,
+ se_schedules[se_count]["child"][se_child_count],
+ )
se_24_page_cnt, se_24_last_page_cnt = calculate_se_page_count(se_24)
- se_24_memo_page_cnt, se_24_memo_last_page_cnt = calculate_memo_page_count(se_24_memo)
-
- total_no_of_pages = (total_no_of_pages + se_24_page_cnt + se_24_memo_page_cnt)
+ (
+ se_24_memo_page_cnt,
+ se_24_memo_last_page_cnt,
+ ) = calculate_memo_page_count(se_24_memo)
+ total_no_of_pages = (
+ total_no_of_pages + se_24_page_cnt + se_24_memo_page_cnt
+ )
- if 'SF' in schedules:
+ if "SF" in schedules:
sf_start_page = total_no_of_pages
- sf_schedules.extend(schedules.get('SF'))
+ sf_schedules.extend(schedules.get("SF"))
sf_schedules_cnt = len(sf_schedules)
if sf_schedules:
has_sf_schedules = True
- os.makedirs(md5_directory + 'SF', exist_ok=True)
+ os.makedirs(md5_directory + "SF", exist_ok=True)
sf_crd = []
sf_non_crd = []
@@ -768,132 +1343,193 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
sf_empty_none_memo = []
sf_empty_sub_memo = []
-
- sf_crd_last_page_cnt = sf_non_crd_last_page_cnt = sf_empty_ord_last_page_cnt = 3
- sf_empty_non_ord_last_page_cnt = sf_empty_none_last_page_cnt = sf_non_sub_last_page_cnt = 3
- sf_crd_memo_last_page_cnt = sf_non_crd_memo_last_page_cnt = sf_empty_ord_memo_last_page_cnt = 2
- sf_empty_non_ord_memo_last_page_cnt = sf_empty_none_memo_last_page_cnt = sf_non_sub_memo_last_page_cnt = 2
-
- sf_crd_page_cnt = sf_non_crd_page_cnt = sf_empty_ord_page_cnt = sf_empty_non_ord_page_cnt = 0
- sf_empty_none_page_cnt = sf_non_sub_page_cnt = sf_crd_memo_page_cnt = sf_non_crd_memo_page_cnt = 0
+ sf_crd_last_page_cnt = (
+ sf_non_crd_last_page_cnt
+ ) = sf_empty_ord_last_page_cnt = 3
+ sf_empty_non_ord_last_page_cnt = (
+ sf_empty_none_last_page_cnt
+ ) = sf_non_sub_last_page_cnt = 3
+ sf_crd_memo_last_page_cnt = (
+ sf_non_crd_memo_last_page_cnt
+ ) = sf_empty_ord_memo_last_page_cnt = 2
+ sf_empty_non_ord_memo_last_page_cnt = (
+ sf_empty_none_memo_last_page_cnt
+ ) = sf_non_sub_memo_last_page_cnt = 2
+
+ sf_crd_page_cnt = (
+ sf_non_crd_page_cnt
+ ) = sf_empty_ord_page_cnt = sf_empty_non_ord_page_cnt = 0
+ sf_empty_none_page_cnt = (
+ sf_non_sub_page_cnt
+ ) = sf_crd_memo_page_cnt = sf_non_crd_memo_page_cnt = 0
sf_empty_ord_memo_page_cnt = sf_empty_non_ord_memo_page_cnt = 0
sf_empty_none_memo_page_cnt = sf_non_sub_memo_page_cnt = 0
for sf_count in range(sf_schedules_cnt):
- process_sf_line_numbers(sf_crd, sf_non_crd, sf_empty_ord, sf_empty_non_ord, sf_empty_none, sf_empty_sub,
- sf_crd_memo, sf_non_crd_memo, sf_empty_ord_memo, sf_empty_non_ord_memo,
- sf_empty_none_memo, sf_empty_sub_memo, sf_schedules[sf_count])
-
- if 'child' in sf_schedules[sf_count]:
- sf_child_schedules = sf_schedules[sf_count]['child']
+ process_sf_line_numbers(
+ sf_crd,
+ sf_non_crd,
+ sf_empty_ord,
+ sf_empty_non_ord,
+ sf_empty_none,
+ sf_empty_sub,
+ sf_crd_memo,
+ sf_non_crd_memo,
+ sf_empty_ord_memo,
+ sf_empty_non_ord_memo,
+ sf_empty_none_memo,
+ sf_empty_sub_memo,
+ sf_schedules[sf_count],
+ )
+
+ if "child" in sf_schedules[sf_count]:
+ sf_child_schedules = sf_schedules[sf_count]["child"]
sf_child_schedules_count = len(sf_child_schedules)
for sf_child_count in range(sf_child_schedules_count):
- process_sf_line_numbers(sf_crd, sf_non_crd, sf_empty_ord, sf_empty_non_ord, sf_empty_none, sf_empty_sub,
- sf_crd_memo, sf_non_crd_memo, sf_empty_ord_memo, sf_empty_non_ord_memo, sf_empty_none_memo, sf_empty_sub_memo,
- sf_schedules[sf_count]['child'][sf_child_count])
-
-
- cor_exp = list(set([sub['designatingCommitteeName'] for sub in sf_crd ]))
- non_cor_exp = list(set([sub['subordinateCommitteeName'] for sub in sf_non_crd ]))
- empty_non_ord = list(set([sub['subordinateCommitteeName'] for sub in sf_empty_non_ord ]))
- empty_ord = list(set([sub['designatingCommitteeName'] for sub in sf_empty_ord]))
- sf_none =list(set([sub['lineNumber'] for sub in sf_empty_none ]))
- sf_sub_none =list(set([sub['lineNumber'] for sub in sf_empty_sub]))
-
+ process_sf_line_numbers(
+ sf_crd,
+ sf_non_crd,
+ sf_empty_ord,
+ sf_empty_non_ord,
+ sf_empty_none,
+ sf_empty_sub,
+ sf_crd_memo,
+ sf_non_crd_memo,
+ sf_empty_ord_memo,
+ sf_empty_non_ord_memo,
+ sf_empty_none_memo,
+ sf_empty_sub_memo,
+ sf_schedules[sf_count]["child"][sf_child_count],
+ )
+
+ cor_exp = list(set([sub["designatingCommitteeName"] for sub in sf_crd]))
+ non_cor_exp = list(
+ set([sub["subordinateCommitteeName"] for sub in sf_non_crd])
+ )
+ empty_non_ord = list(
+ set([sub["subordinateCommitteeName"] for sub in sf_empty_non_ord])
+ )
+ empty_ord = list(
+ set([sub["designatingCommitteeName"] for sub in sf_empty_ord])
+ )
+ sf_none = list(set([sub["lineNumber"] for sub in sf_empty_none]))
+ sf_sub_none = list(set([sub["lineNumber"] for sub in sf_empty_sub]))
newdict_cor = {}
for val in range(len(cor_exp)):
for i in sf_crd:
- if i['coordinateExpenditure'] == 'Y' and i['designatingCommitteeName'] == cor_exp[val]:
+ if (
+ i["coordinateExpenditure"] == "Y"
+ and i["designatingCommitteeName"] == cor_exp[val]
+ ):
if cor_exp[val] not in newdict_cor:
- newdict_cor[cor_exp[val]]=[i]
- else:
+ newdict_cor[cor_exp[val]] = [i]
+ else:
newdict_cor[cor_exp[val]].append(i)
newdict_non_cor = {}
for val in range(len(non_cor_exp)):
for i in sf_non_crd:
- if i['coordinateExpenditure'] == 'N' and i['subordinateCommitteeName'] == non_cor_exp[val]:
+ if (
+ i["coordinateExpenditure"] == "N"
+ and i["subordinateCommitteeName"] == non_cor_exp[val]
+ ):
if non_cor_exp[val] not in newdict_non_cor:
- newdict_non_cor[non_cor_exp[val]]=[i]
- else:
+ newdict_non_cor[non_cor_exp[val]] = [i]
+ else:
newdict_non_cor[non_cor_exp[val]].append(i)
-
newdict_empty_ord = {}
if len(newdict_empty_ord) >= 0:
for val in range(len(empty_ord)):
for i in sf_empty_ord:
- if i['coordinateExpenditure'] == '' and i['subordinateCommitteeName'] == '':
+ if (
+ i["coordinateExpenditure"] == ""
+ and i["subordinateCommitteeName"] == ""
+ ):
if empty_ord[val] not in newdict_empty_ord:
- newdict_empty_ord[empty_ord[val]]=[i]
- else:
+ newdict_empty_ord[empty_ord[val]] = [i]
+ else:
newdict_empty_ord[empty_ord[val]].append(i)
-
newdict_empty_non_ord = {}
if len(empty_non_ord) >= 0:
for val in range(len(empty_non_ord)):
for i in sf_empty_non_ord:
- if i['coordinateExpenditure'] == '' and i['designatingCommitteeName'] == '':
+ if (
+ i["coordinateExpenditure"] == ""
+ and i["designatingCommitteeName"] == ""
+ ):
if empty_non_ord[val] not in newdict_empty_non_ord:
- newdict_empty_non_ord[empty_non_ord[val]]=[i]
- else:
+ newdict_empty_non_ord[empty_non_ord[val]] = [i]
+ else:
newdict_empty_non_ord[empty_non_ord[val]].append(i)
-
+
newdict_sf_none = {}
if len(newdict_sf_none) >= 0:
for val in range(len(sf_none)):
for i in sf_empty_none:
- if i['coordinateExpenditure'] == '' and i['subordinateCommitteeName'] == '' and i['designatingCommitteeName'] == '' :
+ if (
+ i["coordinateExpenditure"] == ""
+ and i["subordinateCommitteeName"] == ""
+ and i["designatingCommitteeName"] == ""
+ ):
if sf_none[val] not in newdict_sf_none:
- newdict_sf_none[sf_none[val]]=[i]
- else:
+ newdict_sf_none[sf_none[val]] = [i]
+ else:
newdict_sf_none[sf_none[val]].append(i)
-
- newdict_sf_sub_none = {}
+
+ newdict_sf_sub_none = {}
for val in range(len(sf_sub_none)):
for i in sf_empty_sub:
- if i['coordinateExpenditure'] == 'N' and i['subordinateCommitteeName'] == '':
+ if (
+ i["coordinateExpenditure"] == "N"
+ and i["subordinateCommitteeName"] == ""
+ ):
if sf_sub_none[val] not in newdict_sf_sub_none:
- newdict_sf_sub_none[sf_sub_none[val]]=[i]
- else:
+ newdict_sf_sub_none[sf_sub_none[val]] = [i]
+ else:
newdict_sf_sub_none[sf_sub_none[val]].append(i)
-
- list_dirs = [newdict_cor, newdict_non_cor, newdict_empty_non_ord, newdict_empty_ord, newdict_sf_none,newdict_sf_sub_none]
-
+ list_dirs = [
+ newdict_cor,
+ newdict_non_cor,
+ newdict_empty_non_ord,
+ newdict_empty_ord,
+ newdict_sf_none,
+ newdict_sf_sub_none,
+ ]
for lis in list_dirs:
if lis == newdict_cor:
- values = list(newdict_cor.values())
+ values = list(newdict_cor.values())
if lis == newdict_non_cor:
- values = list(newdict_non_cor.values())
+ values = list(newdict_non_cor.values())
if lis == newdict_empty_non_ord:
- values = list(newdict_empty_non_ord.values())
+ values = list(newdict_empty_non_ord.values())
if lis == newdict_empty_ord:
- values = list(newdict_empty_ord.values())
+ values = list(newdict_empty_ord.values())
if lis == newdict_sf_none:
values = list(newdict_sf_none.values())
if lis == newdict_sf_sub_none:
- values = list(newdict_sf_sub_none.values())
-
- for val in values:
- sf_crd_page_cnt, sf_crd_last_page_cnt = calculate_page_count(val)
- total_no_of_pages = total_no_of_pages+sf_crd_page_cnt
-
+ values = list(newdict_sf_sub_none.values())
+ for val in values:
+ sf_crd_page_cnt, sf_crd_last_page_cnt = calculate_page_count(
+ val
+ )
+ total_no_of_pages = total_no_of_pages + sf_crd_page_cnt
- if 'SH' in schedules:
+ if "SH" in schedules:
sh_start_page = total_no_of_pages
- sh_schedules.extend(schedules.get('SH'))
+ sh_schedules.extend(schedules.get("SH"))
sh_schedules_cnt = len(sh_schedules)
- sh_line_numbers = ['30A', '21A', '18B', '18A']
+ sh_line_numbers = ["30A", "21A", "18B", "18A"]
if sh_schedules_cnt > 0:
sh_30a = []
sh_21a = []
@@ -908,107 +1544,146 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
sh_30a_last_page_cnt = sh_21a_last_page_cnt = 3
sh_18b_last_page_cnt = 2
- sh_30a_memo_last_page_cnt = sh_21a_memo_last_page_cnt = sh_18b_memo_last_page_cnt = 2
- sh_30a_page_cnt = sh_21a_page_cnt = sh_18b_page_cnt = sh_30a_memo_page_cnt = 0
+ sh_30a_memo_last_page_cnt = (
+ sh_21a_memo_last_page_cnt
+ ) = sh_18b_memo_last_page_cnt = 2
+ sh_30a_page_cnt = (
+ sh_21a_page_cnt
+ ) = sh_18b_page_cnt = sh_30a_memo_page_cnt = 0
sh_21a_memo_page_cnt = sh_18b_memo_page_cnt = 0
for sh_count in range(sh_schedules_cnt):
- process_sh_line_numbers(sh_30a, sh_21a,sh_18b, sh_18a, sh_h1, sh_h2,
- sh_30a_memo, sh_21a_memo, sh_18b_memo, sh_18a_memo,
- sh_schedules[sh_count])
- if 'child' in sh_schedules[sh_count]:
- sh_child_schedules = sh_schedules[sh_count]['child']
+ process_sh_line_numbers(
+ sh_30a,
+ sh_21a,
+ sh_18b,
+ sh_18a,
+ sh_h1,
+ sh_h2,
+ sh_30a_memo,
+ sh_21a_memo,
+ sh_18b_memo,
+ sh_18a_memo,
+ sh_schedules[sh_count],
+ )
+ if "child" in sh_schedules[sh_count]:
+ sh_child_schedules = sh_schedules[sh_count]["child"]
sh_child_schedules_count = len(sh_child_schedules)
for sh_child_count in range(sh_child_schedules_count):
- if sh_schedules[sh_count]['child'][sh_child_count]['lineNumber'] in sh_line_numbers:
- process_sh_line_numbers(sh_30a, sh_21a,sh_18b, sh_18a, sh_h1, sh_h2,
- sh_30a_memo, sh_21a_memo,sh_18b_memo, sh_18a_memo,
- sh_schedules[sh_count]['child'][sh_child_count])
-
+ if (
+ sh_schedules[sh_count]["child"][sh_child_count][
+ "lineNumber"
+ ]
+ in sh_line_numbers
+ ):
+ process_sh_line_numbers(
+ sh_30a,
+ sh_21a,
+ sh_18b,
+ sh_18a,
+ sh_h1,
+ sh_h2,
+ sh_30a_memo,
+ sh_21a_memo,
+ sh_18b_memo,
+ sh_18a_memo,
+ sh_schedules[sh_count]["child"][sh_child_count],
+ )
if len(sh_30a) != 0:
sh6_start_page = total_no_of_pages
sh6_schedules_cnt = len(sh_30a)
if sh6_schedules_cnt > 0:
has_sh6_schedules = True
- os.makedirs(md5_directory + 'SH6', exist_ok=True)
+ os.makedirs(md5_directory + "SH6", exist_ok=True)
if len(sh_21a) != 0:
sh4_start_page = total_no_of_pages
sh4_schedules_cnt = len(sh_21a)
if sh4_schedules_cnt > 0:
has_sh4_schedules = True
- os.makedirs(md5_directory + 'SH4', exist_ok=True)
+ os.makedirs(md5_directory + "SH4", exist_ok=True)
if len(sh_18b) != 0:
sh5_start_page = total_no_of_pages
sh5_schedules_cnt = len(sh_18b)
if sh5_schedules_cnt > 0:
has_sh5_schedules = True
- os.makedirs(md5_directory + 'SH5', exist_ok=True)
+ os.makedirs(md5_directory + "SH5", exist_ok=True)
if len(sh_18a) != 0:
sh3_start_page = total_no_of_pages
sh3_schedules_cnt = len(sh_18a)
if sh3_schedules_cnt > 0:
has_sh3_schedules = True
- os.makedirs(md5_directory + 'SH3', exist_ok=True)
+ os.makedirs(md5_directory + "SH3", exist_ok=True)
if len(sh_h1) != 0:
sh1_start_page = total_no_of_pages
sh1_schedules_cnt = len(sh_h1)
if sh1_schedules_cnt > 0:
has_sh1_schedules = True
- os.makedirs(md5_directory + 'SH1', exist_ok=True)
-
+ os.makedirs(md5_directory + "SH1", exist_ok=True)
if len(sh_h2) != 0:
sh2_start_page = total_no_of_pages
sh2_schedules_cnt = len(sh_h2)
if sh2_schedules_cnt > 0:
has_sh2_schedules = True
- os.makedirs(md5_directory + 'SH2', exist_ok=True)
-
-
+ os.makedirs(md5_directory + "SH2", exist_ok=True)
sh_30a_page_cnt, sh_30a_last_page_cnt = calculate_page_count(sh_30a)
- total_no_of_pages = (total_no_of_pages + sh_30a_page_cnt)
- sh_30a_memo_page_cnt, sh_30a_memo_last_page_cnt = calculate_memo_page_count(sh_30a_memo)
+ total_no_of_pages = total_no_of_pages + sh_30a_page_cnt
+ (
+ sh_30a_memo_page_cnt,
+ sh_30a_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sh_30a_memo)
sh_21a_page_cnt, sh_21a_last_page_cnt = calculate_page_count(sh_21a)
- total_no_of_pages = (total_no_of_pages + sh_21a_page_cnt)
- sh_21a_memo_page_cnt, sh_21a_memo_last_page_cnt = calculate_memo_page_count(sh_21a_memo)
-
- sh_18b_page_cnt, sh_18b_last_page_cnt = calculate_sh5page_count(sh_18b)
- total_no_of_pages = (total_no_of_pages + sh_18b_page_cnt)
- sh_18b_memo_page_cnt, sh_18b_memo_last_page_cnt = calculate_memo_page_count(sh_18b_memo)
+ total_no_of_pages = total_no_of_pages + sh_21a_page_cnt
+ (
+ sh_21a_memo_page_cnt,
+ sh_21a_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sh_21a_memo)
+
+ sh_18b_page_cnt, sh_18b_last_page_cnt = calculate_sh5page_count(
+ sh_18b
+ )
+ total_no_of_pages = total_no_of_pages + sh_18b_page_cnt
+ (
+ sh_18b_memo_page_cnt,
+ sh_18b_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sh_18b_memo)
sh_18a_page_cnt, sh_18a_last_page_cnt = calculate_page_count(sh_18a)
- total_no_of_pages = (total_no_of_pages + sh_18a_page_cnt)
- sh_18a_memo_page_cnt, sh_18a_memo_last_page_cnt = calculate_memo_page_count(sh_18a_memo)
+ total_no_of_pages = total_no_of_pages + sh_18a_page_cnt
+ (
+ sh_18a_memo_page_cnt,
+ sh_18a_memo_last_page_cnt,
+ ) = calculate_memo_page_count(sh_18a_memo)
sh2_page_cnt, sh2_last_page_cnt = calculate_sh2_page_count(sh_h2)
- total_no_of_pages = (total_no_of_pages + sh2_page_cnt)
+ total_no_of_pages = total_no_of_pages + sh2_page_cnt
- if ('SL' in schedules and schedules['SL']) or len(sl_summary) > 0:
+ if ("SL" in schedules and schedules["SL"]) or len(sl_summary) > 0:
sl_start_page = 0
sl_start_page = total_no_of_pages
- total_sl_pages = total_no_of_pages+1
+ total_sl_pages = total_no_of_pages + 1
total_no_of_pages += total_sl_pages
- if 'SL' in schedules:
- sl_summary.extend(schedules['SL'])
-
+ if "SL" in schedules:
+ sl_summary.extend(schedules["SL"])
+
sl_summary_cnt = len(sl_summary)
if sl_summary_cnt > 0:
has_sl_summary = True
- os.makedirs(md5_directory + 'SL', exist_ok=True)
+ os.makedirs(md5_directory + "SL", exist_ok=True)
sl_levin_page_cnt = 0
levin_name_data = {}
for sl_count in range(sl_summary_cnt):
- levin_name = sl_summary[sl_count]['accountName']
+ levin_name = sl_summary[sl_count]["accountName"]
if not levin_name_data.get(levin_name):
levin_name_data[levin_name] = []
levin_name_data[levin_name].append(sl_summary[sl_count])
@@ -1019,65 +1694,89 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
for name in levin_name_data:
account_data = levin_name_data[name]
sl_levin_page_cnt += len(account_data)
- sl_page_cnt, sl_last_page_cnt = 1,1
- total_no_of_pages = (total_no_of_pages + sl_levin_page_cnt)
-
- process_sl_levin(f3x_data, md5_directory, name, account_data, sl_levin_page_cnt, sl_page_cnt,
- sl_last_page_cnt, total_no_of_pages)
-
-
- if 'SL-A' in schedules:
+ sl_page_cnt, sl_last_page_cnt = 1, 1
+ total_no_of_pages = total_no_of_pages + sl_levin_page_cnt
+
+ process_sl_levin(
+ f3x_data,
+ md5_directory,
+ name,
+ account_data,
+ sl_levin_page_cnt,
+ sl_page_cnt,
+ sl_last_page_cnt,
+ total_no_of_pages,
+ )
+
+ if "SL-A" in schedules:
la_start_page = total_no_of_pages
- la_schedules.extend(schedules.get('SL-A'))
+ la_schedules.extend(schedules.get("SL-A"))
la_schedules_cnt = len(la_schedules)
if la_schedules:
has_la_schedules = True
- os.makedirs(md5_directory + 'SL-A', exist_ok=True)
+ os.makedirs(md5_directory + "SL-A", exist_ok=True)
la_1a = []
la_2 = []
la_1a_memo = []
la_2_memo = []
-
+
la_1a_last_page_cnt = la_2_last_page_cnt = 4
la_1a_memo_last_page_cnt = la_2_memo_last_page_cnt = 2
- la_1a_page_cnt = la_2_page_cnt = la_1a_memo_page_cnt = la_2_memo_page_cnt = 0
+ la_1a_page_cnt = (
+ la_2_page_cnt
+ ) = la_1a_memo_page_cnt = la_2_memo_page_cnt = 0
la_schedules_cnt = len(la_schedules)
-
+
for la_count in range(la_schedules_cnt):
- process_la_line_numbers(la_1a, la_2, la_1a_memo, la_2_memo,
- la_schedules[la_count])
+ process_la_line_numbers(
+ la_1a, la_2, la_1a_memo, la_2_memo, la_schedules[la_count]
+ )
- if 'child' in la_schedules[la_count]:
- la_child_schedules = la_schedules[la_count]['child']
+ if "child" in la_schedules[la_count]:
+ la_child_schedules = la_schedules[la_count]["child"]
la_child_schedules_count = len(la_child_schedules)
for la_child_count in range(la_child_schedules_count):
- la_schedules.append(la_schedules[la_count]['child'][la_child_count])
- process_la_line_numbers(la_1a, la_2, la_1a_memo, la_2_memo,
- la_schedules[la_count]['child'][la_child_count])
+ la_schedules.append(
+ la_schedules[la_count]["child"][la_child_count]
+ )
+ process_la_line_numbers(
+ la_1a,
+ la_2,
+ la_1a_memo,
+ la_2_memo,
+ la_schedules[la_count]["child"][la_child_count],
+ )
la_1a_page_cnt, la_1a_last_page_cnt = calculate_la_page_count(la_1a)
la_2_page_cnt, la_2_last_page_cnt = calculate_la_page_count(la_2)
- la_1a_memo_page_cnt, la_1a_memo_last_page_cnt = calculate_la_page_count(la_1a_memo)
- la_2_memo_page_cnt, la_2_memo_last_page_cnt = calculate_la_page_count(la_2_memo)
-
+ la_1a_memo_page_cnt, la_1a_memo_last_page_cnt = calculate_la_page_count(
+ la_1a_memo
+ )
+ la_2_memo_page_cnt, la_2_memo_last_page_cnt = calculate_la_page_count(
+ la_2_memo
+ )
- total_no_of_pages = (total_no_of_pages + la_1a_page_cnt + la_2_page_cnt
- + la_1a_memo_page_cnt + la_2_memo_page_cnt)
+ total_no_of_pages = (
+ total_no_of_pages
+ + la_1a_page_cnt
+ + la_2_page_cnt
+ + la_1a_memo_page_cnt
+ + la_2_memo_page_cnt
+ )
slb_start_page = total_no_of_pages
-
- if 'SL-B' in schedules or len(slb_schedules) > 0:
+ if "SL-B" in schedules or len(slb_schedules) > 0:
slb_start_page = total_no_of_pages
- if 'SL-B' in schedules:
- slb_schedules.extend(schedules['SL-B'])
+ if "SL-B" in schedules:
+ slb_schedules.extend(schedules["SL-B"])
slb_schedules_cnt = len(slb_schedules)
if slb_schedules_cnt > 0:
has_slb_schedules = True
- os.makedirs(md5_directory + 'SL-B', exist_ok=True)
+ os.makedirs(md5_directory + "SL-B", exist_ok=True)
slb_4a = []
slb_4b = []
slb_4c = []
@@ -1088,20 +1787,38 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
slb_4c_memo = []
slb_4d_memo = []
slb_5_memo = []
-
- slb_4a_last_page_cnt = slb_4b_last_page_cnt = slb_4c_last_page_cnt = slb_4d_last_page_cnt = slb_5_last_page_cnt = 5
- slb_4a_memo_last_page_cnt = slb_4b_memo_last_page_cnt = slb_4c_memo_last_page_cnt = 2
+ slb_4a_last_page_cnt = (
+ slb_4b_last_page_cnt
+ ) = (
+ slb_4c_last_page_cnt
+ ) = slb_4d_last_page_cnt = slb_5_last_page_cnt = 5
+ slb_4a_memo_last_page_cnt = (
+ slb_4b_memo_last_page_cnt
+ ) = slb_4c_memo_last_page_cnt = 2
slb_4d_memo_last_page_cnt = slb_5_memo_last_page_cnt = 2
- slb_4a_page_cnt = slb_4b_page_cnt = slb_4c_page_cnt = slb_4d_page_cnt = lb_5_page_cnt = 0
- slb_4a_memo_page_cnt = slb_4b_memo_page_cnt = slb_4c_memo_page_cnt = slb_4d_memo_page_cnt = lb_5_memo_page_cnt = 0
-
+ slb_4a_page_cnt = (
+ slb_4b_page_cnt
+ ) = slb_4c_page_cnt = slb_4d_page_cnt = lb_5_page_cnt = 0
+ slb_4a_memo_page_cnt = (
+ slb_4b_memo_page_cnt
+ ) = slb_4c_memo_page_cnt = slb_4d_memo_page_cnt = lb_5_memo_page_cnt = 0
for slb_count in range(slb_schedules_cnt):
- process_slb_line_numbers(slb_4a, slb_4b, slb_4c, slb_4d, slb_5,
- slb_4a_memo, slb_4b_memo, slb_4c_memo, slb_4d_memo, slb_5_memo,
- slb_schedules[slb_count])
+ process_slb_line_numbers(
+ slb_4a,
+ slb_4b,
+ slb_4c,
+ slb_4d,
+ slb_5,
+ slb_4a_memo,
+ slb_4b_memo,
+ slb_4c_memo,
+ slb_4d_memo,
+ slb_5_memo,
+ slb_schedules[slb_count],
+ )
slb_4a_page_cnt, slb_4a_last_page_cnt = calculate_slb_page_count(slb_4a)
slb_4b_page_cnt, slb_4b_last_page_cnt = calculate_slb_page_count(slb_4b)
@@ -1109,15 +1826,40 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
slb_4d_page_cnt, slb_4d_last_page_cnt = calculate_slb_page_count(slb_4d)
slb_5_page_cnt, slb_5_last_page_cnt = calculate_slb_page_count(slb_5)
- slb_4a_memo_page_cnt, slb_4a_memo_last_page_cnt = calculate_slb_page_count(slb_4a_memo)
- slb_4b_memo_page_cnt, slb_4b_memo_last_page_cnt = calculate_slb_page_count(slb_4b_memo)
- slb_4c_memo_page_cnt, slb_4c_memo_last_page_cnt = calculate_slb_page_count(slb_4c_memo)
- slb_4d_memo_page_cnt, slb_4d_memo_last_page_cnt = calculate_slb_page_count(slb_4d_memo)
- slb_5_memo_page_cnt, slb_5_memo_last_page_cnt = calculate_slb_page_count(slb_5_memo)
-
- total_no_of_pages = (total_no_of_pages + slb_4a_page_cnt + slb_4b_page_cnt + slb_4c_page_cnt
- + slb_4d_page_cnt + slb_5_page_cnt + slb_4a_memo_page_cnt + slb_4b_memo_page_cnt
- + slb_4c_memo_page_cnt + slb_4d_memo_page_cnt + slb_5_memo_page_cnt)
+ (
+ slb_4a_memo_page_cnt,
+ slb_4a_memo_last_page_cnt,
+ ) = calculate_slb_page_count(slb_4a_memo)
+ (
+ slb_4b_memo_page_cnt,
+ slb_4b_memo_last_page_cnt,
+ ) = calculate_slb_page_count(slb_4b_memo)
+ (
+ slb_4c_memo_page_cnt,
+ slb_4c_memo_last_page_cnt,
+ ) = calculate_slb_page_count(slb_4c_memo)
+ (
+ slb_4d_memo_page_cnt,
+ slb_4d_memo_last_page_cnt,
+ ) = calculate_slb_page_count(slb_4d_memo)
+ (
+ slb_5_memo_page_cnt,
+ slb_5_memo_last_page_cnt,
+ ) = calculate_slb_page_count(slb_5_memo)
+
+ total_no_of_pages = (
+ total_no_of_pages
+ + slb_4a_page_cnt
+ + slb_4b_page_cnt
+ + slb_4c_page_cnt
+ + slb_4d_page_cnt
+ + slb_5_page_cnt
+ + slb_4a_memo_page_cnt
+ + slb_4b_memo_page_cnt
+ + slb_4c_memo_page_cnt
+ + slb_4d_memo_page_cnt
+ + slb_5_memo_page_cnt
+ )
if total_sc_pages > 0:
sc_start_page = total_no_of_pages + 1
total_no_of_pages += total_sc_pages
@@ -1128,184 +1870,369 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
if sa_schedules_cnt > 0:
# process Schedule 11AI
sa_11a_start_page = sa_start_page
- process_sa_line(f3x_data, md5_directory, '11AI', sa_11a, sa_11a_page_cnt, sa_11a_start_page,
- sa_11a_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "11AI",
+ sa_11a,
+ sa_11a_page_cnt,
+ sa_11a_start_page,
+ sa_11a_last_page_cnt,
+ total_no_of_pages,
+ )
sa_11a_memo_start_page = sa_11a_start_page + sa_11a_page_cnt
# process Schedule 11B
sa_11b_start_page = sa_11a_start_page + sa_11a_memo_page_cnt
- process_sa_line(f3x_data, md5_directory, '11B', sa_11b, sa_11b_page_cnt, sa_11b_start_page,
- sa_11b_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "11B",
+ sa_11b,
+ sa_11b_page_cnt,
+ sa_11b_start_page,
+ sa_11b_last_page_cnt,
+ total_no_of_pages,
+ )
sa_11b_memo_start_page = sa_11b_start_page + sa_11b_page_cnt
# process Schedule 11C
sa_11c_start_page = sa_11b_memo_start_page + sa_11b_memo_page_cnt
- process_sa_line(f3x_data, md5_directory, '11C', sa_11c, sa_11c_page_cnt, sa_11c_start_page,
- sa_11c_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "11C",
+ sa_11c,
+ sa_11c_page_cnt,
+ sa_11c_start_page,
+ sa_11c_last_page_cnt,
+ total_no_of_pages,
+ )
sa_11c_memo_start_page = sa_11c_start_page + sa_11c_page_cnt
# process Schedule 12
sa_12_start_page = sa_11c_memo_start_page + sa_11c_page_cnt
- process_sa_line(f3x_data, md5_directory, '12', sa_12, sa_12_page_cnt, sa_12_start_page,
- sa_12_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "12",
+ sa_12,
+ sa_12_page_cnt,
+ sa_12_start_page,
+ sa_12_last_page_cnt,
+ total_no_of_pages,
+ )
sa_12_memo_start_page = sa_12_start_page + sa_12_page_cnt
# process Schedule 13
sa_13_start_page = sa_12_memo_start_page + sa_12_page_cnt
- process_sa_line(f3x_data, md5_directory, '13', sa_13, sa_13_page_cnt, sa_13_start_page,
- sa_13_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "13",
+ sa_13,
+ sa_13_page_cnt,
+ sa_13_start_page,
+ sa_13_last_page_cnt,
+ total_no_of_pages,
+ )
sa_13_memo_start_page = sa_13_start_page + sa_13_page_cnt
# process Schedule 14
sa_14_start_page = sa_13_start_page + sa_13_page_cnt
- process_sa_line(f3x_data, md5_directory, '14', sa_14, sa_14_page_cnt, sa_14_start_page,
- sa_14_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "14",
+ sa_14,
+ sa_14_page_cnt,
+ sa_14_start_page,
+ sa_14_last_page_cnt,
+ total_no_of_pages,
+ )
sa_14_memo_start_page = sa_14_start_page + sa_14_page_cnt
# process_sa_memo(f3x_data, md5_directory, '14', sa_14_memo, sa_14_memo_page_cnt, sa_14_memo_start_page,
# sa_14_memo_last_page_cnt, total_no_of_pages)
# process Schedule 15
sa_15_start_page = sa_14_start_page + sa_14_page_cnt
- process_sa_line(f3x_data, md5_directory, '15', sa_15, sa_15_page_cnt, sa_15_start_page,
- sa_15_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "15",
+ sa_15,
+ sa_15_page_cnt,
+ sa_15_start_page,
+ sa_15_last_page_cnt,
+ total_no_of_pages,
+ )
sa_15_memo_start_page = sa_15_start_page + sa_15_page_cnt
# process_sa_memo(f3x_data, md5_directory, '15', sa_15_memo, sa_15_memo_page_cnt, sa_15_memo_start_page,
# sa_15_memo_last_page_cnt, total_no_of_pages)
# process Schedule 16
sa_16_start_page = sa_15_start_page + sa_15_page_cnt
- process_sa_line(f3x_data, md5_directory, '16', sa_16, sa_16_page_cnt, sa_16_start_page,
- sa_16_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "16",
+ sa_16,
+ sa_16_page_cnt,
+ sa_16_start_page,
+ sa_16_last_page_cnt,
+ total_no_of_pages,
+ )
sa_16_memo_start_page = sa_16_start_page + sa_16_page_cnt
# process_sa_memo(f3x_data, md5_directory, '16', sa_16_memo, sa_16_memo_page_cnt, sa_16_memo_start_page,
# sa_16_memo_last_page_cnt, total_no_of_pages)
# process Schedule 17
sa_17_start_page = sa_16_start_page + sa_16_page_cnt
- process_sa_line(f3x_data, md5_directory, '17', sa_17, sa_17_page_cnt, sa_17_start_page,
- sa_17_last_page_cnt, total_no_of_pages)
+ process_sa_line(
+ f3x_data,
+ md5_directory,
+ "17",
+ sa_17,
+ sa_17_page_cnt,
+ sa_17_start_page,
+ sa_17_last_page_cnt,
+ total_no_of_pages,
+ )
sa_17_memo_start_page = sa_17_start_page + sa_17_page_cnt
# process_sa_memo(f3x_data, md5_directory, '17', sa_17_memo, sa_17_memo_page_cnt, sa_17_memo_start_page,
# sa_17_memo_last_page_cnt, total_no_of_pages)
-
-
# Schedule B line number processing starts here
if sb_schedules_cnt > 0:
# process Schedule 21B
sb_21b_start_page = sb_start_page
- process_sb_line(f3x_data, md5_directory, '21B', sb_21b, sb_21b_page_cnt, sb_21b_start_page,
- sb_21b_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "21B",
+ sb_21b,
+ sb_21b_page_cnt,
+ sb_21b_start_page,
+ sb_21b_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_21b_memo_start_page = sb_21b_start_page + sb_21b_page_cnt
# process_sb_memo(f3x_data, md5_directory, '21B', sb_21b_memo, sb_21b_memo_page_cnt, sb_21b_memo_start_page,
# sb_21b_memo_last_page_cnt, total_no_of_pages)
# process Schedule 22
sb_22_start_page = sb_21b_start_page + sb_21b_page_cnt
- process_sb_line(f3x_data, md5_directory, '22', sb_22, sb_22_page_cnt, sb_22_start_page,
- sb_22_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "22",
+ sb_22,
+ sb_22_page_cnt,
+ sb_22_start_page,
+ sb_22_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_22_memo_start_page = sb_22_start_page + sb_22_page_cnt
# process_sb_memo(f3x_data, md5_directory, '22', sb_22_memo, sb_22_memo_page_cnt, sb_22_memo_start_page,
# sb_22_memo_last_page_cnt, total_no_of_pages)
# process Schedule 23
sb_23_start_page = sb_22_start_page + sb_22_page_cnt
- process_sb_line(f3x_data, md5_directory, '23', sb_23, sb_23_page_cnt, sb_23_start_page,
- sb_23_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "23",
+ sb_23,
+ sb_23_page_cnt,
+ sb_23_start_page,
+ sb_23_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_23_memo_start_page = sb_23_start_page + sb_23_page_cnt
# process_sb_memo(f3x_data, md5_directory, '23', sb_23_memo, sb_23_memo_page_cnt, sb_23_memo_start_page,
# sb_23_memo_last_page_cnt, total_no_of_pages)
# process Schedule 26
sb_26_start_page = sb_23_start_page + sb_23_page_cnt
- process_sb_line(f3x_data, md5_directory, '26', sb_26, sb_26_page_cnt, sb_26_start_page,
- sb_26_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "26",
+ sb_26,
+ sb_26_page_cnt,
+ sb_26_start_page,
+ sb_26_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_26_memo_start_page = sb_26_start_page + sb_26_page_cnt
# process_sb_memo(f3x_data, md5_directory, '26', sb_26_memo, sb_26_memo_page_cnt, sb_26_memo_start_page,
# sb_26_memo_last_page_cnt, total_no_of_pages)
# process Schedule 27
sb_27_start_page = sb_26_start_page + sb_26_page_cnt
- process_sb_line(f3x_data, md5_directory, '27', sb_27, sb_27_page_cnt, sb_27_start_page,
- sb_27_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "27",
+ sb_27,
+ sb_27_page_cnt,
+ sb_27_start_page,
+ sb_27_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_27_memo_start_page = sb_27_start_page + sb_27_page_cnt
# process_sb_memo(f3x_data, md5_directory, '27', sb_27_memo, sb_27_memo_page_cnt, sb_27_memo_start_page,
# sb_27_memo_last_page_cnt, total_no_of_pages)
# process Schedule 28A
sb_28a_start_page = sb_27_start_page + sb_27_page_cnt
- process_sb_line(f3x_data, md5_directory, '28A', sb_28a, sb_28a_page_cnt, sb_28a_start_page,
- sb_28a_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "28A",
+ sb_28a,
+ sb_28a_page_cnt,
+ sb_28a_start_page,
+ sb_28a_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_28a_memo_start_page = sb_28a_start_page + sb_28a_page_cnt
# process_sb_memo(f3x_data, md5_directory, '28A', sb_28a_memo, sb_28a_memo_page_cnt, sb_28a_memo_start_page,
# sb_28a_memo_last_page_cnt, total_no_of_pages)
# process Schedule 28B
sb_28b_start_page = sb_28a_start_page + sb_28a_page_cnt
- process_sb_line(f3x_data, md5_directory, '28B', sb_28b, sb_28b_page_cnt, sb_28b_start_page,
- sb_28b_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "28B",
+ sb_28b,
+ sb_28b_page_cnt,
+ sb_28b_start_page,
+ sb_28b_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_28b_memo_start_page = sb_28b_start_page + sb_28b_page_cnt
# process_sb_memo(f3x_data, md5_directory, '28B', sb_28b_memo, sb_28b_memo_page_cnt, sb_28b_memo_start_page,
# sb_28b_memo_last_page_cnt, total_no_of_pages)
# process Schedule 28C
sb_28c_start_page = sb_28b_start_page + sb_28b_page_cnt
- process_sb_line(f3x_data, md5_directory, '28C', sb_28c, sb_28c_page_cnt, sb_28c_start_page,
- sb_28c_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "28C",
+ sb_28c,
+ sb_28c_page_cnt,
+ sb_28c_start_page,
+ sb_28c_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_28c_memo_start_page = sb_28c_start_page + sb_28c_page_cnt
# process_sb_memo(f3x_data, md5_directory, '28C', sb_28c_memo, sb_28c_memo_page_cnt, sb_28c_memo_start_page,
# sb_28c_memo_last_page_cnt, total_no_of_pages)
# process Schedule 29
sb_29_start_page = sb_28c_start_page + sb_28c_page_cnt
- process_sb_line(f3x_data, md5_directory, '29', sb_29, sb_29_page_cnt, sb_29_start_page,
- sb_29_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "29",
+ sb_29,
+ sb_29_page_cnt,
+ sb_29_start_page,
+ sb_29_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_29_memo_start_page = sb_29_start_page + sb_29_page_cnt
# process_sb_memo(f3x_data, md5_directory, '29', sb_29_memo, sb_29_memo_page_cnt, sb_29_memo_start_page,
# sb_29_memo_last_page_cnt, total_no_of_pages)
# process Schedule 30B
sb_30b_start_page = sb_29_start_page + sb_29_page_cnt
- process_sb_line(f3x_data, md5_directory, '30B', sb_30b, sb_30b_page_cnt, sb_30b_start_page,
- sb_30b_last_page_cnt, total_no_of_pages)
+ process_sb_line(
+ f3x_data,
+ md5_directory,
+ "30B",
+ sb_30b,
+ sb_30b_page_cnt,
+ sb_30b_start_page,
+ sb_30b_last_page_cnt,
+ total_no_of_pages,
+ )
# sb_30b_memo_start_page = sb_30b_start_page + sb_30b_page_cnt
# process_sb_memo(f3x_data, md5_directory, '30B', sb_30b_memo, sb_30b_memo_page_cnt, sb_30b_memo_start_page,
# sb_30b_memo_last_page_cnt, total_no_of_pages)
- if 'SC' in schedules and sc_schedules_cnt > 0:
- sc1_list, sc1_start_page, totalOutstandingLoans = process_sc_line(f3x_data, md5_directory, sc_schedules, sc_start_page, total_no_of_pages)
+ if "SC" in schedules and sc_schedules_cnt > 0:
+ sc1_list, sc1_start_page, totalOutstandingLoans = process_sc_line(
+ f3x_data, md5_directory, sc_schedules, sc_start_page, total_no_of_pages
+ )
else:
sc1_list = []
if sc1_list:
for sc1 in sc1_list:
- process_sc1_line(f3x_data, md5_directory, sc1, sc1_start_page, total_no_of_pages)
+ process_sc1_line(
+ f3x_data, md5_directory, sc1, sc1_start_page, total_no_of_pages
+ )
sc1_start_page += 1
-
- if 'SD' in schedules and sd_schedules_cnt > 0:
- sd_total_balance = process_sd_line(f3x_data, md5_directory, sd_dict, sd_start_page, total_no_of_pages, total_sd_pages, totalOutstandingLoans)
-
+
+ if "SD" in schedules and sd_schedules_cnt > 0:
+ sd_total_balance = process_sd_line(
+ f3x_data,
+ md5_directory,
+ sd_dict,
+ sd_start_page,
+ total_no_of_pages,
+ total_sd_pages,
+ totalOutstandingLoans,
+ )
+
if se_schedules_cnt > 0:
se_24_start_page = se_start_page
- process_se_line(f3x_data, md5_directory, '24', se_24, se_24_page_cnt, se_24_start_page,
- se_24_last_page_cnt, total_no_of_pages)
+ process_se_line(
+ f3x_data,
+ md5_directory,
+ "24",
+ se_24,
+ se_24_page_cnt,
+ se_24_start_page,
+ se_24_last_page_cnt,
+ total_no_of_pages,
+ )
# se_24_memo_start_page = se_24_start_page + se_24_page_cnt
# process_se_memo(f3x_data, md5_directory, '24', se_24_memo, se_24_memo_page_cnt, se_24_memo_start_page,
# se_24_memo_last_page_cnt, total_no_of_pages)
if la_schedules_cnt > 0:
la_1a_start_page = la_start_page
- process_la_line(f3x_data, md5_directory, '1A', la_1a, la_1a_page_cnt, la_1a_start_page,
- la_1a_last_page_cnt, total_no_of_pages)
+ process_la_line(
+ f3x_data,
+ md5_directory,
+ "1A",
+ la_1a,
+ la_1a_page_cnt,
+ la_1a_start_page,
+ la_1a_last_page_cnt,
+ total_no_of_pages,
+ )
la_1a_memo_start_page = la_1a_start_page + la_1a_page_cnt
# process_la_memo(f3x_data, md5_directory, '1A', la_1a_memo, la_1a_memo_page_cnt, la_1a_memo_start_page,
# la_1a_memo_last_page_cnt, total_no_of_pages)
-
# process Schedule 11B
- la_2_start_page = la_1a_start_page + la_1a_page_cnt
- process_la_line(f3x_data, md5_directory, '2', la_2, la_2_page_cnt, la_2_start_page,
- la_2_last_page_cnt, total_no_of_pages)
+ la_2_start_page = la_1a_start_page + la_1a_page_cnt
+ process_la_line(
+ f3x_data,
+ md5_directory,
+ "2",
+ la_2,
+ la_2_page_cnt,
+ la_2_start_page,
+ la_2_last_page_cnt,
+ total_no_of_pages,
+ )
la_2_memo_start_page = la_2_start_page + la_2_page_cnt
# process_la_memo(f3x_data, md5_directory, '2', la_2_memo, la_2_memo_page_cnt, la_2_memo_start_page,
# la_2_memo_last_page_cnt, total_no_of_pages)
@@ -1317,59 +2244,100 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
if lis == newdict_cor:
values = list(newdict_cor.values())
if lis == newdict_non_cor:
- values = list(newdict_non_cor.values())
+ values = list(newdict_non_cor.values())
if lis == newdict_empty_non_ord:
- values = list(newdict_empty_non_ord.values())
+ values = list(newdict_empty_non_ord.values())
if lis == newdict_empty_ord:
values = list(newdict_empty_ord.values())
if lis == newdict_sf_none:
- values = list(newdict_sf_none.values())
+ values = list(newdict_sf_none.values())
if lis == newdict_sf_sub_none:
- values = list(newdict_sf_sub_none.values())
+ values = list(newdict_sf_sub_none.values())
for rec in values:
- if rec[0].get('designatingCommitteeName') and rec[0].get('coordinateExpenditure') is 'Y':
- cord_name = 'designatingCommittee'
- elif rec[0].get('designatingCommitteeName') and rec[0].get('coordinateExpenditure') == '':
- cord_name = 'designatingNamewithoutEXP'
- elif rec[0].get('subordinateCommitteeName') and rec[0].get('coordinateExpenditure') is 'N':
- cord_name = 'subCommittee'
- elif rec[0].get('subordinateCommitteeName') and rec[0].get('coordinateExpenditure') == '':
- cord_name = 'subordinateCommitteewithoutEXP'
-
- elif rec[0].get('subordinateCommitteeName') == '' and rec[0].get('coordinateExpenditure') is 'N':
- cord_name = 'withsubCommittee'
-
+ if (
+ rec[0].get("designatingCommitteeName")
+ and rec[0].get("coordinateExpenditure") == "Y"
+ ):
+ cord_name = "designatingCommittee"
+ elif (
+ rec[0].get("designatingCommitteeName")
+ and rec[0].get("coordinateExpenditure") == ""
+ ):
+ cord_name = "designatingNamewithoutEXP"
+ elif (
+ rec[0].get("subordinateCommitteeName")
+ and rec[0].get("coordinateExpenditure") == "N"
+ ):
+ cord_name = "subCommittee"
+ elif (
+ rec[0].get("subordinateCommitteeName")
+ and rec[0].get("coordinateExpenditure") == ""
+ ):
+ cord_name = "subordinateCommitteewithoutEXP"
+
+ elif (
+ rec[0].get("subordinateCommitteeName") == ""
+ and rec[0].get("coordinateExpenditure") == "N"
+ ):
+ cord_name = "withsubCommittee"
+
else:
- cord_name = 'payee'
+ cord_name = "payee"
sf_crd_page_cnt, sf_crd_last_page_cnt = calculate_page_count(rec)
if count == 0:
count += 1
sf_crd_start_page = sf_start_page
- process_sf_line(f3x_data, md5_directory, '25', rec, sf_crd_page_cnt, sf_crd_start_page,
- sf_crd_last_page_cnt, total_no_of_pages, cord_name)
+ process_sf_line(
+ f3x_data,
+ md5_directory,
+ "25",
+ rec,
+ sf_crd_page_cnt,
+ sf_crd_start_page,
+ sf_crd_last_page_cnt,
+ total_no_of_pages,
+ cord_name,
+ )
# sf_crd_memo_start_page = sf_crd_start_page + sf_crd_page_cnt
# process_sf_memo(f3x_data, md5_directory, '25', sf_crd_memo, sf_crd_memo_page_cnt, sf_crd_memo_start_page,
# sf_crd_memo_last_page_cnt, total_no_of_pages, cord_name)
elif count == 1:
count += 1
sf_non_crd_start_page = sf_crd_start_page + sf_crd_page_cnt
- process_sf_line(f3x_data, md5_directory, '25', rec, sf_crd_page_cnt, sf_non_crd_start_page,
- sf_crd_last_page_cnt, total_no_of_pages, cord_name)
+ process_sf_line(
+ f3x_data,
+ md5_directory,
+ "25",
+ rec,
+ sf_crd_page_cnt,
+ sf_non_crd_start_page,
+ sf_crd_last_page_cnt,
+ total_no_of_pages,
+ cord_name,
+ )
# sf_non_crd_memo_start_page = sf_non_crd_start_page + sf_crd_page_cnt
# process_sf_memo(f3x_data, md5_directory, '25', sf_non_crd_memo, sf_non_crd_memo_page_cnt, sf_non_crd_memo_start_page,
# sf_crd_memo_last_page_cnt, total_no_of_pages, cord_name)
else:
count += 1
sf_non_crd_start_page = sf_non_crd_start_page + sf_crd_page_cnt
- process_sf_line(f3x_data, md5_directory, '25', rec, sf_crd_page_cnt, sf_non_crd_start_page,
- sf_crd_last_page_cnt, total_no_of_pages, cord_name)
+ process_sf_line(
+ f3x_data,
+ md5_directory,
+ "25",
+ rec,
+ sf_crd_page_cnt,
+ sf_non_crd_start_page,
+ sf_crd_last_page_cnt,
+ total_no_of_pages,
+ cord_name,
+ )
# sf_non_crd_memo_start_page = sf_non_crd_start_page + sf_crd_page_cnt
# process_sf_memo(f3x_data, md5_directory, '25', sf_non_crd_memo, sf_crd_memo_page_cnt, sf_non_crd_memo_start_page,
# sf_crd_memo_last_page_cnt, total_no_of_pages, cord_name)
-
if lis == newdict_cor:
sf_memo = sf_crd_memo
if lis == newdict_non_cor:
@@ -1382,305 +2350,569 @@ def process_schedules(f3x_data, md5_directory, total_no_of_pages):
sf_memo = sf_empty_none_memo
if lis == newdict_sf_sub_none:
sf_memo = sf_empty_sub_memo
- sf_memo_page_cnt, sf_memo_last_page_cnt = calculate_memo_page_count(sf_memo)
+ sf_memo_page_cnt, sf_memo_last_page_cnt = calculate_memo_page_count(
+ sf_memo
+ )
sf_memo_start_page = sf_crd_start_page + sf_crd_page_cnt
# process_sf_memo(f3x_data, md5_directory, '25', sf_memo, sf_memo_page_cnt,
# sf_memo_start_page, sf_memo_last_page_cnt, total_no_of_pages, cord_name)
-
if slb_schedules_cnt > 0:
slb_4a_start_page = slb_start_page
- process_slb_line(f3x_data, md5_directory, '4A', slb_4a, slb_4a_page_cnt, slb_4a_start_page,
- slb_4a_last_page_cnt, total_no_of_pages)
+ process_slb_line(
+ f3x_data,
+ md5_directory,
+ "4A",
+ slb_4a,
+ slb_4a_page_cnt,
+ slb_4a_start_page,
+ slb_4a_last_page_cnt,
+ total_no_of_pages,
+ )
slb_4a_memo_start_page = slb_4a_start_page + slb_4a_memo_page_cnt
# process_slb_memo(f3x_data, md5_directory, '4A', slb_4a_memo, slb_4a_memo_page_cnt, slb_4a_memo_start_page,
# slb_4a_memo_last_page_cnt, total_no_of_pages)
# process Schedule 4b
slb_4b_start_page = slb_4a_start_page + slb_4a_page_cnt
- process_slb_line(f3x_data, md5_directory, '4B', slb_4b, slb_4b_page_cnt, slb_4b_start_page,
- slb_4b_last_page_cnt, total_no_of_pages)
+ process_slb_line(
+ f3x_data,
+ md5_directory,
+ "4B",
+ slb_4b,
+ slb_4b_page_cnt,
+ slb_4b_start_page,
+ slb_4b_last_page_cnt,
+ total_no_of_pages,
+ )
slb_4b_memo_start_page = slb_4b_start_page + slb_4b_page_cnt
# process_slb_memo(f3x_data, md5_directory, '4B', slb_4b_memo, slb_4b_memo_page_cnt, slb_4b_memo_start_page,
# slb_4b_memo_last_page_cnt, total_no_of_pages)
# process Schedule 4c
slb_4c_start_page = slb_4b_start_page + slb_4b_page_cnt
- process_slb_line(f3x_data, md5_directory, '4C', slb_4c, slb_4c_page_cnt, slb_4c_start_page,
- slb_4c_last_page_cnt, total_no_of_pages)
+ process_slb_line(
+ f3x_data,
+ md5_directory,
+ "4C",
+ slb_4c,
+ slb_4c_page_cnt,
+ slb_4c_start_page,
+ slb_4c_last_page_cnt,
+ total_no_of_pages,
+ )
slb_4c_memo_start_page = slb_4c_start_page + slb_4c_page_cnt
# process_slb_memo(f3x_data, md5_directory, '4C', slb_4c_memo, slb_4c_memo_page_cnt, slb_4c_memo_start_page,
# slb_4c_memo_last_page_cnt, total_no_of_pages)
# process Schedule 4d
slb_4d_start_page = slb_4c_start_page + slb_4c_page_cnt
- process_slb_line(f3x_data, md5_directory, '4D', slb_4d, slb_4d_page_cnt, slb_4d_start_page,
- slb_4d_last_page_cnt, total_no_of_pages)
+ process_slb_line(
+ f3x_data,
+ md5_directory,
+ "4D",
+ slb_4d,
+ slb_4d_page_cnt,
+ slb_4d_start_page,
+ slb_4d_last_page_cnt,
+ total_no_of_pages,
+ )
slb_4d_memo_start_page = slb_4d_start_page + slb_4d_page_cnt
# process_slb_memo(f3x_data, md5_directory, '4D', slb_4d_memo, slb_4d_memo_page_cnt, slb_4d_memo_start_page,
# slb_4d_memo_last_page_cnt, total_no_of_pages)
# process Schedule 5
slb_5_start_page = slb_4d_start_page + slb_4d_page_cnt
- process_slb_line(f3x_data, md5_directory, '5', slb_5, slb_5_page_cnt, slb_5_start_page,
- slb_5_last_page_cnt, total_no_of_pages)
+ process_slb_line(
+ f3x_data,
+ md5_directory,
+ "5",
+ slb_5,
+ slb_5_page_cnt,
+ slb_5_start_page,
+ slb_5_last_page_cnt,
+ total_no_of_pages,
+ )
slb_5_memo_start_page = slb_5_start_page + slb_5_page_cnt
# process_slb_memo(f3x_data, md5_directory, '5', slb_5_memo, slb_5_memo_page_cnt, slb_5_memo_start_page,
# slb_5_memo_last_page_cnt, total_no_of_pages)
if sh6_schedules_cnt > 0:
sh_30a_start_page = total_no_of_pages
- process_sh6_line(f3x_data, md5_directory, '30A', sh_30a, sh_30a_page_cnt, sh_30a_start_page,
- sh_30a_last_page_cnt, total_no_of_pages)
+ process_sh6_line(
+ f3x_data,
+ md5_directory,
+ "30A",
+ sh_30a,
+ sh_30a_page_cnt,
+ sh_30a_start_page,
+ sh_30a_last_page_cnt,
+ total_no_of_pages,
+ )
sh_30a_memo_start_page = sh_30a_start_page + sh_30a_page_cnt
# process_sh_memo(f3x_data, md5_directory, 'SH6/', '30A', sh_30a_memo, sh_30a_memo_page_cnt, sh_30a_memo_start_page,
# sh_30a_memo_last_page_cnt, total_no_of_pages)
if sh4_schedules_cnt > 0:
sh_21a_start_page = total_no_of_pages
- process_sh4_line(f3x_data, md5_directory, '21A', sh_21a, sh_21a_page_cnt, sh_21a_start_page,
- sh_21a_last_page_cnt, total_no_of_pages)
+ process_sh4_line(
+ f3x_data,
+ md5_directory,
+ "21A",
+ sh_21a,
+ sh_21a_page_cnt,
+ sh_21a_start_page,
+ sh_21a_last_page_cnt,
+ total_no_of_pages,
+ )
sh_21a_memo_start_page = sh_21a_start_page + sh_21a_page_cnt
# process_sh_memo(f3x_data, md5_directory, 'SH4/', '21A', sh_21a_memo, sh_21a_memo_page_cnt, sh_21a_memo_start_page,
# sh_21a_memo_last_page_cnt, total_no_of_pages)
if sh5_schedules_cnt > 0:
sh_18b_start_page = total_no_of_pages
- process_sh5_line(f3x_data, md5_directory, '18B', sh_18b, sh_18b_page_cnt, sh_18b_start_page,
- sh_18b_last_page_cnt, total_no_of_pages)
+ process_sh5_line(
+ f3x_data,
+ md5_directory,
+ "18B",
+ sh_18b,
+ sh_18b_page_cnt,
+ sh_18b_start_page,
+ sh_18b_last_page_cnt,
+ total_no_of_pages,
+ )
sh_18b_memo_start_page = sh_18b_start_page + sh_18b_page_cnt
# process_sh_memo(f3x_data, md5_directory, 'SH5/', '18B', sh_18b_memo, sh_18b_memo_page_cnt, sh_18b_memo_start_page,
# sh_18b_memo_last_page_cnt, total_no_of_pages)
if sh3_schedules_cnt > 0:
sh_18a_start_page = total_no_of_pages
- process_sh3_line(f3x_data, md5_directory, '18A', sh_18a, sh_18a_page_cnt, sh_18a_start_page,
- sh_18a_last_page_cnt, total_no_of_pages)
+ process_sh3_line(
+ f3x_data,
+ md5_directory,
+ "18A",
+ sh_18a,
+ sh_18a_page_cnt,
+ sh_18a_start_page,
+ sh_18a_last_page_cnt,
+ total_no_of_pages,
+ )
sh_18a_memo_start_page = sh_18a_start_page + sh_18a_page_cnt
# process_sh_memo(f3x_data, md5_directory, 'SH3/', '18A', sh_18a_memo, sh_18a_memo_page_cnt, sh_18a_memo_start_page,
# sh_18a_memo_last_page_cnt, total_no_of_pages)
if sh1_schedules_cnt > 0:
- tran_type_ident = sh_h1[0]['transactionTypeIdentifier']
+ tran_type_ident = sh_h1[0]["transactionTypeIdentifier"]
if tran_type_ident:
sh1_page_cnt = sh1_memo_page_cnt = 1
sh1_start_page, sh1_last_page_cnt = 1, 3
- total_no_of_pages = (total_no_of_pages + sh1_page_cnt)
-
- process_sh1_line(f3x_data, md5_directory, tran_type_ident, sh_h1, sh1_page_cnt, sh1_start_page,
- sh1_last_page_cnt, total_no_of_pages)
-
+ total_no_of_pages = total_no_of_pages + sh1_page_cnt
+
+ process_sh1_line(
+ f3x_data,
+ md5_directory,
+ tran_type_ident,
+ sh_h1,
+ sh1_page_cnt,
+ sh1_start_page,
+ sh1_last_page_cnt,
+ total_no_of_pages,
+ )
if sh2_schedules_cnt > 0:
- tran_type_ident = sh_h2[0]['transactionTypeIdentifier']
+ tran_type_ident = sh_h2[0]["transactionTypeIdentifier"]
if tran_type_ident:
- sh2_start_page = total_no_of_pages
- process_sh2_line(f3x_data, md5_directory, tran_type_ident, sh_h2, sh2_page_cnt, sh2_start_page,
- sh2_last_page_cnt, total_no_of_pages)
-
+ sh2_start_page = total_no_of_pages
+ process_sh2_line(
+ f3x_data,
+ md5_directory,
+ tran_type_ident,
+ sh_h2,
+ sh2_page_cnt,
+ sh2_start_page,
+ sh2_last_page_cnt,
+ total_no_of_pages,
+ )
output_data = {
- 'has_sa_schedules': has_sa_schedules,
- 'has_sb_schedules': has_sb_schedules,
- 'has_sc_schedules': has_sc_schedules,
- 'has_sd_schedules': has_sd_schedules,
- 'has_la_schedules': has_la_schedules,
- 'has_slb_schedules': has_slb_schedules,
- 'has_sh3_schedules': has_sh3_schedules,
- 'has_sh6_schedules': has_sh6_schedules,
- 'has_sh4_schedules': has_sh4_schedules,
- 'has_sh5_schedules': has_sh5_schedules,
- 'has_sh1_schedules': has_sh1_schedules,
- 'has_sh2_schedules': has_sh2_schedules,
- 'has_sl_summary' : has_sl_summary,
- 'has_sf_schedules': has_sf_schedules,
- 'has_se_schedules': has_se_schedules
- }
-
+ "has_sa_schedules": has_sa_schedules,
+ "has_sb_schedules": has_sb_schedules,
+ "has_sc_schedules": has_sc_schedules,
+ "has_sd_schedules": has_sd_schedules,
+ "has_la_schedules": has_la_schedules,
+ "has_slb_schedules": has_slb_schedules,
+ "has_sh3_schedules": has_sh3_schedules,
+ "has_sh6_schedules": has_sh6_schedules,
+ "has_sh4_schedules": has_sh4_schedules,
+ "has_sh5_schedules": has_sh5_schedules,
+ "has_sh1_schedules": has_sh1_schedules,
+ "has_sh2_schedules": has_sh2_schedules,
+ "has_sl_summary": has_sl_summary,
+ "has_sf_schedules": has_sf_schedules,
+ "has_se_schedules": has_se_schedules,
+ }
+
return output_data, total_no_of_pages
-def process_sd_line(f3x_data, md5_directory, sd_dict, sd_start_page, total_no_of_pages, total_sd_pages, totalOutstandingLoans):
- sd_total_balance = '0.00'
+def process_sd_line(
+ f3x_data,
+ md5_directory,
+ sd_dict,
+ sd_start_page,
+ total_no_of_pages,
+ total_sd_pages,
+ totalOutstandingLoans,
+):
+ sd_total_balance = "0.00"
sd_schedule_total = 0.00
page_count = 0
- os.makedirs(md5_directory + 'SD/', exist_ok=True)
- sd_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SD')
+ os.makedirs(md5_directory + "SD/", exist_ok=True)
+ sd_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SD")
for line_number in sd_dict:
sd_list = sd_dict.get(line_number)
sd_sub_total = 0.00
sd_page_dict = {}
- sd_page_dict['committeeName'] = f3x_data.get('committeeName')
- sd_page_dict['totalNoPages'] = total_no_of_pages
- sd_page_dict['lineNumber'] = line_number
+ sd_page_dict["committeeName"] = f3x_data.get("committeeName")
+ sd_page_dict["totalNoPages"] = total_no_of_pages
+ sd_page_dict["lineNumber"] = line_number
if sd_list:
for i in range(len(sd_list)):
- sd_schedule_total += float(sd_list[i].get('balanceAtClose'))
- sd_sub_total += float(sd_list[i].get('balanceAtClose'))
- sd_page_dict['pageNo'] = sd_start_page + page_count
- concat_no = i%3+1
- if 'creditorOrganizationName' in sd_list[i] and sd_list[i].get('creditorOrganizationName') != "":
- sd_page_dict['creditorName_{}'.format(concat_no)] = sd_list[i].get('creditorOrganizationName')
+ sd_schedule_total += float(sd_list[i].get("balanceAtClose"))
+ sd_sub_total += float(sd_list[i].get("balanceAtClose"))
+ sd_page_dict["pageNo"] = sd_start_page + page_count
+ concat_no = i % 3 + 1
+ if (
+ "creditorOrganizationName" in sd_list[i]
+ and sd_list[i].get("creditorOrganizationName") != ""
+ ):
+ sd_page_dict["creditorName_{}".format(concat_no)] = sd_list[i].get(
+ "creditorOrganizationName"
+ )
else:
- sd_page_dict['creditorName_{}'.format(concat_no)] = ""
- for item in ['creditorPrefix', 'creditorLastName', 'creditorFirstName', 'creditorMiddleName', 'creditorSuffix']:
+ sd_page_dict["creditorName_{}".format(concat_no)] = ""
+ for item in [
+ "creditorPrefix",
+ "creditorLastName",
+ "creditorFirstName",
+ "creditorMiddleName",
+ "creditorSuffix",
+ ]:
if sd_list[i].get(item) != "":
- sd_page_dict['creditorName_{}'.format(concat_no)] += sd_list[i].get(item) + " "
- for item in ['creditorStreet1', 'creditorStreet2', 'creditorCity', 'creditorState', 'creditorZipCode', 'purposeOfDebtOrObligation', 'transactionId']:
- sd_page_dict[item+'_{}'.format(concat_no)] = sd_list[i].get(item)
- for item in ['beginningBalance', 'incurredAmount', 'paymentAmount', 'balanceAtClose']:
- sd_page_dict[item+'_{}'.format(concat_no)] = '{0:.2f}'.format(float(sd_list[i].get(item)))
- if i%3 == 2 or i == len(sd_list)-1:
- sd_page_dict['subTotal'] = '{0:.2f}'.format(sd_sub_total)
- if page_count == total_sd_pages-1:
- sd_page_dict['total'] = '{0:.2f}'.format(sd_schedule_total)
- sd_page_dict['totalOutstandingLoans'] = totalOutstandingLoans
- sd_total_balance = sd_page_dict['totalBalance'] = '{0:.2f}'.format(sd_schedule_total + float(totalOutstandingLoans))
- sd_outfile = md5_directory + 'SD' + '/page_' + str(sd_page_dict['pageNo']) + '.pdf'
+ sd_page_dict["creditorName_{}".format(concat_no)] += (
+ sd_list[i].get(item) + " "
+ )
+ for item in [
+ "creditorStreet1",
+ "creditorStreet2",
+ "creditorCity",
+ "creditorState",
+ "creditorZipCode",
+ "purposeOfDebtOrObligation",
+ "transactionId",
+ ]:
+ sd_page_dict[item + "_{}".format(concat_no)] = sd_list[i].get(item)
+ for item in [
+ "beginningBalance",
+ "incurredAmount",
+ "paymentAmount",
+ "balanceAtClose",
+ ]:
+ sd_page_dict[item + "_{}".format(concat_no)] = "{0:.2f}".format(
+ float(sd_list[i].get(item))
+ )
+ if i % 3 == 2 or i == len(sd_list) - 1:
+ sd_page_dict["subTotal"] = "{0:.2f}".format(sd_sub_total)
+ if page_count == total_sd_pages - 1:
+ sd_page_dict["total"] = "{0:.2f}".format(sd_schedule_total)
+ sd_page_dict["totalOutstandingLoans"] = totalOutstandingLoans
+ sd_total_balance = sd_page_dict[
+ "totalBalance"
+ ] = "{0:.2f}".format(
+ sd_schedule_total + float(totalOutstandingLoans)
+ )
+ sd_outfile = (
+ md5_directory
+ + "SD"
+ + "/page_"
+ + str(sd_page_dict["pageNo"])
+ + ".pdf"
+ )
pypdftk.fill_form(sd_infile, sd_page_dict, sd_outfile)
- del_j=1
- while del_j <= i%3+1:
- for item in ['creditorName', 'creditorStreet1', 'creditorStreet2', 'creditorCity', 'creditorState', 'creditorZipCode',
- 'purposeOfDebtOrObligation', 'transactionId','beginningBalance', 'incurredAmount', 'paymentAmount', 'balanceAtClose']:
- del sd_page_dict[item+'_{}'.format(del_j)]
+ del_j = 1
+ while del_j <= i % 3 + 1:
+ for item in [
+ "creditorName",
+ "creditorStreet1",
+ "creditorStreet2",
+ "creditorCity",
+ "creditorState",
+ "creditorZipCode",
+ "purposeOfDebtOrObligation",
+ "transactionId",
+ "beginningBalance",
+ "incurredAmount",
+ "paymentAmount",
+ "balanceAtClose",
+ ]:
+ del sd_page_dict[item + "_{}".format(del_j)]
del_j += 1
- if path.isfile(md5_directory + 'SD/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SD/all_pages.pdf', md5_directory + 'SD' + '/page_' + str(sd_page_dict['pageNo']) + '.pdf'],
- md5_directory + 'SD/temp_all_pages.pdf')
- os.rename(md5_directory + 'SD/temp_all_pages.pdf', md5_directory + 'SD/all_pages.pdf')
+ if path.isfile(md5_directory + "SD/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SD/all_pages.pdf",
+ md5_directory
+ + "SD"
+ + "/page_"
+ + str(sd_page_dict["pageNo"])
+ + ".pdf",
+ ],
+ md5_directory + "SD/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SD/temp_all_pages.pdf",
+ md5_directory + "SD/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SD' + '/page_' + str(sd_page_dict['pageNo']) + '.pdf', md5_directory + 'SD/all_pages.pdf')
+ os.rename(
+ md5_directory
+ + "SD"
+ + "/page_"
+ + str(sd_page_dict["pageNo"])
+ + ".pdf",
+ md5_directory + "SD/all_pages.pdf",
+ )
page_count += 1
sd_sub_total = 0.00
return sd_total_balance
-def process_sd_line(f3x_data, md5_directory, sd_dict, sd_start_page, total_no_of_pages, total_sd_pages, totalOutstandingLoans):
- sd_total_balance = '0.00'
+def process_sd_line(
+ f3x_data,
+ md5_directory,
+ sd_dict,
+ sd_start_page,
+ total_no_of_pages,
+ total_sd_pages,
+ totalOutstandingLoans,
+):
+ sd_total_balance = "0.00"
sd_schedule_total = 0.00
page_count = 0
- os.makedirs(md5_directory + 'SD/', exist_ok=True)
- sd_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SD')
+ os.makedirs(md5_directory + "SD/", exist_ok=True)
+ sd_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SD")
for line_number in sd_dict:
sd_list = sd_dict.get(line_number)
sd_sub_total = 0.00
sd_page_dict = {}
- sd_page_dict['committeeName'] = f3x_data.get('committeeName')
- sd_page_dict['totalNoPages'] = total_no_of_pages
- sd_page_dict['lineNumber'] = line_number
+ sd_page_dict["committeeName"] = f3x_data.get("committeeName")
+ sd_page_dict["totalNoPages"] = total_no_of_pages
+ sd_page_dict["lineNumber"] = line_number
if sd_list:
for i in range(len(sd_list)):
- sd_schedule_total += float(sd_list[i].get('balanceAtClose'))
- sd_sub_total += float(sd_list[i].get('balanceAtClose'))
- sd_page_dict['pageNo'] = sd_start_page + page_count
- concat_no = i%3+1
- if 'creditorOrganizationName' in sd_list[i] and sd_list[i].get('creditorOrganizationName') != "":
- sd_page_dict['creditorName_{}'.format(concat_no)] = sd_list[i].get('creditorOrganizationName')
+ sd_schedule_total += float(sd_list[i].get("balanceAtClose"))
+ sd_sub_total += float(sd_list[i].get("balanceAtClose"))
+ sd_page_dict["pageNo"] = sd_start_page + page_count
+ concat_no = i % 3 + 1
+ if (
+ "creditorOrganizationName" in sd_list[i]
+ and sd_list[i].get("creditorOrganizationName") != ""
+ ):
+ sd_page_dict["creditorName_{}".format(concat_no)] = sd_list[i].get(
+ "creditorOrganizationName"
+ )
else:
- sd_page_dict['creditorName_{}'.format(concat_no)] = ""
- for item in ['creditorPrefix', 'creditorLastName', 'creditorFirstName', 'creditorMiddleName', 'creditorSuffix']:
+ sd_page_dict["creditorName_{}".format(concat_no)] = ""
+ for item in [
+ "creditorPrefix",
+ "creditorLastName",
+ "creditorFirstName",
+ "creditorMiddleName",
+ "creditorSuffix",
+ ]:
if sd_list[i].get(item) != "":
- sd_page_dict['creditorName_{}'.format(concat_no)] += sd_list[i].get(item) + " "
- for item in ['creditorStreet1', 'creditorStreet2', 'creditorCity', 'creditorState', 'creditorZipCode', 'purposeOfDebtOrObligation', 'transactionId']:
- sd_page_dict[item+'_{}'.format(concat_no)] = sd_list[i].get(item)
- for item in ['beginningBalance', 'incurredAmount', 'paymentAmount', 'balanceAtClose']:
- sd_page_dict[item+'_{}'.format(concat_no)] = '{0:.2f}'.format(float(sd_list[i].get(item)))
- if i%3 == 2 or i == len(sd_list)-1:
- sd_page_dict['subTotal'] = '{0:.2f}'.format(sd_sub_total)
- if page_count == total_sd_pages-1:
- sd_page_dict['total'] = '{0:.2f}'.format(sd_schedule_total)
- sd_page_dict['totalOutstandingLoans'] = totalOutstandingLoans
- sd_total_balance = sd_page_dict['totalBalance'] = '{0:.2f}'.format(sd_schedule_total + float(totalOutstandingLoans))
- sd_outfile = md5_directory + 'SD' + '/page_' + str(sd_page_dict['pageNo']) + '.pdf'
+ sd_page_dict["creditorName_{}".format(concat_no)] += (
+ sd_list[i].get(item) + " "
+ )
+ for item in [
+ "creditorStreet1",
+ "creditorStreet2",
+ "creditorCity",
+ "creditorState",
+ "creditorZipCode",
+ "purposeOfDebtOrObligation",
+ "transactionId",
+ ]:
+ sd_page_dict[item + "_{}".format(concat_no)] = sd_list[i].get(item)
+ for item in [
+ "beginningBalance",
+ "incurredAmount",
+ "paymentAmount",
+ "balanceAtClose",
+ ]:
+ sd_page_dict[item + "_{}".format(concat_no)] = "{0:.2f}".format(
+ float(sd_list[i].get(item))
+ )
+ if i % 3 == 2 or i == len(sd_list) - 1:
+ sd_page_dict["subTotal"] = "{0:.2f}".format(sd_sub_total)
+ if page_count == total_sd_pages - 1:
+ sd_page_dict["total"] = "{0:.2f}".format(sd_schedule_total)
+ sd_page_dict["totalOutstandingLoans"] = totalOutstandingLoans
+ sd_total_balance = sd_page_dict[
+ "totalBalance"
+ ] = "{0:.2f}".format(
+ sd_schedule_total + float(totalOutstandingLoans)
+ )
+ sd_outfile = (
+ md5_directory
+ + "SD"
+ + "/page_"
+ + str(sd_page_dict["pageNo"])
+ + ".pdf"
+ )
pypdftk.fill_form(sd_infile, sd_page_dict, sd_outfile)
- del_j=1
- while del_j <= i%3+1:
- for item in ['creditorName', 'creditorStreet1', 'creditorStreet2', 'creditorCity', 'creditorState', 'creditorZipCode',
- 'purposeOfDebtOrObligation', 'transactionId','beginningBalance', 'incurredAmount', 'paymentAmount', 'balanceAtClose']:
- del sd_page_dict[item+'_{}'.format(del_j)]
+ del_j = 1
+ while del_j <= i % 3 + 1:
+ for item in [
+ "creditorName",
+ "creditorStreet1",
+ "creditorStreet2",
+ "creditorCity",
+ "creditorState",
+ "creditorZipCode",
+ "purposeOfDebtOrObligation",
+ "transactionId",
+ "beginningBalance",
+ "incurredAmount",
+ "paymentAmount",
+ "balanceAtClose",
+ ]:
+ del sd_page_dict[item + "_{}".format(del_j)]
del_j += 1
- if path.isfile(md5_directory + 'SD/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SD/all_pages.pdf', md5_directory + 'SD' + '/page_' + str(sd_page_dict['pageNo']) + '.pdf'],
- md5_directory + 'SD/temp_all_pages.pdf')
- os.rename(md5_directory + 'SD/temp_all_pages.pdf', md5_directory + 'SD/all_pages.pdf')
+ if path.isfile(md5_directory + "SD/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SD/all_pages.pdf",
+ md5_directory
+ + "SD"
+ + "/page_"
+ + str(sd_page_dict["pageNo"])
+ + ".pdf",
+ ],
+ md5_directory + "SD/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SD/temp_all_pages.pdf",
+ md5_directory + "SD/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SD' + '/page_' + str(sd_page_dict['pageNo']) + '.pdf', md5_directory + 'SD/all_pages.pdf')
+ os.rename(
+ md5_directory
+ + "SD"
+ + "/page_"
+ + str(sd_page_dict["pageNo"])
+ + ".pdf",
+ md5_directory + "SD/all_pages.pdf",
+ )
page_count += 1
sd_sub_total = 0.00
return sd_total_balance
-def process_sc_line(f3x_data, md5_directory, sc_schedules, sc_start_page, total_no_of_pages):
+def process_sc_line(
+ f3x_data, md5_directory, sc_schedules, sc_start_page, total_no_of_pages
+):
sc_schedule_total = 0.00
- os.makedirs(md5_directory + 'SC/', exist_ok=True)
- sc_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SC')
+ os.makedirs(md5_directory + "SC/", exist_ok=True)
+ sc_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SC")
sc1_list = []
- totalOutstandingLoans = '0.00'
+ totalOutstandingLoans = "0.00"
for sc in sc_schedules:
- page_subtotal = '{0:.2f}'.format(float(sc.get('loanBalance')))
+ page_subtotal = "{0:.2f}".format(float(sc.get("loanBalance")))
memo_array = []
sc_schedule_total += float(page_subtotal)
sc_schedule_page_dict = {}
- sc_schedule_page_dict['TRANSACTION_ID'] = sc.get('transactionId')
- sc_schedule_page_dict['totalPages'] = total_no_of_pages
- sc_schedule_page_dict['committeeName'] = f3x_data.get('committeeName')
- sc_schedule_page_dict['pageSubtotal'] = page_subtotal
- for i in ['memoCode', 'memoDescription', 'lenderStreet1', 'lenderStreet2', 'lenderCity', 'lenderState', 'lenderZipCode', 'electionOtherDescription', 'isLoanSecured']:
+ sc_schedule_page_dict["TRANSACTION_ID"] = sc.get("transactionId")
+ sc_schedule_page_dict["totalPages"] = total_no_of_pages
+ sc_schedule_page_dict["committeeName"] = f3x_data.get("committeeName")
+ sc_schedule_page_dict["pageSubtotal"] = page_subtotal
+ for i in [
+ "memoCode",
+ "memoDescription",
+ "lenderStreet1",
+ "lenderStreet2",
+ "lenderCity",
+ "lenderState",
+ "lenderZipCode",
+ "electionOtherDescription",
+ "isLoanSecured",
+ ]:
sc_schedule_page_dict[i] = sc.get(i)
- for i in ['loanAmountOriginal','loanPaymentToDate', 'loanBalance', 'loanInterestRate']:
- sc_schedule_page_dict[i] = '{0:.2f}'.format(float(sc.get(i)))
- if 'electionCode' in sc and sc.get('electionCode') != "":
- sc_schedule_page_dict['electionType'] = sc.get('electionCode')[0:1]
- sc_schedule_page_dict['electionYear'] = sc.get('electionCode')[1:5]
- lenderName =""
- if sc.get('lenderOrganizationName') == "":
- for i in ['lenderPrefix', 'lenderLastName', 'lenderFirstName', 'lenderMiddleName', 'lenderSuffix']:
+ for i in [
+ "loanAmountOriginal",
+ "loanPaymentToDate",
+ "loanBalance",
+ "loanInterestRate",
+ ]:
+ sc_schedule_page_dict[i] = "{0:.2f}".format(float(sc.get(i)))
+ if "electionCode" in sc and sc.get("electionCode") != "":
+ sc_schedule_page_dict["electionType"] = sc.get("electionCode")[0:1]
+ sc_schedule_page_dict["electionYear"] = sc.get("electionCode")[1:5]
+ lenderName = ""
+ if sc.get("lenderOrganizationName") == "":
+ for i in [
+ "lenderPrefix",
+ "lenderLastName",
+ "lenderFirstName",
+ "lenderMiddleName",
+ "lenderSuffix",
+ ]:
if sc.get(i) != "":
lenderName += sc.get(i) + " "
- sc_schedule_page_dict['lenderName'] = lenderName [0:-1]
+ sc_schedule_page_dict["lenderName"] = lenderName[0:-1]
else:
- sc_schedule_page_dict['lenderName'] = sc.get('lenderOrganizationName')
- if 'loanIncurredDate' in sc:
- date_array = sc.get('loanIncurredDate').split("/")
- sc_schedule_page_dict['loanIncurredDateMonth'] = date_array[0]
- sc_schedule_page_dict['loanIncurredDateDay'] = date_array[1]
- sc_schedule_page_dict['loanIncurredDateYear'] = date_array[2]
- if 'loanDueDate' in sc and sc.get('loanDueDate'):
- if "-" in sc.get('loanDueDate'):
- date_array = sc.get('loanDueDate').split("-")
+ sc_schedule_page_dict["lenderName"] = sc.get("lenderOrganizationName")
+ if "loanIncurredDate" in sc:
+ date_array = sc.get("loanIncurredDate").split("/")
+ sc_schedule_page_dict["loanIncurredDateMonth"] = date_array[0]
+ sc_schedule_page_dict["loanIncurredDateDay"] = date_array[1]
+ sc_schedule_page_dict["loanIncurredDateYear"] = date_array[2]
+ if "loanDueDate" in sc and sc.get("loanDueDate"):
+ if "-" in sc.get("loanDueDate"):
+ date_array = sc.get("loanDueDate").split("-")
if len(date_array) == 3:
- sc_schedule_page_dict['loanDueDateMonth'] = date_array[1]
- sc_schedule_page_dict['loanDueDateDay'] = date_array[2]
- sc_schedule_page_dict['loanDueDateYear'] = date_array[0]
+ sc_schedule_page_dict["loanDueDateMonth"] = date_array[1]
+ sc_schedule_page_dict["loanDueDateDay"] = date_array[2]
+ sc_schedule_page_dict["loanDueDateYear"] = date_array[0]
else:
- sc_schedule_page_dict['loanDueDateYear'] = sc.get('loanDueDate')
- elif "/" in sc.get('loanDueDate'):
- date_array = sc.get('loanDueDate').split("/")
+ sc_schedule_page_dict["loanDueDateYear"] = sc.get("loanDueDate")
+ elif "/" in sc.get("loanDueDate"):
+ date_array = sc.get("loanDueDate").split("/")
if len(date_array) == 3:
- sc_schedule_page_dict['loanDueDateMonth'] = date_array[0]
- sc_schedule_page_dict['loanDueDateDay'] = date_array[1]
- sc_schedule_page_dict['loanDueDateYear'] = date_array[2]
+ sc_schedule_page_dict["loanDueDateMonth"] = date_array[0]
+ sc_schedule_page_dict["loanDueDateDay"] = date_array[1]
+ sc_schedule_page_dict["loanDueDateYear"] = date_array[2]
else:
- sc_schedule_page_dict['loanDueDateYear'] = sc.get('loanDueDate')
+ sc_schedule_page_dict["loanDueDateYear"] = sc.get("loanDueDate")
else:
- sc_schedule_page_dict['loanDueDateYear'] = sc.get('loanDueDate')
- if 'child' in sc and sc.get('child'):
+ sc_schedule_page_dict["loanDueDateYear"] = sc.get("loanDueDate")
+ if "child" in sc and sc.get("child"):
sc2 = []
- for sc_child in sc.get('child'):
- if sc_child.get('transactionTypeIdentifier') == 'SC2':
+ for sc_child in sc.get("child"):
+ if sc_child.get("transactionTypeIdentifier") == "SC2":
sc2.append(sc_child)
- elif sc_child.get('transactionTypeIdentifier') == 'SC1':
- sc_child['SCPageNo'] = sc_start_page
+ elif sc_child.get("transactionTypeIdentifier") == "SC1":
+ sc_child["SCPageNo"] = sc_start_page
sc1_list.append(sc_child)
if sc2:
sc2_list_list = []
temp_sc2 = []
for i in range(len(sc2)):
temp_sc2.append(sc2[i])
- if i%4 == 3 or i == len(sc2)-1:
+ if i % 4 == 3 or i == len(sc2) - 1:
sc2_list_list.append(temp_sc2)
temp_sc2 = []
for i in range(len(sc2_list_list)):
@@ -1688,111 +2920,249 @@ def process_sc_line(f3x_data, md5_directory, sc_schedules, sc_start_page, total_
sc_schedule_single_page_dict = sc_schedule_page_dict
for j in range(len(sc2_list_list[i])):
sc2_name = ""
- for k in ['preffix', 'lastName', 'firstName', 'middleName', 'suffix']:
+ for k in [
+ "preffix",
+ "lastName",
+ "firstName",
+ "middleName",
+ "suffix",
+ ]:
if sc2_list_list[i][j].get(k) != "":
sc2_name += sc2_list_list[i][j].get(k) + " "
- sc_schedule_single_page_dict['name{}'.format(j+1)] = sc2_name[0:-1]
- sc_schedule_single_page_dict['street1_{}'.format(j+1)] = sc2_list_list[i][j].get('street1')
- sc_schedule_single_page_dict['street2_{}'.format(j+1)] = sc2_list_list[i][j].get('street2')
- sc_schedule_single_page_dict['city_{}'.format(j+1)] = sc2_list_list[i][j].get('city')
- sc_schedule_single_page_dict['state_{}'.format(j+1)] = sc2_list_list[i][j].get('state')
- sc_schedule_single_page_dict['zipCode_{}'.format(j+1)] = sc2_list_list[i][j].get('zipCode')
- sc_schedule_single_page_dict['employer_{}'.format(j+1)] = sc2_list_list[i][j].get('employer')
- sc_schedule_single_page_dict['occupation_{}'.format(j+1)] = sc2_list_list[i][j].get('occupation')
- sc_schedule_single_page_dict['guaranteedAmount_{}'.format(j+1)] = '{0:.2f}'.format(float(sc2_list_list[i][j].get('guaranteedAmount')))
- sc_schedule_single_page_dict['pageNo'] = sc_start_page
- if sc_schedules[len(sc_schedules)-1].get('transactionId') == sc_schedule_single_page_dict.get('TRANSACTION_ID') and i == len(sc2_list_list)-1:
- totalOutstandingLoans = sc_schedule_single_page_dict['scheduleTotal'] = '{0:.2f}'.format(sc_schedule_total)
- sc_outfile = md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf'
- pypdftk.fill_form(sc_infile, sc_schedule_single_page_dict, sc_outfile)
+ sc_schedule_single_page_dict["name{}".format(j + 1)] = sc2_name[
+ 0:-1
+ ]
+ sc_schedule_single_page_dict[
+ "street1_{}".format(j + 1)
+ ] = sc2_list_list[i][j].get("street1")
+ sc_schedule_single_page_dict[
+ "street2_{}".format(j + 1)
+ ] = sc2_list_list[i][j].get("street2")
+ sc_schedule_single_page_dict[
+ "city_{}".format(j + 1)
+ ] = sc2_list_list[i][j].get("city")
+ sc_schedule_single_page_dict[
+ "state_{}".format(j + 1)
+ ] = sc2_list_list[i][j].get("state")
+ sc_schedule_single_page_dict[
+ "zipCode_{}".format(j + 1)
+ ] = sc2_list_list[i][j].get("zipCode")
+ sc_schedule_single_page_dict[
+ "employer_{}".format(j + 1)
+ ] = sc2_list_list[i][j].get("employer")
+ sc_schedule_single_page_dict[
+ "occupation_{}".format(j + 1)
+ ] = sc2_list_list[i][j].get("occupation")
+ sc_schedule_single_page_dict[
+ "guaranteedAmount_{}".format(j + 1)
+ ] = "{0:.2f}".format(
+ float(sc2_list_list[i][j].get("guaranteedAmount"))
+ )
+ sc_schedule_single_page_dict["pageNo"] = sc_start_page
+ if (
+ sc_schedules[len(sc_schedules) - 1].get("transactionId")
+ == sc_schedule_single_page_dict.get("TRANSACTION_ID")
+ and i == len(sc2_list_list) - 1
+ ):
+ totalOutstandingLoans = sc_schedule_single_page_dict[
+ "scheduleTotal"
+ ] = "{0:.2f}".format(sc_schedule_total)
+ sc_outfile = (
+ md5_directory + "SC" + "/page_" + str(sc_start_page) + ".pdf"
+ )
+ pypdftk.fill_form(
+ sc_infile, sc_schedule_single_page_dict, sc_outfile
+ )
# Memo text changes
- if 'memoDescription' in sc_schedule_page_dict and sc_schedule_page_dict['memoDescription']:
+ if (
+ "memoDescription" in sc_schedule_page_dict
+ and sc_schedule_page_dict["memoDescription"]
+ ):
memo_dict = {}
- temp_memo_outfile = md5_directory + 'SC/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SC/page_memo_' + str(sc_start_page) + '.pdf'
- memo_dict['scheduleName_1'] = 'SC13'
- memo_dict['memoDescription_1'] = sc_schedule_page_dict['memoDescription']
- if 'TRANSACTION_ID' in sc_schedule_page_dict and sc_schedule_page_dict['TRANSACTION_ID']:
- memo_dict['transactionId_1'] = sc_schedule_page_dict['TRANSACTION_ID']
+ temp_memo_outfile = md5_directory + "SC/page_memo_temp.pdf"
+ memo_infile = current_app.config[
+ "FORM_TEMPLATES_LOCATION"
+ ].format("TEXT")
+ memo_outfile = (
+ md5_directory
+ + "SC/page_memo_"
+ + str(sc_start_page)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = "SC13"
+ memo_dict["memoDescription_1"] = sc_schedule_page_dict[
+ "memoDescription"
+ ]
+ if (
+ "TRANSACTION_ID" in sc_schedule_page_dict
+ and sc_schedule_page_dict["TRANSACTION_ID"]
+ ):
+ memo_dict["transactionId_1"] = sc_schedule_page_dict[
+ "TRANSACTION_ID"
+ ]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sc_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sc_outfile)
for j in range(len(sc2_list_list[i])):
- del sc_schedule_single_page_dict['name{}'.format(j+1)]
- del sc_schedule_single_page_dict['street1_{}'.format(j+1)]
- del sc_schedule_single_page_dict['street2_{}'.format(j+1)]
- del sc_schedule_single_page_dict['city_{}'.format(j+1)]
- del sc_schedule_single_page_dict['state_{}'.format(j+1)]
- del sc_schedule_single_page_dict['zipCode_{}'.format(j+1)]
- del sc_schedule_single_page_dict['employer_{}'.format(j+1)]
- del sc_schedule_single_page_dict['occupation_{}'.format(j+1)]
- del sc_schedule_single_page_dict['guaranteedAmount_{}'.format(j+1)]
- if path.isfile(md5_directory + 'SC/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SC/all_pages.pdf', md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf'],
- md5_directory + 'SC/temp_all_pages.pdf')
- os.rename(md5_directory + 'SC/temp_all_pages.pdf', md5_directory + 'SC/all_pages.pdf')
+ del sc_schedule_single_page_dict["name{}".format(j + 1)]
+ del sc_schedule_single_page_dict["street1_{}".format(j + 1)]
+ del sc_schedule_single_page_dict["street2_{}".format(j + 1)]
+ del sc_schedule_single_page_dict["city_{}".format(j + 1)]
+ del sc_schedule_single_page_dict["state_{}".format(j + 1)]
+ del sc_schedule_single_page_dict["zipCode_{}".format(j + 1)]
+ del sc_schedule_single_page_dict["employer_{}".format(j + 1)]
+ del sc_schedule_single_page_dict["occupation_{}".format(j + 1)]
+ del sc_schedule_single_page_dict[
+ "guaranteedAmount_{}".format(j + 1)
+ ]
+ if path.isfile(md5_directory + "SC/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SC/all_pages.pdf",
+ md5_directory
+ + "SC"
+ + "/page_"
+ + str(sc_start_page)
+ + ".pdf",
+ ],
+ md5_directory + "SC/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SC/temp_all_pages.pdf",
+ md5_directory + "SC/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf', md5_directory + 'SC/all_pages.pdf')
+ os.rename(
+ md5_directory
+ + "SC"
+ + "/page_"
+ + str(sc_start_page)
+ + ".pdf",
+ md5_directory + "SC/all_pages.pdf",
+ )
sc_start_page += 1
else:
- sc_schedule_page_dict['pageNo'] = sc_start_page
- if sc_schedules[len(sc_schedules)-1].get('transactionId') == sc_schedule_page_dict.get('TRANSACTION_ID'):
- totalOutstandingLoans = sc_schedule_page_dict['scheduleTotal'] = '{0:.2f}'.format(sc_schedule_total)
- sc_outfile = md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf'
+ sc_schedule_page_dict["pageNo"] = sc_start_page
+ if sc_schedules[len(sc_schedules) - 1].get(
+ "transactionId"
+ ) == sc_schedule_page_dict.get("TRANSACTION_ID"):
+ totalOutstandingLoans = sc_schedule_page_dict[
+ "scheduleTotal"
+ ] = "{0:.2f}".format(sc_schedule_total)
+ sc_outfile = (
+ md5_directory + "SC" + "/page_" + str(sc_start_page) + ".pdf"
+ )
pypdftk.fill_form(sc_infile, sc_schedule_page_dict, sc_outfile)
# Memo text changes
- if 'memoDescription' in sc_schedule_page_dict and sc_schedule_page_dict['memoDescription']:
+ if (
+ "memoDescription" in sc_schedule_page_dict
+ and sc_schedule_page_dict["memoDescription"]
+ ):
memo_dict = {}
- temp_memo_outfile = md5_directory + 'SC/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SC/page_memo_' + str(sc_start_page) + '.pdf'
- memo_dict['scheduleName_1'] = 'SC13'
- memo_dict['memoDescription_1'] = sc_schedule_page_dict['memoDescription']
- if 'TRANSACTION_ID' in sc_schedule_page_dict and sc_schedule_page_dict['TRANSACTION_ID']:
- memo_dict['transactionId_1'] = sc_schedule_page_dict['TRANSACTION_ID']
+ temp_memo_outfile = md5_directory + "SC/page_memo_temp.pdf"
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory + "SC/page_memo_" + str(sc_start_page) + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = "SC13"
+ memo_dict["memoDescription_1"] = sc_schedule_page_dict[
+ "memoDescription"
+ ]
+ if (
+ "TRANSACTION_ID" in sc_schedule_page_dict
+ and sc_schedule_page_dict["TRANSACTION_ID"]
+ ):
+ memo_dict["transactionId_1"] = sc_schedule_page_dict[
+ "TRANSACTION_ID"
+ ]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sc_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sc_outfile)
- if path.isfile(md5_directory + 'SC/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SC/all_pages.pdf', md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf'],
- md5_directory + 'SC/temp_all_pages.pdf')
- os.rename(md5_directory + 'SC/temp_all_pages.pdf', md5_directory + 'SC/all_pages.pdf')
+ if path.isfile(md5_directory + "SC/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SC/all_pages.pdf",
+ md5_directory
+ + "SC"
+ + "/page_"
+ + str(sc_start_page)
+ + ".pdf",
+ ],
+ md5_directory + "SC/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SC/temp_all_pages.pdf",
+ md5_directory + "SC/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf', md5_directory + 'SC/all_pages.pdf')
+ os.rename(
+ md5_directory + "SC" + "/page_" + str(sc_start_page) + ".pdf",
+ md5_directory + "SC/all_pages.pdf",
+ )
sc_start_page += 1
else:
- sc_schedule_page_dict['pageNo'] = sc_start_page
- if sc_schedules[len(sc_schedules)-1].get('transactionId') == sc_schedule_page_dict.get('TRANSACTION_ID'):
- totalOutstandingLoans = sc_schedule_page_dict['scheduleTotal'] = '{0:.2f}'.format(sc_schedule_total)
- sc_outfile = md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf'
+ sc_schedule_page_dict["pageNo"] = sc_start_page
+ if sc_schedules[len(sc_schedules) - 1].get(
+ "transactionId"
+ ) == sc_schedule_page_dict.get("TRANSACTION_ID"):
+ totalOutstandingLoans = sc_schedule_page_dict[
+ "scheduleTotal"
+ ] = "{0:.2f}".format(sc_schedule_total)
+ sc_outfile = md5_directory + "SC" + "/page_" + str(sc_start_page) + ".pdf"
pypdftk.fill_form(sc_infile, sc_schedule_page_dict, sc_outfile)
# Memo text changes
- if 'memoDescription' in sc_schedule_page_dict and sc_schedule_page_dict['memoDescription']:
+ if (
+ "memoDescription" in sc_schedule_page_dict
+ and sc_schedule_page_dict["memoDescription"]
+ ):
memo_dict = {}
- temp_memo_outfile = md5_directory + 'SC/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SC/page_memo_' + str(sc_start_page) + '.pdf'
- memo_dict['scheduleName_1'] = 'SC13'
- memo_dict['memoDescription_1'] = sc_schedule_page_dict['memoDescription']
- if 'TRANSACTION_ID' in sc_schedule_page_dict and sc_schedule_page_dict['TRANSACTION_ID']:
- memo_dict['transactionId_1'] = sc_schedule_page_dict['TRANSACTION_ID']
+ temp_memo_outfile = md5_directory + "SC/page_memo_temp.pdf"
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory + "SC/page_memo_" + str(sc_start_page) + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = "SC13"
+ memo_dict["memoDescription_1"] = sc_schedule_page_dict[
+ "memoDescription"
+ ]
+ if (
+ "TRANSACTION_ID" in sc_schedule_page_dict
+ and sc_schedule_page_dict["TRANSACTION_ID"]
+ ):
+ memo_dict["transactionId_1"] = sc_schedule_page_dict[
+ "TRANSACTION_ID"
+ ]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sc_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sc_outfile)
- if path.isfile(md5_directory + 'SC/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SC/all_pages.pdf', md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf'],
- md5_directory + 'SC/temp_all_pages.pdf')
- os.rename(md5_directory + 'SC/temp_all_pages.pdf', md5_directory + 'SC/all_pages.pdf')
+ if path.isfile(md5_directory + "SC/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SC/all_pages.pdf",
+ md5_directory + "SC" + "/page_" + str(sc_start_page) + ".pdf",
+ ],
+ md5_directory + "SC/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SC/temp_all_pages.pdf",
+ md5_directory + "SC/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SC' + '/page_' + str(sc_start_page) + '.pdf', md5_directory + 'SC/all_pages.pdf')
+ os.rename(
+ md5_directory + "SC" + "/page_" + str(sc_start_page) + ".pdf",
+ md5_directory + "SC/all_pages.pdf",
+ )
sc_start_page += 1
return sc1_list, sc_start_page, totalOutstandingLoans
@@ -1906,121 +3276,182 @@ def process_sc_line(f3x_data, md5_directory, sc_schedules, sc_start_page, total_
def process_sc1_line(f3x_data, md5_directory, sc1, sc1_start_page, total_no_of_pages):
sc1_schedule_page_dict = {}
- sc1_schedule_page_dict['PAGENO'] = sc1_start_page
- sc1_schedule_page_dict['TRANSACTION_ID'] = sc1.get('transactionId')
- sc1_schedule_page_dict['TOTALPAGES'] = total_no_of_pages
- sc1_schedule_page_dict['committeeName'] = f3x_data.get('committeeName')
- sc1_schedule_page_dict['committeeId'] = f3x_data.get('committeeId')
- sc1_schedule_page_dict['lenderName'] = sc1.get('lenderOrganizationName')
- for i in ['lenderStreet1', 'lenderStreet2', 'lenderCity', 'lenderState', 'lenderZipCode', 'loanInterestRate', 'isLoanRestructured', 'otherPartiesLiable',
- 'pledgedCollateralIndicator', 'pledgeCollateralDescription', 'perfectedInterestIndicator', 'futureIncomeIndicator', 'SCPageNo']:
+ sc1_schedule_page_dict["PAGENO"] = sc1_start_page
+ sc1_schedule_page_dict["TRANSACTION_ID"] = sc1.get("transactionId")
+ sc1_schedule_page_dict["TOTALPAGES"] = total_no_of_pages
+ sc1_schedule_page_dict["committeeName"] = f3x_data.get("committeeName")
+ sc1_schedule_page_dict["committeeId"] = f3x_data.get("committeeId")
+ sc1_schedule_page_dict["lenderName"] = sc1.get("lenderOrganizationName")
+ for i in [
+ "lenderStreet1",
+ "lenderStreet2",
+ "lenderCity",
+ "lenderState",
+ "lenderZipCode",
+ "loanInterestRate",
+ "isLoanRestructured",
+ "otherPartiesLiable",
+ "pledgedCollateralIndicator",
+ "pledgeCollateralDescription",
+ "perfectedInterestIndicator",
+ "futureIncomeIndicator",
+ "SCPageNo",
+ ]:
sc1_schedule_page_dict[i] = sc1.get(i)
- if sc1.get('loanIncurredDate') != "":
- date_array = sc1.get('loanIncurredDate').split("/")
- sc1_schedule_page_dict['loanIncurredDateMonth'] = date_array[0]
- sc1_schedule_page_dict['loanIncurredDateDay'] = date_array[1]
- sc1_schedule_page_dict['loanIncurredDateYear'] = date_array[2]
-
- if sc1.get('loanDueDate') != "":
- if "-" in sc1.get('loanDueDate'):
- date_array = sc1.get('loanDueDate').split("-")
+ if sc1.get("loanIncurredDate") != "":
+ date_array = sc1.get("loanIncurredDate").split("/")
+ sc1_schedule_page_dict["loanIncurredDateMonth"] = date_array[0]
+ sc1_schedule_page_dict["loanIncurredDateDay"] = date_array[1]
+ sc1_schedule_page_dict["loanIncurredDateYear"] = date_array[2]
+
+ if sc1.get("loanDueDate") != "":
+ if "-" in sc1.get("loanDueDate"):
+ date_array = sc1.get("loanDueDate").split("-")
if len(date_array) == 3:
- sc1_schedule_page_dict['loanDueDateMonth'] = date_array[1]
- sc1_schedule_page_dict['loanDueDateDay'] = date_array[2]
- sc1_schedule_page_dict['loanDueDateYear'] = date_array[0]
+ sc1_schedule_page_dict["loanDueDateMonth"] = date_array[1]
+ sc1_schedule_page_dict["loanDueDateDay"] = date_array[2]
+ sc1_schedule_page_dict["loanDueDateYear"] = date_array[0]
else:
- sc1_schedule_page_dict['loanDueDateYear'] = sc1.get('loanDueDate')
- elif "/" in sc1.get('loanDueDate'):
- date_array = sc1.get('loanDueDate').split("/")
+ sc1_schedule_page_dict["loanDueDateYear"] = sc1.get("loanDueDate")
+ elif "/" in sc1.get("loanDueDate"):
+ date_array = sc1.get("loanDueDate").split("/")
if len(date_array) == 3:
- sc1_schedule_page_dict['loanDueDateMonth'] = date_array[0]
- sc1_schedule_page_dict['loanDueDateDay'] = date_array[1]
- sc1_schedule_page_dict['loanDueDateYear'] = date_array[2]
+ sc1_schedule_page_dict["loanDueDateMonth"] = date_array[0]
+ sc1_schedule_page_dict["loanDueDateDay"] = date_array[1]
+ sc1_schedule_page_dict["loanDueDateYear"] = date_array[2]
else:
- sc1_schedule_page_dict['loanDueDateYear'] = sc1.get('loanDueDate')
+ sc1_schedule_page_dict["loanDueDateYear"] = sc1.get("loanDueDate")
else:
- sc1_schedule_page_dict['loanDueDateYear'] = sc1.get('loanDueDate')
- if sc1.get('originalLoanDate') != "":
- date_array = sc1.get('originalLoanDate').split("/")
- sc1_schedule_page_dict['originalLoanDateMonth'] = date_array[0]
- sc1_schedule_page_dict['originalLoanDateDay'] = date_array[1]
- sc1_schedule_page_dict['originalLoanDateYear'] = date_array[2]
- if sc1.get('depositoryAccountEstablishedDate') != "":
- date_array = sc1.get('depositoryAccountEstablishedDate').split("/")
- sc1_schedule_page_dict['ACCOUNT_EST_DATE_MM'] = date_array[0]
- sc1_schedule_page_dict['ACCOUNT_EST_DATE_DD'] = date_array[1]
- sc1_schedule_page_dict['ACCOUNT_EST_DATE_YY'] = date_array[2]
- sc1_schedule_page_dict['loanAmount'] = '{0:.2f}'.format(float(sc1.get('loanAmount')))
- sc1_schedule_page_dict['creditAmountThisDraw'] = '{0:.2f}'.format(float(sc1.get('creditAmountThisDraw')))
- sc1_schedule_page_dict['totalOutstandingBalance'] = '{0:.2f}'.format(float(sc1.get('totalOutstandingBalance')))
- sc1_schedule_page_dict['BACK_REF_TRAN_ID'] = sc1.get('backReferenceTransactionIdNumber')
- sc1_schedule_page_dict['pledgeCollateralAmount'] = '{0:.2f}'.format(float(sc1.get('pledgeCollateralAmount')))
- sc1_schedule_page_dict['PLEDGE_DESC'] = sc1.get('futureIncomeDescription')
- sc1_schedule_page_dict['PLEDGE_ESTIMATED_AMOUNT'] = '{0:.2f}'.format(float(sc1.get('futureIncomeEstimate')))
+ sc1_schedule_page_dict["loanDueDateYear"] = sc1.get("loanDueDate")
+ if sc1.get("originalLoanDate") != "":
+ date_array = sc1.get("originalLoanDate").split("/")
+ sc1_schedule_page_dict["originalLoanDateMonth"] = date_array[0]
+ sc1_schedule_page_dict["originalLoanDateDay"] = date_array[1]
+ sc1_schedule_page_dict["originalLoanDateYear"] = date_array[2]
+ if sc1.get("depositoryAccountEstablishedDate") != "":
+ date_array = sc1.get("depositoryAccountEstablishedDate").split("/")
+ sc1_schedule_page_dict["ACCOUNT_EST_DATE_MM"] = date_array[0]
+ sc1_schedule_page_dict["ACCOUNT_EST_DATE_DD"] = date_array[1]
+ sc1_schedule_page_dict["ACCOUNT_EST_DATE_YY"] = date_array[2]
+ sc1_schedule_page_dict["loanAmount"] = "{0:.2f}".format(
+ float(sc1.get("loanAmount"))
+ )
+ sc1_schedule_page_dict["creditAmountThisDraw"] = "{0:.2f}".format(
+ float(sc1.get("creditAmountThisDraw"))
+ )
+ sc1_schedule_page_dict["totalOutstandingBalance"] = "{0:.2f}".format(
+ float(sc1.get("totalOutstandingBalance"))
+ )
+ sc1_schedule_page_dict["BACK_REF_TRAN_ID"] = sc1.get(
+ "backReferenceTransactionIdNumber"
+ )
+ sc1_schedule_page_dict["pledgeCollateralAmount"] = "{0:.2f}".format(
+ float(sc1.get("pledgeCollateralAmount"))
+ )
+ sc1_schedule_page_dict["PLEDGE_DESC"] = sc1.get("futureIncomeDescription")
+ sc1_schedule_page_dict["PLEDGE_ESTIMATED_AMOUNT"] = "{0:.2f}".format(
+ float(sc1.get("futureIncomeEstimate"))
+ )
treasurerName = ""
- for i in ['treasurerPrefix', 'treasurerLastName', 'treasurerFirstName', 'treasurerMiddleName', 'treasurerSuffix']:
+ for i in [
+ "treasurerPrefix",
+ "treasurerLastName",
+ "treasurerFirstName",
+ "treasurerMiddleName",
+ "treasurerSuffix",
+ ]:
if sc1.get(i) != "":
treasurerName += sc1.get(i) + " "
- sc1_schedule_page_dict['COMMITTEE_TREASURER_NAME'] = treasurerName[0:-1]
- sc1_schedule_page_dict['DEPOSITORY_NAME'] = sc1.get('depositoryAccountLocation')
- sc1_schedule_page_dict['DEPOSITORY_STREET1'] = sc1.get('depositoryAccountStreet1')
- sc1_schedule_page_dict['DEPOSITORY_STREET2'] = sc1.get('depositoryAccountStreet2')
- sc1_schedule_page_dict['DEPOSITORY_CITY'] = sc1.get('depositoryAccountCity')
- sc1_schedule_page_dict['DEPOSITORY_STATE'] = sc1.get('depositoryAccountState')
- sc1_schedule_page_dict['DEPOSITORY_ZIP'] = sc1.get('depositoryAccountZipCode')
- sc1_schedule_page_dict['BASIS'] = sc1.get('basisOfLoanDescription')
- if sc1.get('treasurerSignedDate') != "":
- date_array = sc1.get('treasurerSignedDate').split("/")
- sc1_schedule_page_dict['TREASUER_SIGN_DATE_MM'] = date_array[0]
- sc1_schedule_page_dict['TREASUER_SIGN_DATE_DD'] = date_array[1]
- sc1_schedule_page_dict['TREASUER_SIGN_DATE_YY'] = date_array[2]
+ sc1_schedule_page_dict["COMMITTEE_TREASURER_NAME"] = treasurerName[0:-1]
+ sc1_schedule_page_dict["DEPOSITORY_NAME"] = sc1.get("depositoryAccountLocation")
+ sc1_schedule_page_dict["DEPOSITORY_STREET1"] = sc1.get("depositoryAccountStreet1")
+ sc1_schedule_page_dict["DEPOSITORY_STREET2"] = sc1.get("depositoryAccountStreet2")
+ sc1_schedule_page_dict["DEPOSITORY_CITY"] = sc1.get("depositoryAccountCity")
+ sc1_schedule_page_dict["DEPOSITORY_STATE"] = sc1.get("depositoryAccountState")
+ sc1_schedule_page_dict["DEPOSITORY_ZIP"] = sc1.get("depositoryAccountZipCode")
+ sc1_schedule_page_dict["BASIS"] = sc1.get("basisOfLoanDescription")
+ if sc1.get("treasurerSignedDate") != "":
+ date_array = sc1.get("treasurerSignedDate").split("/")
+ sc1_schedule_page_dict["TREASUER_SIGN_DATE_MM"] = date_array[0]
+ sc1_schedule_page_dict["TREASUER_SIGN_DATE_DD"] = date_array[1]
+ sc1_schedule_page_dict["TREASUER_SIGN_DATE_YY"] = date_array[2]
authorizedName = ""
- for i in ['authorizedPrefix', 'authorizedLastName', 'authorizedFirstName', 'authorizedMiddleName', 'authorizedSuffix']:
+ for i in [
+ "authorizedPrefix",
+ "authorizedLastName",
+ "authorizedFirstName",
+ "authorizedMiddleName",
+ "authorizedSuffix",
+ ]:
if sc1.get(i) != "":
authorizedName += sc1.get(i) + " "
- sc1_schedule_page_dict['AUTH_REP_NAME'] = authorizedName[0:-1]
- sc1_schedule_page_dict['AUTH_REP_TITLE'] = sc1.get('authorizedTitle')
- if sc1.get('authorizedSignedDate') != "":
- date_array = sc1.get('authorizedSignedDate').split("/")
- sc1_schedule_page_dict['AUTH_REP_SIGN_MM'] = date_array[0]
- sc1_schedule_page_dict['AUTH_REP_SIGN_DD'] = date_array[1]
- sc1_schedule_page_dict['AUTH_REP_SIGN_YY'] = date_array[2]
- sc1_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SC1')
- sc1_outfile = md5_directory + 'SC' + '/page_' + str(sc1_start_page) + '.pdf'
+ sc1_schedule_page_dict["AUTH_REP_NAME"] = authorizedName[0:-1]
+ sc1_schedule_page_dict["AUTH_REP_TITLE"] = sc1.get("authorizedTitle")
+ if sc1.get("authorizedSignedDate") != "":
+ date_array = sc1.get("authorizedSignedDate").split("/")
+ sc1_schedule_page_dict["AUTH_REP_SIGN_MM"] = date_array[0]
+ sc1_schedule_page_dict["AUTH_REP_SIGN_DD"] = date_array[1]
+ sc1_schedule_page_dict["AUTH_REP_SIGN_YY"] = date_array[2]
+ sc1_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SC1")
+ sc1_outfile = md5_directory + "SC" + "/page_" + str(sc1_start_page) + ".pdf"
pypdftk.fill_form(sc1_infile, sc1_schedule_page_dict, sc1_outfile)
# Memo text changes
- if 'memoDescription' in sc1_schedule_page_dict and sc1_schedule_page_dict['memoDescription']:
+ if (
+ "memoDescription" in sc1_schedule_page_dict
+ and sc1_schedule_page_dict["memoDescription"]
+ ):
memo_dict = {}
- temp_memo_outfile = md5_directory + 'SC/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SC/page_memo_' + str(sc1_start_page) + '.pdf'
- memo_dict['scheduleName_1'] = 'SC1'
- memo_dict['memoDescription_1'] = sc1_schedule_page_dict['memoDescription']
- if 'transactionId' in sc1_schedule_page_dict and sc1_schedule_page_dict['transactionId']:
- memo_dict['transactionId_1'] = sc1_schedule_page_dict['transactionId']
+ temp_memo_outfile = md5_directory + "SC/page_memo_temp.pdf"
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("TEXT")
+ memo_outfile = md5_directory + "SC/page_memo_" + str(sc1_start_page) + ".pdf"
+ memo_dict["scheduleName_1"] = "SC1"
+ memo_dict["memoDescription_1"] = sc1_schedule_page_dict["memoDescription"]
+ if (
+ "transactionId" in sc1_schedule_page_dict
+ and sc1_schedule_page_dict["transactionId"]
+ ):
+ memo_dict["transactionId_1"] = sc1_schedule_page_dict["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sc1_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sc1_outfile)
- if path.isfile(md5_directory + 'SC/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SC/all_pages.pdf', md5_directory + 'SC' + '/page_' + str(sc1_start_page) + '.pdf'],
- md5_directory + 'SC/temp_all_pages.pdf')
- os.rename(md5_directory + 'SC/temp_all_pages.pdf', md5_directory + 'SC/all_pages.pdf')
+ if path.isfile(md5_directory + "SC/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SC/all_pages.pdf",
+ md5_directory + "SC" + "/page_" + str(sc1_start_page) + ".pdf",
+ ],
+ md5_directory + "SC/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SC/temp_all_pages.pdf", md5_directory + "SC/all_pages.pdf"
+ )
else:
- os.rename(md5_directory + 'SC/all_pages.pdf', md5_directory + 'SC' + '/page_' + str(sc1_start_page) + '.pdf')
+ os.rename(
+ md5_directory + "SC/all_pages.pdf",
+ md5_directory + "SC" + "/page_" + str(sc1_start_page) + ".pdf",
+ )
# This method is invoked for each SA line number, it builds PDF for line numbers
-def process_sa_line(f3x_data, md5_directory, line_number, sa_line, sa_line_page_cnt, sa_line_start_page,
- sa_line_last_page_cnt, total_no_of_pages):
+def process_sa_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ sa_line,
+ sa_line_page_cnt,
+ sa_line_start_page,
+ sa_line_last_page_cnt,
+ total_no_of_pages,
+):
has_sa_schedules = False
if len(sa_line) > 0:
sa_line_start_page += 1
has_sa_schedules = True
schedule_total = 0.00
- os.makedirs(md5_directory + 'SA/' + line_number, exist_ok=True)
- sa_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SA')
+ os.makedirs(md5_directory + "SA/" + line_number, exist_ok=True)
+ sa_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SA")
if sa_line_page_cnt > 0:
for sa_page_no in range(sa_line_page_cnt):
@@ -2031,38 +3462,65 @@ def process_sa_line(f3x_data, md5_directory, line_number, sa_line, sa_line_page_
memo_array = []
last_page = False
sa_schedule_page_dict = {}
- sa_schedule_page_dict['lineNumber'] = line_number
- sa_schedule_page_dict['pageNo'] = sa_line_start_page + sa_page_no
- sa_schedule_page_dict['totalPages'] = total_no_of_pages
+ sa_schedule_page_dict["lineNumber"] = line_number
+ sa_schedule_page_dict["pageNo"] = sa_line_start_page + sa_page_no
+ sa_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sa_page_no * 3
- if ((sa_page_no + 1) == sa_line_page_cnt):
+ if (sa_page_no + 1) == sa_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sa_schedule_dict = build_sa_per_page_schedule_dict(last_page, sa_line_last_page_cnt,
- page_start_index, sa_schedule_page_dict,
- sa_line, memo_array)
+ sa_schedule_dict = build_sa_per_page_schedule_dict(
+ last_page,
+ sa_line_last_page_cnt,
+ page_start_index,
+ sa_schedule_page_dict,
+ sa_line,
+ memo_array,
+ )
- page_subtotal = float(sa_schedule_page_dict['pageSubtotal'])
+ page_subtotal = float(sa_schedule_page_dict["pageSubtotal"])
schedule_total += page_subtotal
if sa_line_page_cnt == (sa_page_no + 1):
- sa_schedule_page_dict['scheduleTotal'] = '{0:.2f}'.format(schedule_total)
- sa_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sa_outfile = md5_directory + 'SA/' + line_number + '/page_' + str(sa_page_no) + '.pdf'
+ sa_schedule_page_dict["scheduleTotal"] = "{0:.2f}".format(
+ schedule_total
+ )
+ sa_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sa_outfile = (
+ md5_directory
+ + "SA/"
+ + line_number
+ + "/page_"
+ + str(sa_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sa_infile, sa_schedule_page_dict, sa_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SA/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SA/' + line_number + '/page_memo_' + str(sa_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SA/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SA/"
+ + line_number
+ + "/page_memo_"
+ + str(sa_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sa_outfile, memo_outfile], temp_memo_outfile)
@@ -2071,28 +3529,50 @@ def process_sa_line(f3x_data, md5_directory, line_number, sa_line, sa_line_page_
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SA/' + line_number + '/page_memo_' + str(sa_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[2]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[2]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[2]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SA/"
+ + line_number
+ + "/page_memo_"
+ + str(sa_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[2]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[2][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[2]["transactionId"]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sa_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sa_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SA/' + line_number + '/'), md5_directory + 'SA/' + line_number
- + '/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SA/" + line_number + "/"),
+ md5_directory + "SA/" + line_number + "/all_pages.pdf",
+ )
# if len(sa_memo) > 0:
# for sa_memo_obj in range(sa_memo):
# sa_outfile = md5_directory + 'SA/' + line_number + '/page_' + str(sa_page_no) + '.pdf'
# pypdftk.fill_form(sa_infile, sa_schedule_page_dict, sa_outfile)
# if all_pages.pdf exists in SA folder, concatenate line number pdf to all_pages.pdf
- if path.isfile(md5_directory + 'SA/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SA/all_pages.pdf', md5_directory + 'SA/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SA/temp_all_pages.pdf')
- os.rename(md5_directory + 'SA/temp_all_pages.pdf', md5_directory + 'SA/all_pages.pdf')
+ if path.isfile(md5_directory + "SA/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SA/all_pages.pdf",
+ md5_directory + "SA/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SA/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SA/temp_all_pages.pdf",
+ md5_directory + "SA/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SA/' + line_number + '/all_pages.pdf', md5_directory + 'SA/all_pages.pdf')
+ os.rename(
+ md5_directory + "SA/" + line_number + "/all_pages.pdf",
+ md5_directory + "SA/all_pages.pdf",
+ )
return has_sa_schedules
@@ -2133,15 +3613,22 @@ def process_sa_line(f3x_data, md5_directory, line_number, sa_line, sa_line_page_
# return has_sa_memo_schedules
-
# This method is invoked for each SB line number, it builds PDF for line numbers
-def process_sb_line(f3x_data, md5_directory, line_number, sb_line, sb_line_page_cnt, sb_line_start_page,
- sb_line_last_page_cnt, total_no_of_pages):
+def process_sb_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ sb_line,
+ sb_line_page_cnt,
+ sb_line_start_page,
+ sb_line_last_page_cnt,
+ total_no_of_pages,
+):
has_sb_schedules = False
if len(sb_line) > 0:
schedule_total = 0.00
- os.makedirs(md5_directory + 'SB/' + line_number, exist_ok=True)
- sb_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SB')
+ os.makedirs(md5_directory + "SB/" + line_number, exist_ok=True)
+ sb_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SB")
if sb_line_page_cnt > 0:
sb_line_start_page += 1
for sb_page_no in range(sb_line_page_cnt):
@@ -2149,37 +3636,64 @@ def process_sb_line(f3x_data, md5_directory, line_number, sb_line, sb_line_page_
memo_array = []
last_page = False
sb_schedule_page_dict = {}
- sb_schedule_page_dict['lineNumber'] = line_number
- sb_schedule_page_dict['pageNo'] = sb_line_start_page + sb_page_no
- sb_schedule_page_dict['totalPages'] = total_no_of_pages
+ sb_schedule_page_dict["lineNumber"] = line_number
+ sb_schedule_page_dict["pageNo"] = sb_line_start_page + sb_page_no
+ sb_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sb_page_no * 3
- if ((sb_page_no + 1) == sb_line_page_cnt):
+ if (sb_page_no + 1) == sb_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sb_schedule_dict = build_sb_per_page_schedule_dict(last_page, sb_line_last_page_cnt,
- page_start_index, sb_schedule_page_dict,
- sb_line, memo_array)
+ sb_schedule_dict = build_sb_per_page_schedule_dict(
+ last_page,
+ sb_line_last_page_cnt,
+ page_start_index,
+ sb_schedule_page_dict,
+ sb_line,
+ memo_array,
+ )
- page_subtotal = float(sb_schedule_page_dict['pageSubtotal'])
+ page_subtotal = float(sb_schedule_page_dict["pageSubtotal"])
schedule_total += page_subtotal
if sb_line_page_cnt == (sb_page_no + 1):
- sb_schedule_page_dict['scheduleTotal'] = '{0:.2f}'.format(schedule_total)
- sb_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sb_outfile = md5_directory + 'SB/' + line_number + '/page_' + str(sb_page_no) + '.pdf'
+ sb_schedule_page_dict["scheduleTotal"] = "{0:.2f}".format(
+ schedule_total
+ )
+ sb_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sb_outfile = (
+ md5_directory
+ + "SB/"
+ + line_number
+ + "/page_"
+ + str(sb_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sb_infile, sb_schedule_page_dict, sb_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SB/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SB/' + line_number + '/page_memo_' + str(sb_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SB/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SB/"
+ + line_number
+ + "/page_memo_"
+ + str(sb_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sb_outfile, memo_outfile], temp_memo_outfile)
@@ -2188,22 +3702,44 @@ def process_sb_line(f3x_data, md5_directory, line_number, sb_line, sb_line_page_
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SB/' + line_number + '/page_memo_' + str(sb_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[2]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[2]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[2]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SB/"
+ + line_number
+ + "/page_memo_"
+ + str(sb_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[2]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[2][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[2]["transactionId"]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sb_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sb_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SB/' + line_number + '/'), md5_directory + 'SB/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SB/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SB/all_pages.pdf', md5_directory + 'SB/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SB/temp_all_pages.pdf')
- os.rename(md5_directory + 'SB/temp_all_pages.pdf', md5_directory + 'SB/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SB/" + line_number + "/"),
+ md5_directory + "SB/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SB/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SB/all_pages.pdf",
+ md5_directory + "SB/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SB/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SB/temp_all_pages.pdf",
+ md5_directory + "SB/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SB/' + line_number + '/all_pages.pdf', md5_directory + 'SB/all_pages.pdf')
+ os.rename(
+ md5_directory + "SB/" + line_number + "/all_pages.pdf",
+ md5_directory + "SB/all_pages.pdf",
+ )
return has_sb_schedules
@@ -2242,13 +3778,21 @@ def process_sb_line(f3x_data, md5_directory, line_number, sb_line, sb_line_page_
# return has_sb_memo_schedules
-def process_se_line(f3x_data, md5_directory, line_number, se_line, se_line_page_cnt, se_line_start_page,
- se_line_last_page_cnt, total_no_of_pages):
+def process_se_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ se_line,
+ se_line_page_cnt,
+ se_line_start_page,
+ se_line_last_page_cnt,
+ total_no_of_pages,
+):
has_se_schedules = False
if len(se_line) > 0:
schedule_total = 0.00
- os.makedirs(md5_directory + 'SE/' + line_number, exist_ok=True)
- se_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SE')
+ os.makedirs(md5_directory + "SE/" + line_number, exist_ok=True)
+ se_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SE")
if se_line_page_cnt > 0:
se_line_start_page += 1
for se_page_no in range(se_line_page_cnt):
@@ -2256,59 +3800,99 @@ def process_se_line(f3x_data, md5_directory, line_number, se_line, se_line_page_
memo_array = []
last_page = False
se_schedule_page_dict = {}
- se_schedule_page_dict['lineNumber'] = line_number
- se_schedule_page_dict['pageNo'] = se_line_start_page + se_page_no
- se_schedule_page_dict['totalPages'] = total_no_of_pages
+ se_schedule_page_dict["lineNumber"] = line_number
+ se_schedule_page_dict["pageNo"] = se_line_start_page + se_page_no
+ se_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = se_page_no * 2
- if ((se_page_no + 1) == se_line_page_cnt):
+ if (se_page_no + 1) == se_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- se_schedule_dict = build_se_per_page_schedule_dict(last_page, se_line_last_page_cnt,
- page_start_index, se_schedule_page_dict,
- se_line, memo_array)
+ se_schedule_dict = build_se_per_page_schedule_dict(
+ last_page,
+ se_line_last_page_cnt,
+ page_start_index,
+ se_schedule_page_dict,
+ se_line,
+ memo_array,
+ )
- page_subtotal = float(se_schedule_page_dict['pageSubtotal'])
+ page_subtotal = float(se_schedule_page_dict["pageSubtotal"])
schedule_total += page_subtotal
if se_line_page_cnt == (se_page_no + 1):
- se_schedule_page_dict['pageTotal'] = '{0:.2f}'.format(schedule_total)
- se_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- se_schedule_page_dict['committeeId'] = f3x_data['committeeId']
+ se_schedule_page_dict["pageTotal"] = "{0:.2f}".format(
+ schedule_total
+ )
+ se_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ se_schedule_page_dict["committeeId"] = f3x_data["committeeId"]
# checking for signed date, it is only available for submitted reports
# and adding in date signed and treasurer name for signed reports
- if len(f3x_data['dateSigned']) > 0:
- date_signed_array = f3x_data['dateSigned'].split("/")
- se_schedule_page_dict['dateSignedMonth'] = date_signed_array[0]
- se_schedule_page_dict['dateSignedDay'] = date_signed_array[1]
- se_schedule_page_dict['dateSignedYear'] = date_signed_array[2]
- se_schedule_page_dict['completingName'] = f3x_data['treasurerName']
- se_outfile = md5_directory + 'SE/' + line_number + '/page_' + str(se_page_no) + '.pdf'
+ if len(f3x_data["dateSigned"]) > 0:
+ date_signed_array = f3x_data["dateSigned"].split("/")
+ se_schedule_page_dict["dateSignedMonth"] = date_signed_array[0]
+ se_schedule_page_dict["dateSignedDay"] = date_signed_array[1]
+ se_schedule_page_dict["dateSignedYear"] = date_signed_array[2]
+ se_schedule_page_dict["completingName"] = f3x_data["treasurerName"]
+ se_outfile = (
+ md5_directory
+ + "SE/"
+ + line_number
+ + "/page_"
+ + str(se_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(se_infile, se_schedule_page_dict, se_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SE/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SE/' + line_number + '/page_memo_' + str(se_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SE/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SE/"
+ + line_number
+ + "/page_memo_"
+ + str(se_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([se_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, se_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SE/' + line_number + '/'), md5_directory + 'SE/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SE/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SE/all_pages.pdf', md5_directory + 'SE/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SE/temp_all_pages.pdf')
- os.rename(md5_directory + 'SE/temp_all_pages.pdf', md5_directory + 'SE/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SE/" + line_number + "/"),
+ md5_directory + "SE/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SE/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SE/all_pages.pdf",
+ md5_directory + "SE/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SE/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SE/temp_all_pages.pdf",
+ md5_directory + "SE/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SE/' + line_number + '/all_pages.pdf', md5_directory + 'SE/all_pages.pdf')
+ os.rename(
+ md5_directory + "SE/" + line_number + "/all_pages.pdf",
+ md5_directory + "SE/all_pages.pdf",
+ )
return has_se_schedules
@@ -2347,14 +3931,23 @@ def process_se_line(f3x_data, md5_directory, line_number, se_line, se_line_page_
# return has_se_memo_schedules
-def process_sf_line(f3x_data, md5_directory, line_number, sf_line, sf_line_page_cnt, sf_line_start_page,
- sf_line_last_page_cnt, total_no_of_pages,cord_name=None):
+def process_sf_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ sf_line,
+ sf_line_page_cnt,
+ sf_line_start_page,
+ sf_line_last_page_cnt,
+ total_no_of_pages,
+ cord_name=None,
+):
has_sf_schedules = False
if len(sf_line) > 0:
schedule_total = 0.00
# import ipdb;ipdb.set_trace()
- os.makedirs(md5_directory + 'SF/' + cord_name, exist_ok=True)
- sf_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SF')
+ os.makedirs(md5_directory + "SF/" + cord_name, exist_ok=True)
+ sf_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SF")
if sf_line_page_cnt > 0:
sf_line_start_page += 1
for sf_page_no in range(sf_line_page_cnt):
@@ -2362,40 +3955,66 @@ def process_sf_line(f3x_data, md5_directory, line_number, sf_line, sf_line_page_
memo_array = []
last_page = False
sf_schedule_page_dict = {}
- sf_schedule_page_dict['lineNumber'] = line_number
- sf_schedule_page_dict['pageNo'] = sf_line_start_page + sf_page_no
- sf_schedule_page_dict['totalPages'] = total_no_of_pages
-
+ sf_schedule_page_dict["lineNumber"] = line_number
+ sf_schedule_page_dict["pageNo"] = sf_line_start_page + sf_page_no
+ sf_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sf_page_no * 3
- if ((sf_page_no + 1) == sf_line_page_cnt):
+ if (sf_page_no + 1) == sf_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sf_schedule_dict = build_sf_per_page_schedule_dict(last_page, sf_line_last_page_cnt,
- page_start_index, sf_schedule_page_dict,
- sf_line, memo_array)
+ sf_schedule_dict = build_sf_per_page_schedule_dict(
+ last_page,
+ sf_line_last_page_cnt,
+ page_start_index,
+ sf_schedule_page_dict,
+ sf_line,
+ memo_array,
+ )
- page_subtotal = float(sf_schedule_page_dict['pageSubtotal'])
- sf_schedule_page_dict['pageSubTotal'] = '{0:.2f}'.format(page_subtotal)
+ page_subtotal = float(sf_schedule_page_dict["pageSubtotal"])
+ sf_schedule_page_dict["pageSubTotal"] = "{0:.2f}".format(page_subtotal)
schedule_total += page_subtotal
if sf_line_page_cnt == (sf_page_no + 1):
- sf_schedule_page_dict['pageTotal'] = '{0:.2f}'.format(schedule_total)
- sf_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sf_outfile = md5_directory + 'SF/' + cord_name + '/page_' + str(sf_page_no) + '.pdf'
+ sf_schedule_page_dict["pageTotal"] = "{0:.2f}".format(
+ schedule_total
+ )
+ sf_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sf_outfile = (
+ md5_directory
+ + "SF/"
+ + cord_name
+ + "/page_"
+ + str(sf_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sf_infile, sf_schedule_page_dict, sf_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SF/' + cord_name + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SF/' + cord_name + '/page_memo_' + str(sf_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SF/" + cord_name + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SF/"
+ + cord_name
+ + "/page_memo_"
+ + str(sf_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sf_outfile, memo_outfile], temp_memo_outfile)
@@ -2404,22 +4023,44 @@ def process_sf_line(f3x_data, md5_directory, line_number, sf_line, sf_line_page_
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SF/' + cord_name + '/page_memo_' + str(sf_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[2]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[2]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[2]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SF/"
+ + cord_name
+ + "/page_memo_"
+ + str(sf_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[2]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[2][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[2]["transactionId"]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sf_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sf_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SF/' + cord_name + '/'), md5_directory + 'SF/' + cord_name
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SF/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SF/all_pages.pdf', md5_directory + 'SF/' + cord_name + '/all_pages.pdf'],
- md5_directory + 'SF/temp_all_pages.pdf')
- os.rename(md5_directory + 'SF/temp_all_pages.pdf', md5_directory + 'SF/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SF/" + cord_name + "/"),
+ md5_directory + "SF/" + cord_name + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SF/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SF/all_pages.pdf",
+ md5_directory + "SF/" + cord_name + "/all_pages.pdf",
+ ],
+ md5_directory + "SF/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SF/temp_all_pages.pdf",
+ md5_directory + "SF/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SF/' + cord_name + '/all_pages.pdf', md5_directory + 'SF/all_pages.pdf')
+ os.rename(
+ md5_directory + "SF/" + cord_name + "/all_pages.pdf",
+ md5_directory + "SF/all_pages.pdf",
+ )
return has_sf_schedules
@@ -2458,54 +4099,96 @@ def process_sf_line(f3x_data, md5_directory, line_number, sf_line, sf_line_page_
# return has_sf_memo_schedules
-def process_la_line(f3x_data, md5_directory, line_number, la_line, la_line_page_cnt, la_line_start_page,
- la_line_last_page_cnt, total_no_of_pages):
+def process_la_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ la_line,
+ la_line_page_cnt,
+ la_line_start_page,
+ la_line_last_page_cnt,
+ total_no_of_pages,
+):
has_la_schedules = False
try:
if len(la_line) > 0:
la_line_start_page += 1
has_la_schedules = True
schedule_total = 0.00
- os.makedirs(md5_directory + 'SL-A/' + line_number, exist_ok=True)
- la_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SL-A')
+ os.makedirs(md5_directory + "SL-A/" + line_number, exist_ok=True)
+ la_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SL-A")
if la_line_page_cnt > 0:
for la_page_no in range(la_line_page_cnt):
page_subtotal = 0.00
memo_array = []
last_page = False
la_schedule_page_dict = {}
- la_schedule_page_dict['lineNumber'] = line_number
- la_schedule_page_dict['pageNo'] = la_line_start_page + la_page_no
- la_schedule_page_dict['totalPages'] = total_no_of_pages
+ la_schedule_page_dict["lineNumber"] = line_number
+ la_schedule_page_dict["pageNo"] = la_line_start_page + la_page_no
+ la_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = la_page_no * 4
- if ((la_page_no + 1) == la_line_page_cnt):
+ if (la_page_no + 1) == la_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
-
- la_schedule_dict = build_la_per_page_schedule_dict(last_page, la_line_last_page_cnt,
- page_start_index, la_schedule_page_dict,
- la_line, memo_array)
- page_subtotal = float(la_schedule_page_dict['pageSubtotal'])
+ la_schedule_dict = build_la_per_page_schedule_dict(
+ last_page,
+ la_line_last_page_cnt,
+ page_start_index,
+ la_schedule_page_dict,
+ la_line,
+ memo_array,
+ )
+
+ page_subtotal = float(la_schedule_page_dict["pageSubtotal"])
schedule_total += page_subtotal
if la_line_page_cnt == (la_page_no + 1):
- la_schedule_page_dict['scheduleTotal'] = '{0:.2f}'.format(schedule_total)
- la_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- la_outfile = md5_directory + 'SL-A/' + line_number + '/page_' + str(la_page_no) + '.pdf'
+ la_schedule_page_dict["scheduleTotal"] = "{0:.2f}".format(
+ schedule_total
+ )
+ la_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ la_outfile = (
+ md5_directory
+ + "SL-A/"
+ + line_number
+ + "/page_"
+ + str(la_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(la_infile, la_schedule_page_dict, la_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SL-A/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SL-A/' + line_number + '/page_memo_' + str(la_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory
+ + "SL-A/"
+ + line_number
+ + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config[
+ "FORM_TEMPLATES_LOCATION"
+ ].format("TEXT")
+ memo_outfile = (
+ md5_directory
+ + "SL-A/"
+ + line_number
+ + "/page_memo_"
+ + str(la_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1][
+ "transactionId"
+ ]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([la_outfile, memo_outfile], temp_memo_outfile)
@@ -2514,28 +4197,58 @@ def process_la_line(f3x_data, md5_directory, line_number, la_line, la_line_page_
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SL-A/' + line_number + '/page_memo_' + str(
- la_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[2]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[2]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[2]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SL-A/"
+ + line_number
+ + "/page_memo_"
+ + str(la_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[2]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[2][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[2][
+ "transactionId"
+ ]
if len(memo_array) >= 4:
- memo_dict['scheduleName_2'] = memo_array[3]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[3]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[3]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[3][
+ "scheduleName"
+ ]
+ memo_dict["memoDescription_2"] = memo_array[3][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[3][
+ "transactionId"
+ ]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
- pypdftk.concat([la_outfile, memo_outfile], temp_memo_outfile)
+ pypdftk.concat(
+ [la_outfile, memo_outfile], temp_memo_outfile
+ )
os.remove(memo_outfile)
os.rename(temp_memo_outfile, la_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SL-A/' + line_number + '/'), md5_directory + 'SL-A/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SL-A/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SL-A/all_pages.pdf', md5_directory + 'SL-A/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SL-A/temp_all_pages.pdf')
- os.rename(md5_directory + 'SL-A/temp_all_pages.pdf', md5_directory + 'SL-A/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SL-A/" + line_number + "/"),
+ md5_directory + "SL-A/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SL-A/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SL-A/all_pages.pdf",
+ md5_directory + "SL-A/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SL-A/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SL-A/temp_all_pages.pdf",
+ md5_directory + "SL-A/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SL-A/' + line_number + '/all_pages.pdf', md5_directory + 'SL-A/all_pages.pdf')
-
+ os.rename(
+ md5_directory + "SL-A/" + line_number + "/all_pages.pdf",
+ md5_directory + "SL-A/all_pages.pdf",
+ )
except Exception as e:
raise e
@@ -2588,13 +4301,21 @@ def process_la_line(f3x_data, md5_directory, line_number, la_line, la_line_page_
# return has_la_memo_schedules
-def process_slb_line(f3x_data, md5_directory, line_number, slb_line, slb_line_page_cnt, slb_line_start_page,
- slb_line_last_page_cnt, total_no_of_pages):
+def process_slb_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ slb_line,
+ slb_line_page_cnt,
+ slb_line_start_page,
+ slb_line_last_page_cnt,
+ total_no_of_pages,
+):
has_slb_schedules = False
if len(slb_line) > 0:
schedule_total = 0.00
- os.makedirs(md5_directory + 'SL-B/' + line_number, exist_ok=True)
- slb_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SL-B')
+ os.makedirs(md5_directory + "SL-B/" + line_number, exist_ok=True)
+ slb_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SL-B")
if slb_line_page_cnt > 0:
slb_line_start_page += 1
for slb_page_no in range(slb_line_page_cnt):
@@ -2602,40 +4323,64 @@ def process_slb_line(f3x_data, md5_directory, line_number, slb_line, slb_line_pa
memo_array = []
last_page = False
slb_schedule_page_dict = {}
- slb_schedule_page_dict['lineNumber'] = line_number
- slb_schedule_page_dict['pageNo'] = slb_line_start_page + slb_page_no
- slb_schedule_page_dict['totalPages'] = total_no_of_pages
+ slb_schedule_page_dict["lineNumber"] = line_number
+ slb_schedule_page_dict["pageNo"] = slb_line_start_page + slb_page_no
+ slb_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = slb_page_no * 5
- if ((slb_page_no + 1) == slb_line_page_cnt):
+ if (slb_page_no + 1) == slb_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- slb_schedule_dict = build_slb_per_page_schedule_dict(last_page, slb_line_last_page_cnt,
- page_start_index, slb_schedule_page_dict,
- slb_line, memo_array)
-
-
-
+ slb_schedule_dict = build_slb_per_page_schedule_dict(
+ last_page,
+ slb_line_last_page_cnt,
+ page_start_index,
+ slb_schedule_page_dict,
+ slb_line,
+ memo_array,
+ )
- page_subtotal = float(slb_schedule_page_dict['pageSubtotal'])
+ page_subtotal = float(slb_schedule_page_dict["pageSubtotal"])
schedule_total += page_subtotal
if slb_line_page_cnt == (slb_page_no + 1):
- slb_schedule_page_dict['scheduleTotal'] = '{0:.2f}'.format(schedule_total)
- slb_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- slb_outfile = md5_directory + 'SL-B/' + line_number + '/page_' + str(slb_page_no) + '.pdf'
+ slb_schedule_page_dict["scheduleTotal"] = "{0:.2f}".format(
+ schedule_total
+ )
+ slb_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ slb_outfile = (
+ md5_directory
+ + "SL-B/"
+ + line_number
+ + "/page_"
+ + str(slb_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(slb_infile, slb_schedule_page_dict, slb_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SL-B/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SL-B/' + line_number + '/page_memo_' + str(slb_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SL-B/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SL-B/"
+ + line_number
+ + "/page_memo_"
+ + str(slb_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([slb_outfile, memo_outfile], temp_memo_outfile)
@@ -2644,82 +4389,161 @@ def process_slb_line(f3x_data, md5_directory, line_number, slb_line, slb_line_pa
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SL-B/' + line_number + '/page_memo_' + str(slb_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[2]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[2]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[2]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SL-B/"
+ + line_number
+ + "/page_memo_"
+ + str(slb_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[2]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[2][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[2]["transactionId"]
if len(memo_array) >= 4:
- memo_dict['scheduleName_2'] = memo_array[3]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[3]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[3]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[3]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[3][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[3][
+ "transactionId"
+ ]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([slb_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, slb_outfile)
if len(memo_array) >= 5:
- temp_memo_outfile = md5_directory + 'SL-B/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SB/' + line_number + '/page_memo_' + str(slb_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[4]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[4]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[4]['transactionId']
+ temp_memo_outfile = (
+ md5_directory
+ + "SL-B/"
+ + line_number
+ + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config[
+ "FORM_TEMPLATES_LOCATION"
+ ].format("TEXT")
+ memo_outfile = (
+ md5_directory
+ + "SB/"
+ + line_number
+ + "/page_memo_"
+ + str(slb_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[4]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[4][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[4]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([slb_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, slb_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SL-B/' + line_number + '/'), md5_directory + 'SL-B/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SL-B/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SL-B/all_pages.pdf', md5_directory + 'SL-B/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SL-B/temp_all_pages.pdf')
- os.rename(md5_directory + 'SL-B/temp_all_pages.pdf', md5_directory + 'SL-B/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SL-B/" + line_number + "/"),
+ md5_directory + "SL-B/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SL-B/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SL-B/all_pages.pdf",
+ md5_directory + "SL-B/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SL-B/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SL-B/temp_all_pages.pdf",
+ md5_directory + "SL-B/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SL-B/' + line_number + '/all_pages.pdf', md5_directory + 'SL-B/all_pages.pdf')
-
+ os.rename(
+ md5_directory + "SL-B/" + line_number + "/all_pages.pdf",
+ md5_directory + "SL-B/all_pages.pdf",
+ )
+
return has_slb_schedules
-def process_slb_memo(f3x_data, md5_directory, line_number, slb_memo, slb_memo_page_cnt, slb_memo_start_page,
- slb_memo_last_page_cnt, total_no_of_pages):
+def process_slb_memo(
+ f3x_data,
+ md5_directory,
+ line_number,
+ slb_memo,
+ slb_memo_page_cnt,
+ slb_memo_start_page,
+ slb_memo_last_page_cnt,
+ total_no_of_pages,
+):
has_slb_memo_schedules = False
try:
if len(slb_memo) > 0:
slb_memo_start_page += 1
has_slb_memo_schedules = True
- os.makedirs(md5_directory + 'SL-B/' + line_number + '/memo', exist_ok=True)
- slb_memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
+ os.makedirs(md5_directory + "SL-B/" + line_number + "/memo", exist_ok=True)
+ slb_memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
if slb_memo_page_cnt > 0:
for slb_memo_page_no in range(slb_memo_page_cnt):
last_page = False
slb_memo_schedule_page_dict = {}
- slb_memo_schedule_page_dict['PAGESTR'] = "PAGE " + str(slb_memo_page_no + 1) + " / " + str(
- total_no_of_pages)
+ slb_memo_schedule_page_dict["PAGESTR"] = (
+ "PAGE "
+ + str(slb_memo_page_no + 1)
+ + " / "
+ + str(total_no_of_pages)
+ )
page_start_index = slb_memo_page_no * 2
- if ((slb_memo_page_no + 1) == slb_memo_page_cnt):
+ if (slb_memo_page_no + 1) == slb_memo_page_cnt:
last_page = True
# This call prepares data to render on PDF
- slb_memo_schedule_page_dict = build_memo_per_page_schedule_dict(last_page,
- slb_memo_last_page_cnt,
- page_start_index,
- slb_memo_schedule_page_dict,
- slb_memo)
- slb_memo_outfile = md5_directory + 'SL-B/' + line_number + '/memo/page_' + str(
- slb_memo_page_no) + '.pdf'
- pypdftk.fill_form(slb_memo_infile, slb_memo_schedule_page_dict, slb_memo_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SL-B/' + line_number + '/memo/'),
- md5_directory + 'SL-B/' + line_number
- + '/memo/all_pages.pdf')
+ slb_memo_schedule_page_dict = build_memo_per_page_schedule_dict(
+ last_page,
+ slb_memo_last_page_cnt,
+ page_start_index,
+ slb_memo_schedule_page_dict,
+ slb_memo,
+ )
+ slb_memo_outfile = (
+ md5_directory
+ + "SL-B/"
+ + line_number
+ + "/memo/page_"
+ + str(slb_memo_page_no)
+ + ".pdf"
+ )
+ pypdftk.fill_form(
+ slb_memo_infile, slb_memo_schedule_page_dict, slb_memo_outfile
+ )
+ pypdftk.concat(
+ directory_files(md5_directory + "SL-B/" + line_number + "/memo/"),
+ md5_directory + "SL-B/" + line_number + "/memo/all_pages.pdf",
+ )
# if all_pages.pdf exists in SA folder, concatenate line number pdf to all_pages.pdf
- if path.isfile(md5_directory + 'SL-B/' + line_number + '/memo/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SL-B/all_pages.pdf',
- md5_directory + 'SL-B/' + line_number + '/memo/all_pages.pdf'],
- md5_directory + 'SL-B/temp_all_pages.pdf')
- os.rename(md5_directory + 'SL-B/temp_all_pages.pdf', md5_directory + 'SL-B/all_pages.pdf')
+ if path.isfile(
+ md5_directory + "SL-B/" + line_number + "/memo/all_pages.pdf"
+ ):
+ pypdftk.concat(
+ [
+ md5_directory + "SL-B/all_pages.pdf",
+ md5_directory
+ + "SL-B/"
+ + line_number
+ + "/memo/all_pages.pdf",
+ ],
+ md5_directory + "SL-B/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SL-B/temp_all_pages.pdf",
+ md5_directory + "SL-B/all_pages.pdf",
+ )
# else:
# os.rename(md5_directory + 'SA/' + line_number + '/all_pages.pdf', md5_directory + 'SA/all_pages.pdf')
except Exception as e:
@@ -2727,9 +4551,17 @@ def process_slb_memo(f3x_data, md5_directory, line_number, slb_memo, slb_memo_pa
return has_slb_memo_schedules
-def process_sl_levin(f3x_data, md5_directory, levin_name, sl_line, sl_line_page_cnt, sl_line_start_page,
- sl_line_last_page_cnt, total_no_of_pages):
-
+def process_sl_levin(
+ f3x_data,
+ md5_directory,
+ levin_name,
+ sl_line,
+ sl_line_page_cnt,
+ sl_line_start_page,
+ sl_line_last_page_cnt,
+ total_no_of_pages,
+):
+
has_sl_summary = False
try:
if len(sl_line) > 0:
@@ -2737,46 +4569,62 @@ def process_sl_levin(f3x_data, md5_directory, levin_name, sl_line, sl_line_page_
import re
- reg = re.compile('^[a-z0-9._A-Z]+$')
+ reg = re.compile("^[a-z0-9._A-Z]+$")
reg = bool(reg.match(levin_name))
p_levin_name = levin_name
if reg is False:
- p_levin_name = re.sub('[^A-Za-z0-9]+', '', levin_name)
- p_levin_name = str(p_levin_name).replace(' ','')
+ p_levin_name = re.sub("[^A-Za-z0-9]+", "", levin_name)
+ p_levin_name = str(p_levin_name).replace(" ", "")
sl_line_start_page += 1
has_sl_summary = True
schedule_total = 0.00
- os.makedirs(md5_directory + 'SL/' + p_levin_name, exist_ok=True)
- sl_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SL')
+ os.makedirs(md5_directory + "SL/" + p_levin_name, exist_ok=True)
+ sl_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SL")
if sl_line_page_cnt > 0:
for sl_page_no in range(sl_line_page_cnt):
# page_subtotal = 0.00
last_page = False
sl_schedule_page_dict = {}
- sl_schedule_page_dict['accountName'] = levin_name
- sl_schedule_page_dict['pageNo'] = sl_line_start_page + sl_page_no
- sl_schedule_page_dict['totalPages'] = total_no_of_pages
+ sl_schedule_page_dict["accountName"] = levin_name
+ sl_schedule_page_dict["pageNo"] = sl_line_start_page + sl_page_no
+ sl_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sl_page_no * 1
- if ((sl_page_no + 1) == sl_line_page_cnt):
- last_page = True
- sl_schedule_dict = build_sl_levin_per_page_schedule_dict(last_page, sl_line_last_page_cnt,
- page_start_index, sl_schedule_page_dict,
- sl_line)
-
- sl_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sl_outfile = md5_directory + 'SL/' + p_levin_name + '/page.pdf'
+ if (sl_page_no + 1) == sl_line_page_cnt:
+ last_page = True
+ sl_schedule_dict = build_sl_levin_per_page_schedule_dict(
+ last_page,
+ sl_line_last_page_cnt,
+ page_start_index,
+ sl_schedule_page_dict,
+ sl_line,
+ )
+
+ sl_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sl_outfile = md5_directory + "SL/" + p_levin_name + "/page.pdf"
pypdftk.fill_form(sl_infile, sl_schedule_page_dict, sl_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SL/' + p_levin_name + '/'), md5_directory + 'SL/' + p_levin_name
- + '/all_pages.pdf')
-
-
- if path.isfile(md5_directory + 'SL/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SL/all_pages.pdf', md5_directory + 'SL/' + p_levin_name + '/all_pages.pdf'],
- md5_directory + 'SL/temp_all_pages.pdf')
- os.rename(md5_directory + 'SL/temp_all_pages.pdf', md5_directory + 'SL/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SL/" + p_levin_name + "/"),
+ md5_directory + "SL/" + p_levin_name + "/all_pages.pdf",
+ )
+
+ if path.isfile(md5_directory + "SL/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SL/all_pages.pdf",
+ md5_directory + "SL/" + p_levin_name + "/all_pages.pdf",
+ ],
+ md5_directory + "SL/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SL/temp_all_pages.pdf",
+ md5_directory + "SL/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SL/' + p_levin_name + '/all_pages.pdf', md5_directory + 'SL/all_pages.pdf')
+ os.rename(
+ md5_directory + "SL/" + p_levin_name + "/all_pages.pdf",
+ md5_directory + "SL/all_pages.pdf",
+ )
except Exception as e:
raise e
@@ -2829,48 +4677,97 @@ def process_sl_levin(f3x_data, md5_directory, levin_name, sl_line, sl_line_page_
# return has_sl_memo_schedules
-def process_sh1_line(f3x_data, md5_directory, tran_type_ident, sh_h1, sh1_page_cnt, sh1_start_page,
- sh1_last_page_cnt, total_no_of_pages):
+def process_sh1_line(
+ f3x_data,
+ md5_directory,
+ tran_type_ident,
+ sh_h1,
+ sh1_page_cnt,
+ sh1_start_page,
+ sh1_last_page_cnt,
+ total_no_of_pages,
+):
has_sh1_schedules = False
# presidentialOnly = presidentialAndSenate = senateOnly = nonPresidentialAndNonSenate = False
try:
has_sh1_schedules = True
- os.makedirs(md5_directory + 'SH1/' + tran_type_ident, exist_ok=True)
- sh1_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SH1')
+ os.makedirs(md5_directory + "SH1/" + tran_type_ident, exist_ok=True)
+ sh1_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SH1")
sh1_page_no = 1
if sh1_page_cnt > 0:
sh1_schedule_page_dict = {}
- sh1_schedule_page_dict['pageNo'] = sh1_start_page + 1
- sh1_schedule_page_dict['totalPages'] = total_no_of_pages
+ sh1_schedule_page_dict["pageNo"] = sh1_start_page + 1
+ sh1_schedule_page_dict["totalPages"] = total_no_of_pages
for sh1_line in sh_h1:
- presidentialOnly = sh1_line['presidentialOnly']
- presidentialAndSenate = sh1_line['presidentialAndSenate']
- senateOnly = sh1_line['senateOnly']
- nonPresidentialAndNonSenate = sh1_line['nonPresidentialAndNonSenate']
- if presidentialOnly or presidentialAndSenate or senateOnly or nonPresidentialAndNonSenate:
- sh1_schedule_page_dict['presidentialOnly'] = str(sh1_line['presidentialOnly'])
- sh1_schedule_page_dict['presidentialAndSenate'] = str(sh1_line['presidentialAndSenate'])
- sh1_schedule_page_dict['senateOnly'] = str(sh1_line['senateOnly'])
- sh1_schedule_page_dict['nonPresidentialAndNonSenate'] = str(sh1_line['nonPresidentialAndNonSenate'])
+ presidentialOnly = sh1_line["presidentialOnly"]
+ presidentialAndSenate = sh1_line["presidentialAndSenate"]
+ senateOnly = sh1_line["senateOnly"]
+ nonPresidentialAndNonSenate = sh1_line["nonPresidentialAndNonSenate"]
+ if (
+ presidentialOnly
+ or presidentialAndSenate
+ or senateOnly
+ or nonPresidentialAndNonSenate
+ ):
+ sh1_schedule_page_dict["presidentialOnly"] = str(
+ sh1_line["presidentialOnly"]
+ )
+ sh1_schedule_page_dict["presidentialAndSenate"] = str(
+ sh1_line["presidentialAndSenate"]
+ )
+ sh1_schedule_page_dict["senateOnly"] = str(sh1_line["senateOnly"])
+ sh1_schedule_page_dict["nonPresidentialAndNonSenate"] = str(
+ sh1_line["nonPresidentialAndNonSenate"]
+ )
else:
- sh1_schedule_page_dict['federalPercent'] = '{0:.2f}'.format(float(sh1_line['federalPercent']))
- sh1_schedule_page_dict['nonFederalPercent'] = '{0:.2f}'.format(float(sh1_line['nonFederalPercent']))
- sh1_schedule_page_dict['administrative'] = str(sh1_line['administrative'])
- sh1_schedule_page_dict['genericVoterDrive'] = str(sh1_line['genericVoterDrive'])
- sh1_schedule_page_dict['publicCommunications'] = str(sh1_line['publicCommunications'])
- sh1_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sh1_outfile = md5_directory + 'SH1/' + tran_type_ident + '/page_' + str(sh1_page_no) + '.pdf'
+ sh1_schedule_page_dict["federalPercent"] = "{0:.2f}".format(
+ float(sh1_line["federalPercent"])
+ )
+ sh1_schedule_page_dict["nonFederalPercent"] = "{0:.2f}".format(
+ float(sh1_line["nonFederalPercent"])
+ )
+ sh1_schedule_page_dict["administrative"] = str(
+ sh1_line["administrative"]
+ )
+ sh1_schedule_page_dict["genericVoterDrive"] = str(
+ sh1_line["genericVoterDrive"]
+ )
+ sh1_schedule_page_dict["publicCommunications"] = str(
+ sh1_line["publicCommunications"]
+ )
+ sh1_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sh1_outfile = (
+ md5_directory
+ + "SH1/"
+ + tran_type_ident
+ + "/page_"
+ + str(sh1_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sh1_infile, sh1_schedule_page_dict, sh1_outfile)
sh1_page_no += 1
- pypdftk.concat(directory_files(md5_directory + 'SH1/' + tran_type_ident + '/'), md5_directory + 'SH1/' + tran_type_ident
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SH1/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SH1/all_pages.pdf', md5_directory + 'SH1/' + tran_type_ident + '/all_pages.pdf'],
- md5_directory + 'SH1/temp_all_pages.pdf')
- os.rename(md5_directory + 'SH1/temp_all_pages.pdf', md5_directory + 'SH1/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SH1/" + tran_type_ident + "/"),
+ md5_directory + "SH1/" + tran_type_ident + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SH1/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SH1/all_pages.pdf",
+ md5_directory + "SH1/" + tran_type_ident + "/all_pages.pdf",
+ ],
+ md5_directory + "SH1/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SH1/temp_all_pages.pdf",
+ md5_directory + "SH1/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SH1/' + tran_type_ident + '/all_pages.pdf', md5_directory + 'SH1/all_pages.pdf')
+ os.rename(
+ md5_directory + "SH1/" + tran_type_ident + "/all_pages.pdf",
+ md5_directory + "SH1/all_pages.pdf",
+ )
except Exception as e:
raise e
return has_sh1_schedules
@@ -2918,42 +4815,66 @@ def process_sh1_line(f3x_data, md5_directory, tran_type_ident, sh_h1, sh1_page_c
# return has_sh1_memo_schedules
-def process_sh2_line(f3x_data, md5_directory, tran_type_ident, sh2_line, sh2_line_page_cnt, sh2_line_start_page,
- sh2_line_last_page_cnt, total_no_of_pages):
+def process_sh2_line(
+ f3x_data,
+ md5_directory,
+ tran_type_ident,
+ sh2_line,
+ sh2_line_page_cnt,
+ sh2_line_start_page,
+ sh2_line_last_page_cnt,
+ total_no_of_pages,
+):
has_sh2_schedules = False
if len(sh2_line) > 0:
has_sh2_schedules = True
- os.makedirs(md5_directory + 'SH2/' + tran_type_ident, exist_ok=True)
- sh2_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SH2')
+ os.makedirs(md5_directory + "SH2/" + tran_type_ident, exist_ok=True)
+ sh2_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SH2")
if sh2_line_page_cnt > 0:
-
+
sh2_line_start_page += 1
for sh2_page_no in range(sh2_line_page_cnt):
last_page = False
sh2_schedule_page_dict = {}
- sh2_schedule_page_dict['pageNo'] = sh2_line_start_page + sh2_page_no
- sh2_schedule_page_dict['totalPages'] = total_no_of_pages
+ sh2_schedule_page_dict["pageNo"] = sh2_line_start_page + sh2_page_no
+ sh2_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sh2_page_no * 6
- if ((sh2_page_no + 1) == sh2_line_page_cnt):
+ if (sh2_page_no + 1) == sh2_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sh2_schedule_dict = build_sh2_per_page_schedule_dict(last_page, sh2_line_last_page_cnt,
- page_start_index, sh2_schedule_page_dict,
- sh2_line)
- sh2_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sh2_outfile = md5_directory + 'SH2/' + tran_type_ident + '/page.pdf'
+ sh2_schedule_dict = build_sh2_per_page_schedule_dict(
+ last_page,
+ sh2_line_last_page_cnt,
+ page_start_index,
+ sh2_schedule_page_dict,
+ sh2_line,
+ )
+ sh2_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sh2_outfile = md5_directory + "SH2/" + tran_type_ident + "/page.pdf"
pypdftk.fill_form(sh2_infile, sh2_schedule_page_dict, sh2_outfile)
-
- pypdftk.concat(directory_files(md5_directory + 'SH2/' + tran_type_ident + '/'), md5_directory + 'SH2/' + tran_type_ident
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SH2/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SH2/all_pages.pdf', md5_directory + 'SH2/' + tran_type_ident + '/all_pages.pdf'],
- md5_directory + 'SH2/temp_all_pages.pdf')
- os.rename(md5_directory + 'SH2/temp_all_pages.pdf', md5_directory + 'SH2/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SH2/" + tran_type_ident + "/"),
+ md5_directory + "SH2/" + tran_type_ident + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SH2/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SH2/all_pages.pdf",
+ md5_directory + "SH2/" + tran_type_ident + "/all_pages.pdf",
+ ],
+ md5_directory + "SH2/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SH2/temp_all_pages.pdf",
+ md5_directory + "SH2/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SH2/' + tran_type_ident + '/all_pages.pdf', md5_directory + 'SH2/all_pages.pdf')
+ os.rename(
+ md5_directory + "SH2/" + tran_type_ident + "/all_pages.pdf",
+ md5_directory + "SH2/all_pages.pdf",
+ )
return has_sh2_schedules
@@ -2995,140 +4916,205 @@ def process_sh2_line(f3x_data, md5_directory, tran_type_ident, sh2_line, sh2_lin
# os.rename(md5_directory + 'SH2/' + tran_type_ident + '/all_pages.pdf', md5_directory + 'SH2/all_pages.pdf')
# return has_sh2_schedules
-def process_sh3_line(f3x_data, md5_directory, line_number, sh3_line, sh3_line_page_cnt, sh3_line_start_page,
- sh3_line_last_page_cnt, total_no_of_pages):
+
+def process_sh3_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ sh3_line,
+ sh3_line_page_cnt,
+ sh3_line_start_page,
+ sh3_line_last_page_cnt,
+ total_no_of_pages,
+):
has_sh3_schedules = False
if len(sh3_line) > 0:
has_sh3_schedules = True
- os.makedirs(md5_directory + 'SH3/' + line_number, exist_ok=True)
- sh3_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SH3')
+ os.makedirs(md5_directory + "SH3/" + line_number, exist_ok=True)
+ sh3_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SH3")
sh3_line_dict = []
sh3_line_transaction = []
- total_dict ={}
+ total_dict = {}
t_transfered = {}
dc_subtotal = 0.00
df_subtotal = 0.00
for sh3 in sh3_line:
- a_n = sh3['accountName']
- hash_check = "%s-%s"%(sh3['accountName'], sh3['receiptDate'])
+ a_n = sh3["accountName"]
+ hash_check = "%s-%s" % (sh3["accountName"], sh3["receiptDate"])
if hash_check not in sh3_line_transaction:
sh3_line_transaction.append(hash_check)
ind = sh3_line_transaction.index(hash_check)
if len(sh3_line_dict) <= ind:
sh3_line_dict.insert(ind, sh3)
- if sh3['activityEventType'] == 'DF':
+ if sh3["activityEventType"] == "DF":
ind = sh3_line_transaction.index(hash_check)
- if sh3_line_dict[ind].get('dfsubs'):
- sh3_line_dict[ind]['dfsubs'].append(sh3)
- sh3_line_dict[ind]['dftotal'] += sh3['transferredAmount']
+ if sh3_line_dict[ind].get("dfsubs"):
+ sh3_line_dict[ind]["dfsubs"].append(sh3)
+ sh3_line_dict[ind]["dftotal"] += sh3["transferredAmount"]
else:
- sh3_line_dict[ind]['dfsubs'] = [sh3]
- sh3_line_dict[ind]['dftotal'] = sh3['transferredAmount']
- elif sh3['activityEventType'] == 'DC':
+ sh3_line_dict[ind]["dfsubs"] = [sh3]
+ sh3_line_dict[ind]["dftotal"] = sh3["transferredAmount"]
+ elif sh3["activityEventType"] == "DC":
ind = sh3_line_transaction.index(hash_check)
- if sh3_line_dict[ind].get('dcsubs'):
- sh3_line_dict[ind]['dcsubs'].append(sh3)
- sh3_line_dict[ind]['dctotal'] += sh3['transferredAmount']
+ if sh3_line_dict[ind].get("dcsubs"):
+ sh3_line_dict[ind]["dcsubs"].append(sh3)
+ sh3_line_dict[ind]["dctotal"] += sh3["transferredAmount"]
else:
- sh3_line_dict[ind]['dcsubs'] = [sh3]
- sh3_line_dict[ind]['dctotal'] = sh3['transferredAmount']
+ sh3_line_dict[ind]["dcsubs"] = [sh3]
+ sh3_line_dict[ind]["dctotal"] = sh3["transferredAmount"]
else:
ind = sh3_line_transaction.index(hash_check)
- if sh3_line_dict[ind].get('subs'):
- sh3_line_dict[ind]['subs'].append(sh3)
+ if sh3_line_dict[ind].get("subs"):
+ sh3_line_dict[ind]["subs"].append(sh3)
else:
- sh3_line_dict[ind]['subs'] = [sh3]
+ sh3_line_dict[ind]["subs"] = [sh3]
if ind in t_transfered:
- t_transfered[ind] += sh3['transferredAmount']
+ t_transfered[ind] += sh3["transferredAmount"]
else:
- t_transfered[ind] = sh3['transferredAmount']
+ t_transfered[ind] = sh3["transferredAmount"]
- if a_n in total_dict and sh3['activityEventType'] in total_dict[a_n]:
- total_dict[a_n][sh3['activityEventType']] += sh3['transferredAmount']
- total_dict[a_n]['lastpage'] = ind
+ if a_n in total_dict and sh3["activityEventType"] in total_dict[a_n]:
+ total_dict[a_n][sh3["activityEventType"]] += sh3["transferredAmount"]
+ total_dict[a_n]["lastpage"] = ind
elif a_n in total_dict:
- total_dict[a_n][sh3['activityEventType']] = sh3['transferredAmount']
- total_dict[a_n]['lastpage'] = ind
+ total_dict[a_n][sh3["activityEventType"]] = sh3["transferredAmount"]
+ total_dict[a_n]["lastpage"] = ind
else:
- total_dict[a_n] = {sh3['activityEventType']: sh3['transferredAmount'], 'lastpage': ind}
-
+ total_dict[a_n] = {
+ sh3["activityEventType"]: sh3["transferredAmount"],
+ "lastpage": ind,
+ }
+
if sh3_line_page_cnt > 0:
sh3_line_start_page += 1
for sh3_page_no, sh3_page in enumerate(sh3_line_dict):
page_subtotal = 0.00
last_page = False
sh3_schedule_page_dict = {}
- sh3_schedule_page_dict['lineNumber'] = line_number
- sh3_schedule_page_dict['pageNo'] = sh3_line_start_page + sh3_page_no
- sh3_schedule_page_dict['totalPages'] = total_no_of_pages
- acc_name = sh3_page.get('accountName')
- lastpage_c = total_dict[acc_name]['lastpage']
+ sh3_schedule_page_dict["lineNumber"] = line_number
+ sh3_schedule_page_dict["pageNo"] = sh3_line_start_page + sh3_page_no
+ sh3_schedule_page_dict["totalPages"] = total_no_of_pages
+ acc_name = sh3_page.get("accountName")
+ lastpage_c = total_dict[acc_name]["lastpage"]
page_start_index = sh3_page_no * 1
- if (sh3_page_no == lastpage_c):
+ if sh3_page_no == lastpage_c:
last_page = True
# This call prepares data to render on PDF
# sh3_schedule_page_dict['adtransactionId'] = sh3_page['transactionId']
- #sh3_schedule_page_dict['adtransferredAmount'] = t_transfered[sh3_page_no]
- sh3_schedule_page_dict['accountName'] = acc_name
- sh3_schedule_page_dict['totalAmountTransferred'] = '{0:.2f}'.format(float(t_transfered[sh3_page_no]))
-
- if 'receiptDate' in sh3_page:
-
- date_array = sh3_page['receiptDate'].split("/")
- sh3_schedule_page_dict['receiptDateMonth'] = date_array[0]
- sh3_schedule_page_dict['receiptDateDay'] = date_array[1]
- sh3_schedule_page_dict['receiptDateYear'] = date_array[2]
-
-
- for sub_sh3 in sh3_page.get('subs', []):
- s_ = sub_sh3['activityEventType'].lower()
- sh3_schedule_page_dict[s_+'transactionId'] = sub_sh3['transactionId']
- sh3_schedule_page_dict[s_+'transferredAmount'] = '{0:.2f}'.format(float(sub_sh3['transferredAmount']))
-
- df_inc = ''
-
- for sub_sh3 in sh3_page.get('dfsubs', []):
- s_ = sub_sh3['activityEventType'].lower()
- sh3_schedule_page_dict[s_+'transactionId'+df_inc] = sub_sh3['transactionId']
- sh3_schedule_page_dict[s_+'transferredAmount'+df_inc] = '{0:.2f}'.format(float(sub_sh3['transferredAmount']))
- sh3_schedule_page_dict[s_+'activityEventName'+df_inc] = sub_sh3['activityEventName']
- sh3_schedule_page_dict[s_+'subtransferredAmount'] = '{0:.2f}'.format(float(sh3_page.get(s_+'total', '')))
- df_inc = '_1'
-
- dc_inc = ''
-
- for sub_sh3 in sh3_page.get('dcsubs', []):
- s_ = sub_sh3['activityEventType'].lower()
- sh3_schedule_page_dict[s_+'transactionId'+dc_inc] = sub_sh3['transactionId']
- sh3_schedule_page_dict[s_+'transferredAmount'+dc_inc] = '{0:.2f}'.format(float(sub_sh3['transferredAmount']))
- sh3_schedule_page_dict[s_+'activityEventName'+dc_inc] = sub_sh3['activityEventName']
- sh3_schedule_page_dict[s_+'subtransferredAmount'] = '{0:.2f}'.format(float(sh3_page.get(s_+'total', '')))
- dc_inc = '_1'
-
- sh3_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- if last_page:
- total_dict[acc_name]['lastpage'] = 0
- sh3_schedule_page_dict['totalAmountPeriod'] = '{0:.2f}'.format(float(sum(total_dict[acc_name].values())))
+ # sh3_schedule_page_dict['adtransferredAmount'] = t_transfered[sh3_page_no]
+ sh3_schedule_page_dict["accountName"] = acc_name
+ sh3_schedule_page_dict["totalAmountTransferred"] = "{0:.2f}".format(
+ float(t_transfered[sh3_page_no])
+ )
+
+ if "receiptDate" in sh3_page:
+
+ date_array = sh3_page["receiptDate"].split("/")
+ sh3_schedule_page_dict["receiptDateMonth"] = date_array[0]
+ sh3_schedule_page_dict["receiptDateDay"] = date_array[1]
+ sh3_schedule_page_dict["receiptDateYear"] = date_array[2]
+
+ for sub_sh3 in sh3_page.get("subs", []):
+ s_ = sub_sh3["activityEventType"].lower()
+ sh3_schedule_page_dict[s_ + "transactionId"] = sub_sh3[
+ "transactionId"
+ ]
+ sh3_schedule_page_dict[s_ + "transferredAmount"] = "{0:.2f}".format(
+ float(sub_sh3["transferredAmount"])
+ )
+
+ df_inc = ""
+
+ for sub_sh3 in sh3_page.get("dfsubs", []):
+ s_ = sub_sh3["activityEventType"].lower()
+ sh3_schedule_page_dict[s_ + "transactionId" + df_inc] = sub_sh3[
+ "transactionId"
+ ]
+ sh3_schedule_page_dict[
+ s_ + "transferredAmount" + df_inc
+ ] = "{0:.2f}".format(float(sub_sh3["transferredAmount"]))
+ sh3_schedule_page_dict[s_ + "activityEventName" + df_inc] = sub_sh3[
+ "activityEventName"
+ ]
+ sh3_schedule_page_dict[
+ s_ + "subtransferredAmount"
+ ] = "{0:.2f}".format(float(sh3_page.get(s_ + "total", "")))
+ df_inc = "_1"
+
+ dc_inc = ""
+
+ for sub_sh3 in sh3_page.get("dcsubs", []):
+ s_ = sub_sh3["activityEventType"].lower()
+ sh3_schedule_page_dict[s_ + "transactionId" + dc_inc] = sub_sh3[
+ "transactionId"
+ ]
+ sh3_schedule_page_dict[
+ s_ + "transferredAmount" + dc_inc
+ ] = "{0:.2f}".format(float(sub_sh3["transferredAmount"]))
+ sh3_schedule_page_dict[s_ + "activityEventName" + dc_inc] = sub_sh3[
+ "activityEventName"
+ ]
+ sh3_schedule_page_dict[
+ s_ + "subtransferredAmount"
+ ] = "{0:.2f}".format(float(sh3_page.get(s_ + "total", "")))
+ dc_inc = "_1"
+
+ sh3_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ if last_page:
+ total_dict[acc_name]["lastpage"] = 0
+ sh3_schedule_page_dict["totalAmountPeriod"] = "{0:.2f}".format(
+ float(sum(total_dict[acc_name].values()))
+ )
for total_key in total_dict[acc_name]:
- sh3_schedule_page_dict[total_key.lower()+'total'] = '{0:.2f}'.format(float(total_dict[acc_name][total_key]))
-
- sh3_outfile = md5_directory + 'SH3/' + line_number + '/page_' + str(sh3_page_no) + '.pdf'
+ sh3_schedule_page_dict[
+ total_key.lower() + "total"
+ ] = "{0:.2f}".format(float(total_dict[acc_name][total_key]))
+
+ sh3_outfile = (
+ md5_directory
+ + "SH3/"
+ + line_number
+ + "/page_"
+ + str(sh3_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sh3_infile, sh3_schedule_page_dict, sh3_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SH3/' + line_number + '/'), md5_directory + 'SH3/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SH3/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SH3/all_pages.pdf', md5_directory + 'SH3/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SH3/temp_allpages.pdf')
- os.rename(md5_directory + 'SH3/temp_all_pages.pdf', md5_directory + 'SH3/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SH3/" + line_number + "/"),
+ md5_directory + "SH3/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SH3/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SH3/all_pages.pdf",
+ md5_directory + "SH3/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SH3/temp_allpages.pdf",
+ )
+ os.rename(
+ md5_directory + "SH3/temp_all_pages.pdf",
+ md5_directory + "SH3/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SH3/' + line_number + '/all_pages.pdf', md5_directory + 'SH3/all_pages.pdf')
-
+ os.rename(
+ md5_directory + "SH3/" + line_number + "/all_pages.pdf",
+ md5_directory + "SH3/all_pages.pdf",
+ )
+
return has_sh3_schedules
-def process_sh6_line(f3x_data, md5_directory, line_number, sh6_line, sh6_line_page_cnt, sh6_line_start_page,
- sh6_line_last_page_cnt, total_no_of_pages):
+def process_sh6_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ sh6_line,
+ sh6_line_page_cnt,
+ sh6_line_start_page,
+ sh6_line_last_page_cnt,
+ total_no_of_pages,
+):
has_sh6_schedules = False
if len(sh6_line) > 0:
total_federal_share = 0.00
@@ -3136,8 +5122,8 @@ def process_sh6_line(f3x_data, md5_directory, line_number, sh6_line, sh6_line_pa
total_fed_levin_share = 0.00
has_sh6_schedules = True
- os.makedirs(md5_directory + 'SH6/' + line_number, exist_ok=True)
- sh6_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SH6')
+ os.makedirs(md5_directory + "SH6/" + line_number, exist_ok=True)
+ sh6_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SH6")
if sh6_line_page_cnt > 0:
sh6_line_start_page += 1
for sh6_page_no in range(sh6_line_page_cnt):
@@ -3145,44 +5131,81 @@ def process_sh6_line(f3x_data, md5_directory, line_number, sh6_line, sh6_line_pa
memo_array = []
last_page = False
sh6_schedule_page_dict = {}
- sh6_schedule_page_dict['lineNumber'] = line_number
- sh6_schedule_page_dict['pageNo'] = sh6_line_start_page + sh6_page_no
- sh6_schedule_page_dict['totalPages'] = total_no_of_pages
+ sh6_schedule_page_dict["lineNumber"] = line_number
+ sh6_schedule_page_dict["pageNo"] = sh6_line_start_page + sh6_page_no
+ sh6_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sh6_page_no * 3
- if ((sh6_page_no + 1) == sh6_line_page_cnt):
+ if (sh6_page_no + 1) == sh6_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sh6_schedule_dict = build_sh6_line_per_page_schedule_dict(last_page, sh6_line_last_page_cnt,
- page_start_index, sh6_schedule_page_dict,
- sh6_line, memo_array)
+ sh6_schedule_dict = build_sh6_line_per_page_schedule_dict(
+ last_page,
+ sh6_line_last_page_cnt,
+ page_start_index,
+ sh6_schedule_page_dict,
+ sh6_line,
+ memo_array,
+ )
- page_fed_subtotal = float(sh6_schedule_page_dict['subTotalFederalShare'])
- page_levin_subtotal = float(sh6_schedule_page_dict['subTotalLevinShare'])
+ page_fed_subtotal = float(
+ sh6_schedule_page_dict["subTotalFederalShare"]
+ )
+ page_levin_subtotal = float(
+ sh6_schedule_page_dict["subTotalLevinShare"]
+ )
- sh6_schedule_page_dict['fedLevinSubTotalShare'] = page_fed_subtotal+page_levin_subtotal
+ sh6_schedule_page_dict["fedLevinSubTotalShare"] = (
+ page_fed_subtotal + page_levin_subtotal
+ )
total_federal_share += page_fed_subtotal
total_levin_share += page_levin_subtotal
if sh6_line_page_cnt == (sh6_page_no + 1):
- sh6_schedule_page_dict['totalFederalShare'] = '{0:.2f}'.format(total_federal_share)
- sh6_schedule_page_dict['totallevinShare'] = '{0:.2f}'.format(total_levin_share)
- sh6_schedule_page_dict['fedLevinTotalShare'] = total_federal_share+total_levin_share
- sh6_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sh6_outfile = md5_directory + 'SH6/' + line_number + '/page_' + str(sh6_page_no) + '.pdf'
+ sh6_schedule_page_dict["totalFederalShare"] = "{0:.2f}".format(
+ total_federal_share
+ )
+ sh6_schedule_page_dict["totallevinShare"] = "{0:.2f}".format(
+ total_levin_share
+ )
+ sh6_schedule_page_dict["fedLevinTotalShare"] = (
+ total_federal_share + total_levin_share
+ )
+ sh6_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sh6_outfile = (
+ md5_directory
+ + "SH6/"
+ + line_number
+ + "/page_"
+ + str(sh6_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sh6_infile, sh6_schedule_page_dict, sh6_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SH6/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SH6/' + line_number + '/page_memo_' + str(sh6_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SH6/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SH6/"
+ + line_number
+ + "/page_memo_"
+ + str(sh6_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sh6_outfile, memo_outfile], temp_memo_outfile)
@@ -3191,37 +5214,67 @@ def process_sh6_line(f3x_data, md5_directory, line_number, sh6_line, sh6_line_pa
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SH6/' + line_number + '/page_memo_' + str(sh6_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SH6/"
+ + line_number
+ + "/page_memo_"
+ + str(sh6_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sh6_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sh6_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SH6/' + line_number + '/'), md5_directory + 'SH6/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SH6/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SH6/all_pages.pdf', md5_directory + 'SH6/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SH6/temp_all_pages.pdf')
- os.rename(md5_directory + 'SH6/temp_all_pages.pdf', md5_directory + 'SH6/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SH6/" + line_number + "/"),
+ md5_directory + "SH6/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SH6/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SH6/all_pages.pdf",
+ md5_directory + "SH6/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SH6/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SH6/temp_all_pages.pdf",
+ md5_directory + "SH6/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SH6/' + line_number + '/all_pages.pdf', md5_directory + 'SH6/all_pages.pdf')
-
+ os.rename(
+ md5_directory + "SH6/" + line_number + "/all_pages.pdf",
+ md5_directory + "SH6/all_pages.pdf",
+ )
+
return has_sh6_schedules
-def process_sh4_line(f3x_data, md5_directory, line_number, sh4_line, sh4_line_page_cnt, sh4_line_start_page,
- sh4_line_last_page_cnt, total_no_of_pages):
+def process_sh4_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ sh4_line,
+ sh4_line_page_cnt,
+ sh4_line_start_page,
+ sh4_line_last_page_cnt,
+ total_no_of_pages,
+):
# import ipdb;ipdb.set_trace()
has_sh4_schedules = False
if len(sh4_line) > 0:
- total_fedshare=0.00
- total_nonfedshare=0.00
- total_fednonfed_share=0.00
+ total_fedshare = 0.00
+ total_nonfedshare = 0.00
+ total_fednonfed_share = 0.00
has_sh4_schedules = True
- os.makedirs(md5_directory + 'SH4/' + line_number, exist_ok=True)
- sh4_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SH4')
+ os.makedirs(md5_directory + "SH4/" + line_number, exist_ok=True)
+ sh4_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SH4")
if sh4_line_page_cnt > 0:
sh4_line_start_page += 1
for sh4_page_no in range(sh4_line_page_cnt):
@@ -3230,44 +5283,76 @@ def process_sh4_line(f3x_data, md5_directory, line_number, sh4_line, sh4_line_pa
last_page = False
has_sh4_schedules = True
sh4_schedule_page_dict = {}
- sh4_schedule_page_dict['lineNumber'] = line_number
- sh4_schedule_page_dict['pageNo'] = sh4_line_start_page + sh4_page_no
- sh4_schedule_page_dict['totalPages'] = total_no_of_pages
+ sh4_schedule_page_dict["lineNumber"] = line_number
+ sh4_schedule_page_dict["pageNo"] = sh4_line_start_page + sh4_page_no
+ sh4_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sh4_page_no * 3
- if ((sh4_page_no + 1) == sh4_line_page_cnt):
+ if (sh4_page_no + 1) == sh4_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sh4_schedule_dict = build_sh4_per_page_schedule_dict(last_page, sh4_line_last_page_cnt,
- page_start_index, sh4_schedule_page_dict,
- sh4_line, memo_array)
-
- page_fed_subtotal = float(sh4_schedule_page_dict['subFedShare'])
- page_nonfed_subtotal = float(sh4_schedule_page_dict['subNonFedShare'])
- sh4_schedule_page_dict['subTotalFedNonFedShare'] = '{0:.2f}'.format(page_fed_subtotal+page_nonfed_subtotal)
+ sh4_schedule_dict = build_sh4_per_page_schedule_dict(
+ last_page,
+ sh4_line_last_page_cnt,
+ page_start_index,
+ sh4_schedule_page_dict,
+ sh4_line,
+ memo_array,
+ )
+ page_fed_subtotal = float(sh4_schedule_page_dict["subFedShare"])
+ page_nonfed_subtotal = float(sh4_schedule_page_dict["subNonFedShare"])
+ sh4_schedule_page_dict["subTotalFedNonFedShare"] = "{0:.2f}".format(
+ page_fed_subtotal + page_nonfed_subtotal
+ )
total_fedshare += page_fed_subtotal
total_nonfedshare += page_nonfed_subtotal
if sh4_line_page_cnt == (sh4_page_no + 1):
- sh4_schedule_page_dict['TotalFedShare'] = '{0:.2f}'.format(total_fedshare)
- sh4_schedule_page_dict['totalNonFedShare'] = '{0:.2f}'.format(total_nonfedshare)
- sh4_schedule_page_dict['TotalFedNonFedShare'] = '{0:.2f}'.format(total_fedshare+total_nonfedshare)
- sh4_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sh4_outfile = md5_directory + 'SH4/' + line_number + '/page_' + str(sh4_page_no) + '.pdf'
+ sh4_schedule_page_dict["TotalFedShare"] = "{0:.2f}".format(
+ total_fedshare
+ )
+ sh4_schedule_page_dict["totalNonFedShare"] = "{0:.2f}".format(
+ total_nonfedshare
+ )
+ sh4_schedule_page_dict["TotalFedNonFedShare"] = "{0:.2f}".format(
+ total_fedshare + total_nonfedshare
+ )
+ sh4_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sh4_outfile = (
+ md5_directory
+ + "SH4/"
+ + line_number
+ + "/page_"
+ + str(sh4_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sh4_infile, sh4_schedule_page_dict, sh4_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SH4/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SH4/' + line_number + '/page_memo_' + str(sh4_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SH4/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SH4/"
+ + line_number
+ + "/page_memo_"
+ + str(sh4_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sh4_outfile, memo_outfile], temp_memo_outfile)
@@ -3276,23 +5361,45 @@ def process_sh4_line(f3x_data, md5_directory, line_number, sh4_line, sh4_line_pa
if len(memo_array) >= 3:
memo_dict = {}
- memo_outfile = md5_directory + 'SH4/' + line_number + '/page_memo_' + str(sh4_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[2]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[2]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[2]['transactionId']
+ memo_outfile = (
+ md5_directory
+ + "SH4/"
+ + line_number
+ + "/page_memo_"
+ + str(sh4_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[2]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[2][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_1"] = memo_array[2]["transactionId"]
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sh4_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sh4_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SH4/' + line_number + '/'), md5_directory + 'SH4/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SH4/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SH4/all_pages.pdf', md5_directory + 'SH4/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SH4/temp_all_pages.pdf')
- os.rename(md5_directory + 'SH4/temp_all_pages.pdf', md5_directory + 'SH4/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SH4/" + line_number + "/"),
+ md5_directory + "SH4/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SH4/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SH4/all_pages.pdf",
+ md5_directory + "SH4/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SH4/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SH4/temp_all_pages.pdf",
+ md5_directory + "SH4/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SH4/' + line_number + '/all_pages.pdf', md5_directory + 'SH4/all_pages.pdf')
-
+ os.rename(
+ md5_directory + "SH4/" + line_number + "/all_pages.pdf",
+ md5_directory + "SH4/all_pages.pdf",
+ )
+
return has_sh4_schedules
@@ -3334,8 +5441,16 @@ def process_sh4_line(f3x_data, md5_directory, line_number, sh4_line, sh4_line_pa
# return has_sh_memo_schedules
-def process_sh5_line(f3x_data, md5_directory, line_number, sh5_line, sh5_line_page_cnt, sh5_line_start_page,
- sh5_line_last_page_cnt, total_no_of_pages):
+def process_sh5_line(
+ f3x_data,
+ md5_directory,
+ line_number,
+ sh5_line,
+ sh5_line_page_cnt,
+ sh5_line_start_page,
+ sh5_line_last_page_cnt,
+ total_no_of_pages,
+):
# import ipdb;ipdb.set_trace()
has_sh5_schedules = False
if len(sh5_line) > 0:
@@ -3345,8 +5460,8 @@ def process_sh5_line(f3x_data, md5_directory, line_number, sh5_line, sh5_line_pa
total_gotv_amt_subtotal = 0.00
total_generic_camp_amt_subtotal = 0.00
has_sh5_schedules = True
- os.makedirs(md5_directory + 'SH5/' + line_number, exist_ok=True)
- sh5_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('SH5')
+ os.makedirs(md5_directory + "SH5/" + line_number, exist_ok=True)
+ sh5_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format("SH5")
if sh5_line_page_cnt > 0:
sh5_line_start_page += 1
for sh5_page_no in range(sh5_line_page_cnt):
@@ -3354,23 +5469,35 @@ def process_sh5_line(f3x_data, md5_directory, line_number, sh5_line, sh5_line_pa
memo_array = []
last_page = False
sh5_schedule_page_dict = {}
- sh5_schedule_page_dict['lineNumber'] = line_number
- sh5_schedule_page_dict['pageNo'] = sh5_line_start_page + sh5_page_no
- sh5_schedule_page_dict['totalPages'] = total_no_of_pages
+ sh5_schedule_page_dict["lineNumber"] = line_number
+ sh5_schedule_page_dict["pageNo"] = sh5_line_start_page + sh5_page_no
+ sh5_schedule_page_dict["totalPages"] = total_no_of_pages
page_start_index = sh5_page_no * 2
- if ((sh5_page_no + 1) == sh5_line_page_cnt):
+ if (sh5_page_no + 1) == sh5_line_page_cnt:
last_page = True
# This call prepares data to render on PDF
- sh5_schedule_dict = build_sh5_per_page_schedule_dict(last_page, sh5_line_last_page_cnt,
- page_start_index, sh5_schedule_page_dict,
- sh5_line, memo_array)
-
- transferred_amt_subtotal = float(sh5_schedule_page_dict['subtotalAmountTransferred'])
- voter_reg_amt_subtotal = float(sh5_schedule_page_dict['subvoterRegistrationAmount'])
- voter_id_amt_subtotal = float(sh5_schedule_page_dict['subvoterIdAmount'])
- gotv_amt_subtotal = float(sh5_schedule_page_dict['subgotvAmount'])
- generic_camp_amt_subtotal = float(sh5_schedule_page_dict['subgenericCampaignAmount'])
+ sh5_schedule_dict = build_sh5_per_page_schedule_dict(
+ last_page,
+ sh5_line_last_page_cnt,
+ page_start_index,
+ sh5_schedule_page_dict,
+ sh5_line,
+ memo_array,
+ )
+ transferred_amt_subtotal = float(
+ sh5_schedule_page_dict["subtotalAmountTransferred"]
+ )
+ voter_reg_amt_subtotal = float(
+ sh5_schedule_page_dict["subvoterRegistrationAmount"]
+ )
+ voter_id_amt_subtotal = float(
+ sh5_schedule_page_dict["subvoterIdAmount"]
+ )
+ gotv_amt_subtotal = float(sh5_schedule_page_dict["subgotvAmount"])
+ generic_camp_amt_subtotal = float(
+ sh5_schedule_page_dict["subgenericCampaignAmount"]
+ )
total_transferred_amt_subtotal += transferred_amt_subtotal
total_voter_reg_amt_subtotal += voter_reg_amt_subtotal
@@ -3378,45 +5505,89 @@ def process_sh5_line(f3x_data, md5_directory, line_number, sh5_line, sh5_line_pa
total_gotv_amt_subtotal += gotv_amt_subtotal
total_generic_camp_amt_subtotal += generic_camp_amt_subtotal
-
-
if sh5_line_page_cnt == (sh5_page_no + 1):
- sh5_schedule_page_dict['totalvoterRegistrationAmount'] = '{0:.2f}'.format( total_voter_reg_amt_subtotal)
- sh5_schedule_page_dict['totalvoterIdAmount'] = '{0:.2f}'.format(total_voter_id_amt_subtotal)
- sh5_schedule_page_dict['totalgotvAmount'] = '{0:.2f}'.format( total_gotv_amt_subtotal)
- sh5_schedule_page_dict['totalgenericCampaignAmount'] = '{0:.2f}'.format(total_generic_camp_amt_subtotal)
- sh5_schedule_page_dict['totalAmountOfTransfersReceived'] = total_voter_reg_amt_subtotal+total_voter_id_amt_subtotal+total_gotv_amt_subtotal+total_generic_camp_amt_subtotal
-
- sh5_schedule_page_dict['committeeName'] = f3x_data['committeeName']
- sh5_outfile = md5_directory + 'SH5/' + line_number + '/page_' + str(sh5_page_no) + '.pdf'
+ sh5_schedule_page_dict[
+ "totalvoterRegistrationAmount"
+ ] = "{0:.2f}".format(total_voter_reg_amt_subtotal)
+ sh5_schedule_page_dict["totalvoterIdAmount"] = "{0:.2f}".format(
+ total_voter_id_amt_subtotal
+ )
+ sh5_schedule_page_dict["totalgotvAmount"] = "{0:.2f}".format(
+ total_gotv_amt_subtotal
+ )
+ sh5_schedule_page_dict[
+ "totalgenericCampaignAmount"
+ ] = "{0:.2f}".format(total_generic_camp_amt_subtotal)
+ sh5_schedule_page_dict["totalAmountOfTransfersReceived"] = (
+ total_voter_reg_amt_subtotal
+ + total_voter_id_amt_subtotal
+ + total_gotv_amt_subtotal
+ + total_generic_camp_amt_subtotal
+ )
+
+ sh5_schedule_page_dict["committeeName"] = f3x_data["committeeName"]
+ sh5_outfile = (
+ md5_directory
+ + "SH5/"
+ + line_number
+ + "/page_"
+ + str(sh5_page_no)
+ + ".pdf"
+ )
pypdftk.fill_form(sh5_infile, sh5_schedule_page_dict, sh5_outfile)
# Memo text changes
memo_dict = {}
if len(memo_array) >= 1:
- temp_memo_outfile = md5_directory + 'SH5/' + line_number + '/page_memo_temp.pdf'
- memo_infile = current_app.config['FORM_TEMPLATES_LOCATION'].format('TEXT')
- memo_outfile = md5_directory + 'SH5/' + line_number + '/page_memo_' + str(sh5_page_no) + '.pdf'
- memo_dict['scheduleName_1'] = memo_array[0]['scheduleName']
- memo_dict['memoDescription_1'] = memo_array[0]['memoDescription']
- memo_dict['transactionId_1'] = memo_array[0]['transactionId']
+ temp_memo_outfile = (
+ md5_directory + "SH5/" + line_number + "/page_memo_temp.pdf"
+ )
+ memo_infile = current_app.config["FORM_TEMPLATES_LOCATION"].format(
+ "TEXT"
+ )
+ memo_outfile = (
+ md5_directory
+ + "SH5/"
+ + line_number
+ + "/page_memo_"
+ + str(sh5_page_no)
+ + ".pdf"
+ )
+ memo_dict["scheduleName_1"] = memo_array[0]["scheduleName"]
+ memo_dict["memoDescription_1"] = memo_array[0]["memoDescription"]
+ memo_dict["transactionId_1"] = memo_array[0]["transactionId"]
if len(memo_array) >= 2:
- memo_dict['scheduleName_2'] = memo_array[1]['scheduleName']
- memo_dict['memoDescription_2'] = memo_array[1]['memoDescription']
- memo_dict['transactionId_2'] = memo_array[1]['transactionId']
+ memo_dict["scheduleName_2"] = memo_array[1]["scheduleName"]
+ memo_dict["memoDescription_2"] = memo_array[1][
+ "memoDescription"
+ ]
+ memo_dict["transactionId_2"] = memo_array[1]["transactionId"]
# build page
pypdftk.fill_form(memo_infile, memo_dict, memo_outfile)
pypdftk.concat([sh5_outfile, memo_outfile], temp_memo_outfile)
os.remove(memo_outfile)
os.rename(temp_memo_outfile, sh5_outfile)
- pypdftk.concat(directory_files(md5_directory + 'SH5/' + line_number + '/'), md5_directory + 'SH5/' + line_number
- + '/all_pages.pdf')
- if path.isfile(md5_directory + 'SH5/all_pages.pdf'):
- pypdftk.concat([md5_directory + 'SH5/all_pages.pdf', md5_directory + 'SH5/' + line_number + '/all_pages.pdf'],
- md5_directory + 'SH5/temp_all_pages.pdf')
- os.rename(md5_directory + 'SH5/temp_all_pages.pdf', md5_directory + 'SH5/all_pages.pdf')
+ pypdftk.concat(
+ directory_files(md5_directory + "SH5/" + line_number + "/"),
+ md5_directory + "SH5/" + line_number + "/all_pages.pdf",
+ )
+ if path.isfile(md5_directory + "SH5/all_pages.pdf"):
+ pypdftk.concat(
+ [
+ md5_directory + "SH5/all_pages.pdf",
+ md5_directory + "SH5/" + line_number + "/all_pages.pdf",
+ ],
+ md5_directory + "SH5/temp_all_pages.pdf",
+ )
+ os.rename(
+ md5_directory + "SH5/temp_all_pages.pdf",
+ md5_directory + "SH5/all_pages.pdf",
+ )
else:
- os.rename(md5_directory + 'SH5/' + line_number + '/all_pages.pdf', md5_directory + 'SH5/all_pages.pdf')
-
+ os.rename(
+ md5_directory + "SH5/" + line_number + "/all_pages.pdf",
+ md5_directory + "SH5/all_pages.pdf",
+ )
+
return has_sh5_schedules
@@ -3430,6 +5601,7 @@ def calculate_sh5page_count(schedules):
schedules_in_last_page = int(schedules_cnt % 2)
return pages_cnt, schedules_in_last_page
+
def calculate_se_page_count(schedules):
schedules_cnt = len(schedules)
if int(schedules_cnt % 2) == 0:
@@ -3440,6 +5612,7 @@ def calculate_se_page_count(schedules):
schedules_in_last_page = int(schedules_cnt % 2)
return pages_cnt, schedules_in_last_page
+
def calculate_page_count(schedules):
schedules_cnt = len(schedules)
if int(schedules_cnt % 3) == 0:
@@ -3459,7 +5632,7 @@ def calculate_la_page_count(schedules):
else:
pages_cnt = int(schedules_cnt / 4) + 1
schedules_in_last_page = int(schedules_cnt % 4)
-
+
return pages_cnt, schedules_in_last_page
@@ -3471,7 +5644,7 @@ def calculate_slb_page_count(schedules):
else:
pages_cnt = int(schedules_cnt / 5) + 1
schedules_in_last_page = int(schedules_cnt % 5)
-
+
return pages_cnt, schedules_in_last_page
@@ -3483,7 +5656,7 @@ def calculate_sh2_page_count(schedules):
else:
pages_cnt = int(schedules_cnt / 6) + 1
schedules_in_last_page = int(schedules_cnt % 6)
-
+
return pages_cnt, schedules_in_last_page
@@ -3499,254 +5672,514 @@ def calculate_memo_page_count(schedules):
# This method builds line number array for SA
-def process_sa_line_numbers(sa_11a, sa_11b, sa_11c, sa_12, sa_13, sa_14, sa_15, sa_16, sa_17,
- sa_11a_memo, sa_11b_memo, sa_11c_memo, sa_12_memo, sa_13_memo, sa_14_memo,
- sa_15_memo, sa_16_memo, sa_17_memo, sa_obj):
- if sa_obj['lineNumber'] == '11A' or sa_obj['lineNumber'] == '11AI' or sa_obj['lineNumber'] == '11AII':
+def process_sa_line_numbers(
+ sa_11a,
+ sa_11b,
+ sa_11c,
+ sa_12,
+ sa_13,
+ sa_14,
+ sa_15,
+ sa_16,
+ sa_17,
+ sa_11a_memo,
+ sa_11b_memo,
+ sa_11c_memo,
+ sa_12_memo,
+ sa_13_memo,
+ sa_14_memo,
+ sa_15_memo,
+ sa_16_memo,
+ sa_17_memo,
+ sa_obj,
+):
+ if (
+ sa_obj["lineNumber"] == "11A"
+ or sa_obj["lineNumber"] == "11AI"
+ or sa_obj["lineNumber"] == "11AII"
+ ):
sa_11a.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_11a_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
- elif sa_obj['lineNumber'] == '11B':
+ if sa_obj["memoDescription"]:
+ sa_11a_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
+ elif sa_obj["lineNumber"] == "11B":
sa_11b.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_11b_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
- elif sa_obj['lineNumber'] == '11C':
+ if sa_obj["memoDescription"]:
+ sa_11b_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
+ elif sa_obj["lineNumber"] == "11C":
sa_11c.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_11c_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
- elif sa_obj['lineNumber'] == '12':
+ if sa_obj["memoDescription"]:
+ sa_11c_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
+ elif sa_obj["lineNumber"] == "12":
sa_12.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_12_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
- elif sa_obj['lineNumber'] == '13':
+ if sa_obj["memoDescription"]:
+ sa_12_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
+ elif sa_obj["lineNumber"] == "13":
sa_13.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_13_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
- elif sa_obj['lineNumber'] == '14':
+ if sa_obj["memoDescription"]:
+ sa_13_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
+ elif sa_obj["lineNumber"] == "14":
sa_14.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_14_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
- elif sa_obj['lineNumber'] == '15':
+ if sa_obj["memoDescription"]:
+ sa_14_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
+ elif sa_obj["lineNumber"] == "15":
sa_15.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_15_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
- elif sa_obj['lineNumber'] == '16':
+ if sa_obj["memoDescription"]:
+ sa_15_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
+ elif sa_obj["lineNumber"] == "16":
sa_16.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_16_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
- elif sa_obj['lineNumber'] == '17':
+ if sa_obj["memoDescription"]:
+ sa_16_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
+ elif sa_obj["lineNumber"] == "17":
sa_17.append(sa_obj)
- if sa_obj['memoDescription']:
- sa_17_memo.append({'scheduleName': 'SA' + sa_obj['lineNumber'], 'memoDescription': sa_obj['memoDescription'],
- 'transactionId': sa_obj['transactionId']})
+ if sa_obj["memoDescription"]:
+ sa_17_memo.append(
+ {
+ "scheduleName": "SA" + sa_obj["lineNumber"],
+ "memoDescription": sa_obj["memoDescription"],
+ "transactionId": sa_obj["transactionId"],
+ }
+ )
# This method builds line number array for SB
-def process_sb_line_numbers(sb_21b, sb_22, sb_23, sb_26, sb_27, sb_28a, sb_28b, sb_28c, sb_29,
- sb_30b, sb_21b_memo, sb_22_memo, sb_23_memo, sb_26_memo, sb_27_memo,
- sb_28a_memo, sb_28b_memo, sb_28c_memo, sb_29_memo, sb_30b_memo, sb_obj):
- if sb_obj['lineNumber'] == '21B':
+def process_sb_line_numbers(
+ sb_21b,
+ sb_22,
+ sb_23,
+ sb_26,
+ sb_27,
+ sb_28a,
+ sb_28b,
+ sb_28c,
+ sb_29,
+ sb_30b,
+ sb_21b_memo,
+ sb_22_memo,
+ sb_23_memo,
+ sb_26_memo,
+ sb_27_memo,
+ sb_28a_memo,
+ sb_28b_memo,
+ sb_28c_memo,
+ sb_29_memo,
+ sb_30b_memo,
+ sb_obj,
+):
+ if sb_obj["lineNumber"] == "21B":
sb_21b.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_21b_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '22':
+ if sb_obj["memoDescription"]:
+ sb_21b_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "22":
sb_22.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_22_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '23':
+ if sb_obj["memoDescription"]:
+ sb_22_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "23":
sb_23.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_23_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '26':
+ if sb_obj["memoDescription"]:
+ sb_23_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "26":
sb_26.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_26_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '27':
+ if sb_obj["memoDescription"]:
+ sb_26_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "27":
sb_27.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_27_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '28A':
+ if sb_obj["memoDescription"]:
+ sb_27_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "28A":
sb_28a.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_28a_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '28B':
+ if sb_obj["memoDescription"]:
+ sb_28a_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "28B":
sb_28b.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_28b_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '28C':
+ if sb_obj["memoDescription"]:
+ sb_28b_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "28C":
sb_28c.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_28c_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '29':
+ if sb_obj["memoDescription"]:
+ sb_28c_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "29":
sb_29.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_29_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
- elif sb_obj['lineNumber'] == '30B':
+ if sb_obj["memoDescription"]:
+ sb_29_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+ elif sb_obj["lineNumber"] == "30B":
sb_30b.append(sb_obj)
- if sb_obj['memoDescription']:
- sb_30b_memo.append({'scheduleName': 'SB' + sb_obj['lineNumber'], 'memoDescription': sb_obj['memoDescription'],
- 'transactionId': sb_obj['transactionId']})
+ if sb_obj["memoDescription"]:
+ sb_30b_memo.append(
+ {
+ "scheduleName": "SB" + sb_obj["lineNumber"],
+ "memoDescription": sb_obj["memoDescription"],
+ "transactionId": sb_obj["transactionId"],
+ }
+ )
+
def process_se_line_numbers(se_24, se_24_memo, se_obj):
- if se_obj['lineNumber'] == '24':
+ if se_obj["lineNumber"] == "24":
se_24.append(se_obj)
- if se_obj['memoDescription']:
- se_24_memo.append({'scheduleName': 'SE' + se_obj['lineNumber'], 'memoDescription': se_obj['memoDescription'],
- 'transactionId': se_obj['transactionId']})
-
-
-def process_sf_line_numbers(sf_crd, sf_non_crd, sf_empty_ord, sf_empty_non_ord, sf_empty_none, sf_empty_sub,
- sf_crd_memo, sf_non_crd_memo, sf_empty_ord_memo, sf_empty_non_ord_memo,
- sf_empty_none_memo, sf_empty_sub_memo,
- sf_obj):
- if sf_obj["coordinateExpenditure"] == "Y":
+ if se_obj["memoDescription"]:
+ se_24_memo.append(
+ {
+ "scheduleName": "SE" + se_obj["lineNumber"],
+ "memoDescription": se_obj["memoDescription"],
+ "transactionId": se_obj["transactionId"],
+ }
+ )
+
+
+def process_sf_line_numbers(
+ sf_crd,
+ sf_non_crd,
+ sf_empty_ord,
+ sf_empty_non_ord,
+ sf_empty_none,
+ sf_empty_sub,
+ sf_crd_memo,
+ sf_non_crd_memo,
+ sf_empty_ord_memo,
+ sf_empty_non_ord_memo,
+ sf_empty_none_memo,
+ sf_empty_sub_memo,
+ sf_obj,
+):
+ if sf_obj["coordinateExpenditure"] == "Y":
sf_crd.append(sf_obj)
- if sf_obj['memoDescription']:
+ if sf_obj["memoDescription"]:
sf_crd_memo.append(
- {'scheduleName': 'SF' + sf_obj['lineNumber'], 'memoDescription': sf_obj['memoDescription'],
- 'transactionId': sf_obj['transactionId']})
- elif sf_obj["coordinateExpenditure"] == "N" and sf_obj['subordinateCommitteeName']:
+ {
+ "scheduleName": "SF" + sf_obj["lineNumber"],
+ "memoDescription": sf_obj["memoDescription"],
+ "transactionId": sf_obj["transactionId"],
+ }
+ )
+ elif sf_obj["coordinateExpenditure"] == "N" and sf_obj["subordinateCommitteeName"]:
sf_non_crd.append(sf_obj)
- if sf_obj['memoDescription']:
+ if sf_obj["memoDescription"]:
sf_non_crd_memo.append(
- {'scheduleName': 'SF' + sf_obj['lineNumber'], 'memoDescription': sf_obj['memoDescription'],
- 'transactionId': sf_obj['transactionId']})
- elif sf_obj["coordinateExpenditure"] == '' and sf_obj['designatingCommitteeName']:
+ {
+ "scheduleName": "SF" + sf_obj["lineNumber"],
+ "memoDescription": sf_obj["memoDescription"],
+ "transactionId": sf_obj["transactionId"],
+ }
+ )
+ elif sf_obj["coordinateExpenditure"] == "" and sf_obj["designatingCommitteeName"]:
sf_empty_ord.append(sf_obj)
- if sf_obj['memoDescription']:
+ if sf_obj["memoDescription"]:
sf_empty_ord_memo.append(
- {'scheduleName': 'SF' + sf_obj['lineNumber'], 'memoDescription': sf_obj['memoDescription'],
- 'transactionId': sf_obj['transactionId']})
- elif sf_obj["coordinateExpenditure"] == '' and sf_obj['subordinateCommitteeName']:
+ {
+ "scheduleName": "SF" + sf_obj["lineNumber"],
+ "memoDescription": sf_obj["memoDescription"],
+ "transactionId": sf_obj["transactionId"],
+ }
+ )
+ elif sf_obj["coordinateExpenditure"] == "" and sf_obj["subordinateCommitteeName"]:
sf_empty_non_ord.append(sf_obj)
- if sf_obj['memoDescription']:
+ if sf_obj["memoDescription"]:
sf_crd_memo.append(
- {'scheduleName': 'SF' + sf_obj['lineNumber'], 'memoDescription': sf_obj['memoDescription'],
- 'transactionId': sf_obj['transactionId']})
- elif sf_obj["coordinateExpenditure"] == '' and sf_obj['subordinateCommitteeName'] == '' and sf_obj['designatingCommitteeName'] == '':
+ {
+ "scheduleName": "SF" + sf_obj["lineNumber"],
+ "memoDescription": sf_obj["memoDescription"],
+ "transactionId": sf_obj["transactionId"],
+ }
+ )
+ elif (
+ sf_obj["coordinateExpenditure"] == ""
+ and sf_obj["subordinateCommitteeName"] == ""
+ and sf_obj["designatingCommitteeName"] == ""
+ ):
sf_empty_none.append(sf_obj)
- if sf_obj['memoDescription']:
+ if sf_obj["memoDescription"]:
sf_empty_none_memo.append(
- {'scheduleName': 'SF' + sf_obj['lineNumber'], 'memoDescription': sf_obj['memoDescription'],
- 'transactionId': sf_obj['transactionId']})
- elif sf_obj["coordinateExpenditure"] == 'N' and sf_obj['subordinateCommitteeName'] == '':
+ {
+ "scheduleName": "SF" + sf_obj["lineNumber"],
+ "memoDescription": sf_obj["memoDescription"],
+ "transactionId": sf_obj["transactionId"],
+ }
+ )
+ elif (
+ sf_obj["coordinateExpenditure"] == "N"
+ and sf_obj["subordinateCommitteeName"] == ""
+ ):
sf_empty_sub.append(sf_obj)
- if sf_obj['memoDescription']:
+ if sf_obj["memoDescription"]:
sf_empty_sub_memo.append(
- {'scheduleName': 'SF' + sf_obj['lineNumber'], 'memoDescription': sf_obj['memoDescription'],
- 'transactionId': sf_obj['transactionId']})
+ {
+ "scheduleName": "SF" + sf_obj["lineNumber"],
+ "memoDescription": sf_obj["memoDescription"],
+ "transactionId": sf_obj["transactionId"],
+ }
+ )
def process_la_line_numbers(la_1a, la_2, la_1a_memo, la_2_memo, la_obj):
- if la_obj['lineNumber'] == '1A':
+ if la_obj["lineNumber"] == "1A":
la_1a.append(la_obj)
- if la_obj['memoDescription']:
+ if la_obj["memoDescription"]:
la_1a_memo.append(
- {'scheduleName': 'SL' + la_obj['lineNumber'], 'memoDescription': la_obj['memoDescription'],
- 'transactionId': la_obj['transactionId']})
- elif la_obj['lineNumber'] == '2':
+ {
+ "scheduleName": "SL" + la_obj["lineNumber"],
+ "memoDescription": la_obj["memoDescription"],
+ "transactionId": la_obj["transactionId"],
+ }
+ )
+ elif la_obj["lineNumber"] == "2":
la_2.append(la_obj)
- if la_obj['memoDescription']:
+ if la_obj["memoDescription"]:
la_2_memo.append(
- {'scheduleName': 'SL' + la_obj['lineNumber'], 'memoDescription': la_obj['memoDescription'],
- 'transactionId': la_obj['transactionId']})
-
-
-def process_slb_line_numbers(slb_4a, slb_4b, slb_4c, slb_4d, slb_5,
- slb_4a_memo, slb_4b_memo, slb_4c_memo, slb_4d_memo, slb_5_memo, slb_obj):
- if slb_obj['lineNumber'] == '4A':
+ {
+ "scheduleName": "SL" + la_obj["lineNumber"],
+ "memoDescription": la_obj["memoDescription"],
+ "transactionId": la_obj["transactionId"],
+ }
+ )
+
+
+def process_slb_line_numbers(
+ slb_4a,
+ slb_4b,
+ slb_4c,
+ slb_4d,
+ slb_5,
+ slb_4a_memo,
+ slb_4b_memo,
+ slb_4c_memo,
+ slb_4d_memo,
+ slb_5_memo,
+ slb_obj,
+):
+ if slb_obj["lineNumber"] == "4A":
slb_4a.append(slb_obj)
- if slb_obj['memoDescription']:
+ if slb_obj["memoDescription"]:
slb_4a_memo.append(
- {'scheduleName': 'SL' + slb_obj['lineNumber'], 'memoDescription': slb_obj['memoDescription'],
- 'transactionId': slb_obj['transactionId']})
- elif slb_obj['lineNumber'] == '4B':
+ {
+ "scheduleName": "SL" + slb_obj["lineNumber"],
+ "memoDescription": slb_obj["memoDescription"],
+ "transactionId": slb_obj["transactionId"],
+ }
+ )
+ elif slb_obj["lineNumber"] == "4B":
slb_4b.append(slb_obj)
- if slb_obj['memoDescription']:
+ if slb_obj["memoDescription"]:
slb_4b_memo.append(
- {'scheduleName': 'SL' + slb_obj['lineNumber'], 'memoDescription': slb_obj['memoDescription'],
- 'transactionId': slb_obj['transactionId']})
- elif slb_obj['lineNumber'] == '4C':
+ {
+ "scheduleName": "SL" + slb_obj["lineNumber"],
+ "memoDescription": slb_obj["memoDescription"],
+ "transactionId": slb_obj["transactionId"],
+ }
+ )
+ elif slb_obj["lineNumber"] == "4C":
slb_4c.append(slb_obj)
- if slb_obj['memoDescription']:
+ if slb_obj["memoDescription"]:
slb_4c_memo.append(
- {'scheduleName': 'SL' + slb_obj['lineNumber'], 'memoDescription': slb_obj['memoDescription'],
- 'transactionId': slb_obj['transactionId']})
- elif slb_obj['lineNumber'] == '4D':
+ {
+ "scheduleName": "SL" + slb_obj["lineNumber"],
+ "memoDescription": slb_obj["memoDescription"],
+ "transactionId": slb_obj["transactionId"],
+ }
+ )
+ elif slb_obj["lineNumber"] == "4D":
slb_4d.append(slb_obj)
- if slb_obj['memoDescription']:
+ if slb_obj["memoDescription"]:
slb_4d_memo.append(
- {'scheduleName': 'SL' + slb_obj['lineNumber'], 'memoDescription': slb_obj['memoDescription'],
- 'transactionId': slb_obj['transactionId']})
- elif slb_obj['lineNumber'] == '5':
+ {
+ "scheduleName": "SL" + slb_obj["lineNumber"],
+ "memoDescription": slb_obj["memoDescription"],
+ "transactionId": slb_obj["transactionId"],
+ }
+ )
+ elif slb_obj["lineNumber"] == "5":
slb_5.append(slb_obj)
- if slb_obj['memoDescription']:
+ if slb_obj["memoDescription"]:
slb_5_memo.append(
- {'scheduleName': 'SL' + slb_obj['lineNumber'], 'memoDescription': slb_obj['memoDescription'],
- 'transactionId': slb_obj['transactionId']})
-
-
-def process_sh_line_numbers(sh_30a, sh_21a,sh_18b, sh_18a, sh_h1, sh_h2,
- sh_30a_memo, sh_21a_memo,sh_18b_memo, sh_18a_memo, sh_obj):
- if sh_obj['lineNumber'] == '30A':
+ {
+ "scheduleName": "SL" + slb_obj["lineNumber"],
+ "memoDescription": slb_obj["memoDescription"],
+ "transactionId": slb_obj["transactionId"],
+ }
+ )
+
+
+def process_sh_line_numbers(
+ sh_30a,
+ sh_21a,
+ sh_18b,
+ sh_18a,
+ sh_h1,
+ sh_h2,
+ sh_30a_memo,
+ sh_21a_memo,
+ sh_18b_memo,
+ sh_18a_memo,
+ sh_obj,
+):
+ if sh_obj["lineNumber"] == "30A":
sh_30a.append(sh_obj)
- if 'memoDescription' in sh_obj and sh_obj['memoDescription']:
+ if "memoDescription" in sh_obj and sh_obj["memoDescription"]:
sh_30a_memo.append(
- {'scheduleName': 'SH' + sh_obj['lineNumber'], 'memoDescription': sh_obj['memoDescription'],
- 'transactionId': sh_obj['transactionId']})
- if sh_obj['lineNumber'] == '21A':
+ {
+ "scheduleName": "SH" + sh_obj["lineNumber"],
+ "memoDescription": sh_obj["memoDescription"],
+ "transactionId": sh_obj["transactionId"],
+ }
+ )
+ if sh_obj["lineNumber"] == "21A":
sh_21a.append(sh_obj)
- if 'memoDescription' in sh_obj and sh_obj['memoDescription']:
+ if "memoDescription" in sh_obj and sh_obj["memoDescription"]:
sh_21a_memo.append(
- {'scheduleName': 'SH' + sh_obj['lineNumber'], 'memoDescription': sh_obj['memoDescription'],
- 'transactionId': sh_obj['transactionId']})
- if sh_obj['lineNumber'] == '18B':
+ {
+ "scheduleName": "SH" + sh_obj["lineNumber"],
+ "memoDescription": sh_obj["memoDescription"],
+ "transactionId": sh_obj["transactionId"],
+ }
+ )
+ if sh_obj["lineNumber"] == "18B":
sh_18b.append(sh_obj)
- if 'memoDescription' in sh_obj and sh_obj['memoDescription']:
+ if "memoDescription" in sh_obj and sh_obj["memoDescription"]:
sh_18b_memo.append(
- {'scheduleName': 'SH' + sh_obj['lineNumber'], 'memoDescription': sh_obj['memoDescription'],
- 'transactionId': sh_obj['transactionId']})
- if sh_obj['lineNumber'] == '18A':
+ {
+ "scheduleName": "SH" + sh_obj["lineNumber"],
+ "memoDescription": sh_obj["memoDescription"],
+ "transactionId": sh_obj["transactionId"],
+ }
+ )
+ if sh_obj["lineNumber"] == "18A":
sh_18a.append(sh_obj)
- if 'memoDescription' in sh_obj and sh_obj['memoDescription']:
+ if "memoDescription" in sh_obj and sh_obj["memoDescription"]:
sh_18a_memo.append(
- {'scheduleName': 'SH' + sh_obj['lineNumber'], 'memoDescription': sh_obj['memoDescription'],
- 'transactionId': sh_obj['transactionId']})
- if sh_obj['transactionTypeIdentifier'] == 'ALLOC_H1':
+ {
+ "scheduleName": "SH" + sh_obj["lineNumber"],
+ "memoDescription": sh_obj["memoDescription"],
+ "transactionId": sh_obj["transactionId"],
+ }
+ )
+ if sh_obj["transactionTypeIdentifier"] == "ALLOC_H1":
sh_h1.append(sh_obj)
- if sh_obj['transactionTypeIdentifier'] == 'ALLOC_H2_RATIO':
+ if sh_obj["transactionTypeIdentifier"] == "ALLOC_H2_RATIO":
sh_h2.append(sh_obj)
def process_memo_text(schedule_dict, schedule, memo_array):
- if 'memoDescription' in schedule_dict and schedule_dict['memoDescription']:
+ if "memoDescription" in schedule_dict and schedule_dict["memoDescription"]:
memo_array.append(
- {'scheduleName': schedule + schedule_dict['lineNumber'],
- 'memoDescription': schedule_dict['memoDescription'],
- 'transactionId': schedule_dict['transactionId']})
+ {
+ "scheduleName": schedule + schedule_dict["lineNumber"],
+ "memoDescription": schedule_dict["memoDescription"],
+ "transactionId": schedule_dict["transactionId"],
+ }
+ )
# This method builds data for individual SA page
-def build_sa_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sa_schedule_page_dict,
- sa_schedules, memo_array):
+def build_sa_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sa_schedule_page_dict,
+ sa_schedules,
+ memo_array,
+):
page_subtotal = 0.00
if not last_page:
transactions_in_page = 3
@@ -3754,68 +6187,97 @@ def build_sa_per_page_schedule_dict(last_page, transactions_in_page, page_start_
if transactions_in_page == 1:
index = 1
sa_schedule_dict = sa_schedules[page_start_index + 0]
- process_memo_text(sa_schedule_dict, 'SA', memo_array)
- if sa_schedule_dict['memoCode'] != 'X':
- page_subtotal += sa_schedule_dict['contributionAmount']
- build_contributor_name_date_dict(index, page_start_index, sa_schedule_dict, sa_schedule_page_dict)
+ process_memo_text(sa_schedule_dict, "SA", memo_array)
+ if sa_schedule_dict["memoCode"] != "X":
+ page_subtotal += sa_schedule_dict["contributionAmount"]
+ build_contributor_name_date_dict(
+ index, page_start_index, sa_schedule_dict, sa_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
sa_schedule_dict = sa_schedules[page_start_index + 0]
- process_memo_text(sa_schedule_dict, 'SA', memo_array)
- if sa_schedule_dict['memoCode'] != 'X':
- page_subtotal += sa_schedule_dict['contributionAmount']
- build_contributor_name_date_dict(index, page_start_index, sa_schedule_dict, sa_schedule_page_dict)
+ process_memo_text(sa_schedule_dict, "SA", memo_array)
+ if sa_schedule_dict["memoCode"] != "X":
+ page_subtotal += sa_schedule_dict["contributionAmount"]
+ build_contributor_name_date_dict(
+ index, page_start_index, sa_schedule_dict, sa_schedule_page_dict
+ )
index = 2
sa_schedule_dict = sa_schedules[page_start_index + 1]
- process_memo_text(sa_schedule_dict, 'SA', memo_array)
- if sa_schedule_dict['memoCode'] != 'X':
- page_subtotal += sa_schedule_dict['contributionAmount']
- build_contributor_name_date_dict(index, page_start_index, sa_schedule_dict, sa_schedule_page_dict)
+ process_memo_text(sa_schedule_dict, "SA", memo_array)
+ if sa_schedule_dict["memoCode"] != "X":
+ page_subtotal += sa_schedule_dict["contributionAmount"]
+ build_contributor_name_date_dict(
+ index, page_start_index, sa_schedule_dict, sa_schedule_page_dict
+ )
elif transactions_in_page == 3:
index = 1
sa_schedule_dict = sa_schedules[page_start_index + 0]
- process_memo_text(sa_schedule_dict, 'SA', memo_array)
- if sa_schedule_dict['memoCode'] != 'X':
- page_subtotal += sa_schedule_dict['contributionAmount']
- build_contributor_name_date_dict(index, page_start_index, sa_schedule_dict, sa_schedule_page_dict)
+ process_memo_text(sa_schedule_dict, "SA", memo_array)
+ if sa_schedule_dict["memoCode"] != "X":
+ page_subtotal += sa_schedule_dict["contributionAmount"]
+ build_contributor_name_date_dict(
+ index, page_start_index, sa_schedule_dict, sa_schedule_page_dict
+ )
index = 2
sa_schedule_dict = sa_schedules[page_start_index + 1]
- process_memo_text(sa_schedule_dict, 'SA', memo_array)
- if sa_schedule_dict['memoCode'] != 'X':
- page_subtotal += sa_schedule_dict['contributionAmount']
- build_contributor_name_date_dict(index, page_start_index, sa_schedule_dict, sa_schedule_page_dict)
+ process_memo_text(sa_schedule_dict, "SA", memo_array)
+ if sa_schedule_dict["memoCode"] != "X":
+ page_subtotal += sa_schedule_dict["contributionAmount"]
+ build_contributor_name_date_dict(
+ index, page_start_index, sa_schedule_dict, sa_schedule_page_dict
+ )
index = 3
sa_schedule_dict = sa_schedules[page_start_index + 2]
- process_memo_text(sa_schedule_dict, 'SA', memo_array)
- if sa_schedule_dict['memoCode'] != 'X':
- page_subtotal += sa_schedule_dict['contributionAmount']
- build_contributor_name_date_dict(index, page_start_index, sa_schedule_dict, sa_schedule_page_dict)
- sa_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
+ process_memo_text(sa_schedule_dict, "SA", memo_array)
+ if sa_schedule_dict["memoCode"] != "X":
+ page_subtotal += sa_schedule_dict["contributionAmount"]
+ build_contributor_name_date_dict(
+ index, page_start_index, sa_schedule_dict, sa_schedule_page_dict
+ )
+ sa_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
return sa_schedule_dict
# This method builds data for individual memo page
-def build_memo_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, memo_schedule_page_dict,
- memo_schedules):
+def build_memo_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ memo_schedule_page_dict,
+ memo_schedules,
+):
if not last_page:
transactions_in_page = 2
if transactions_in_page == 1:
index = 1
memo_schedule_dict = memo_schedules[page_start_index + 0]
- build_memo_dict(index, page_start_index, memo_schedule_dict, memo_schedule_page_dict)
+ build_memo_dict(
+ index, page_start_index, memo_schedule_dict, memo_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
memo_schedule_dict = memo_schedules[page_start_index + 0]
- build_memo_dict(index, page_start_index, memo_schedule_dict, memo_schedule_page_dict)
+ build_memo_dict(
+ index, page_start_index, memo_schedule_dict, memo_schedule_page_dict
+ )
index = 2
memo_schedule_dict = memo_schedules[page_start_index + 1]
- build_memo_dict(index, page_start_index, memo_schedule_dict, memo_schedule_page_dict)
+ build_memo_dict(
+ index, page_start_index, memo_schedule_dict, memo_schedule_page_dict
+ )
return memo_schedule_page_dict
-def build_sh4_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sh4_schedule_page_dict,
- sh4_schedules, memo_array):
+def build_sh4_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sh4_schedule_page_dict,
+ sh4_schedules,
+ memo_array,
+):
page_fed_subtotal = 0.00
page_nonfed_subtotal = 0.00
if not last_page:
@@ -3824,178 +6286,246 @@ def build_sh4_per_page_schedule_dict(last_page, transactions_in_page, page_start
if transactions_in_page == 1:
index = 1
sh4_schedule_dict = sh4_schedules[page_start_index + 0]
- process_memo_text(sh4_schedule_dict, 'H4', memo_array)
- if sh4_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh4_schedule_dict['federalShare']
- page_nonfed_subtotal += sh4_schedule_dict['nonfederalShare']
- build_sh_name_date_dict(index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict)
+ process_memo_text(sh4_schedule_dict, "H4", memo_array)
+ if sh4_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh4_schedule_dict["federalShare"]
+ page_nonfed_subtotal += sh4_schedule_dict["nonfederalShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
sh4_schedule_dict = sh4_schedules[page_start_index + 0]
- process_memo_text(sh4_schedule_dict, 'H4', memo_array)
- if sh4_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh4_schedule_dict['federalShare']
- page_nonfed_subtotal += sh4_schedule_dict['nonfederalShare']
- build_sh_name_date_dict(index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict)
+ process_memo_text(sh4_schedule_dict, "H4", memo_array)
+ if sh4_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh4_schedule_dict["federalShare"]
+ page_nonfed_subtotal += sh4_schedule_dict["nonfederalShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict
+ )
index = 2
sh4_schedule_dict = sh4_schedules[page_start_index + 1]
- process_memo_text(sh4_schedule_dict, 'H4', memo_array)
- if sh4_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh4_schedule_dict['federalShare']
- page_nonfed_subtotal += sh4_schedule_dict['nonfederalShare']
- build_sh_name_date_dict(index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict)
+ process_memo_text(sh4_schedule_dict, "H4", memo_array)
+ if sh4_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh4_schedule_dict["federalShare"]
+ page_nonfed_subtotal += sh4_schedule_dict["nonfederalShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict
+ )
elif transactions_in_page == 3:
index = 1
sh4_schedule_dict = sh4_schedules[page_start_index + 0]
- process_memo_text(sh4_schedule_dict, 'H4', memo_array)
- if sh4_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh4_schedule_dict['federalShare']
- page_nonfed_subtotal += sh4_schedule_dict['nonfederalShare']
- build_sh_name_date_dict(index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict)
+ process_memo_text(sh4_schedule_dict, "H4", memo_array)
+ if sh4_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh4_schedule_dict["federalShare"]
+ page_nonfed_subtotal += sh4_schedule_dict["nonfederalShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict
+ )
index = 2
sh4_schedule_dict = sh4_schedules[page_start_index + 1]
- process_memo_text(sh4_schedule_dict, 'H4', memo_array)
- if sh4_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh4_schedule_dict['federalShare']
- page_nonfed_subtotal += sh4_schedule_dict['nonfederalShare']
- build_sh_name_date_dict(index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict)
+ process_memo_text(sh4_schedule_dict, "H4", memo_array)
+ if sh4_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh4_schedule_dict["federalShare"]
+ page_nonfed_subtotal += sh4_schedule_dict["nonfederalShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict
+ )
index = 3
sh4_schedule_dict = sh4_schedules[page_start_index + 2]
- process_memo_text(sh4_schedule_dict, 'H4', memo_array)
- if sh4_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh4_schedule_dict['federalShare']
- page_nonfed_subtotal += sh4_schedule_dict['nonfederalShare']
- build_sh_name_date_dict(index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict)
- sh4_schedule_page_dict['subFedShare'] = '{0:.2f}'.format(page_fed_subtotal)
- sh4_schedule_page_dict['subNonFedShare'] = '{0:.2f}'.format( page_nonfed_subtotal)
- sh4_schedule_page_dict['subTotalFedNonFedShare'] = float(sh4_schedule_page_dict['subFedShare'])+float(sh4_schedule_page_dict['subNonFedShare'])
+ process_memo_text(sh4_schedule_dict, "H4", memo_array)
+ if sh4_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh4_schedule_dict["federalShare"]
+ page_nonfed_subtotal += sh4_schedule_dict["nonfederalShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh4_schedule_dict, sh4_schedule_page_dict
+ )
+ sh4_schedule_page_dict["subFedShare"] = "{0:.2f}".format(page_fed_subtotal)
+ sh4_schedule_page_dict["subNonFedShare"] = "{0:.2f}".format(page_nonfed_subtotal)
+ sh4_schedule_page_dict["subTotalFedNonFedShare"] = float(
+ sh4_schedule_page_dict["subFedShare"]
+ ) + float(sh4_schedule_page_dict["subNonFedShare"])
return sh4_schedules
-def build_sh2_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sh2_schedule_page_dict,
- sh2_schedules):
+
+def build_sh2_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sh2_schedule_page_dict,
+ sh2_schedules,
+):
page_subtotal = 0.00
if not last_page:
transactions_in_page = 6
if transactions_in_page == 1:
index = 1
sh2_schedule_dict = sh2_schedules[page_start_index + 0]
-
+
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
sh2_schedule_dict = sh2_schedules[page_start_index + 0]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 2
sh2_schedule_dict = sh2_schedules[page_start_index + 1]
-
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
elif transactions_in_page == 3:
index = 1
sh2_schedule_dict = sh2_schedules[page_start_index + 0]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 2
sh2_schedule_dict = sh2_schedules[page_start_index + 1]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 3
sh2_schedule_dict = sh2_schedules[page_start_index + 2]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
elif transactions_in_page == 4:
index = 1
sh2_schedule_dict = sh2_schedules[page_start_index + 0]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 2
sh2_schedule_dict = sh2_schedules[page_start_index + 1]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 3
sh2_schedule_dict = sh2_schedules[page_start_index + 2]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 4
sh2_schedule_dict = sh2_schedules[page_start_index + 3]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
elif transactions_in_page == 5:
index = 1
sh2_schedule_dict = sh2_schedules[page_start_index + 0]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 2
sh2_schedule_dict = sh2_schedules[page_start_index + 1]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 3
sh2_schedule_dict = sh2_schedules[page_start_index + 2]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 4
sh2_schedule_dict = sh2_schedules[page_start_index + 3]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 5
sh2_schedule_dict = sh2_schedules[page_start_index + 4]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
elif transactions_in_page == 6:
index = 1
sh2_schedule_dict = sh2_schedules[page_start_index + 0]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 2
sh2_schedule_dict = sh2_schedules[page_start_index + 1]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 3
sh2_schedule_dict = sh2_schedules[page_start_index + 2]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 4
sh2_schedule_dict = sh2_schedules[page_start_index + 3]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 5
sh2_schedule_dict = sh2_schedules[page_start_index + 4]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
index = 6
sh2_schedule_dict = sh2_schedules[page_start_index + 5]
for key in sh2_schedules[page_start_index]:
- build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_dict)
+ build_sh2_name_date_dict(
+ index, key, sh2_schedule_dict, sh2_schedule_page_dict
+ )
return sh2_schedule_dict
-def build_sh5_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sh5_schedule_page_dict,
- sh5_schedules, memo_array):
+
+def build_sh5_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sh5_schedule_page_dict,
+ sh5_schedules,
+ memo_array,
+):
transferred_amt_subtotal = 0.00
voter_reg_amt_subtotal = 0.00
voter_id_amt_subtotal = 0.00
@@ -4008,49 +6538,65 @@ def build_sh5_per_page_schedule_dict(last_page, transactions_in_page, page_start
if transactions_in_page == 1:
index = 1
sh5_schedule_dict = sh5_schedules[page_start_index + 0]
- process_memo_text(sh5_schedule_dict, 'H5', memo_array)
- transferred_amt_subtotal += sh5_schedule_dict['totalAmountTransferred']
- voter_reg_amt_subtotal += sh5_schedule_dict['voterRegistrationAmount']
- voter_id_amt_subtotal += sh5_schedule_dict['voterIdAmount']
- gotv_amt_subtotal += sh5_schedule_dict['gotvAmount']
- generic_camp_amt_subtotal += sh5_schedule_dict['genericCampaignAmount']
- build_sh_name_date_dict(index, page_start_index, sh5_schedule_dict, sh5_schedule_page_dict)
+ process_memo_text(sh5_schedule_dict, "H5", memo_array)
+ transferred_amt_subtotal += sh5_schedule_dict["totalAmountTransferred"]
+ voter_reg_amt_subtotal += sh5_schedule_dict["voterRegistrationAmount"]
+ voter_id_amt_subtotal += sh5_schedule_dict["voterIdAmount"]
+ gotv_amt_subtotal += sh5_schedule_dict["gotvAmount"]
+ generic_camp_amt_subtotal += sh5_schedule_dict["genericCampaignAmount"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh5_schedule_dict, sh5_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
sh5_schedule_dict = sh5_schedules[page_start_index + 0]
- process_memo_text(sh5_schedule_dict, 'H5', memo_array)
- transferred_amt_subtotal += sh5_schedule_dict['totalAmountTransferred']
- voter_reg_amt_subtotal += sh5_schedule_dict['voterRegistrationAmount']
- voter_id_amt_subtotal += sh5_schedule_dict['voterIdAmount']
- gotv_amt_subtotal += sh5_schedule_dict['gotvAmount']
- generic_camp_amt_subtotal += sh5_schedule_dict['genericCampaignAmount']
- build_sh_name_date_dict(index, page_start_index, sh5_schedule_dict, sh5_schedule_page_dict)
+ process_memo_text(sh5_schedule_dict, "H5", memo_array)
+ transferred_amt_subtotal += sh5_schedule_dict["totalAmountTransferred"]
+ voter_reg_amt_subtotal += sh5_schedule_dict["voterRegistrationAmount"]
+ voter_id_amt_subtotal += sh5_schedule_dict["voterIdAmount"]
+ gotv_amt_subtotal += sh5_schedule_dict["gotvAmount"]
+ generic_camp_amt_subtotal += sh5_schedule_dict["genericCampaignAmount"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh5_schedule_dict, sh5_schedule_page_dict
+ )
index = 2
sh5_schedule_dict = sh5_schedules[page_start_index + 1]
- process_memo_text(sh5_schedule_dict, 'H5', memo_array)
- transferred_amt_subtotal += sh5_schedule_dict['totalAmountTransferred']
- voter_reg_amt_subtotal += sh5_schedule_dict['voterRegistrationAmount']
- voter_id_amt_subtotal += sh5_schedule_dict['voterIdAmount']
- gotv_amt_subtotal += sh5_schedule_dict['gotvAmount']
- generic_camp_amt_subtotal += sh5_schedule_dict['genericCampaignAmount']
- build_sh_name_date_dict(index, page_start_index, sh5_schedule_dict, sh5_schedule_page_dict)
-
- sh5_schedule_page_dict['subtotalAmountTransferred'] = '{0:.2f}'.format(transferred_amt_subtotal)
- sh5_schedule_page_dict['subvoterRegistrationAmount'] = '{0:.2f}'.format( voter_reg_amt_subtotal)
- sh5_schedule_page_dict['subvoterIdAmount'] = '{0:.2f}'.format(voter_id_amt_subtotal)
- sh5_schedule_page_dict['subgotvAmount'] = '{0:.2f}'.format( gotv_amt_subtotal)
- sh5_schedule_page_dict['subgenericCampaignAmount'] = '{0:.2f}'.format(generic_camp_amt_subtotal)
-
+ process_memo_text(sh5_schedule_dict, "H5", memo_array)
+ transferred_amt_subtotal += sh5_schedule_dict["totalAmountTransferred"]
+ voter_reg_amt_subtotal += sh5_schedule_dict["voterRegistrationAmount"]
+ voter_id_amt_subtotal += sh5_schedule_dict["voterIdAmount"]
+ gotv_amt_subtotal += sh5_schedule_dict["gotvAmount"]
+ generic_camp_amt_subtotal += sh5_schedule_dict["genericCampaignAmount"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh5_schedule_dict, sh5_schedule_page_dict
+ )
+ sh5_schedule_page_dict["subtotalAmountTransferred"] = "{0:.2f}".format(
+ transferred_amt_subtotal
+ )
+ sh5_schedule_page_dict["subvoterRegistrationAmount"] = "{0:.2f}".format(
+ voter_reg_amt_subtotal
+ )
+ sh5_schedule_page_dict["subvoterIdAmount"] = "{0:.2f}".format(voter_id_amt_subtotal)
+ sh5_schedule_page_dict["subgotvAmount"] = "{0:.2f}".format(gotv_amt_subtotal)
+ sh5_schedule_page_dict["subgenericCampaignAmount"] = "{0:.2f}".format(
+ generic_camp_amt_subtotal
+ )
# sh5_schedule_page_dict['subTotalFedNonFedShare'] = float(sh5_schedule_page_dict['subFedShare'])+float(sh5_schedule_page_dict['subNonFedShare'])
return sh5_schedules
-def build_sh6_line_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sh6_schedule_page_dict,
- sh6_schedules, memo_array):
+def build_sh6_line_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sh6_schedule_page_dict,
+ sh6_schedules,
+ memo_array,
+):
page_fed_subtotal = 0.00
page_levin_subtotal = 0.00
if not last_page:
@@ -4059,199 +6605,264 @@ def build_sh6_line_per_page_schedule_dict(last_page, transactions_in_page, page_
if transactions_in_page == 1:
index = 1
sh6_schedule_dict = sh6_schedules[page_start_index + 0]
- process_memo_text(sh6_schedule_dict, 'H6', memo_array)
- if sh6_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh6_schedule_dict['federalShare']
- page_levin_subtotal += sh6_schedule_dict['levinShare']
- build_sh_name_date_dict(index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict)
+ process_memo_text(sh6_schedule_dict, "H6", memo_array)
+ if sh6_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh6_schedule_dict["federalShare"]
+ page_levin_subtotal += sh6_schedule_dict["levinShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
sh6_schedule_dict = sh6_schedules[page_start_index + 0]
- process_memo_text(sh6_schedule_dict, 'H6', memo_array)
- if sh6_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh6_schedule_dict['federalShare']
- page_levin_subtotal += sh6_schedule_dict['levinShare']
- build_sh_name_date_dict(index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict)
+ process_memo_text(sh6_schedule_dict, "H6", memo_array)
+ if sh6_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh6_schedule_dict["federalShare"]
+ page_levin_subtotal += sh6_schedule_dict["levinShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict
+ )
index = 2
sh6_schedule_dict = sh6_schedules[page_start_index + 1]
- process_memo_text(sh6_schedule_dict, 'H6', memo_array)
- if sh6_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh6_schedule_dict['federalShare']
- page_levin_subtotal += sh6_schedule_dict['levinShare']
- build_sh_name_date_dict(index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict)
+ process_memo_text(sh6_schedule_dict, "H6", memo_array)
+ if sh6_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh6_schedule_dict["federalShare"]
+ page_levin_subtotal += sh6_schedule_dict["levinShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict
+ )
elif transactions_in_page == 3:
index = 1
sh6_schedule_dict = sh6_schedules[page_start_index + 0]
- process_memo_text(sh6_schedule_dict, 'H6', memo_array)
- if sh6_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh6_schedule_dict['federalShare']
- page_levin_subtotal += sh6_schedule_dict['levinShare']
- build_sh_name_date_dict(index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict)
+ process_memo_text(sh6_schedule_dict, "H6", memo_array)
+ if sh6_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh6_schedule_dict["federalShare"]
+ page_levin_subtotal += sh6_schedule_dict["levinShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict
+ )
index = 2
sh6_schedule_dict = sh6_schedules[page_start_index + 1]
- process_memo_text(sh6_schedule_dict, 'H6', memo_array)
- if sh6_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh6_schedule_dict['federalShare']
- page_levin_subtotal += sh6_schedule_dict['levinShare']
- build_sh_name_date_dict(index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict)
+ process_memo_text(sh6_schedule_dict, "H6", memo_array)
+ if sh6_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh6_schedule_dict["federalShare"]
+ page_levin_subtotal += sh6_schedule_dict["levinShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict
+ )
index = 3
sh6_schedule_dict = sh6_schedules[page_start_index + 2]
- process_memo_text(sh6_schedule_dict, 'H6', memo_array)
- if sh6_schedule_dict['memoCode'] != 'X':
- page_fed_subtotal += sh6_schedule_dict['federalShare']
- page_levin_subtotal += sh6_schedule_dict['levinShare']
- build_sh_name_date_dict(index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict)
- sh6_schedule_page_dict['subTotalFederalShare'] = '{0:.2f}'.format(page_fed_subtotal)
- sh6_schedule_page_dict['subTotalLevinShare'] = '{0:.2f}'.format(page_levin_subtotal)
- sh6_schedule_page_dict['fedLevinSubTotalShare'] = float(sh6_schedule_page_dict['subTotalFederalShare'])+float(sh6_schedule_page_dict['subTotalLevinShare'])
+ process_memo_text(sh6_schedule_dict, "H6", memo_array)
+ if sh6_schedule_dict["memoCode"] != "X":
+ page_fed_subtotal += sh6_schedule_dict["federalShare"]
+ page_levin_subtotal += sh6_schedule_dict["levinShare"]
+ build_sh_name_date_dict(
+ index, page_start_index, sh6_schedule_dict, sh6_schedule_page_dict
+ )
+ sh6_schedule_page_dict["subTotalFederalShare"] = "{0:.2f}".format(page_fed_subtotal)
+ sh6_schedule_page_dict["subTotalLevinShare"] = "{0:.2f}".format(page_levin_subtotal)
+ sh6_schedule_page_dict["fedLevinSubTotalShare"] = float(
+ sh6_schedule_page_dict["subTotalFederalShare"]
+ ) + float(sh6_schedule_page_dict["subTotalLevinShare"])
return sh6_schedule_dict
+
# This method builds data for individual SB page
-def build_sb_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sb_schedule_page_dict,
- sb_schedules, memo_array):
+def build_sb_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sb_schedule_page_dict,
+ sb_schedules,
+ memo_array,
+):
page_subtotal = 0.00
if not last_page:
transactions_in_page = 3
if transactions_in_page == 1:
index = 1
sb_schedule_dict = sb_schedules[page_start_index + 0]
- process_memo_text(sb_schedule_dict, 'SB', memo_array)
- if sb_schedule_dict['memoCode'] != 'X':
- page_subtotal += sb_schedule_dict['expenditureAmount']
+ process_memo_text(sb_schedule_dict, "SB", memo_array)
+ if sb_schedule_dict["memoCode"] != "X":
+ page_subtotal += sb_schedule_dict["expenditureAmount"]
for key in sb_schedules[page_start_index]:
- build_payee_name_date_dict(index, key, sb_schedule_dict, sb_schedule_page_dict)
+ build_payee_name_date_dict(
+ index, key, sb_schedule_dict, sb_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
sb_schedule_dict = sb_schedules[page_start_index + 0]
- process_memo_text(sb_schedule_dict, 'SB', memo_array)
- if sb_schedule_dict['memoCode'] != 'X':
- page_subtotal += sb_schedule_dict['expenditureAmount']
+ process_memo_text(sb_schedule_dict, "SB", memo_array)
+ if sb_schedule_dict["memoCode"] != "X":
+ page_subtotal += sb_schedule_dict["expenditureAmount"]
for key in sb_schedules[page_start_index]:
- build_payee_name_date_dict(index, key, sb_schedule_dict, sb_schedule_page_dict)
+ build_payee_name_date_dict(
+ index, key, sb_schedule_dict, sb_schedule_page_dict
+ )
index = 2
sb_schedule_dict = sb_schedules[page_start_index + 1]
- process_memo_text(sb_schedule_dict, 'SB', memo_array)
- if sb_schedule_dict['memoCode'] != 'X':
- page_subtotal += sb_schedule_dict['expenditureAmount']
+ process_memo_text(sb_schedule_dict, "SB", memo_array)
+ if sb_schedule_dict["memoCode"] != "X":
+ page_subtotal += sb_schedule_dict["expenditureAmount"]
for key in sb_schedules[page_start_index]:
- build_payee_name_date_dict(index, key, sb_schedule_dict, sb_schedule_page_dict)
+ build_payee_name_date_dict(
+ index, key, sb_schedule_dict, sb_schedule_page_dict
+ )
elif transactions_in_page == 3:
index = 1
sb_schedule_dict = sb_schedules[page_start_index + 0]
- process_memo_text(sb_schedule_dict, 'SB', memo_array)
- if sb_schedule_dict['memoCode'] != 'X':
- page_subtotal += sb_schedule_dict['expenditureAmount']
+ process_memo_text(sb_schedule_dict, "SB", memo_array)
+ if sb_schedule_dict["memoCode"] != "X":
+ page_subtotal += sb_schedule_dict["expenditureAmount"]
for key in sb_schedules[page_start_index]:
- build_payee_name_date_dict(index, key, sb_schedule_dict, sb_schedule_page_dict)
+ build_payee_name_date_dict(
+ index, key, sb_schedule_dict, sb_schedule_page_dict
+ )
index = 2
sb_schedule_dict = sb_schedules[page_start_index + 1]
- process_memo_text(sb_schedule_dict, 'SB', memo_array)
- if sb_schedule_dict['memoCode'] != 'X':
- page_subtotal += sb_schedule_dict['expenditureAmount']
+ process_memo_text(sb_schedule_dict, "SB", memo_array)
+ if sb_schedule_dict["memoCode"] != "X":
+ page_subtotal += sb_schedule_dict["expenditureAmount"]
for key in sb_schedules[page_start_index]:
- build_payee_name_date_dict(index, key, sb_schedule_dict, sb_schedule_page_dict)
+ build_payee_name_date_dict(
+ index, key, sb_schedule_dict, sb_schedule_page_dict
+ )
index = 3
sb_schedule_dict = sb_schedules[page_start_index + 2]
- process_memo_text(sb_schedule_dict, 'SB', memo_array)
- if sb_schedule_dict['memoCode'] != 'X':
- page_subtotal += sb_schedule_dict['expenditureAmount']
+ process_memo_text(sb_schedule_dict, "SB", memo_array)
+ if sb_schedule_dict["memoCode"] != "X":
+ page_subtotal += sb_schedule_dict["expenditureAmount"]
for key in sb_schedules[page_start_index]:
- build_payee_name_date_dict(index, key, sb_schedule_dict, sb_schedule_page_dict)
- sb_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
+ build_payee_name_date_dict(
+ index, key, sb_schedule_dict, sb_schedule_page_dict
+ )
+ sb_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
return sb_schedule_dict
-def build_se_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, se_schedule_page_dict,
- se_schedules, memo_array):
+
+def build_se_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ se_schedule_page_dict,
+ se_schedules,
+ memo_array,
+):
page_subtotal = 0.00
if not last_page:
transactions_in_page = 2
if transactions_in_page == 1:
index = 1
se_schedule_dict = se_schedules[page_start_index + 0]
- process_memo_text(se_schedule_dict, 'SE', memo_array)
- if se_schedule_dict['memoCode'] != 'X':
- page_subtotal += se_schedule_dict['expenditureAmount']
+ process_memo_text(se_schedule_dict, "SE", memo_array)
+ if se_schedule_dict["memoCode"] != "X":
+ page_subtotal += se_schedule_dict["expenditureAmount"]
for key in se_schedules[page_start_index]:
build_se_name_date_dict(index, key, se_schedule_dict, se_schedule_page_dict)
elif transactions_in_page == 2:
index = 1
se_schedule_dict = se_schedules[page_start_index + 0]
- process_memo_text(se_schedule_dict, 'SE', memo_array)
- if se_schedule_dict['memoCode'] != 'X':
- page_subtotal += se_schedule_dict['expenditureAmount']
+ process_memo_text(se_schedule_dict, "SE", memo_array)
+ if se_schedule_dict["memoCode"] != "X":
+ page_subtotal += se_schedule_dict["expenditureAmount"]
for key in se_schedules[page_start_index]:
build_se_name_date_dict(index, key, se_schedule_dict, se_schedule_page_dict)
index = 2
se_schedule_dict = se_schedules[page_start_index + 1]
- process_memo_text(se_schedule_dict, 'SE', memo_array)
- if se_schedule_dict['memoCode'] != 'X':
- page_subtotal += se_schedule_dict['expenditureAmount']
+ process_memo_text(se_schedule_dict, "SE", memo_array)
+ if se_schedule_dict["memoCode"] != "X":
+ page_subtotal += se_schedule_dict["expenditureAmount"]
for key in se_schedules[page_start_index]:
build_se_name_date_dict(index, key, se_schedule_dict, se_schedule_page_dict)
- se_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
+ se_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
return se_schedule_dict
-def build_sf_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, sf_schedule_page_dict,
- sf_schedules, memo_array):
+
+def build_sf_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ sf_schedule_page_dict,
+ sf_schedules,
+ memo_array,
+):
page_subtotal = 0.00
if not last_page:
transactions_in_page = 3
if transactions_in_page == 1:
index = 1
sf_schedule_dict = sf_schedules[page_start_index + 0]
- process_memo_text(sf_schedule_dict, 'SF', memo_array)
- if sf_schedule_dict['memoCode'] != 'X':
- page_subtotal += sf_schedule_dict['expenditureAmount']
+ process_memo_text(sf_schedule_dict, "SF", memo_array)
+ if sf_schedule_dict["memoCode"] != "X":
+ page_subtotal += sf_schedule_dict["expenditureAmount"]
for key in sf_schedules[page_start_index]:
- build_payee_sf_name_date_dict(index, key, sf_schedule_dict, sf_schedule_page_dict)
+ build_payee_sf_name_date_dict(
+ index, key, sf_schedule_dict, sf_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
sf_schedule_dict = sf_schedules[page_start_index + 0]
- process_memo_text(sf_schedule_dict, 'SF', memo_array)
- if sf_schedule_dict['memoCode'] != 'X':
- page_subtotal += sf_schedule_dict['expenditureAmount']
+ process_memo_text(sf_schedule_dict, "SF", memo_array)
+ if sf_schedule_dict["memoCode"] != "X":
+ page_subtotal += sf_schedule_dict["expenditureAmount"]
for key in sf_schedules[page_start_index]:
- build_payee_sf_name_date_dict(index, key, sf_schedule_dict, sf_schedule_page_dict)
+ build_payee_sf_name_date_dict(
+ index, key, sf_schedule_dict, sf_schedule_page_dict
+ )
index = 2
sf_schedule_dict = sf_schedules[page_start_index + 1]
- process_memo_text(sf_schedule_dict, 'SF', memo_array)
- if sf_schedule_dict['memoCode'] != 'X':
- page_subtotal += sf_schedule_dict['expenditureAmount']
+ process_memo_text(sf_schedule_dict, "SF", memo_array)
+ if sf_schedule_dict["memoCode"] != "X":
+ page_subtotal += sf_schedule_dict["expenditureAmount"]
for key in sf_schedules[page_start_index]:
- build_payee_sf_name_date_dict(index, key, sf_schedule_dict, sf_schedule_page_dict)
+ build_payee_sf_name_date_dict(
+ index, key, sf_schedule_dict, sf_schedule_page_dict
+ )
elif transactions_in_page == 3:
index = 1
sf_schedule_dict = sf_schedules[page_start_index + 0]
- process_memo_text(sf_schedule_dict, 'SF', memo_array)
- if sf_schedule_dict['memoCode'] != 'X':
- page_subtotal += sf_schedule_dict['expenditureAmount']
+ process_memo_text(sf_schedule_dict, "SF", memo_array)
+ if sf_schedule_dict["memoCode"] != "X":
+ page_subtotal += sf_schedule_dict["expenditureAmount"]
for key in sf_schedules[page_start_index]:
- build_payee_sf_name_date_dict(index, key, sf_schedule_dict, sf_schedule_page_dict)
+ build_payee_sf_name_date_dict(
+ index, key, sf_schedule_dict, sf_schedule_page_dict
+ )
index = 2
sf_schedule_dict = sf_schedules[page_start_index + 1]
- process_memo_text(sf_schedule_dict, 'SF', memo_array)
- if sf_schedule_dict['memoCode'] != 'X':
- page_subtotal += sf_schedule_dict['expenditureAmount']
+ process_memo_text(sf_schedule_dict, "SF", memo_array)
+ if sf_schedule_dict["memoCode"] != "X":
+ page_subtotal += sf_schedule_dict["expenditureAmount"]
for key in sf_schedules[page_start_index]:
- build_payee_sf_name_date_dict(index, key, sf_schedule_dict, sf_schedule_page_dict)
+ build_payee_sf_name_date_dict(
+ index, key, sf_schedule_dict, sf_schedule_page_dict
+ )
index = 3
sf_schedule_dict = sf_schedules[page_start_index + 2]
- process_memo_text(sf_schedule_dict, 'SF', memo_array)
- if sf_schedule_dict['memoCode'] != 'X':
- page_subtotal += sf_schedule_dict['expenditureAmount']
+ process_memo_text(sf_schedule_dict, "SF", memo_array)
+ if sf_schedule_dict["memoCode"] != "X":
+ page_subtotal += sf_schedule_dict["expenditureAmount"]
for key in sf_schedules[page_start_index]:
- build_payee_sf_name_date_dict(index, key, sf_schedule_dict, sf_schedule_page_dict)
- sf_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
+ build_payee_sf_name_date_dict(
+ index, key, sf_schedule_dict, sf_schedule_page_dict
+ )
+ sf_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
return sf_schedule_dict
-def build_la_per_page_schedule_dict(last_page, tranlactions_in_page, page_start_index, la_schedule_page_dict,
- la_schedules, memo_array):
+def build_la_per_page_schedule_dict(
+ last_page,
+ tranlactions_in_page,
+ page_start_index,
+ la_schedule_page_dict,
+ la_schedules,
+ memo_array,
+):
page_subtotal = 0.00
-
+
try:
if not last_page:
tranlactions_in_page = 4
@@ -4259,86 +6870,113 @@ def build_la_per_page_schedule_dict(last_page, tranlactions_in_page, page_start_
if tranlactions_in_page == 1:
index = 1
la_schedule_dict = la_schedules[page_start_index + 0]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
elif tranlactions_in_page == 2:
index = 1
la_schedule_dict = la_schedules[page_start_index + 0]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
index = 2
la_schedule_dict = la_schedules[page_start_index + 1]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
elif tranlactions_in_page == 3:
try:
index = 1
la_schedule_dict = la_schedules[page_start_index + 0]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
index = 2
la_schedule_dict = la_schedules[page_start_index + 1]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
index = 3
la_schedule_dict = la_schedules[page_start_index + 2]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
except Exception as e:
print(e)
-
+
elif tranlactions_in_page == 4:
index = 1
la_schedule_dict = la_schedules[page_start_index + 0]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
index = 2
la_schedule_dict = la_schedules[page_start_index + 1]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
index = 3
la_schedule_dict = la_schedules[page_start_index + 2]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
index = 4
la_schedule_dict = la_schedules[page_start_index + 3]
- process_memo_text(la_schedule_dict, 'SL', memo_array)
- if la_schedule_dict['memoCode'] != 'X':
- page_subtotal += la_schedule_dict['contributionAmount']
- build_contributor_la_name_date_dict(index, page_start_index, la_schedule_dict, la_schedule_page_dict)
-
+ process_memo_text(la_schedule_dict, "SL", memo_array)
+ if la_schedule_dict["memoCode"] != "X":
+ page_subtotal += la_schedule_dict["contributionAmount"]
+ build_contributor_la_name_date_dict(
+ index, page_start_index, la_schedule_dict, la_schedule_page_dict
+ )
+
except Exception as e:
- print('Error : ' + e + ' in Schedule SL_A process_la_line' )
+ print("Error : " + e + " in Schedule SL_A process_la_line")
raise e
-
- la_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
+
+ la_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
return la_schedule_dict
-def build_slb_per_page_schedule_dict(last_page, transactions_in_page, page_start_index, slb_schedule_page_dict,
- slb_schedules, memo_array):
+
+def build_slb_per_page_schedule_dict(
+ last_page,
+ transactions_in_page,
+ page_start_index,
+ slb_schedule_page_dict,
+ slb_schedules,
+ memo_array,
+):
page_subtotal = 0.00
if not last_page:
@@ -4346,120 +6984,155 @@ def build_slb_per_page_schedule_dict(last_page, transactions_in_page, page_start
if transactions_in_page == 1:
index = 1
slb_schedule_dict = slb_schedules[page_start_index + 0]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
elif transactions_in_page == 2:
index = 1
slb_schedule_dict = slb_schedules[page_start_index + 0]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 2
slb_schedule_dict = slb_schedules[page_start_index + 1]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
elif transactions_in_page == 3:
index = 1
slb_schedule_dict = slb_schedules[page_start_index + 0]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 2
slb_schedule_dict = slb_schedules[page_start_index + 1]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 3
slb_schedule_dict = slb_schedules[page_start_index + 2]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
elif transactions_in_page == 4:
index = 1
slb_schedule_dict = slb_schedules[page_start_index + 0]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 2
slb_schedule_dict = slb_schedules[page_start_index + 1]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 3
slb_schedule_dict = slb_schedules[page_start_index + 2]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 4
slb_schedule_dict = slb_schedules[page_start_index + 3]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
elif transactions_in_page == 5:
index = 1
slb_schedule_dict = slb_schedules[page_start_index + 0]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 2
slb_schedule_dict = slb_schedules[page_start_index + 1]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 3
slb_schedule_dict = slb_schedules[page_start_index + 2]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 4
slb_schedule_dict = slb_schedules[page_start_index + 3]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
index = 5
slb_schedule_dict = slb_schedules[page_start_index + 4]
- process_memo_text(slb_schedule_dict, 'SL', memo_array)
- if slb_schedule_dict['memoCode'] != 'X':
- page_subtotal += slb_schedule_dict['expenditureAmount']
+ process_memo_text(slb_schedule_dict, "SL", memo_array)
+ if slb_schedule_dict["memoCode"] != "X":
+ page_subtotal += slb_schedule_dict["expenditureAmount"]
for key in slb_schedules[page_start_index]:
- build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_dict)
- slb_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
+ build_slb_name_date_dict(
+ index, key, slb_schedule_dict, slb_schedule_page_dict
+ )
+ slb_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
return slb_schedule_dict
-def build_sl_levin_per_page_schedule_dict(last_page, tranlactions_in_page, page_start_index, sl_levin_schedule_page_dict,
- sl_levin_schedules):
+def build_sl_levin_per_page_schedule_dict(
+ last_page,
+ tranlactions_in_page,
+ page_start_index,
+ sl_levin_schedule_page_dict,
+ sl_levin_schedules,
+):
page_subtotal = 0.00
try:
if not last_page:
@@ -4470,70 +7143,94 @@ def build_sl_levin_per_page_schedule_dict(last_page, tranlactions_in_page, page_
index = 1
sl_levin_schedule_dict = sl_levin_schedules[0]
- build_contributor_sl_levin_name_date_dict(index, page_start_index, sl_levin_schedule_dict, sl_levin_schedule_page_dict)
-
-
+ build_contributor_sl_levin_name_date_dict(
+ index,
+ page_start_index,
+ sl_levin_schedule_dict,
+ sl_levin_schedule_page_dict,
+ )
+
except Exception as e:
- print('Error : ' + e + ' in Schedule SL process_sl_levin_line' )
+ print("Error : " + e + " in Schedule SL process_sl_levin_line")
raise e
-
- sl_levin_schedule_page_dict['pageSubtotal'] = '{0:.2f}'.format(page_subtotal)
+
+ sl_levin_schedule_page_dict["pageSubtotal"] = "{0:.2f}".format(page_subtotal)
return sl_levin_schedule_dict
# This method filters data and message data to render PDF
-def build_contributor_name_date_dict(index, key, sa_schedule_dict, sa_schedule_page_dict):
+def build_contributor_name_date_dict(
+ index, key, sa_schedule_dict, sa_schedule_page_dict
+):
try:
- if 'contributorLastName' in sa_schedule_dict and sa_schedule_dict['contributorLastName']:
- sa_schedule_page_dict['contributorName_' + str(index)] = (sa_schedule_dict['contributorLastName'] + ','
- + sa_schedule_dict['contributorFirstName'] + ','
- + sa_schedule_dict['contributorMiddleName'] + ','
- + sa_schedule_dict['contributorPrefix'] + ','
- + sa_schedule_dict['contributorSuffix'])
- del sa_schedule_dict['contributorLastName']
- del sa_schedule_dict['contributorFirstName']
- del sa_schedule_dict['contributorMiddleName']
- del sa_schedule_dict['contributorPrefix']
- del sa_schedule_dict['contributorSuffix']
- elif 'contributorOrgName' in sa_schedule_dict:
- sa_schedule_page_dict["contributorName_" + str(index)] = sa_schedule_dict['contributorOrgName']
- del sa_schedule_dict['contributorOrgName']
-
- if 'electionCode' in sa_schedule_dict and sa_schedule_dict['electionCode']:
- key = 'electionCode'
- if sa_schedule_dict[key][0] in ['P', 'G']:
- sa_schedule_dict['electionType'] = sa_schedule_dict[key][0:1]
+ if (
+ "contributorLastName" in sa_schedule_dict
+ and sa_schedule_dict["contributorLastName"]
+ ):
+ sa_schedule_page_dict["contributorName_" + str(index)] = (
+ sa_schedule_dict["contributorLastName"]
+ + ","
+ + sa_schedule_dict["contributorFirstName"]
+ + ","
+ + sa_schedule_dict["contributorMiddleName"]
+ + ","
+ + sa_schedule_dict["contributorPrefix"]
+ + ","
+ + sa_schedule_dict["contributorSuffix"]
+ )
+ del sa_schedule_dict["contributorLastName"]
+ del sa_schedule_dict["contributorFirstName"]
+ del sa_schedule_dict["contributorMiddleName"]
+ del sa_schedule_dict["contributorPrefix"]
+ del sa_schedule_dict["contributorSuffix"]
+ elif "contributorOrgName" in sa_schedule_dict:
+ sa_schedule_page_dict["contributorName_" + str(index)] = sa_schedule_dict[
+ "contributorOrgName"
+ ]
+ del sa_schedule_dict["contributorOrgName"]
+
+ if "electionCode" in sa_schedule_dict and sa_schedule_dict["electionCode"]:
+ key = "electionCode"
+ if sa_schedule_dict[key][0] in ["P", "G"]:
+ sa_schedule_dict["electionType"] = sa_schedule_dict[key][0:1]
else:
- sa_schedule_dict['electionType'] = 'O'
- sa_schedule_dict['electionYear'] = sa_schedule_dict[key][1::]
-
- if 'contributionDate' in sa_schedule_dict:
- date_array = sa_schedule_dict['contributionDate'].split("/")
- sa_schedule_page_dict['contributionDateMonth_' + str(index)] = date_array[0]
- sa_schedule_page_dict['contributionDateDay_' + str(index)] = date_array[1]
- sa_schedule_page_dict['contributionDateYear_' + str(index)] = date_array[2]
- del sa_schedule_dict['contributionDate']
-
- if 'contributionAmount' in sa_schedule_dict:
- if sa_schedule_dict['contributionAmount'] == '':
- sa_schedule_dict['contributionAmount'] = 0.0
- sa_schedule_page_dict['contributionAmount_' + str(index)] = '{0:.2f}'.format(
- sa_schedule_dict['contributionAmount'])
- del sa_schedule_dict['contributionAmount']
-
- if 'contributionAggregate' in sa_schedule_dict:
- if sa_schedule_dict['contributionAggregate'] == '':
- sa_schedule_dict['contributionAggregate'] = 0.0
- sa_schedule_page_dict['contributionAggregate_' + str(index)] = '{0:.2f}'.format(
- sa_schedule_dict['contributionAggregate'])
- del sa_schedule_dict['contributionAggregate']
+ sa_schedule_dict["electionType"] = "O"
+ sa_schedule_dict["electionYear"] = sa_schedule_dict[key][1::]
+
+ if "contributionDate" in sa_schedule_dict:
+ date_array = sa_schedule_dict["contributionDate"].split("/")
+ sa_schedule_page_dict["contributionDateMonth_" + str(index)] = date_array[0]
+ sa_schedule_page_dict["contributionDateDay_" + str(index)] = date_array[1]
+ sa_schedule_page_dict["contributionDateYear_" + str(index)] = date_array[2]
+ del sa_schedule_dict["contributionDate"]
+
+ if "contributionAmount" in sa_schedule_dict:
+ if sa_schedule_dict["contributionAmount"] == "":
+ sa_schedule_dict["contributionAmount"] = 0.0
+ sa_schedule_page_dict[
+ "contributionAmount_" + str(index)
+ ] = "{0:.2f}".format(sa_schedule_dict["contributionAmount"])
+ del sa_schedule_dict["contributionAmount"]
+
+ if "contributionAggregate" in sa_schedule_dict:
+ if sa_schedule_dict["contributionAggregate"] == "":
+ sa_schedule_dict["contributionAggregate"] = 0.0
+ sa_schedule_page_dict[
+ "contributionAggregate_" + str(index)
+ ] = "{0:.2f}".format(sa_schedule_dict["contributionAggregate"])
+ del sa_schedule_dict["contributionAggregate"]
for key in sa_schedule_dict:
- if key != 'lineNumber':
- sa_schedule_page_dict[key + '_' + str(index)] = sa_schedule_dict[key]
+ if key != "lineNumber":
+ sa_schedule_page_dict[key + "_" + str(index)] = sa_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule A transaction: ' + str(sa_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule A transaction: "
+ + str(sa_schedule_dict)
+ )
raise e
@@ -4542,9 +7239,16 @@ def build_memo_dict(index, key, sa_memo_schedule_dict, sa_memo_schedule_page_dic
try:
for key in sa_memo_schedule_dict:
# if key != 'lineNumber':
- sa_memo_schedule_page_dict[key + '_' + str(index)] = sa_memo_schedule_dict[key]
+ sa_memo_schedule_page_dict[key + "_" + str(index)] = sa_memo_schedule_dict[
+ key
+ ]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule A memo transaction: ' + str(sa_memo_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule A memo transaction: "
+ + str(sa_memo_schedule_dict)
+ )
raise e
@@ -4553,201 +7257,332 @@ def build_payee_name_date_dict(index, key, sb_schedule_dict, sb_schedule_page_di
if not sb_schedule_dict.get(key):
sb_schedule_dict[key] = ""
- if 'payeeLastName' in sb_schedule_dict and sb_schedule_dict['payeeLastName']:
- sb_schedule_page_dict['payeeName_' + str(index)] = (sb_schedule_dict['payeeLastName'] + ','
- + sb_schedule_dict['payeeFirstName'] + ','
- + sb_schedule_dict['payeeMiddleName'] + ','
- + sb_schedule_dict['payeePrefix'] + ','
- + sb_schedule_dict['payeeSuffix'])
- elif 'payeeOrganizationName' in sb_schedule_dict:
- sb_schedule_page_dict["payeeName_" + str(index)] = sb_schedule_dict['payeeOrganizationName']
-
- if 'beneficiaryCandidateLastName' in sb_schedule_dict and sb_schedule_dict['beneficiaryCandidateLastName']:
- sb_schedule_page_dict['beneficiaryName_' + str(index)] = (sb_schedule_dict['beneficiaryCandidateLastName'] + ','
- + sb_schedule_dict['beneficiaryCandidateFirstName'] + ','
- + sb_schedule_dict['beneficiaryCandidateMiddleName'] + ','
- + sb_schedule_dict['beneficiaryCandidatePrefix'] + ','
- + sb_schedule_dict['beneficiaryCandidateSuffix'])
- if key == 'electionCode':
- if sb_schedule_dict[key] and sb_schedule_dict[key][0] in ['P','G']:
- sb_schedule_page_dict['electionType_' + str(index)] = sb_schedule_dict[key][0:1]
+ if "payeeLastName" in sb_schedule_dict and sb_schedule_dict["payeeLastName"]:
+ sb_schedule_page_dict["payeeName_" + str(index)] = (
+ sb_schedule_dict["payeeLastName"]
+ + ","
+ + sb_schedule_dict["payeeFirstName"]
+ + ","
+ + sb_schedule_dict["payeeMiddleName"]
+ + ","
+ + sb_schedule_dict["payeePrefix"]
+ + ","
+ + sb_schedule_dict["payeeSuffix"]
+ )
+ elif "payeeOrganizationName" in sb_schedule_dict:
+ sb_schedule_page_dict["payeeName_" + str(index)] = sb_schedule_dict[
+ "payeeOrganizationName"
+ ]
+
+ if (
+ "beneficiaryCandidateLastName" in sb_schedule_dict
+ and sb_schedule_dict["beneficiaryCandidateLastName"]
+ ):
+ sb_schedule_page_dict["beneficiaryName_" + str(index)] = (
+ sb_schedule_dict["beneficiaryCandidateLastName"]
+ + ","
+ + sb_schedule_dict["beneficiaryCandidateFirstName"]
+ + ","
+ + sb_schedule_dict["beneficiaryCandidateMiddleName"]
+ + ","
+ + sb_schedule_dict["beneficiaryCandidatePrefix"]
+ + ","
+ + sb_schedule_dict["beneficiaryCandidateSuffix"]
+ )
+ if key == "electionCode":
+ if sb_schedule_dict[key] and sb_schedule_dict[key][0] in ["P", "G"]:
+ sb_schedule_page_dict["electionType_" + str(index)] = sb_schedule_dict[
+ key
+ ][0:1]
else:
- sb_schedule_page_dict['electionType_' + str(index)] = 'O'
- sb_schedule_page_dict['electionYear_' + str(index)] = sb_schedule_dict[key][1::]
+ sb_schedule_page_dict["electionType_" + str(index)] = "O"
+ sb_schedule_page_dict["electionYear_" + str(index)] = sb_schedule_dict[key][
+ 1::
+ ]
- if key == 'expenditureDate':
+ if key == "expenditureDate":
date_array = sb_schedule_dict[key].split("/")
- sb_schedule_page_dict['expenditureDateMonth_' + str(index)] = date_array[0]
- sb_schedule_page_dict['expenditureDateDay_' + str(index)] = date_array[1]
- sb_schedule_page_dict['expenditureDateYear_' + str(index)] = date_array[2]
+ sb_schedule_page_dict["expenditureDateMonth_" + str(index)] = date_array[0]
+ sb_schedule_page_dict["expenditureDateDay_" + str(index)] = date_array[1]
+ sb_schedule_page_dict["expenditureDateYear_" + str(index)] = date_array[2]
else:
- if key == 'expenditureAmount' or key == 'expenditureAggregate':
- sb_schedule_page_dict[key + '_' + str(index)] = '{0:.2f}'.format(sb_schedule_dict[key])
+ if key == "expenditureAmount" or key == "expenditureAggregate":
+ sb_schedule_page_dict[key + "_" + str(index)] = "{0:.2f}".format(
+ sb_schedule_dict[key]
+ )
else:
- sb_schedule_page_dict[key + '_' + str(index)] = sb_schedule_dict[key]
+ sb_schedule_page_dict[key + "_" + str(index)] = sb_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule B transaction: ' + str(sb_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule B transaction: "
+ + str(sb_schedule_dict)
+ )
raise e
+
def build_se_name_date_dict(index, key, se_schedule_dict, se_schedule_page_dict):
try:
if not se_schedule_dict.get(key):
se_schedule_dict[key] = ""
- if 'payeeLastName' in se_schedule_dict and se_schedule_dict['payeeLastName']:
- se_schedule_page_dict['payeeName_' + str(index)] = (se_schedule_dict['payeeLastName'] + ','
- + se_schedule_dict['payeeFirstName'] + ','
- + se_schedule_dict['payeeMiddleName'] + ','
- + se_schedule_dict['payeePrefix'] + ','
- + se_schedule_dict['payeeSuffix'])
- elif 'payeeOrganizationName' in se_schedule_dict:
- se_schedule_page_dict["payeeName_" + str(index)] = se_schedule_dict['payeeOrganizationName']
-
- if 'candidateLastName' in se_schedule_dict:
- se_schedule_page_dict['candidateName_' + str(index)] = (se_schedule_dict['candidateLastName'] + ','
- + se_schedule_dict['candidateFirstName'] + ','
- + se_schedule_dict['candidateMiddleName'] + ','
- + se_schedule_dict['candidatePrefix'] + ','
- + se_schedule_dict['candidateSuffix'])
- if 'completingLastName' in se_schedule_dict:
- se_schedule_page_dict['completingName_' + str(index)] = (se_schedule_dict['completingLastName'] + ','
- + se_schedule_dict['completingFirstName'] + ','
- + se_schedule_dict['completingMiddleName'] + ','
- + se_schedule_dict['completingPrefix'] + ','
- + se_schedule_dict['completingSuffix'])
-
- if (key == 'disbursementDate' and len(se_schedule_dict[key])) > 0:
+ if "payeeLastName" in se_schedule_dict and se_schedule_dict["payeeLastName"]:
+ se_schedule_page_dict["payeeName_" + str(index)] = (
+ se_schedule_dict["payeeLastName"]
+ + ","
+ + se_schedule_dict["payeeFirstName"]
+ + ","
+ + se_schedule_dict["payeeMiddleName"]
+ + ","
+ + se_schedule_dict["payeePrefix"]
+ + ","
+ + se_schedule_dict["payeeSuffix"]
+ )
+ elif "payeeOrganizationName" in se_schedule_dict:
+ se_schedule_page_dict["payeeName_" + str(index)] = se_schedule_dict[
+ "payeeOrganizationName"
+ ]
+
+ if "candidateLastName" in se_schedule_dict:
+ se_schedule_page_dict["candidateName_" + str(index)] = (
+ se_schedule_dict["candidateLastName"]
+ + ","
+ + se_schedule_dict["candidateFirstName"]
+ + ","
+ + se_schedule_dict["candidateMiddleName"]
+ + ","
+ + se_schedule_dict["candidatePrefix"]
+ + ","
+ + se_schedule_dict["candidateSuffix"]
+ )
+ if "completingLastName" in se_schedule_dict:
+ se_schedule_page_dict["completingName_" + str(index)] = (
+ se_schedule_dict["completingLastName"]
+ + ","
+ + se_schedule_dict["completingFirstName"]
+ + ","
+ + se_schedule_dict["completingMiddleName"]
+ + ","
+ + se_schedule_dict["completingPrefix"]
+ + ","
+ + se_schedule_dict["completingSuffix"]
+ )
+
+ if (key == "disbursementDate" and len(se_schedule_dict[key])) > 0:
date_array = se_schedule_dict[key].split("/")
- se_schedule_page_dict['disbursementDateMonth_' + str(index)] = date_array[0]
- se_schedule_page_dict['disbursementDateDay_' + str(index)] = date_array[1]
- se_schedule_page_dict['disbursementDateYear_' + str(index)] = date_array[2]
+ se_schedule_page_dict["disbursementDateMonth_" + str(index)] = date_array[0]
+ se_schedule_page_dict["disbursementDateDay_" + str(index)] = date_array[1]
+ se_schedule_page_dict["disbursementDateYear_" + str(index)] = date_array[2]
- if (key == 'dateSigned' and len(se_schedule_dict[key])) > 0:
+ if (key == "dateSigned" and len(se_schedule_dict[key])) > 0:
date_array = se_schedule_dict[key].split("/")
- se_schedule_page_dict['dateSignedMonth_' + str(index)] = date_array[0]
- se_schedule_page_dict['dateSignedDay_' + str(index)] = date_array[1]
- se_schedule_page_dict['dateSignedYear_' + str(index)] = date_array[2]
-
- if key == 'electionCode':
- if se_schedule_dict[key][0] in ['P','G']:
- se_schedule_page_dict['electionType_' + str(index)] = se_schedule_dict[key][0:1]
+ se_schedule_page_dict["dateSignedMonth_" + str(index)] = date_array[0]
+ se_schedule_page_dict["dateSignedDay_" + str(index)] = date_array[1]
+ se_schedule_page_dict["dateSignedYear_" + str(index)] = date_array[2]
+
+ if key == "electionCode":
+ if se_schedule_dict[key][0] in ["P", "G"]:
+ se_schedule_page_dict["electionType_" + str(index)] = se_schedule_dict[
+ key
+ ][0:1]
else:
- se_schedule_page_dict['electionType_' + str(index)] = 'O'
- se_schedule_page_dict['electionYear_' + str(index)] = se_schedule_dict[key][1::]
+ se_schedule_page_dict["electionType_" + str(index)] = "O"
+ se_schedule_page_dict["electionYear_" + str(index)] = se_schedule_dict[key][
+ 1::
+ ]
- if (key == 'disseminationDate' and len(se_schedule_dict[key])) > 0:
+ if (key == "disseminationDate" and len(se_schedule_dict[key])) > 0:
date_array = se_schedule_dict[key].split("/")
- se_schedule_page_dict['disseminationDateMonth_' + str(index)] = date_array[0]
- se_schedule_page_dict['disseminationDateDay_' + str(index)] = date_array[1]
- se_schedule_page_dict['disseminationDateYear_' + str(index)] = date_array[2]
+ se_schedule_page_dict["disseminationDateMonth_" + str(index)] = date_array[
+ 0
+ ]
+ se_schedule_page_dict["disseminationDateDay_" + str(index)] = date_array[1]
+ se_schedule_page_dict["disseminationDateYear_" + str(index)] = date_array[2]
else:
- if key == 'expenditureAmount' or key == 'calendarYTDPerElectionForOffice':
- se_schedule_page_dict[key + '_' + str(index)] = '{0:.2f}'.format(se_schedule_dict[key]) if se_schedule_dict[key] else 0.0
+ if key == "expenditureAmount" or key == "calendarYTDPerElectionForOffice":
+ se_schedule_page_dict[key + "_" + str(index)] = (
+ "{0:.2f}".format(se_schedule_dict[key])
+ if se_schedule_dict[key]
+ else 0.0
+ )
else:
- se_schedule_page_dict[key + '_' + str(index)] = se_schedule_dict[key]
-
-
+ se_schedule_page_dict[key + "_" + str(index)] = se_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule E transaction: ' + str(se_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule E transaction: "
+ + str(se_schedule_dict)
+ )
raise e
+
def build_payee_sf_name_date_dict(index, key, sf_schedule_dict, sf_schedule_page_dict):
try:
if not sf_schedule_dict.get(key):
sf_schedule_dict[key] = ""
- if 'designatingCommitteeName' in sf_schedule_dict:
- sf_schedule_page_dict['designatingCommitteeName'] = sf_schedule_dict['designatingCommitteeName']
-
- if 'subordinateCommitteeName' in sf_schedule_dict:
- sf_schedule_page_dict['subordinateCommitteeName'] = sf_schedule_dict['subordinateCommitteeName']
- sf_schedule_page_dict['subordinateCommitteeStreet1'] = sf_schedule_dict['subordinateCommitteeStreet1']
- sf_schedule_page_dict['subordinateCommitteeStreet2'] = sf_schedule_dict['subordinateCommitteeStreet2']
- sf_schedule_page_dict['subordinateCommitteeCity'] = sf_schedule_dict['subordinateCommitteeCity']
- sf_schedule_page_dict['subordinateCommitteeState'] = sf_schedule_dict['subordinateCommitteeState']
- sf_schedule_page_dict['subordinateCommitteeZipCode'] = sf_schedule_dict['subordinateCommitteeZipCode']
-
- if 'payeeLastName' in sf_schedule_dict and sf_schedule_dict['payeeLastName']:
- sf_schedule_page_dict['payeeName_' + str(index)] = (sf_schedule_dict['payeeLastName'] + ','
- + sf_schedule_dict['payeeFirstName'] + ','
- + sf_schedule_dict['payeeMiddleName'] + ','
- + sf_schedule_dict['payeePrefix'] + ','
- + sf_schedule_dict['payeeSuffix'])
- elif 'payeeOrganizationName' in sf_schedule_dict and sf_schedule_dict['payeeOrganizationName']:
- sf_schedule_page_dict["payeeName_" + str(index)] = sf_schedule_dict['payeeOrganizationName']
- elif 'designatingCommitteeName' in sf_schedule_dict and sf_schedule_dict['designatingCommitteeName']:
- sf_schedule_page_dict["payeeName_" + str(index)] = sf_schedule_dict['designatingCommitteeName']
-
- if 'payeeCandidateLastName' in sf_schedule_dict:
- sf_schedule_page_dict['payeeCandidateName_' + str(index)] = (sf_schedule_dict['payeeCandidateLastName'] + ','
- + sf_schedule_dict['payeeCandidateFirstName'] + ','
- + sf_schedule_dict['payeeCandidateMiddleName'] + ','
- + sf_schedule_dict['payeeCandidatePrefix'] + ','
- + sf_schedule_dict['payeeCandidateSuffix'])
-
- if key == 'expenditureDate' and sf_schedule_dict['expenditureDate'] not in ["none", "null", " ", ""]:
+ if "designatingCommitteeName" in sf_schedule_dict:
+ sf_schedule_page_dict["designatingCommitteeName"] = sf_schedule_dict[
+ "designatingCommitteeName"
+ ]
+
+ if "subordinateCommitteeName" in sf_schedule_dict:
+ sf_schedule_page_dict["subordinateCommitteeName"] = sf_schedule_dict[
+ "subordinateCommitteeName"
+ ]
+ sf_schedule_page_dict["subordinateCommitteeStreet1"] = sf_schedule_dict[
+ "subordinateCommitteeStreet1"
+ ]
+ sf_schedule_page_dict["subordinateCommitteeStreet2"] = sf_schedule_dict[
+ "subordinateCommitteeStreet2"
+ ]
+ sf_schedule_page_dict["subordinateCommitteeCity"] = sf_schedule_dict[
+ "subordinateCommitteeCity"
+ ]
+ sf_schedule_page_dict["subordinateCommitteeState"] = sf_schedule_dict[
+ "subordinateCommitteeState"
+ ]
+ sf_schedule_page_dict["subordinateCommitteeZipCode"] = sf_schedule_dict[
+ "subordinateCommitteeZipCode"
+ ]
+
+ if "payeeLastName" in sf_schedule_dict and sf_schedule_dict["payeeLastName"]:
+ sf_schedule_page_dict["payeeName_" + str(index)] = (
+ sf_schedule_dict["payeeLastName"]
+ + ","
+ + sf_schedule_dict["payeeFirstName"]
+ + ","
+ + sf_schedule_dict["payeeMiddleName"]
+ + ","
+ + sf_schedule_dict["payeePrefix"]
+ + ","
+ + sf_schedule_dict["payeeSuffix"]
+ )
+ elif (
+ "payeeOrganizationName" in sf_schedule_dict
+ and sf_schedule_dict["payeeOrganizationName"]
+ ):
+ sf_schedule_page_dict["payeeName_" + str(index)] = sf_schedule_dict[
+ "payeeOrganizationName"
+ ]
+ elif (
+ "designatingCommitteeName" in sf_schedule_dict
+ and sf_schedule_dict["designatingCommitteeName"]
+ ):
+ sf_schedule_page_dict["payeeName_" + str(index)] = sf_schedule_dict[
+ "designatingCommitteeName"
+ ]
+
+ if "payeeCandidateLastName" in sf_schedule_dict:
+ sf_schedule_page_dict["payeeCandidateName_" + str(index)] = (
+ sf_schedule_dict["payeeCandidateLastName"]
+ + ","
+ + sf_schedule_dict["payeeCandidateFirstName"]
+ + ","
+ + sf_schedule_dict["payeeCandidateMiddleName"]
+ + ","
+ + sf_schedule_dict["payeeCandidatePrefix"]
+ + ","
+ + sf_schedule_dict["payeeCandidateSuffix"]
+ )
+
+ if key == "expenditureDate" and sf_schedule_dict["expenditureDate"] not in [
+ "none",
+ "null",
+ " ",
+ "",
+ ]:
date_array = sf_schedule_dict[key].split("/")
- sf_schedule_page_dict['expenditureDateMonth_' + str(index)] = date_array[0]
- sf_schedule_page_dict['expenditureDateDay_' + str(index)] = date_array[1]
- sf_schedule_page_dict['expenditureDateYear_' + str(index)] = date_array[2]
+ sf_schedule_page_dict["expenditureDateMonth_" + str(index)] = date_array[0]
+ sf_schedule_page_dict["expenditureDateDay_" + str(index)] = date_array[1]
+ sf_schedule_page_dict["expenditureDateYear_" + str(index)] = date_array[2]
else:
- if key == 'expenditureAmount' or key == 'aggregateGeneralElectionExpended':
- sf_schedule_page_dict[key + '_' + str(index)] = '{0:.2f}'.format(sf_schedule_dict[key]) if sf_schedule_dict[key] else 0.0
+ if key == "expenditureAmount" or key == "aggregateGeneralElectionExpended":
+ sf_schedule_page_dict[key + "_" + str(index)] = (
+ "{0:.2f}".format(sf_schedule_dict[key])
+ if sf_schedule_dict[key]
+ else 0.0
+ )
else:
- sf_schedule_page_dict[key + '_' + str(index)] = sf_schedule_dict[key]
+ sf_schedule_page_dict[key + "_" + str(index)] = sf_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule F transaction: ' + str(sf_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule F transaction: "
+ + str(sf_schedule_dict)
+ )
raise e
-def build_contributor_la_name_date_dict(index, key, la_schedule_dict, la_schedule_page_dict):
+def build_contributor_la_name_date_dict(
+ index, key, la_schedule_dict, la_schedule_page_dict
+):
try:
- #print("la", la_schedule_dict, la_schedule_page_dict, index, key)
- if 'contributorLastName' in la_schedule_dict and la_schedule_dict['contributorLastName']:
- la_schedule_page_dict['contributorName_' + str(index)] = (la_schedule_dict['contributorLastName'] + ','
- + la_schedule_dict['contributorFirstName'] + ','
- + la_schedule_dict['contributorMiddleName'] + ','
- + la_schedule_dict['contributorPrefix'] + ','
- + la_schedule_dict['contributorSuffix'])
- del la_schedule_dict['contributorLastName']
- del la_schedule_dict['contributorFirstName']
- del la_schedule_dict['contributorMiddleName']
- del la_schedule_dict['contributorPrefix']
- del la_schedule_dict['contributorSuffix']
- elif 'contributorOrgName' in la_schedule_dict:
- la_schedule_page_dict["contributorName_" + str(index)] = la_schedule_dict['contributorOrgName']
- del la_schedule_dict['contributorOrgName']
-
-
-
- if 'contributionDate' in la_schedule_dict:
- date_array = la_schedule_dict['contributionDate'].split("/")
- la_schedule_page_dict['contributionDateMonth_' + str(index)] = date_array[0]
- la_schedule_page_dict['contributionDateDay_' + str(index)] = date_array[1]
- la_schedule_page_dict['contributionDateYear_' + str(index)] = date_array[2]
- del la_schedule_dict['contributionDate']
-
- if 'contributionAmount' in la_schedule_dict:
- if la_schedule_dict['contributionAmount'] == '':
- la_schedule_dict['contributionAmount'] = 0.0
- la_schedule_page_dict['contributionAmount_' + str(index)] = '{0:.2f}'.format(
- la_schedule_dict['contributionAmount'])
- del la_schedule_dict['contributionAmount']
-
- if 'contributionAggregate' in la_schedule_dict:
- if la_schedule_dict['contributionAggregate'] == '':
- la_schedule_dict['contributionAggregate'] = 0.0
- la_schedule_page_dict['contributionAggregate_' + str(index)] = '{0:.2f}'.format(
- la_schedule_dict['contributionAggregate'])
- del la_schedule_dict['contributionAggregate']
+ # print("la", la_schedule_dict, la_schedule_page_dict, index, key)
+ if (
+ "contributorLastName" in la_schedule_dict
+ and la_schedule_dict["contributorLastName"]
+ ):
+ la_schedule_page_dict["contributorName_" + str(index)] = (
+ la_schedule_dict["contributorLastName"]
+ + ","
+ + la_schedule_dict["contributorFirstName"]
+ + ","
+ + la_schedule_dict["contributorMiddleName"]
+ + ","
+ + la_schedule_dict["contributorPrefix"]
+ + ","
+ + la_schedule_dict["contributorSuffix"]
+ )
+ del la_schedule_dict["contributorLastName"]
+ del la_schedule_dict["contributorFirstName"]
+ del la_schedule_dict["contributorMiddleName"]
+ del la_schedule_dict["contributorPrefix"]
+ del la_schedule_dict["contributorSuffix"]
+ elif "contributorOrgName" in la_schedule_dict:
+ la_schedule_page_dict["contributorName_" + str(index)] = la_schedule_dict[
+ "contributorOrgName"
+ ]
+ del la_schedule_dict["contributorOrgName"]
+
+ if "contributionDate" in la_schedule_dict:
+ date_array = la_schedule_dict["contributionDate"].split("/")
+ la_schedule_page_dict["contributionDateMonth_" + str(index)] = date_array[0]
+ la_schedule_page_dict["contributionDateDay_" + str(index)] = date_array[1]
+ la_schedule_page_dict["contributionDateYear_" + str(index)] = date_array[2]
+ del la_schedule_dict["contributionDate"]
+
+ if "contributionAmount" in la_schedule_dict:
+ if la_schedule_dict["contributionAmount"] == "":
+ la_schedule_dict["contributionAmount"] = 0.0
+ la_schedule_page_dict[
+ "contributionAmount_" + str(index)
+ ] = "{0:.2f}".format(la_schedule_dict["contributionAmount"])
+ del la_schedule_dict["contributionAmount"]
+
+ if "contributionAggregate" in la_schedule_dict:
+ if la_schedule_dict["contributionAggregate"] == "":
+ la_schedule_dict["contributionAggregate"] = 0.0
+ la_schedule_page_dict[
+ "contributionAggregate_" + str(index)
+ ] = "{0:.2f}".format(la_schedule_dict["contributionAggregate"])
+ del la_schedule_dict["contributionAggregate"]
for key in la_schedule_dict:
- if key != 'lineNumber':
- la_schedule_page_dict[key + '_' + str(index)] = la_schedule_dict[key]
+ if key != "lineNumber":
+ la_schedule_page_dict[key + "_" + str(index)] = la_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule SL-A tranlaction: ' + str(la_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule SL-A tranlaction: "
+ + str(la_schedule_dict)
+ )
raise e
@@ -4756,116 +7591,213 @@ def build_slb_name_date_dict(index, key, slb_schedule_dict, slb_schedule_page_di
if not slb_schedule_dict.get(key):
slb_schedule_dict[key] = ""
- if 'payeeLastName' in slb_schedule_dict and slb_schedule_dict['payeeLastName']:
- slb_schedule_page_dict['payeeName_' + str(index)] = (slb_schedule_dict['payeeLastName'] + ','
- + slb_schedule_dict['payeeFirstName'] + ','
- + slb_schedule_dict['payeeMiddleName'] + ','
- + slb_schedule_dict['payeePrefix'] + ','
- + slb_schedule_dict['payeeSuffix'])
- elif 'payeeOrganizationName' in slb_schedule_dict:
- slb_schedule_page_dict["payeeName_" + str(index)] = slb_schedule_dict['payeeOrganizationName']
-
- if key == 'expenditureDate':
+ if "payeeLastName" in slb_schedule_dict and slb_schedule_dict["payeeLastName"]:
+ slb_schedule_page_dict["payeeName_" + str(index)] = (
+ slb_schedule_dict["payeeLastName"]
+ + ","
+ + slb_schedule_dict["payeeFirstName"]
+ + ","
+ + slb_schedule_dict["payeeMiddleName"]
+ + ","
+ + slb_schedule_dict["payeePrefix"]
+ + ","
+ + slb_schedule_dict["payeeSuffix"]
+ )
+ elif "payeeOrganizationName" in slb_schedule_dict:
+ slb_schedule_page_dict["payeeName_" + str(index)] = slb_schedule_dict[
+ "payeeOrganizationName"
+ ]
+
+ if key == "expenditureDate":
date_array = slb_schedule_dict[key].split("/")
- slb_schedule_page_dict['expenditureDateMonth_' + str(index)] = date_array[0]
- slb_schedule_page_dict['expenditureDateDay_' + str(index)] = date_array[1]
- slb_schedule_page_dict['expenditureDateYear_' + str(index)] = date_array[2]
+ slb_schedule_page_dict["expenditureDateMonth_" + str(index)] = date_array[0]
+ slb_schedule_page_dict["expenditureDateDay_" + str(index)] = date_array[1]
+ slb_schedule_page_dict["expenditureDateYear_" + str(index)] = date_array[2]
else:
- if key == 'expenditureAmount' or key == 'expenditureAggregate':
- slb_schedule_page_dict[key + '_' + str(index)] = '{0:.2f}'.format(slb_schedule_dict[key])
+ if key == "expenditureAmount" or key == "expenditureAggregate":
+ slb_schedule_page_dict[key + "_" + str(index)] = "{0:.2f}".format(
+ slb_schedule_dict[key]
+ )
else:
- slb_schedule_page_dict[key + '_' + str(index)] = slb_schedule_dict[key]
+ slb_schedule_page_dict[key + "_" + str(index)] = slb_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule-LB transaction: ' + str(slb_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule-LB transaction: "
+ + str(slb_schedule_dict)
+ )
raise e
-def build_contributor_sl_levin_name_date_dict(index, key, sl_schedule_dict, sl_schedule_page_dict):
+def build_contributor_sl_levin_name_date_dict(
+ index, key, sl_schedule_dict, sl_schedule_page_dict
+):
try:
- list_SL_convert_2_decimals = ['itemizedReceiptsFromPersons', 'unitemizedReceiptsFromPersons',
- 'totalReceiptsFromPersons','otherReceipts','totalReceipts','voterRegistrationDisbursements',
- 'voterIdDisbursements','gotvDisbursements','genericCampaignDisbursements','totalSubDisbursements',
- 'otherDisbursements','totalDisbursements','beginningCashOnHand','receipts','subtotal',
- 'disbursements','endingCashOnHand','itemizedReceiptsFromPersonsYTD',
- 'unitemizedReceiptsFromPersonsYTD','totalReceiptsFromPersonsYTD','otherReceiptsYTD',
- 'totalReceiptsYTD','voterRegistrationDisbursementsYTD','voterIdDisbursementsYTD',
- 'gotvDisbursementsYTD','genericCampaignDisbursementsYTD','totalSubDisbursementsYTD',
- 'otherDisbursementsYTD','totalDisbursementsYTD','beginningCashOnHandYTD','receiptsYTD',
- 'subtotalYTD','disbursementsYTD','endingCashOnHandYTD']
- list_skip = ['accountName', 'receipts','disbursements', 'subtotal', 'receiptsYTD','disbursementsYTD','subtotalYTD']
+ list_SL_convert_2_decimals = [
+ "itemizedReceiptsFromPersons",
+ "unitemizedReceiptsFromPersons",
+ "totalReceiptsFromPersons",
+ "otherReceipts",
+ "totalReceipts",
+ "voterRegistrationDisbursements",
+ "voterIdDisbursements",
+ "gotvDisbursements",
+ "genericCampaignDisbursements",
+ "totalSubDisbursements",
+ "otherDisbursements",
+ "totalDisbursements",
+ "beginningCashOnHand",
+ "receipts",
+ "subtotal",
+ "disbursements",
+ "endingCashOnHand",
+ "itemizedReceiptsFromPersonsYTD",
+ "unitemizedReceiptsFromPersonsYTD",
+ "totalReceiptsFromPersonsYTD",
+ "otherReceiptsYTD",
+ "totalReceiptsYTD",
+ "voterRegistrationDisbursementsYTD",
+ "voterIdDisbursementsYTD",
+ "gotvDisbursementsYTD",
+ "genericCampaignDisbursementsYTD",
+ "totalSubDisbursementsYTD",
+ "otherDisbursementsYTD",
+ "totalDisbursementsYTD",
+ "beginningCashOnHandYTD",
+ "receiptsYTD",
+ "subtotalYTD",
+ "disbursementsYTD",
+ "endingCashOnHandYTD",
+ ]
+ list_skip = [
+ "accountName",
+ "receipts",
+ "disbursements",
+ "subtotal",
+ "receiptsYTD",
+ "disbursementsYTD",
+ "subtotalYTD",
+ ]
for key in sl_schedule_dict:
- if key == 'receipts':
- sl_schedule_page_dict[key] = sl_schedule_dict['totalReceipts']
- if key == 'disbursements':
- sl_schedule_page_dict[key] = sl_schedule_dict['totalDisbursements']
- if key == 'subtotal':
- sl_schedule_page_dict[key] = sl_schedule_dict['totalReceipts'] + sl_schedule_dict['beginningCashOnHand']
- if key == 'receiptsYTD':
- sl_schedule_page_dict[key] = sl_schedule_dict['totalReceiptsYTD']
- if key == 'disbursementsYTD':
- sl_schedule_page_dict[key] = sl_schedule_dict['totalDisbursementsYTD']
- if key == 'subtotalYTD':
- sl_schedule_page_dict[key] = sl_schedule_dict['totalReceiptsYTD'] + sl_schedule_dict['beginningCashOnHandYTD']
+ if key == "receipts":
+ sl_schedule_page_dict[key] = sl_schedule_dict["totalReceipts"]
+ if key == "disbursements":
+ sl_schedule_page_dict[key] = sl_schedule_dict["totalDisbursements"]
+ if key == "subtotal":
+ sl_schedule_page_dict[key] = (
+ sl_schedule_dict["totalReceipts"]
+ + sl_schedule_dict["beginningCashOnHand"]
+ )
+ if key == "receiptsYTD":
+ sl_schedule_page_dict[key] = sl_schedule_dict["totalReceiptsYTD"]
+ if key == "disbursementsYTD":
+ sl_schedule_page_dict[key] = sl_schedule_dict["totalDisbursementsYTD"]
+ if key == "subtotalYTD":
+ sl_schedule_page_dict[key] = (
+ sl_schedule_dict["totalReceiptsYTD"]
+ + sl_schedule_dict["beginningCashOnHandYTD"]
+ )
if key not in list_skip:
sl_schedule_page_dict[key] = sl_schedule_dict[key]
if key in list_SL_convert_2_decimals:
- sl_schedule_page_dict[key] = '{0:.2f}'.format(sl_schedule_page_dict[key])
-
+ sl_schedule_page_dict[key] = "{0:.2f}".format(
+ sl_schedule_page_dict[key]
+ )
except Exception as e:
- print('Error at key: ' + key + ' in Schedule SL tranlaction: ' + str(sl_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule SL tranlaction: "
+ + str(sl_schedule_dict)
+ )
raise e
def build_sh_name_date_dict(index, key, sh_schedule_dict, sh_schedule_page_dict):
try:
- float_val = ('federalShare','levinShare','totalFedLevinAmount','nonfederalShare', 'totalFedNonfedAmount',
- 'totalAmountTransferred','voterRegistrationAmount','voterIdAmount', 'gotvAmount',
- 'genericCampaignAmount','activityEventTotalYTD')
-
- if 'activityEventType' in sh_schedule_dict:
- sh_schedule_page_dict["activityEventType_" + str(index)] = sh_schedule_dict['activityEventType']
-
- if 'payeeLastName' in sh_schedule_dict and sh_schedule_dict['payeeLastName']:
- sh_schedule_page_dict['payeeName_' + str(index)] = (sh_schedule_dict['payeeLastName'] + ','
- + sh_schedule_dict['payeeFirstName'] + ','
- + sh_schedule_dict['payeeMiddleName'] + ','
- + sh_schedule_dict['payeePrefix'] + ','
- + sh_schedule_dict['payeeSuffix'])
- elif 'payeeOrganizationName' in sh_schedule_dict:
- sh_schedule_page_dict["payeeName_" + str(index)] = sh_schedule_dict['payeeOrganizationName']
+ float_val = (
+ "federalShare",
+ "levinShare",
+ "totalFedLevinAmount",
+ "nonfederalShare",
+ "totalFedNonfedAmount",
+ "totalAmountTransferred",
+ "voterRegistrationAmount",
+ "voterIdAmount",
+ "gotvAmount",
+ "genericCampaignAmount",
+ "activityEventTotalYTD",
+ )
+ if "activityEventType" in sh_schedule_dict:
+ sh_schedule_page_dict["activityEventType_" + str(index)] = sh_schedule_dict[
+ "activityEventType"
+ ]
+
+ if "payeeLastName" in sh_schedule_dict and sh_schedule_dict["payeeLastName"]:
+ sh_schedule_page_dict["payeeName_" + str(index)] = (
+ sh_schedule_dict["payeeLastName"]
+ + ","
+ + sh_schedule_dict["payeeFirstName"]
+ + ","
+ + sh_schedule_dict["payeeMiddleName"]
+ + ","
+ + sh_schedule_dict["payeePrefix"]
+ + ","
+ + sh_schedule_dict["payeeSuffix"]
+ )
+ elif "payeeOrganizationName" in sh_schedule_dict:
+ sh_schedule_page_dict["payeeName_" + str(index)] = sh_schedule_dict[
+ "payeeOrganizationName"
+ ]
for key in sh_schedule_dict:
- if key == 'expenditureDate':
+ if key == "expenditureDate":
date_array = sh_schedule_dict[key].split("/")
- sh_schedule_page_dict['expenditureDateMonth_' + str(index)] = date_array[0]
- sh_schedule_page_dict['expenditureDateDay_' + str(index)] = date_array[1]
- sh_schedule_page_dict['expenditureDateYear_' + str(index)] = date_array[2]
+ sh_schedule_page_dict[
+ "expenditureDateMonth_" + str(index)
+ ] = date_array[0]
+ sh_schedule_page_dict["expenditureDateDay_" + str(index)] = date_array[
+ 1
+ ]
+ sh_schedule_page_dict["expenditureDateYear_" + str(index)] = date_array[
+ 2
+ ]
+
+ if key == "receiptDate":
- if key == 'receiptDate':
-
date_array = sh_schedule_dict[key].split("/")
- sh_schedule_page_dict['receiptDateMonth_' + str(index)] = date_array[0]
- sh_schedule_page_dict['receiptDateDay_' + str(index)] = date_array[1]
- sh_schedule_page_dict['receiptDateYear_' + str(index)] = date_array[2]
+ sh_schedule_page_dict["receiptDateMonth_" + str(index)] = date_array[0]
+ sh_schedule_page_dict["receiptDateDay_" + str(index)] = date_array[1]
+ sh_schedule_page_dict["receiptDateYear_" + str(index)] = date_array[2]
if key in float_val:
- sh_schedule_page_dict[key + '_' + str(index)] = '{:.2f}'.format(float(sh_schedule_dict[key]))
+ sh_schedule_page_dict[key + "_" + str(index)] = "{:.2f}".format(
+ float(sh_schedule_dict[key])
+ )
continue
else:
if key != 0:
- sh_schedule_page_dict[key + '_' + str(index)] = sh_schedule_dict[key]
+ sh_schedule_page_dict[key + "_" + str(index)] = sh_schedule_dict[
+ key
+ ]
- if key != 'lineNumber' and key != 0:
- sh_schedule_page_dict[key + '_' + str(index)] = sh_schedule_dict[key]
+ if key != "lineNumber" and key != 0:
+ sh_schedule_page_dict[key + "_" + str(index)] = sh_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule SH transaction: ' + str(sh_schedule_dict))
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule SH transaction: "
+ + str(sh_schedule_dict)
+ )
raise e
@@ -4873,14 +7805,18 @@ def build_sh2_name_date_dict(index, key, sh2_schedule_dict, sh2_schedule_page_di
try:
for key in sh2_schedule_dict:
- if key in ['fundraising','directCandidateSupport']:
+ if key in ["fundraising", "directCandidateSupport"]:
sh2_schedule_dict[key] = str(sh2_schedule_dict[key])
- if key in ['federalPercent', 'nonFederalPercent']:
- sh2_schedule_dict[key] = '{:.2f}'.format(float(sh2_schedule_dict[key]))
+ if key in ["federalPercent", "nonFederalPercent"]:
+ sh2_schedule_dict[key] = "{:.2f}".format(float(sh2_schedule_dict[key]))
-
- sh2_schedule_page_dict[key + '_' + str(index)] = sh2_schedule_dict[key]
+ sh2_schedule_page_dict[key + "_" + str(index)] = sh2_schedule_dict[key]
except Exception as e:
- print('Error at key: ' + key + ' in Schedule SH2 tranlaction: ' + str(sh2_schedule_dict))
- raise e
\ No newline at end of file
+ print(
+ "Error at key: "
+ + key
+ + " in Schedule SH2 tranlaction: "
+ + str(sh2_schedule_dict)
+ )
+ raise e
diff --git a/routes/src/form99.py b/routes/src/form99.py
index 72a96e2..0e46eb3 100644
--- a/routes/src/form99.py
+++ b/routes/src/form99.py
@@ -1,19 +1,15 @@
import flask
import boto3
-import re
import os
import pypdftk
import shutil
import pdfkit
import bs4
-import urllib.request
-import sys
-import traceback
from flask import json
from flask import request, current_app
from flask_api import status
-from routes.src import common, form
+from routes.src import common
from routes.src.utils import md5_for_text, md5_for_file, directory_files, error
@@ -30,10 +26,6 @@ def print_f99_pdftk_html(
attachment_file_content=None,
):
# check if json_file is in the request
- # HTML("templates/forms/test.html").write_pdf("output/pdf/test/test.pdf")
- # HTML(string='''