mirror of
https://github.com/GSA/notifications-admin.git
synced 2026-02-05 10:53:28 -05:00
Renamed header of CSV to be 'to' - matches API
This commit is contained in:
@@ -1,9 +1,6 @@
|
||||
import csv
|
||||
import io
|
||||
import uuid
|
||||
import botocore
|
||||
|
||||
from datetime import date
|
||||
|
||||
from flask import (
|
||||
request,
|
||||
@@ -17,7 +14,6 @@ from flask import (
|
||||
)
|
||||
|
||||
from flask_login import login_required, current_user
|
||||
from werkzeug import secure_filename
|
||||
from notifications_python_client.errors import HTTPError
|
||||
from utils.template import Template, NeededByTemplateError, NoPlaceholderForDataError
|
||||
|
||||
@@ -32,11 +28,6 @@ from app.main.dao import services_dao
|
||||
from app import job_api_client
|
||||
from app.utils import validate_recipient, InvalidPhoneError, InvalidEmailError
|
||||
|
||||
first_column_header = {
|
||||
'email': 'email',
|
||||
'sms': 'phone'
|
||||
}
|
||||
|
||||
|
||||
@main.route("/services/<service_id>/send/<template_type>", methods=['GET'])
|
||||
def choose_template(service_id, template_type):
|
||||
@@ -91,7 +82,7 @@ def send_messages(service_id, template_id):
|
||||
return render_template(
|
||||
'views/send.html',
|
||||
template=template,
|
||||
column_headers=[first_column_header[template.template_type]] + template.placeholders_as_markup,
|
||||
column_headers=['to'] + template.placeholders_as_markup,
|
||||
form=form,
|
||||
service=service,
|
||||
service_id=service_id
|
||||
@@ -105,10 +96,9 @@ def get_example_csv(service_id, template_id):
|
||||
placeholders = list(Template(template).placeholders)
|
||||
output = io.StringIO()
|
||||
writer = csv.writer(output)
|
||||
writer.writerow([first_column_header[template['template_type']]] + placeholders)
|
||||
writer.writerow(['to'] + placeholders)
|
||||
writer.writerow([current_user.mobile_number] + ["test {}".format(header) for header in placeholders])
|
||||
|
||||
return(output.getvalue(), 200, {'Content-Type': 'text/csv; charset=utf-8'})
|
||||
return output.getvalue(), 200, {'Content-Type': 'text/csv; charset=utf-8'}
|
||||
|
||||
|
||||
@main.route("/services/<service_id>/send/<template_id>/to-self", methods=['GET'])
|
||||
@@ -118,7 +108,7 @@ def send_message_to_self(service_id, template_id):
|
||||
placeholders = list(Template(template).placeholders)
|
||||
output = io.StringIO()
|
||||
writer = csv.writer(output)
|
||||
writer.writerow([first_column_header[template['template_type']]] + placeholders)
|
||||
writer.writerow(['to'] + placeholders)
|
||||
writer.writerow([current_user.mobile_number] + ["test {}".format(header) for header in placeholders])
|
||||
filedata = {
|
||||
'file_name': 'Test run',
|
||||
@@ -146,19 +136,18 @@ def check_messages(service_id, upload_id):
|
||||
if not contents:
|
||||
flash('There was a problem reading your upload file')
|
||||
raw_template = templates_dao.get_service_template_or_404(service_id, template_id)['data']
|
||||
recipient_type = first_column_header[raw_template['template_type']]
|
||||
upload_result = _get_rows(contents, raw_template)
|
||||
session['upload_data']['notification_count'] = len(upload_result['rows'])
|
||||
template = Template(
|
||||
raw_template,
|
||||
values=upload_result['rows'][0] if upload_result['valid'] else {},
|
||||
drop_values={recipient_type}
|
||||
drop_values={'to'}
|
||||
)
|
||||
return render_template(
|
||||
'views/check-sms.html',
|
||||
upload_result=upload_result,
|
||||
template=template,
|
||||
column_headers=[recipient_type] + list(
|
||||
column_headers=['to'] + list(
|
||||
template.placeholders if upload_result['valid'] else template.placeholders_as_markup
|
||||
),
|
||||
original_file_name=upload_data.get('original_file_name'),
|
||||
@@ -203,12 +192,11 @@ def _get_rows(contents, raw_template):
|
||||
for row in reader:
|
||||
rows.append(row)
|
||||
try:
|
||||
recipient_column = first_column_header[raw_template['template_type']]
|
||||
validate_recipient(
|
||||
row[recipient_column],
|
||||
row['to'],
|
||||
template_type=raw_template['template_type']
|
||||
)
|
||||
Template(raw_template, values=row, drop_values={recipient_column}).replaced
|
||||
Template(raw_template, values=row, drop_values={'to'}).replaced
|
||||
except (InvalidEmailError, InvalidPhoneError, NeededByTemplateError, NoPlaceholderForDataError):
|
||||
valid = False
|
||||
return {"valid": valid, "rows": rows}
|
||||
|
||||
@@ -53,13 +53,13 @@
|
||||
caption=original_file_name,
|
||||
field_headings=column_headers
|
||||
) %}
|
||||
{% if item.phone|valid_phone_number %}
|
||||
{% if item.to|valid_phone_number %}
|
||||
{% call field() %}
|
||||
{{ item.phone }}
|
||||
{{ item.to }}
|
||||
{% endcall %}
|
||||
{% else %}
|
||||
{% call field(status='missing') %}
|
||||
{{ item.phone }}
|
||||
{{ item.to }}
|
||||
{% endcall %}
|
||||
{% endif %}
|
||||
{% for column in template.placeholders %}
|
||||
|
||||
Reference in New Issue
Block a user