forked from CMS/memberPlumbing
membershipViewer: Add basic front desk web page thingy
This commit is contained in:
parent
c0d7ef4f86
commit
6048990ea9
56
membershipViewer.py
Normal file
56
membershipViewer.py
Normal file
@ -0,0 +1,56 @@
|
||||
#!/usr/bin/env python3
|
||||
import re
|
||||
|
||||
from flask import Flask, render_template
|
||||
|
||||
app = Flask(__name__)
|
||||
|
||||
from common import *
|
||||
|
||||
def parse_list(member, regex):
|
||||
data_list = []
|
||||
for key, value in member.items():
|
||||
match = re.match(regex, key)
|
||||
if match is not None and value != '':
|
||||
data_list.append(match.group(1))
|
||||
|
||||
return ", ".join(data_list)
|
||||
|
||||
def parse_members(members):
|
||||
data = []
|
||||
for member in members:
|
||||
props = {
|
||||
'Name': member['Account Name'],
|
||||
'Renewal Date': member['Renewal Date'],
|
||||
'Card Number': member['Access Card Facility Code'] + '-' \
|
||||
+ member['Access Card Number'],
|
||||
'Account on Hold': "Yes" if member['Account on Hold'] != '' else "No" }
|
||||
|
||||
certifications = []
|
||||
access = []
|
||||
levels = []
|
||||
|
||||
props['Certifications'] = parse_list(member, 'Certified: (.*)')
|
||||
props['Door Access'] = parse_list(member, 'Access (.*)\?')
|
||||
props['Memebership Level'] = parse_list(member, 'CMS (.*)')
|
||||
|
||||
data.append(props)
|
||||
|
||||
return data
|
||||
|
||||
@app.route("/")
|
||||
def main():
|
||||
# maybe not now: membership agreement signed
|
||||
# TODO: renewal date
|
||||
|
||||
members = getMembershipworksData(
|
||||
"lvl,xws,xms,xsc,xas,xfd,xac,phn,eml,lbl,xcf,nam,end")
|
||||
|
||||
data = parse_members(members)
|
||||
headers = ['Name', 'Certifications', 'Door Access', 'Memebership Level',
|
||||
'Card Number', 'Renewal Date', 'Account on Hold']
|
||||
|
||||
return render_template("members.html", headers=headers, members=data)
|
||||
|
||||
if __name__ == "__main__":
|
||||
app.run(debug=True, host='0.0.0.0')
|
44
templates/members.html
Normal file
44
templates/members.html
Normal file
@ -0,0 +1,44 @@
|
||||
<html>
|
||||
<head>
|
||||
<title> CMS Members </title>
|
||||
<style>
|
||||
table {
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
td, th{
|
||||
border: 1px solid black;
|
||||
}
|
||||
|
||||
td {
|
||||
padding: 3px;
|
||||
}
|
||||
|
||||
tr:nth-child(even) {
|
||||
background-color: #ccc;
|
||||
}
|
||||
|
||||
tr[onHold=Yes] {
|
||||
background-color: #f66;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<h1>Members</h1>
|
||||
<table>
|
||||
<tr>
|
||||
{% for header in headers %}
|
||||
<th> {{ header }} </th>
|
||||
{% endfor %}
|
||||
</tr>
|
||||
{% for member in members %}
|
||||
<tr onHold ="{{ member['Account on Hold'] }}">
|
||||
{% for header in headers %}
|
||||
<td> {{ member[header] }} </td>
|
||||
{% endfor %}
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</div>
|
||||
</table>
|
||||
</body>
|
||||
</html>
|
Loading…
Reference in New Issue
Block a user