Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
{{!
2
    This file is part of Moodle - http://moodle.org/
3
 
4
    Moodle is free software: you can redistribute it and/or modify
5
    it under the terms of the GNU General Public License as published by
6
    the Free Software Foundation, either version 3 of the License, or
7
    (at your option) any later version.
8
 
9
    Moodle is distributed in the hope that it will be useful,
10
    but WITHOUT ANY WARRANTY; without even the implied warranty of
11
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
    GNU General Public License for more details.
13
 
14
    You should have received a copy of the GNU General Public License
15
    along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
16
}}
17
{{!
18
    @template core/form_autocomplete_input
19
 
20
    Moodle template for the input field in an autocomplate form element.
21
 
22
    Classes required for JS:
23
    * none
24
 
25
    Data attributes required for JS:
26
    * none
27
 
28
    Context variables required for this template:
29
    * inputId The dom id of this input field.
30
    * suggestionsId The dom id of the suggestions list.
31
    * selectionId The dom id of the current selection list.
32
    * downArrowId The dom id of the down arrow to open the suggestions.
33
    * placeholder The place holder text when the field is empty
34
 
35
    Example context (json):
36
    { "inputID": 1, "suggestionsId": 2, "selectionId": 3, "downArrowId": 4, "placeholder": "Select something" }
37
}}
38
{{#showSuggestions}}
39
<div class="d-md-inline-block mr-md-2 position-relative">
40
    <input type="text"{{!
41
    }} id="{{inputId}}"{{!
42
    }} class="form-control"{{!
43
    }} list="{{suggestionsId}}"{{!
44
    }} placeholder="{{placeholder}}"{{!
45
    }} role="combobox"{{!
46
    }} aria-expanded="false"{{!
47
    }} autocomplete="off"{{!
48
    }} autocorrect="off"{{!
49
    }} autocapitalize="off"{{!
50
    }} aria-autocomplete="list"{{!
51
    }} aria-owns="{{suggestionsId}} {{selectionId}}"{{!
52
    }} {{#tags}}data-tags="1"{{/tags}}{{!
53
    }} {{#multiple}}data-multiple="multiple"{{/multiple}}{{!
54
    }}>
55
    <span class="form-autocomplete-downarrow" id="{{downArrowId}}">
56
        <svg width="18" height="18" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
57
            <path d="M12 15.25L16.25 9.75H7.75L12 15.25Z" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
58
        </svg>
59
    </span>
60
</div>
61
{{/showSuggestions}}
62
{{^showSuggestions}}
63
<div class="d-md-inline-block mr-md-2">
64
    <input type="text"{{!
65
    }} id="{{inputId}}"{{!
66
    }} class="form-control"{{!
67
    }} placeholder="{{placeholder}}"{{!
68
    }} role="textbox"{{!
69
    }} aria-owns="{{selectionId}}"{{!
70
    }} {{#tags}}data-tags="1"{{/tags}}{{!
71
    }} {{#multiple}}data-multiple="multiple"{{/multiple}}{{!
72
    }}>
73
</div>
74
{{/showSuggestions}}
75
 
76
{{#js}}
77
require(['jquery'], function($) {
78
    // Set the minimum width of the input so that the placeholder is whole displayed.
79
    var inputElement = $(document.getElementById('{{inputId}}'));
80
    if (inputElement.length) {
81
        inputElement.css('min-width', inputElement.attr('placeholder').length + 'ch');
82
    }
83
});
84
{{/js}}