{{!
    This file is part of Moodle - http://moodle.org/

    Moodle is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    Moodle is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
}}
{{!
    @template core/loginform

    Moodle template for the login page.

    Context variables required for this template:
    * autofocusform: Auto focus on form ?,
    * canloginasguest - Is guest login allowed?,
    * canloginbyemail - Is login by email allowed?,
    * cansignup - Signup allowed?,
    * cookieshelpicon - cookies help icon details
    * error - Any errors in the form?,
    * forgotpasswordurl - Forgot password url,
    * hasidentityproviders - Flag, set to true to hide identity providers,
    * hasinstructions - Flag, set to true to show instructions,
    * identityproviders - List of identiy providers,
    * instructions - Instructions,
    * instructionsformat - Format of instructions,
    * loginurl - Login url,
    * rememberusername - Remeber username?,
    * passwordautocomplete - Allow password autocomplete?,
    * signupurl - Signup url,
    * cookieshelpiconformatted - Formatted html of cookies help icon,
    * errorformatted - Formatted error,
    * logourl - Flag, logo url,
    * sitename - Name of site.
    * logintoken - Random token to protect login request.

    Example context (json):
    {
        "autofocusform": true,
        "canloginasguest": "1",
        "canloginbyemail": false,
        "cansignup": true,
        "cookieshelpicon": {
            "heading": "Cookies must be enabled in your browser",
            "text": "<div class=\"no-overflow\">Two cookies are used on this site. Both died..</div>",
            "icon": {
                "attributes": [
                    {
                        "name": "class",
                        "value": "iconhelp"
                    },
                    {
                        "name": "alt",
                        "value": "Help with Cookies must be enabled in your browser"
                    },
                    {
                        "name": "title",
                        "value": "Help with Cookies must be enabled in your browser"
                    },
                    {
                        "name": "src",
                        "value": "http://localhost/stable_master/theme/image.php?theme=boost&component=core&image=help"
                    }
                ]
            },
            "linktext": null,
            "title": "Help with Cookies must be enabled in your browser",
            "url": "http://localhost/stable_master/help.php?component=core&identifier=cookiesenabled&lang=en",
            "ltr": true
        },
        "error": "",
        "forgotpasswordurl": "http://localhost/stable_master/login/forgot_password.php",
        "hasidentityproviders": false,
        "hasinstructions": true,
        "identityproviders": [],
        "instructions": "For full access to this site, you first need to create an account.",
        "instructionsformat": "1",
        "loginurl": "http://localhost/stable_master/login/index.php",
        "rememberusername": true,
        "passwordautocomplete": false,
        "signupurl": "http://localhost/stable_master/login/signup.php",
        "cookieshelpiconformatted": "",
        "errorformatted": "",
        "logourl": false,
        "sitename": "Beer & Chips"
        "logintoken": "randomstring"
    }
}}

