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='''
























This is bold text
This is underline text
This is italics text
Title

  1. one
  2. two
  3. three
''').write_pdf("output/pdf/test/test.pdf") - # pdfkit.from_file("templates/forms/test.html", "output/pdf/test/test.pdf") - # pypdftk.stamp(current_app.config['FORM_TEMPLATES_LOCATION'].format('F99'), "output/pdf/test/test.pdf", "output/pdf/test/output.pdf") try: silent_print = silent_print txn_img_num = begin_image_num @@ -359,13 +351,18 @@ def print_f99_pdftk_html( 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, + ) else: response["pdf_url"] = ( current_app.config["PRINT_OUTPUT_FILE_URL"].format( @@ -388,7 +385,7 @@ def print_f99_pdftk_html( "summary": { "committeeId": form99_json_data.get("committeeId", None), "begin_image_num": begin_image_num, - "end_image_num": txn_img_num + "end_image_num": txn_img_num, } } response["txn_img_json"] = txn_img_json @@ -427,5 +424,4 @@ def print_f99_pdftk_html( ) return flask.jsonify(**envelope), status.HTTP_400_BAD_REQUEST except Exception as e: - traceback.print_exception(*sys.exc_info()) return error("Error generating print preview, error message: " + str(e)) diff --git a/routes/src/log.py b/routes/src/log.py index f104017..06ff49c 100644 --- a/routes/src/log.py +++ b/routes/src/log.py @@ -12,10 +12,7 @@ def log_init(): formatter = jsonlogger.JsonFormatter( - '{"timestamp":%(asctime),"message":%(message),' - '"function_name":%(funcName),"logger_name":%(name),' - '"logger_level":%(levelname),"filename":%(filename),' - '"line_number":%(lineno)' + "%(timestamp)s %(messages)s %(funcName)s %(name)s %(levelname)s %(filename)s %(lineno)s" ) logHandler = logging.StreamHandler(sys.stdout) diff --git a/routes/src/schedules/sb_schedule.py b/routes/src/schedules/sb_schedule.py index 31650f3..b340579 100644 --- a/routes/src/schedules/sb_schedule.py +++ b/routes/src/schedules/sb_schedule.py @@ -58,10 +58,17 @@ def print_sb_line( schedule_total += float(schedule_page_dict["pageSubtotal"]) if page_cnt == page_num + 1: - schedule_page_dict["scheduleTotal"] = "{0:.2f}".format(schedule_total) + schedule_page_dict["scheduleTotal"] = "{0:.2f}".format( + schedule_total + ) schedule_page_dict["committeeName"] = f3x_data["committeeName"] sb_outfile = ( - md5_directory + "SB/" + line_number + "/page_" + str(page_num) + ".pdf" + md5_directory + + "SB/" + + line_number + + "/page_" + + str(page_num) + + ".pdf" ) pypdftk.fill_form(sb_infile, schedule_page_dict, sb_outfile) @@ -100,11 +107,10 @@ def print_sb_line( md5_directory + "SB/all_pages.pdf", ) except: - logging.error('**** Start - Error inside if condition ****') + logging.error("**** Start - Error inside if condition ****") # printing stack trace traceback.print_exception(*sys.exc_info()) - logging.error('**** End - Error inside if condition ****') - + logging.error("**** End - Error inside if condition ****") return current_page_num, image_num except: diff --git a/routes/src/schedules/sd_schedule.py b/routes/src/schedules/sd_schedule.py index 8b9f1ac..5b19db1 100644 --- a/routes/src/schedules/sd_schedule.py +++ b/routes/src/schedules/sd_schedule.py @@ -1,7 +1,5 @@ import os import pypdftk -import sys -import traceback from flask import current_app from os import path @@ -152,5 +150,5 @@ def print_sd_line( sd_sub_total = 0 return sd_total_balance, image_num - except: - traceback.print_exception(*sys.exc_info()) + except Exception as e: + return error("Error generating print preview, error message: " + str(e)) diff --git a/routes/src/schedules/sh3_schedule.py b/routes/src/schedules/sh3_schedule.py index c92155d..9ae84a6 100644 --- a/routes/src/schedules/sh3_schedule.py +++ b/routes/src/schedules/sh3_schedule.py @@ -1,7 +1,6 @@ import os import pypdftk -from math import ceil from flask import current_app from os import path from routes.src.utils import directory_files diff --git a/routes/src/schedules/slb_schedule.py b/routes/src/schedules/slb_schedule.py index f287548..0d1c240 100644 --- a/routes/src/schedules/slb_schedule.py +++ b/routes/src/schedules/slb_schedule.py @@ -1,7 +1,5 @@ import os import pypdftk -import sys -import traceback from flask import current_app from os import path @@ -212,8 +210,8 @@ def print_slb_line( ) return image_num - except: - traceback.print_exception(*sys.exc_info()) + except Exception as e: + return error("Error generating print preview, error message: " + str(e)) def build_slb_per_page_schedule_dict( diff --git a/routes/src/tests/conftest.py b/routes/src/tests/conftest.py new file mode 100644 index 0000000..e69de29 diff --git a/routes/src/tests/test_common.py b/routes/src/tests/test_common.py new file mode 100644 index 0000000..6a34dd0 --- /dev/null +++ b/routes/src/tests/test_common.py @@ -0,0 +1,12 @@ +from unittest import TestCase +from routes.src.common import get_return_envelope + + +class TestCommon(TestCase): + def test_get_return_envelope(self): + msg = "Test message 1" + data = [1, 2, 3] + envelope = get_return_envelope(success=True, message=msg, data=data) + self.assertTrue(envelope["success"]) + self.assertEqual(msg, envelope["message"]) + self.assertEqual(data, envelope["results"]) diff --git a/routes/src/utils.py b/routes/src/utils.py index 21bfab0..bff5267 100644 --- a/routes/src/utils.py +++ b/routes/src/utils.py @@ -49,4 +49,4 @@ def error(msg): # delete directory if it exists def delete_directory(dir_name): if os.path.isdir(dir_name) and os.listdir(dir_name): - rmtree(dir_name) \ No newline at end of file + rmtree(dir_name) diff --git a/runtime.txt b/runtime.txt new file mode 100644 index 0000000..5a26ef3 --- /dev/null +++ b/runtime.txt @@ -0,0 +1 @@ +python-3.7.x diff --git a/tasks.py b/tasks.py new file mode 100644 index 0000000..2def12a --- /dev/null +++ b/tasks.py @@ -0,0 +1,198 @@ +import os +import json +import git +import sys +import cfenv + +from invoke import task + +env = cfenv.AppEnv() + +APP_NAME = "fecfile-image-generator" +ORG_NAME = "fec-fecfileonline-prototyping" + + +def _resolve_rule(repo, branch): + """Get space associated with first matching rule.""" + for space, rule in DEPLOY_RULES: + if rule(repo, branch): + return space + return None + + +def _detect_branch(repo): + try: + return repo.active_branch.name + except TypeError: + return None + + +def _detect_space(repo, branch=None): + """Detect space from active git branch. + + :param str branch: Optional branch name override + :returns: Space name if space is detected and confirmed, else `None` + """ + space = _resolve_rule(repo, branch) + if space is None: + print("The current configuration does not require a deployment to cloud.gov.") + return None + print(f"Detected space {space}") + return space + + +DEPLOY_RULES = ( + ("prod", lambda _, branch: branch == "main"), + ("stage", lambda _, branch: branch.startswith("release")), + ("dev", lambda _, branch: branch == "develop"), +) + + +def _login_to_cf(ctx, space): + # Set api + api = "https://api.fr.cloud.gov" + ctx.run(f"cf api {api}", echo=True) + # Authenticate + user_var_name = f"$FEC_CF_USERNAME_{space.upper()}" + pass_var_name = f"$FEC_CF_PASSWORD_{space.upper()}" + + login_command = f'cf auth "{user_var_name}" "{pass_var_name}"' + result = ctx.run(login_command, echo=True, warn=True) + if result.return_code != 0: + print("\n\nError logging into cloud.gov.") + print("Please check your authentication environment variables:") + + print(f"You must set the {user_var_name} and {pass_var_name} environment ") + print("variables with space-deployer service account credentials") + print("") + print( + "If you don't have a service account, you can create one with the following commands:" + ) + print(" cf login -u [email-address] -o {ORG_NAME} -a api.fr.cloud.gov --sso") + print(" cf target -o {ORG_NAME} -s {space}") + print( + " cf create-service cloud-gov-service-account space-deployer [my-service-account-name]" + ) + print( + " cf create-service-key [my-server-account-name] [my-service-key-name]" + ) + print(" cf service-key [my-server-account-name] [my-service-key-name]") + + exit(1) + + +def _do_deploy(ctx, space): + + manifest_filename = f"manifest-{space}.yml" + existing_deploy = ctx.run(f"cf app {APP_NAME}", echo=True, warn=True) + print("\n") + + cmd = "push --strategy rolling" if existing_deploy.ok else "push" + new_deploy = ctx.run( + f"cf {cmd} {APP_NAME} -f {manifest_filename}", + echo=True, + warn=True, + ) + return new_deploy + + +def _print_help_text(): + help_text = """ + Usage: + invoke deploy [--space SPACE] [--branch BRANCH] [--login] [--help] + + --space SPACE If provided, the SPACE space in cloud.gov will be targeted for deployment. + Either --space or --branch must be provided + Allowed values are dev, stage, and prod. + + + --branch BRANCH Name of the branch to use for deployment. Will auto-detect + the git branch in the current directory by default + Either --space or --branch must be provided + + --login If this flag is set, deploy with attempt to login to a + service account specified in the environemnt variables + $FEC_CF_USERNAME_[SPACE] and $FEC_CF_PASSWORD_[SPACE] + + --help If set, display help/usage text and exit + + """ + print(help_text) + + +def _rollback(ctx): + print("Build failed!") + # Check if there are active deployments + app_guid = ctx.run(f"cf app {APP_NAME} --guid", hide=True, warn=True) + app_guid_formatted = app_guid.stdout.strip() + status = ctx.run( + f'cf curl "/v3/deployments?app_guids={app_guid_formatted}&status_values=ACTIVE"', + hide=True, + warn=True, + ) + active_deployments = ( + json.loads(status.stdout).get("pagination").get("total_results") + ) + # Try to roll back + if active_deployments > 0: + print("Attempting to roll back any deployment in progress...") + # Show the in-between state + ctx.run(f"cf app {APP_NAME}", echo=True, warn=True) + cancel_deploy = ctx.run( + f"cf cancel-deployment {APP_NAME}", echo=True, warn=True + ) + if cancel_deploy.ok: + print("Successfully cancelled deploy. Check logs.") + else: + print("Unable to cancel deploy. Check logs.") + + +@task +def deploy(ctx, space=None, branch=None, login=False, help=False): + """Deploy app to Cloud Foundry. + Log in using credentials stored per environment + like `FEC_CF_USERNAME_DEV` and `FEC_CF_PASSWORD_DEV`; + Push to either `space` or the space detected from the name and tags + of the current branch. + Note: Must pass `space` or `branch` if repo is in detached HEAD mode, + e.g. when running on Circle. + + Example usage: invoke deploy --space dev + """ + + if help: + _print_help_text() + exit(0) + + # Detect space + repo = git.Repo(".") + branch = branch or _detect_branch(repo) + space = space or _detect_space(repo, branch) + if space is None: + # this is not an error condition, it just means the current space/branch is not + # a candidate for deployment. Return successful exit code + return sys.exit(0) + + if login: + _login_to_cf(ctx, space) + + # Target space + ctx.run(f"cf target -o {ORG_NAME} -s {space}", echo=True) + + # Set deploy variables + with open(".cfmeta", "w") as fp: + json.dump({"user": os.getenv("USER"), "branch": branch}, fp) + + new_deploy = _do_deploy(ctx, space) + + if not new_deploy.ok: + _rollback(ctx) + return sys.exit(1) + + ctx.run("cf apps", echo=True, warn=True) + print( + f"A new version of your application '{APP_NAME}' has been successfully pushed!" + ) + + # Needed for CircleCI + return sys.exit(0)