From b254e5da2c312b2180e7714f8bbd8851fd4ade9c Mon Sep 17 00:00:00 2001 From: chriswebb09 Date: Mon, 8 Jan 2024 21:45:28 -0500 Subject: [PATCH 1/2] update for archived reports --- DirectReport/browserview/dashboard/routes.py | 23 +++- DirectReport/browserview/main/routes.py | 1 + .../browserview/static/js/archived_report.js | 80 +++++++++++ .../static/js/archived_report_components.js | 129 ++++++++++++++++++ .../browserview/static/js/chart_helper.js | 15 +- .../static/js/teamreport/teamreport.js | 5 +- .../js/teamreport/teamreport_components.js | 62 +++++---- .../templates/archived_report.html | 22 +++ .../templates/team/teamreport.html | 3 +- DirectReport/models/Report/report_builder.py | 2 + 10 files changed, 297 insertions(+), 45 deletions(-) create mode 100644 DirectReport/browserview/static/js/archived_report.js create mode 100644 DirectReport/browserview/static/js/archived_report_components.js create mode 100644 DirectReport/browserview/templates/archived_report.html diff --git a/DirectReport/browserview/dashboard/routes.py b/DirectReport/browserview/dashboard/routes.py index 7ee46931..5d74c28c 100644 --- a/DirectReport/browserview/dashboard/routes.py +++ b/DirectReport/browserview/dashboard/routes.py @@ -37,7 +37,7 @@ def dashboard_reports_saved(): :return: Rendered HTML template for the list page. """ - results = requests.get('/api/reports/list') + results = requests.get('http://127.0.0.1:5000/api/reports/list') return render_template('list.html', title='List', data=results) @@ -76,6 +76,7 @@ def dashboard_reports_update(): repo_data.append(repo["name"]) raw_data = team_summary_from_shortlog(prompt)["choices"][0]["message"]["content"] response_data = json.loads(raw_data) + print(response_data) response_data["commit_nums"] = { "15 days": 4, "30 days": (commits_last_month / 10), @@ -92,6 +93,7 @@ def dashboard_reports_update(): "1 year": 30, } response_data["repos"] = repo_data + print(repo_data) ReportBuilder.new(response_data, prompt, current_user.id, current_user.github_repo) return response_data, 201 @@ -101,7 +103,22 @@ def dashboard_reports_update(): def dashboard_saved_report(uid=None): reports = ReportBuilder.get_reports_for_user_id(current_user.id) report = list(filter(lambda report: report["uuid"] == uid, reports))[0] - json_data = json.dumps(report) + print(report) + report["commit_nums"] = { + "15 days": 4, + "30 days": (8 / 10), + "60 days": (10 / 10), + "90 days": (12 / 10), + "120 days": 3, + } + report["pull_requests"] = { + "30 days": 4, + "60 days": 6, + "90 days": 8, + "120 days": 10, + "150 days": 10, + "1 year": 30, + } return render_template( - 'team/teamreport.html', title='Team Report', data=json_data, report=json_data, raw_input=report['raw_input'] + 'archived_report.html', title='Team Report', data=report, raw_input={"raw_input": report["raw_input"]}, report=report["report"] ) diff --git a/DirectReport/browserview/main/routes.py b/DirectReport/browserview/main/routes.py index 3e07f2ef..e247717e 100644 --- a/DirectReport/browserview/main/routes.py +++ b/DirectReport/browserview/main/routes.py @@ -72,6 +72,7 @@ def reponame(): 'X-GitHub-Api-Version': '2022-11-28', } response_data = requests.get(url=repo_name, headers=headers, auth=(client_id, client_secret)) + print(response_data) if response_data.status_code == 200: json_response_data = json.loads(response_data.content) res_json = {"json_array": json_response_data} diff --git a/DirectReport/browserview/static/js/archived_report.js b/DirectReport/browserview/static/js/archived_report.js new file mode 100644 index 00000000..1bc3b7a5 --- /dev/null +++ b/DirectReport/browserview/static/js/archived_report.js @@ -0,0 +1,80 @@ +const {useState, useEffect} = React; +const ArchivedReport = (reportDataElems) => { + + const [teamData, setTeamData] = useState([]); + const [repos, setRepos] = useState([]); + const [reportData, setReportData] = useState({}); + const [commits, setCommits] = useState([]); + const [pullRequests, setPullRequests] = useState({}); + const [broadCategories, setBroadCategories] = useState({}); + const [commitNums, setCommitNums] = useState({}); + const [rawInputText, setRawInputText] = useState(""); + const [commentText, setCommentText] = useState(""); + + + const openRepoPopover = () => { + console.log("open repo popover"); + // setRepoSelected(true); + } + + useEffect(() => { + const results = reportDataElems; + printData({results}) + }, [reportDataElems]); + + function printData(reportDataElems) { + var obj = JSON.parse(JSON.stringify(reportDataElems)); + // var objb = JSON.parse(JSON.stringify(obj)); + var test_data = JSON.parse(JSON.stringify(obj.results.data)) + setCommitNums(test_data.commit_nums); + setPullRequests(test_data.pull_requests); + var test_data2 = JSON.parse(JSON.stringify(obj.results.raw_input_elem)) + setRawInputText(test_data2.raw_input); + var new_data = obj.results.reportDataElems.replace(/\'/g, "\""); + var test1 = JSON.parse(new_data); + Object.entries(test1).forEach((entry) => { + const [key, value] = entry; + var obj_new = JSON.parse(JSON.stringify(value)); + if (key === "team") { + setTeamData({ + teamData:obj_new, + }); + } else if (key === "report") { + setReportData(obj_new); + } else if (key === "commits") { + setCommits({ + commits:obj_new, + }); + } else if (key === "broad_categories") { + setBroadCategories(obj_new); + } else if (key === "repos") { + setRepos({ + repos:obj_new, + }); + } else if (key == "commit_nums") { + setCommitNums(obj_new); + } else if (key == "pull_requests") { + setPullRequests(obj_new); + } + }) + } + + return ( +
+

+ Archived Team Report +

+
+ {EditArchiveSummaryElem({ + "repos": repos, + "commits": commits, + "raw_text": rawInputText + }, {reportData}, openRepoPopover)} + {ArchivedSummarySection(commentText, reportData)} + {ShowArchivedTeamSection({teamData}, closePopover)} + {showAllGraphics({"commit_nums": commitNums, "pull_requests": pullRequests, "broad_categories": broadCategories}, '#map-container', '#map-container2', '#map-container3')} +
+ +
+ ) +} diff --git a/DirectReport/browserview/static/js/archived_report_components.js b/DirectReport/browserview/static/js/archived_report_components.js new file mode 100644 index 00000000..d24ce27f --- /dev/null +++ b/DirectReport/browserview/static/js/archived_report_components.js @@ -0,0 +1,129 @@ +const EditArchiveSummaryElem = (props, state, openRepoPopover) => { + let raw_text = props['raw_text']; + return ( +
+
+

Github Data

+
+
+ {ArchivedEntry(raw_text)} +
+
+ +
+
+ ) +} + + +const ShowArchivedSummary = (report) => { + return ( +

+ {report && +

+ {report.summary} +
+ } +

+ ); +}; + +const ArchivedEntry = (raw_input) => { + return ( +
+

{raw_input}

+
+ ) +} + + +const ShowArchivedHighlights = (report) => { + if (!(report !== undefined)) { + return ( +
+ +
+ ) + } else { + return ( +
+
+
    + {/* Check if 'highlights' in report is not undefined */} + {report["highlights"] !== undefined ? + // Map each highlight to an HTML structure + report["highlights"].map(high_light => +
  • +

    + {high_light.title} +

    +

    + {high_light.description} +

    +
  • + ) : null // Render nothing if 'highlights' is undefined + } +
+
+
+ ) + } + +} + + +const ArchivedSummarySection = (commentText, reportData) => { + console.log("ArchivedSummarySection") + console.log(reportData); + return ( +
+
+

Summary

+
+
+ {ShowArchivedSummary(reportData)} + {ShowArchivedHighlights(reportData)} +
+
+
+
+ ) +} + + +const ShowArchivedTeamSection = (teamData, closePopover) => { + console.log(teamData["teamData"]); + return ( +
+
+

Team

+ {PopoverUI(closePopover)} +
+ {ShowArchivedTeamList(teamData["teamData"])} +
+
+
+ ) +} +const ShowArchivedTeamList = (team) => { + + if (!(team !== undefined)) { + return ( + null + ) + } else { + return ( +
+ {team.teamData !== undefined && team.teamData.length > 0? + team.teamData.map(team_member => + + ) : null + } +
+ ) + } +} \ No newline at end of file diff --git a/DirectReport/browserview/static/js/chart_helper.js b/DirectReport/browserview/static/js/chart_helper.js index 0d1a122b..5c9257f8 100644 --- a/DirectReport/browserview/static/js/chart_helper.js +++ b/DirectReport/browserview/static/js/chart_helper.js @@ -60,13 +60,13 @@ function showGraphics(data, divtag) { } }) .attr('y', function (value, index) { - return (chartHeight - 30) - (value[1] * 5) + return (chartHeight - 30) - (value[1] * 8) }) .attr("width", function (value, index) { return (chartWidth / data.length) - padding }) .attr("height", function (value, index) { - return value[1] * 5 + return value[1] * 8 }) .attr("fill", "blueviolet"); @@ -86,7 +86,6 @@ function showGraphics(data, divtag) { .style("font-size", "10px") .style("text-anchor", "center") .text(function (value, index) { - print(value[0].split("_")[0].slice(0, 8)) return value[0].split("_")[0].slice(0, 8) }) } @@ -128,14 +127,14 @@ function showGraphics2(data, divtag) { } }) .attr('y', function (value, index) { - return (chartHeight - 30) - (value[1] * 10) + return (chartHeight - 30) - (value[1] * 18) }) .attr("width", function (value, index) { return (chartWidth / data.length) - padding }) .attr("height", function (value, index) { // console.log(value[1] * 20) - return (value[1] * 10) - 5 + return (value[1] * 18) - 5 }) .attr("fill", "steelblue"); @@ -204,13 +203,13 @@ function showGraphics3(data, divtag) { } }) .attr('y', function (value, index) { - return (chartHeight - 30) - (value[1] * 10) + return (chartHeight - 30) - (value[1] * 17) }) .attr("width", function (value, index) { return (chartWidth / data.length) - padding }) .attr("height", function (value, index) { - return value[1] * 10 + return value[1] * 17 }) .attr("fill", "teal"); @@ -230,7 +229,7 @@ function showGraphics3(data, divtag) { .style("font-size", "8px") .style("text-anchor", "center") .text(function (value, index) { - return value[0].split("_")[0].slice(0, 6) + ' ' + value[0].split("_")[1] + return value[0].split("_")[0] }).call(wrap, 5); } diff --git a/DirectReport/browserview/static/js/teamreport/teamreport.js b/DirectReport/browserview/static/js/teamreport/teamreport.js index 99987519..36482943 100644 --- a/DirectReport/browserview/static/js/teamreport/teamreport.js +++ b/DirectReport/browserview/static/js/teamreport/teamreport.js @@ -62,7 +62,7 @@ class TeamReport extends React.Component { } handleSubmit() { - const payload = {"prompt": this.state.commentText}; + const payload = {"prompt": this.state.commentText} axios({ method: 'post', url: '/dashboard/reports/update', @@ -72,6 +72,7 @@ class TeamReport extends React.Component { "Content-Type": "application/json" } }).then(result => { + console.log(result.data); this.handleTeamDataChange(result.data["team"]); this.handleReportDataChange(result.data["report"]); showAllGraphics(result.data, '#map-container', '#map-container2', '#map-container3'); @@ -154,7 +155,7 @@ class TeamReport extends React.Component { {spinnerUI()}
{EditSummaryElem({"repos": this.state.repos, "commits": this.state.commits}, this.state, this.openRepoPopover)} - {SummarySection(this.state.teamData, this.state.reportData)} + {SummarySection(this.state.reportData)} {TeamSection(this.state.teamData, this.closePopover)}
{this.state.teamData.length <= 0 && ( diff --git a/DirectReport/browserview/static/js/teamreport/teamreport_components.js b/DirectReport/browserview/static/js/teamreport/teamreport_components.js index dcfb646f..af5611d0 100644 --- a/DirectReport/browserview/static/js/teamreport/teamreport_components.js +++ b/DirectReport/browserview/static/js/teamreport/teamreport_components.js @@ -1,10 +1,9 @@ const { useState, useEffect } = React; // Define a functional component named 'ShowSummary' -const ShowSummary = ({ report }) => { +const ShowSummary = (report) => { return (

- {/* Check if 'report' and 'report.summary' are not null or undefined */} {report && report.summary &&

{report.summary} @@ -17,8 +16,10 @@ const ShowSummary = ({ report }) => { // Define a functional component named 'ShowHighlights' const ShowHighlights = (report) => { + console.log(report); return (
+ {/*

{report}

*/}
    {/* Check if 'highlights' in report is not undefined */} {report["highlights"] !== undefined ? @@ -41,10 +42,9 @@ const ShowHighlights = (report) => { const ShowTeamList = (team) => { - console.log(team); return (
    - {team !== undefined ? + {team !== undefined && team.length > 0? team.map(team_member =>