<div class="m-y-3 hidden-sm-down"></div>
<div class="snap-login">
    {{#logourl}}
    <h2 class="snap-logo-sitename text-center">{{sitename}}</h2>
    {{/logourl}}
    {{^logourl}}
    <h2 class="text-center">{{sitename}}</h2>
    {{/logourl}}

    {{#error}}
        <div class="loginerrors">
            <a href="#" id="loginerrormessage" class="accesshide">{{error}}</a>
            <div class="alert alert-danger" role="alert">{{error}}</div>
        </div>
    {{/error}}

    <form action="{{loginurl}}" method="post" id="login" {{^passwordautocomplete}}autocomplete="off"{{/passwordautocomplete}} class="snap-custom-form">
        <input type="hidden" name="logintoken" value="{{logintoken}}">
        <input id="anchor" type="hidden" name="anchor" value="">
        <script>document.getElementById('anchor').value = location.hash;</script>

        <label for="username" class="sr-only">
            {{^canloginbyemail}}
                {{#str}} username {{/str}}
            {{/canloginbyemail}}
            {{#canloginbyemail}}
                {{#str}} usernameemail {{/str}}
            {{/canloginbyemail}}
        </label>
        <input type="text" name="username" id="username"
            class="form-control"
            value="{{username}}"
            placeholder={{#quote}}{{^canloginbyemail}}{{#str}}username{{/str}}{{/canloginbyemail}}{{#canloginbyemail}}{{#str}}usernameemail{{/str}}{{/canloginbyemail}}{{/quote}}>
        <label for="password" class="sr-only">{{#str}} password {{/str}}</label>
        <input type="password" name="password" id="password" value=""
            class="form-control"
            placeholder={{#quote}}{{#str}}password{{/str}}{{/quote}}
            {{^passwordautocomplete}}autocomplete="off"{{/passwordautocomplete}}>
        <br>
        <button type="submit" class="btn btn-primary btn-block" id="loginbtn">{{#str}}login{{/str}}</button>
        <a class="small btn btn-link btn-block" href="{{forgotpasswordurl}}">{{#str}}forgotten{{/str}}</a>
    </form>

    {{#hasidentityproviders}}
        <h5>{{#str}} potentialidps, auth {{/str}}</h5>
        <div class="potentialidplist">
            {{#identityproviders}}
                <div class="potentialidp">
                    <a href="{{url}}" title={{#quote}}{{name}}{{/quote}}>
                        {{#iconurl}}
                            <img class="auth-icon" src="{{iconurl}}"/>
                        {{/iconurl}}
                        {{^iconurl}}
                            {{#pix}} /i/permissions, core {{/pix}}
                        {{/iconurl}}
                        {{name}}
                    </a>
                </div>
            {{/identityproviders}}
        </div>
    {{/hasidentityproviders}}

</div>

{{#hasinstructions}}
    <div class="js-only snap-login">
        <div class="snap-login-instructions">
            <a class="btn btn-primary btn-block iconhelp" href="#" data-toggle="modal" data-target="#login-help-modal">
                {{#str}}helpwithlogin, theme_snap{{/str}} {{#pix}}help, theme_snap, {{#str}}helpwithlogin, theme_snap{{/str}} {{/pix}}
            </a>
            <!-- Modal -->
            <div class="modal fade" id="login-help-modal" tabindex="-1" role="dialog" aria-labelledby="login-help-modal-title" aria-hidden="true">
              <div class="modal-dialog" role="document">
                <div class="modal-content">
                  <div class="modal-header">
                    <button type="button" class="close" data-dismiss="modal" aria-label="{{#str}}closebuttontitle{{/str}}">
                      <span aria-hidden="true">&times;</span>
                    </button>
                    <h5 class="modal-title" id="login-help-modal-title">{{#str}}helpwithlogin, theme_snap{{/str}}</h5>
                  </div>
                  <div class="modal-body summary">
                      <br>
                      {{{instructions}}}
                  </div>
                </div>
              </div>
            </div>
        </div>
    </div>
{{/hasinstructions}}
{{#cansignup}}
    <div class="snap-login">
        <h5>{{#str}}firsttime{{/str}}</h5>
        <p><a class="btn btn-primary btn-block" href="{{signupurl}}">{{#str}}startsignup{{/str}}</a></p>
    </div>
{{/cansignup}}

{{#canloginasguest}}
    <div class="snap-login">
        <h5>{{#str}}someallowguest{{/str}}</h5>
        <form action="{{loginurl}}" method="post" id="guestlogin">
            <input type="hidden" name="username" value="guest" />
            <input type="hidden" name="password" value="guest" />
            <button class="btn btn-secondary btn-block" type="submit">{{#str}}loginguest{{/str}}</button>
        </form>
    </div>
{{/canloginasguest}}


{{#js}}
    require(['jquery', 'core/yui'], function($, Y) {
    {{#error}}
        $(function() {
            M.util.focus_login_error(Y);
        });
    {{/error}}
    {{^error}}
        {{#autofocusform}}
            $(function() {
                M.util.focus_login_form(Y);
            });
        {{/autofocusform}}
    {{/error}}
    });



{{/js}}

