def _generateDataListByPackage(self, dataEntryLst, pkgName, list_fields, listName, columnNames, searchColumnNames, fileNo, custom_header=None): outDir = os.path.join(self.outDir, fileNo.replace(".","_")) with open("%s/%s-%s.html" % (outDir, pkgName, listName), 'w+') as output: output.write("<html>\n") tName = safeElementId("%s-%s" % (listName, pkgName)) outputDataListTableHeader(output, tName, columnNames, searchColumnNames) output.write("<body id=\"dt_example\">") output.write("""<div id="container" style="width:80%">""") if pkgName == "All": pkgLinkName = pkgName output.write("<h1>%s %s List</h1>" % (pkgLinkName, listName)) else: output.write("<h2 align=\"right\"><a href=\"./All-%s.html\">" "All %s</a></h2>" % (listName, listName)) pkgLinkName = getPackageHRefLink(pkgName) output.write("<h1>Package: %s %s List</h1>" % (pkgLinkName, listName)) if not custom_header: outputDataTableHeader(output, columnNames, tName) outputDataTableFooter(output, columnNames, tName) else: outputCustomDataTableHeader(output, custom_header, tName) outputDataTableFooter(output, columnNames, tName) """ table body """ output.write("<tbody>\n") for dataEntry in dataEntryLst: tableRow = [""]*len(list_fields) allFields = dataEntry.fields output.write("<tr>\n") for idx, id in enumerate(list_fields): # If value has / in it, we take the first value as usual # but assume the information is a "multiple" field and # attempt to find the second bit of information within it idVal,multval = id[1].split('/') if (len(id[1].split('/')) > 1) else (id[1],None) if idVal in allFields: value = allFields[idVal].value if multval: # and (multval in value.dataEntries["1"].fields) value = self.findSubValue(dataEntry, value,multval,id); if type(value) is list: tmpValue="<ul>" for entry in value: if id[-1]: tmpValue += "<li>"+id[-1](dataEntry, entry,sourceField=id[1], targetField=id[-2], glbData=self.dataMap, crossRef=self.crossRef)+"</li>" else: tmpValue += "<li>"+ entry +"</li>" value = tmpValue+"</ul>" else: if id[-1]: value = id[-1](dataEntry, value,sourceField=id[1], targetField=id[-2], glbData=self.dataMap, crossRef=self.crossRef) tableRow[idx] = value for item in tableRow: #output.write("<td class=\"ellipsis\">%s</td>\n" % item) output.write("<td>%s</td>\n" % item) output.write("</tr>\n") output.write("</tbody>\n") output.write("</table>\n") output.write("</div>\n") output.write("</div>\n") output.write ("</body></html>\n")
def _generateICRSummaryPageImpl(self, inputJson, listName, pkgName, isForAll=False): outDir = self._outDir pkgHtmlName = pkgName outFilename = "%s/%s-%s.html" % (outDir, pkgName, listName) if not isForAll: if pkgName in pkgMap: pkgName = pkgMap[pkgName] pkgHtmlName = pkgName + '-ICR.html' outFilename = "%s/%s" % (outDir, pkgHtmlName) with open(outFilename, 'w+') as output: output.write("<html>\n") tName = safeElementId("%s-%s" % (listName, pkgName)) useAjax = useAjaxDataTable(len(inputJson)) columnNames = [x[0] for x in summary_list_fields] searchColumns = ['IA #', 'Name', 'Custodial Package', 'Date Created', 'File #', 'Remote Procedure', 'Routine', 'Date Activated'] if useAjax: ajaxSrc = '%s_array.txt' % pkgName outputLargeDataListTableHeader(output, ajaxSrc, tName, columnNames, searchColumns) else: outputDataListTableHeader(output, tName, columnNames, searchColumns) output.write("<body id=\"dt_example\">") output.write("""<div id="container" style="width:80%">""") if isForAll: output.write("<h1>%s %s</h1>" % (pkgName, listName)) else: output.write("<h2 align=\"right\"><a href=\"./All-%s.html\">" "All %s</a></h2>" % (listName, listName)) output.write("<h1>Package: %s %s</h1>" % (pkgName, listName)) # pkgLinkName = getPackageHRefLink(pkgName) outputDataTableHeader(output, columnNames, tName) outputDataTableFooter(output, columnNames, tName) """ table body """ output.write("<tbody>\n") if not useAjax: """ Now convert the ICR Data to Table data """ for icrSummary in inputJson: output.write("<tr>\n") for item in icrSummary: #output.write("<td class=\"ellipsis\">%s</td>\n" % item) output.write("<td>%s</td>\n" % item) output.write("</tr>\n") else: logging.info("Ajax source file: %s" % ajaxSrc) """ Write out the data file in JSON format """ outJson = {"aaData": []} with open(os.path.join(outDir, ajaxSrc), 'w') as ajaxOut: outArray = outJson["aaData"] for icrSummary in inputJson: outArray.append(icrSummary) json.dump(outJson, ajaxOut) output.write("</tbody>\n") output.write("</table>\n") output.write("</div>\n") output.write("</div>\n") output.write ("</body></html>\n")
def _generateRequirementsSummaryPageImpl(self, inputJson, listName, pkgName, isForAll=False): outDir = self._outDir listName = listName.strip() pkgName = pkgName.strip() # TODO: Use Utility functions to generate filename name pkgHtmlName = pkgName.replace('/', '_') outFilename = "%s/%s-%s.html" % (outDir, pkgName.replace( '/', '_'), listName) if not isForAll: outFilename = "%s/%s-Req.html" % (outDir, pkgHtmlName) with open(outFilename, 'w+') as output: output.write("<html>\n") tName = "%s-%s" % (listName.replace( ' ', '_'), pkgName.replace(' ', '_')) useAjax = False #useAjaxDataTable(len(inputJson)) columnNames = fieldList searchColumns = searchColumnList if useAjax: ajaxSrc = '%s_array.txt' % pkgName outputLargeDataListTableHeader(output, ajaxSrc, tName, columnNames, searchColumns) else: outputDataListTableHeader(output, tName, columnNames, searchColumns, hideColumnNames=['Recently Updated']) output.write("<body id=\"dt_example\">") output.write("""<div id="container" style="width:80%">""") if isForAll: output.write("<h1>%s %s</h1>" % (pkgName, listName)) reqData = inputJson else: reqData = inputJson[pkgName] output.write("<h2 align=\"right\"><a href=\"./All-%s.html\">" "All %s</a></h2>" % (listName, listName)) output.write("<h1>BFF Entry: %s %s</h1>" % (pkgName, listName)) outputDataTableHeader(output, columnNames, tName) outputDataTableFooter(output, columnNames, tName) """ table body """ output.write("<tbody>\n") if not useAjax: """ Now convert the requirements Data to Table data """ for reqEntry in reqData: output.write("<tr>\n") if not isForAll: reqSummary = self._convertReqEntryToSummaryInfo( reqEntry) if not reqSummary in allReqs: allReqs.append(reqSummary) else: reqSummary = reqEntry for idx, item in enumerate(fieldList): # List of objects should be displayed as a UL object if isinstance(reqSummary[idx], list): output.write("<td><ul>") for entry in reqSummary[idx]: if pkgName in entry: output.write( "<li class='disabled'>%s</li>\n" % entry) else: output.write("<li>%s</li>\n" % entry) output.write("</ul></td>") # Otherwise, write it out as is else: if pkgName in str(reqSummary[idx]): output.write("<td class='disabled'>%s</td>\n" % reqSummary[idx]) else: output.write("<td>%s</td>\n" % reqSummary[idx]) output.write("</tr>\n") else: logger.info("Ajax source file: %s" % ajaxSrc) """ Write out the data file in JSON format """ outJson = {"aaData": []} with open(os.path.join(outDir, ajaxSrc), 'w') as ajaxOut: outArray = outJson["aaData"] for reqSummary in inputJson: outArray.append(reqSummary) json.dump(outJson, ajaxOut) output.write("</tbody>\n") output.write("</table>\n") output.write("</div>\n") output.write("</div>\n") output.write("</body></html>\n")
def _generateICRSummaryPageImpl(inputJson, listName, pkgName, date, outDir, isForAll=False): listName = listName.strip() pkgName = pkgName.strip() pkgHtmlName = pkgName outFilename = os.path.join(outDir, "%s-%s.html" % (pkgName, listName)) if not isForAll: if pkgName in PACKAGE_MAP: pkgName = PACKAGE_MAP[pkgName] pkgHtmlName = pkgName + '-ICR.html' outFilename = "%s/%s" % (outDir, pkgHtmlName) with open(outFilename, 'w+') as output: output.write("<html>\n") tName = "%s-%s" % (listName.replace(' ', '_'), pkgName.replace(' ', '_')) useAjax = _useAjaxDataTable(len(inputJson)) columnNames = [x[0] for x in SUMMARY_LIST_FIELDS] searchColumns = ['IA #', 'Name', 'Custodial Package', 'Date Created', 'File #', 'Remote Procedure', 'Routine', 'Date Activated', 'General Description'] hideColumns = ['General Description'] if useAjax: ajaxSrc = '%s_array.txt' % pkgName outputLargeDataListTableHeader(output, ajaxSrc, tName, columnNames, searchColumns, hideColumns) else: outputDataListTableHeader(output, tName, columnNames, searchColumns, hideColumns) output.write("<body id=\"dt_example\">") output.write("""<div id="container" style="width:80%">""") if isForAll: output.write("<h1>%s %s</h1>" % (pkgName, listName)) else: output.write("<h2 align=\"right\"><a href=\"./All-%s.html\">" "All %s</a></h2>" % (listName, listName)) output.write("<h1>Package: %s %s</h1>" % (pkgName, listName)) # pkgLinkName = _getPackageHRefLink(pkgName) outputDataTableHeader(output, columnNames, tName) outputDataTableFooter(output, columnNames, tName) """ table body """ output.write("<tbody>\n") if not useAjax: """ Now convert the ICR Data to Table data """ for icrSummary in inputJson: output.write("<tr>\n") for item in icrSummary: #output.write("<td class=\"ellipsis\">%s</td>\n" % item) output.write("<td>%s</td>\n" % item) output.write("</tr>\n") else: logger.debug("Ajax source file: %s" % ajaxSrc) """ Write out the data file in JSON format """ outJson = {"aaData": []} with open(os.path.join(outDir, ajaxSrc), 'w') as ajaxOut: outArray = outJson["aaData"] for icrSummary in inputJson: outArray.append(icrSummary) json.dump(outJson, ajaxOut) output.write("</tbody>\n") output.write("</table>\n") if date is not None: link = "https://foia-vista.osehra.org/VistA_Integration_Agreement/" output.write("<a href=\"%s\">Generated from %s IA Listing Descriptions</a>" % (link, date)) output.write("</div>\n") output.write("</div>\n") output.write ("</body></html>\n")
def _generateICRSummaryPageImpl(self, inputJson, listName, pkgName, date, isForAll=False): outDir = self._outDir listName = listName.strip() pkgName = pkgName.strip() pkgHtmlName = pkgName outFilename = "%s/%s-%s.html" % (outDir, pkgName, listName) if not isForAll: if pkgName in pkgMap: pkgName = pkgMap[pkgName] pkgHtmlName = pkgName + '-ICR.html' outFilename = "%s/%s" % (outDir, pkgHtmlName) with open(outFilename, 'w+') as output: output.write("<html>\n") tName = "%s-%s" % (listName.replace(' ', '_'), pkgName.replace(' ', '_')) useAjax = useAjaxDataTable(len(inputJson)) columnNames = [x[0] for x in summary_list_fields] searchColumns = ['IA #', 'Name', 'Custodial Package', 'Date Created', 'File #', 'Remote Procedure', 'Routine', 'Date Activated', 'General Description'] hideColumns = ['General Description'] if useAjax: ajaxSrc = '%s_array.txt' % pkgName outputLargeDataListTableHeader(output, ajaxSrc, tName, columnNames, searchColumns, hideColumns) else: outputDataListTableHeader(output, tName, columnNames, searchColumns, hideColumns) output.write("<body id=\"dt_example\">") output.write("""<div id="container" style="width:80%">""") if isForAll: output.write("<h1>%s %s</h1>" % (pkgName, listName)) else: output.write("<h2 align=\"right\"><a href=\"./All-%s.html\">" "All %s</a></h2>" % (listName, listName)) output.write("<h1>Package: %s %s</h1>" % (pkgName, listName)) # pkgLinkName = getPackageHRefLink(pkgName) outputDataTableHeader(output, columnNames, tName) outputDataTableFooter(output, columnNames, tName) """ table body """ output.write("<tbody>\n") if not useAjax: """ Now convert the ICR Data to Table data """ for icrSummary in inputJson: output.write("<tr>\n") for item in icrSummary: #output.write("<td class=\"ellipsis\">%s</td>\n" % item) output.write("<td>%s</td>\n" % item) output.write("</tr>\n") else: logging.info("Ajax source file: %s" % ajaxSrc) """ Write out the data file in JSON format """ outJson = {"aaData": []} with open(os.path.join(outDir, ajaxSrc), 'w') as ajaxOut: outArray = outJson["aaData"] for icrSummary in inputJson: outArray.append(icrSummary) json.dump(outJson, ajaxOut) output.write("</tbody>\n") output.write("</table>\n") if date is not None: link = "https://foia-vista.osehra.org/VistA_Integration_Agreement/" output.write("<a href=\"%s\">Generated from %s IA Listing Descriptions</a>" % (link, date)) output.write("</div>\n") output.write("</div>\n") output.write ("</body></html>\n")
def _generateDataListByPackage(self, dataEntryLst, pkgName, list_fields, listName, columnNames, searchColumnNames, fileNoOutDir, custom_header=None): filename = os.path.join(fileNoOutDir, "%s-%s.html" % (pkgName, listName)) with open(filename, 'w') as output: output.write("<html>\n") if pkgName == "All": tName = "%s %s List" % (normalizePackageName(pkgName), listName) else: tName = normalizePackageName(pkgName) outputDataListTableHeader(output, tName, columnNames, searchColumnNames) output.write("<body id=\"dt_example\">") output.write( "<a class=\"brand\" href=\"%s\" style=\"height:50px; padding: 0px;\"> \ <img src=\"https://osehra.org/sites/default/files/vivian.png\" width=\"137\" height=\"50\"/></a>" % VIV_URL) output.write("""<div id="container" style="width:80%">""") if pkgName == "All": pkgLinkName = pkgName output.write("<h1>%s %s List</h1>" % (pkgLinkName, listName)) else: output.write("<h2 align=\"right\"><a href=\"./All-%s.html\">" "All %s</a></h2>" % (listName, listName)) pkgLinkName = getPackageHRefLink(pkgName) output.write("<h1>Package: %s %s List</h1>" % (pkgLinkName, listName)) if not custom_header: outputDataTableHeader(output, columnNames, tName) outputDataTableFooter(output, columnNames, tName) else: outputCustomDataTableHeaderRows(output, custom_header, tName) outputDataTableFooter(output, columnNames, tName) # table body output.write("<tbody>\n") for dataEntry in dataEntryLst: tableRow = [""] * len(list_fields) allFields = dataEntry.fields output.write("<tr>\n") for idx, id in enumerate(list_fields): # If value has / in it, we take the first value as usual # but assume the information is a "multiple" field and # attempt to find the second bit of information within it idVal, multval = id[1].split('/') if ( len(id[1].split('/')) > 1) else (id[1], None) if idVal in allFields: value = allFields[idVal].value if multval: # and (multval in value.dataEntries["1"].fields) value = self.findSubValue(dataEntry, value, multval, id) if isinstance(value, list) and id[0] != "Description": # Don't write out descriptions as lists tmpValue = "<ul>" for entry in value: if id[-1]: tmpValue += "<li>" + id[-1]( dataEntry, entry, sourceField=id[1], targetField=id[-2], glbData=self.dataMap, crossRef=self.crossRef) + "</li>" else: tmpValue += "<li>" + entry + "</li>" value = tmpValue + "</ul>" else: if id[-1]: value = id[-1](dataEntry, value, sourceField=id[1], targetField=id[-2], glbData=self.dataMap, crossRef=self.crossRef) tableRow[idx] = value for item in tableRow: output.write("<td>%s</td>\n" % item) output.write("</tr>\n") output.write("</tbody>\n") output.write("</table>\n") output.write("</div>\n") output.write("</div>\n") output.write("</body></html>\n")
def _generateRequirementsSummaryPageImpl(self, inputJson, listName, pkgName, isForAll=False): outDir = self._outDir listName = listName.strip() pkgName = pkgName.strip() pkgHtmlName = pkgName.replace('/','_') outFilename = "%s/%s-%s.html" % (outDir, pkgName.replace('/','_'), listName) if not isForAll: outFilename = "%s/%s-Req.html" % (outDir, pkgHtmlName) with open(outFilename, 'w+') as output: output.write("<html>\n") tName = "%s-%s" % (listName.replace(' ', '_'), pkgName.replace(' ', '_')) useAjax = False #useAjaxDataTable(len(inputJson)) columnNames = fieldList searchColumns = searchColumnList if useAjax: ajaxSrc = '%s_array.txt' % pkgName outputLargeDataListTableHeader(output, ajaxSrc, tName, columnNames, searchColumns) else: outputDataListTableHeader(output, tName, columnNames, searchColumns, hideColumnNames=['Recently Updated']) output.write("<body id=\"dt_example\">") output.write("""<div id="container" style="width:80%">""") if isForAll: output.write("<h1>%s %s</h1>" % (pkgName, listName)) reqData= inputJson else: reqData=inputJson[pkgName] output.write("<h2 align=\"right\"><a href=\"./All-%s.html\">" "All %s</a></h2>" % (listName, listName)) output.write("<h1>BFF Entry: %s %s</h1>" % (pkgName, listName)) outputDataTableHeader(output, columnNames, tName) outputDataTableFooter(output, columnNames, tName) """ table body """ output.write("<tbody>\n") if not useAjax: """ Now convert the requirements Data to Table data """ for reqEntry in reqData: output.write("<tr>\n") if not isForAll: reqSummary = self._convertReqEntryToSummaryInfo(reqEntry); if not reqSummary in allReqs: allReqs.append(reqSummary) else: reqSummary = reqEntry for idx,item in enumerate(fieldList): # List of objects should be displayed as a UL object if type(reqSummary[idx]) is list: output.write("<td><ul>") for entry in reqSummary[idx]: if pkgName in entry: output.write("<li class='disabled'>%s</li>\n" % entry) else: output.write("<li>%s</li>\n" % entry) output.write("</ul></td>") # Otherwise, write it out as is else: if pkgName in str(reqSummary[idx]): output.write("<td class='disabled'>%s</td>\n" % reqSummary[idx]) else: output.write("<td>%s</td>\n" % reqSummary[idx]) output.write("</tr>\n") else: logging.info("Ajax source file: %s" % ajaxSrc) """ Write out the data file in JSON format """ outJson = {"aaData": []} with open(os.path.join(outDir, ajaxSrc), 'w') as ajaxOut: outArray = outJson["aaData"] for reqSummary in inputJson: outArray.append(reqSummary) json.dump(outJson, ajaxOut) output.write("</tbody>\n") output.write("</table>\n") output.write("</div>\n") output.write("</div>\n") output.write ("</body></html>\n")
def _generateDataListByPackage(self, dataEntryLst, pkgName, list_fields, listName, columnNames, searchColumnNames, fileNoOutDir, custom_header=None): filename = os.path.join(fileNoOutDir, "%s-%s.html" % (pkgName, listName)) with open(filename, 'w') as output: output.write("<html>\n") if pkgName == "All": tName = "%s %s List" % (normalizePackageName(pkgName), listName) else: tName = normalizePackageName(pkgName) outputDataListTableHeader(output, tName, columnNames, searchColumnNames) output.write("<body id=\"dt_example\">") output.write("""<div id="container" style="width:80%">""") if pkgName == "All": pkgLinkName = pkgName output.write("<h1>%s %s List</h1>" % (pkgLinkName, listName)) else: output.write("<h2 align=\"right\"><a href=\"./All-%s.html\">" "All %s</a></h2>" % (listName, listName)) pkgLinkName = getPackageHRefLink(pkgName) output.write("<h1>Package: %s %s List</h1>" % (pkgLinkName, listName)) if not custom_header: outputDataTableHeader(output, columnNames, tName) outputDataTableFooter(output, columnNames, tName) else: outputCustomDataTableHeaderRows(output, custom_header, tName) outputDataTableFooter(output, columnNames, tName) """ table body """ output.write("<tbody>\n") for dataEntry in dataEntryLst: tableRow = [""]*len(list_fields) allFields = dataEntry.fields output.write("<tr>\n") for idx, id in enumerate(list_fields): # If value has / in it, we take the first value as usual # but assume the information is a "multiple" field and # attempt to find the second bit of information within it idVal, multval = id[1].split('/') if (len(id[1].split('/')) > 1) else (id[1],None) if idVal in allFields: value = allFields[idVal].value if multval: # and (multval in value.dataEntries["1"].fields) value = self.findSubValue(dataEntry, value,multval,id) if type(value) is list and id[0] != "Description": # Don't write out descriptions as lists tmpValue="<ul>" for entry in value: if id[-1]: tmpValue += "<li>"+id[-1](dataEntry, entry,sourceField=id[1], targetField=id[-2], glbData=self.dataMap, crossRef=self.crossRef)+"</li>" else: tmpValue += "<li>"+ entry +"</li>" value = tmpValue+"</ul>" else: if id[-1]: value = id[-1](dataEntry, value,sourceField=id[1], targetField=id[-2], glbData=self.dataMap, crossRef=self.crossRef) tableRow[idx] = value for item in tableRow: #output.write("<td class=\"ellipsis\">%s</td>\n" % item) output.write("<td>%s</td>\n" % item) output.write("</tr>\n") output.write("</tbody>\n") output.write("</table>\n") output.write("</div>\n") output.write("</div>\n") output.write ("</body></html>\n")