diff options
| author | Christian Kollmann <christian.kollmann@a-sit.at> | 2021-12-02 15:03:09 +0100 | 
|---|---|---|
| committer | Christian Kollmann <christian.kollmann@a-sit.at> | 2021-12-02 16:13:48 +0100 | 
| commit | 6fff1b53525348d531c96b45c920a8ce72288f60 (patch) | |
| tree | 8db3e70ab71df189eb6cdb2bfbe28b1a67e2227c /connector/src/main/resources/templates | |
| parent | e5934d538aabcfc1f3b92472753de729d6ce1cce (diff) | |
| download | National_eIDAS_Gateway-6fff1b53525348d531c96b45c920a8ce72288f60.tar.gz National_eIDAS_Gateway-6fff1b53525348d531c96b45c920a8ce72288f60.tar.bz2 National_eIDAS_Gateway-6fff1b53525348d531c96b45c920a8ce72288f60.zip | |
Display all results to user after residency search
Diffstat (limited to 'connector/src/main/resources/templates')
| -rw-r--r-- | connector/src/main/resources/templates/residency.html | 122 | 
1 files changed, 105 insertions, 17 deletions
| diff --git a/connector/src/main/resources/templates/residency.html b/connector/src/main/resources/templates/residency.html index 38f490ca..3f0532dd 100644 --- a/connector/src/main/resources/templates/residency.html +++ b/connector/src/main/resources/templates/residency.html @@ -12,24 +12,86 @@              th:attr="src=@{/static/js/jquery-3.6.0.min.js}"></script>      <title th:text="#{gui.residency.title}">Österreichischer Wohnsitz</title>      <script type="text/javascript" th:inline="javascript"> +        $(document).ready(function () { +            $("#textResult").hide(); +            $("#tableResult").hide(); +            $("#loading").hide(); +            $.ajaxSetup({ +                beforeSend: function () { +                    $("#loading").show(); +                }, +                complete: function () { +                    $("#loading").hide(); +                } +            }); +        }); +          function search() {              let updatedText = /*[[#{gui.residency.updated}]]*/ 'Updated text';              let errorText = /*[[#{gui.residency.error}]]*/ 'Error'; +            let applyText = /*[[#{gui.residency.apply}]]*/ 'Apply'; +            let foundText = /*[[#{gui.residency.found}]]*/ 'Found {0}'; +            let uniqueText = /*[[#{gui.residency.unique}]]*/ 'Unique'; +            let invalidInputText = /*[[#{gui.residency.header.inputinvalid}]]*/ 'Invalid'; +            if (!$("#inputForm #inputMunicipality").val().trim() && !$("#inputForm #inputVillage").val().trim()) { +                $("#textResult").show().text(invalidInputText); +                return; +            }              $.ajax({                  type: "POST",                  url: "http://localhost:8080/ms_connector/residency/search",                  data: $("#inputForm").serialize()              }).done(function (data, textStatus, jqXHR) { -                $("#inputMunicipality").val(data["municipality"]); -                $("#inputVillage").val(data["village"]); -                $("#inputStreet").val(data["street"]); -                $("#inputNumber").val(data["number"]); -                $("#textInfo").text(updatedText); +                if (data["resultCount"] == 1) { +                    $("#textResult").show().text(uniqueText); +                    $("#tableResult tbody").empty(); +                    $("#tableResult").hide(); +                    $("#inputForm #inputMunicipality").val(data["results"][0]["municipality"]); +                    $("#inputForm #inputVillage").val(data["results"][0]["village"]); +                    $("#inputForm #inputStreet").val(data["results"][0]["street"]); +                    $("#inputForm #inputNumber").val(data["results"][0]["number"]); +                    return; +                } +                $("#textResult").show().text(foundText.replace("{0}", data["resultCount"])); +                $("#tableResult").show(); +                $("#tableResult tbody").empty(); +                $.each(data.results, function (i, output) { +                    $("#tableResult tbody") +                        .append($("<tr>") +                            .append($("<td>").text(output["municipality"] !== null ? output["municipality"] : "")) +                            .append($("<td>").text(output["village"] !== null ? output["village"] : "")) +                            .append($("<td>").text(output["street"] !== null ? output["street"] : "")) +                            .append($("<td>").text(output["number"] !== null ? output["number"] : "")) +                            .append($("<td>").text(applyText).attr("href", "#").click(function () { +                                $("#inputForm #inputMunicipality").val($(this).parent().children("td:nth-child(1)").text()); +                                $("#inputForm #inputVillage").val($(this).parent().children("td:nth-child(2)").text()); +                                $("#inputForm #inputStreet").val($(this).parent().children("td:nth-child(3)").text()); +                                $("#inputForm #inputNumber").val($(this).parent().children("td:nth-child(4)").text()); +                                $("#textResult").show().text(updatedText); +                                search(); +                            })) +                        ); +                })              }).fail(function (jqXHR, textStatus, errorThrown) { -                $("#textInfo").text(errorText); +                $("#textResult").show().text(errorText);              })          } + +        function clearInput() { +            $("#inputForm #inputMunicipality").val(""); +            $("#inputForm #inputVillage").val(""); +            $("#inputForm #inputStreet").val(""); +            $("#inputForm #inputNumber").val(""); +            $("#textResult").hide(); +            $("#tableResult").hide(); +        }      </script> +    <style> +        td { +            padding: 0.5em; +            margin: 0.5em; +        } +    </style>  </head>  <body> @@ -41,38 +103,64 @@      <h2 th:text="#{gui.residency.header.selection}">Search your Austrian Residency</h2>      <div id="residency"> -        <div> -            <p><span id="textInfo">Infotext</span></p> -        </div>          <form id="inputForm" method="post" action="$contextPath$submitEndpoint"                th:attr="action=@{${submitEndpoint}}"> +            <div th:text="#{gui.residency.header.help}">Please enter a Municipality or Village first</div>              <div> -                <label for="inputMunicipality">Municipality</label> -                <input type="text" id="inputMunicipality" name="municipality" value="Municipality"/> +                <label for="inputMunicipality" th:text="#{gui.residency.input.municipality}">Municipality</label> +                <input type="text" id="inputMunicipality" name="municipality" value=""/>              </div>              <div> -                <label for="inputVillage">Village</label> -                <input type="text" id="inputVillage" name="village" value="Village"/> +                <label for="inputVillage" th:text="#{gui.residency.input.village}">Village</label> +                <input type="text" id="inputVillage" name="village" value=""/>              </div>              <div> -                <label for="inputStreet">Street</label> -                <input type="text" id="inputStreet" name="street" value="Street"/> +                <label for="inputStreet" th:text="#{gui.residency.input.street}">Street</label> +                <input type="text" id="inputStreet" name="street" value=""/>              </div>              <div> -                <label for="inputNumber">Number</label> -                <input type="text" id="inputNumber" name="number" value="Number"/> +                <label for="inputNumber" th:text="#{gui.residency.input.number}">Number</label> +                <input type="text" id="inputNumber" name="number" value=""/>              </div>              <div>                  <button type="button" class="block" onclick="search()" th:attr="value=#{gui.residency.search}">Search                  </button>              </div>              <div> +                <button type="button" class="block" onclick="clearInput()" th:attr="value=#{gui.residency.clear}">Clear +                </button> +            </div> +            <div>                  <button type="button" class="block" th:attr="value=#{gui.residency.proceed}">Proceed</button>              </div> +            <div> +                <img id="loading"  src="$contextPath/static/img/ajax-loader.gif" +                     th:attr="src=@{/static/img/ajax-loader.gif}" /> +            </div>              <input type="hidden" name="pendingid" value="$pendingid" th:attr="value=${pendingid}"/>          </form>      </div> +    <div id="result"> +        <div> +            <p><span id="textResult"></span></p> +        </div> +        <table id="tableResult"> +            <thead> +            <tr> +                <th th:text="#{gui.residency.input.municipality}">Municipality</th> +                <th th:text="#{gui.residency.input.village}">Village</th> +                <th th:text="#{gui.residency.input.street}">Street</th> +                <th th:text="#{gui.residency.input.number}">Number</th> +                <th th:text="#{gui.residency.apply}">Apply</th> +            </tr> +            </thead> +            <tbody> + +            </tbody> +        </table> +    </div> +      <form class="block" method="post" action="$contextPath$submitEndpoint" th:attr="action=@{${submitEndpoint}}">          <input type="submit" class="btn btn-outline-primary btn-block" value="Abbrechen/Cancel"                 th:attr="value=#{gui.residency.cancel}"> | 
