mirror of
https://github.com/moodle/moodle.git
synced 2025-03-14 04:30:15 +01:00
Merge branch 'MDL-43969-master' of git://github.com/andrewnicols/moodle
This commit is contained in:
commit
f10418699d
@ -19,8 +19,10 @@ function SHORTFORMS() {
|
||||
|
||||
var SELECTORS = {
|
||||
COLLAPSEEXPAND: '.collapsible-actions .collapseexpand',
|
||||
COLLAPSED: '.collapsed',
|
||||
FIELDSETCOLLAPSIBLE: 'fieldset.collapsible',
|
||||
FIELDSETLEGENDLINK: 'fieldset.collapsible .fheader',
|
||||
FHEADER: '.fheader',
|
||||
LEGENDFTOGGLER: 'legend.ftoggler'
|
||||
},
|
||||
CSS = {
|
||||
@ -120,6 +122,11 @@ Y.extend(SHORTFORMS, Y.Base, {
|
||||
headerlink.appendChild(legendelement.get('firstChild'));
|
||||
headerlink.setAttribute('role', 'button');
|
||||
headerlink.setAttribute('aria-controls', fieldset.generateID());
|
||||
if (legendelement.ancestor(SELECTORS.COLLAPSED)) {
|
||||
headerlink.setAttribute('aria-expanded', 'false');
|
||||
} else {
|
||||
headerlink.setAttribute('aria-expanded', 'true');
|
||||
}
|
||||
legendelement.prepend(headerlink);
|
||||
|
||||
return this;
|
||||
@ -134,10 +141,17 @@ Y.extend(SHORTFORMS, Y.Base, {
|
||||
* @chainable
|
||||
*/
|
||||
set_state: function(fieldset, collapsed) {
|
||||
headerlink = fieldset.one(SELECTORS.FHEADER);
|
||||
if (collapsed) {
|
||||
fieldset.addClass(CSS.COLLAPSED);
|
||||
if (headerlink) {
|
||||
headerlink.setAttribute('aria-expanded', 'false');
|
||||
}
|
||||
} else {
|
||||
fieldset.removeClass(CSS.COLLAPSED);
|
||||
if (headerlink) {
|
||||
headerlink.setAttribute('aria-expanded', 'true');
|
||||
}
|
||||
}
|
||||
var statuselement = this.form.one('input[name=mform_isexpanded_'+fieldset.get('id')+']');
|
||||
if (!statuselement) {
|
||||
|
@ -1 +1 @@
|
||||
YUI.add("moodle-form-shortforms",function(e,t){function n(){n.superclass.constructor.apply(this,arguments)}var r={COLLAPSEEXPAND:".collapsible-actions .collapseexpand",FIELDSETCOLLAPSIBLE:"fieldset.collapsible",FIELDSETLEGENDLINK:"fieldset.collapsible .fheader",LEGENDFTOGGLER:"legend.ftoggler"},i={COLLAPSEALL:"collapse-all",COLLAPSED:"collapsed",FHEADER:"fheader"},s={};s.formid={value:null},e.extend(n,e.Base,{form:null,initializer:function(){var t=e.one("#"+this.get("formid")),n,i,s,o;if(!t)return;this.form=t,n=t.all(r.FIELDSETCOLLAPSIBLE),n.each(this.process_fieldset,this),t.delegate("click",this.switch_state,r.FIELDSETLEGENDLINK,this),t.delegate("key",this.switch_state,"down:enter,32",r.FIELDSETLEGENDLINK,this),i=t.one(r.COLLAPSEEXPAND),i&&(s=e.Node.create('<a href="#"></a>'),s.setHTML(i.getHTML()),s.setAttribute("class",i.getAttribute("class")),s.setAttribute("role","button"),o=[],t.all(r.FIELDSETLEGENDLINK).each(function(e){o[o.length]=e.generateID()}),s.setAttribute("aria-controls",o.join(" ")),s.on("click",this.set_state_all,this,!0),s.on("key",this.set_state_all,"down:enter,32",this,!0),i.replace(s),this.update_btns(t))},process_fieldset:function(t){var n=t.one(r.LEGENDFTOGGLER),s=e.Node.create('<a href="#"></a>');return s.addClass(i.FHEADER),s.appendChild(n.get("firstChild")),s.setAttribute("role","button"),s.setAttribute("aria-controls",t.generateID()),n.prepend(s),this},set_state:function(e,t){t?e.addClass(i.COLLAPSED):e.removeClass(i.COLLAPSED);var n=this.form.one("input[name=mform_isexpanded_"+e.get("id")+"]");return n?(n.set("value",t?0:1),this):this},set_state_all:function(e){e.preventDefault();var t=e.target.hasClass(i.COLLAPSEALL),n=this.form.all(r.FIELDSETCOLLAPSIBLE);n.each(function(e){this.set_state(e,t)},this),this.update_btns()},switch_state:function(e){e.preventDefault();var t=e.target.ancestor(r.FIELDSETCOLLAPSIBLE);this.set_state(t,!t.hasClass(i.COLLAPSED)),this.update_btns()},update_btns:function(){var e,t=0,n=!1,s;return e=this.form.one(r.COLLAPSEEXPAND),e?(s=this.form.all(r.FIELDSETCOLLAPSIBLE),s.each(function(e){e.hasClass(i.COLLAPSED)&&t++}),t!==0&&(n=!0),n?(e.removeClass(i.COLLAPSEALL),e.setHTML(M.util.get_string("expandall","moodle"))):(e.addClass(i.COLLAPSEALL),e.setHTML(M.util.get_string("collapseall","moodle"))),this):this}},{NAME:"moodle-form-shortforms",ATTRS:s}),M.form=M.form||{},M.form.shortforms=M.form.shortforms||function(e){return new n(e)}},"@VERSION@",{requires:["node","base","selector-css3"]});
|
||||
YUI.add("moodle-form-shortforms",function(e,t){function n(){n.superclass.constructor.apply(this,arguments)}var r={COLLAPSEEXPAND:".collapsible-actions .collapseexpand",COLLAPSED:".collapsed",FIELDSETCOLLAPSIBLE:"fieldset.collapsible",FIELDSETLEGENDLINK:"fieldset.collapsible .fheader",FHEADER:".fheader",LEGENDFTOGGLER:"legend.ftoggler"},i={COLLAPSEALL:"collapse-all",COLLAPSED:"collapsed",FHEADER:"fheader"},s={};s.formid={value:null},e.extend(n,e.Base,{form:null,initializer:function(){var t=e.one("#"+this.get("formid")),n,i,s,o;if(!t)return;this.form=t,n=t.all(r.FIELDSETCOLLAPSIBLE),n.each(this.process_fieldset,this),t.delegate("click",this.switch_state,r.FIELDSETLEGENDLINK,this),t.delegate("key",this.switch_state,"down:enter,32",r.FIELDSETLEGENDLINK,this),i=t.one(r.COLLAPSEEXPAND),i&&(s=e.Node.create('<a href="#"></a>'),s.setHTML(i.getHTML()),s.setAttribute("class",i.getAttribute("class")),s.setAttribute("role","button"),o=[],t.all(r.FIELDSETLEGENDLINK).each(function(e){o[o.length]=e.generateID()}),s.setAttribute("aria-controls",o.join(" ")),s.on("click",this.set_state_all,this,!0),s.on("key",this.set_state_all,"down:enter,32",this,!0),i.replace(s),this.update_btns(t))},process_fieldset:function(t){var n=t.one(r.LEGENDFTOGGLER),s=e.Node.create('<a href="#"></a>');return s.addClass(i.FHEADER),s.appendChild(n.get("firstChild")),s.setAttribute("role","button"),s.setAttribute("aria-controls",t.generateID()),n.ancestor(r.COLLAPSED)?s.setAttribute("aria-expanded","false"):s.setAttribute("aria-expanded","true"),n.prepend(s),this},set_state:function(e,t){headerlink=e.one(r.FHEADER),t?(e.addClass(i.COLLAPSED),headerlink&&headerlink.setAttribute("aria-expanded","false")):(e.removeClass(i.COLLAPSED),headerlink&&headerlink.setAttribute("aria-expanded","true"));var n=this.form.one("input[name=mform_isexpanded_"+e.get("id")+"]");return n?(n.set("value",t?0:1),this):this},set_state_all:function(e){e.preventDefault();var t=e.target.hasClass(i.COLLAPSEALL),n=this.form.all(r.FIELDSETCOLLAPSIBLE);n.each(function(e){this.set_state(e,t)},this),this.update_btns()},switch_state:function(e){e.preventDefault();var t=e.target.ancestor(r.FIELDSETCOLLAPSIBLE);this.set_state(t,!t.hasClass(i.COLLAPSED)),this.update_btns()},update_btns:function(){var e,t=0,n=!1,s;return e=this.form.one(r.COLLAPSEEXPAND),e?(s=this.form.all(r.FIELDSETCOLLAPSIBLE),s.each(function(e){e.hasClass(i.COLLAPSED)&&t++}),t!==0&&(n=!0),n?(e.removeClass(i.COLLAPSEALL),e.setHTML(M.util.get_string("expandall","moodle"))):(e.addClass(i.COLLAPSEALL),e.setHTML(M.util.get_string("collapseall","moodle"))),this):this}},{NAME:"moodle-form-shortforms",ATTRS:s}),M.form=M.form||{},M.form.shortforms=M.form.shortforms||function(e){return new n(e)}},"@VERSION@",{requires:["node","base","selector-css3"]});
|
||||
|
@ -19,8 +19,10 @@ function SHORTFORMS() {
|
||||
|
||||
var SELECTORS = {
|
||||
COLLAPSEEXPAND: '.collapsible-actions .collapseexpand',
|
||||
COLLAPSED: '.collapsed',
|
||||
FIELDSETCOLLAPSIBLE: 'fieldset.collapsible',
|
||||
FIELDSETLEGENDLINK: 'fieldset.collapsible .fheader',
|
||||
FHEADER: '.fheader',
|
||||
LEGENDFTOGGLER: 'legend.ftoggler'
|
||||
},
|
||||
CSS = {
|
||||
@ -119,6 +121,11 @@ Y.extend(SHORTFORMS, Y.Base, {
|
||||
headerlink.appendChild(legendelement.get('firstChild'));
|
||||
headerlink.setAttribute('role', 'button');
|
||||
headerlink.setAttribute('aria-controls', fieldset.generateID());
|
||||
if (legendelement.ancestor(SELECTORS.COLLAPSED)) {
|
||||
headerlink.setAttribute('aria-expanded', 'false');
|
||||
} else {
|
||||
headerlink.setAttribute('aria-expanded', 'true');
|
||||
}
|
||||
legendelement.prepend(headerlink);
|
||||
|
||||
return this;
|
||||
@ -133,10 +140,17 @@ Y.extend(SHORTFORMS, Y.Base, {
|
||||
* @chainable
|
||||
*/
|
||||
set_state: function(fieldset, collapsed) {
|
||||
headerlink = fieldset.one(SELECTORS.FHEADER);
|
||||
if (collapsed) {
|
||||
fieldset.addClass(CSS.COLLAPSED);
|
||||
if (headerlink) {
|
||||
headerlink.setAttribute('aria-expanded', 'false');
|
||||
}
|
||||
} else {
|
||||
fieldset.removeClass(CSS.COLLAPSED);
|
||||
if (headerlink) {
|
||||
headerlink.setAttribute('aria-expanded', 'true');
|
||||
}
|
||||
}
|
||||
var statuselement = this.form.one('input[name=mform_isexpanded_'+fieldset.get('id')+']');
|
||||
if (!statuselement) {
|
||||
|
14
lib/form/yui/src/shortforms/js/shortforms.js
vendored
14
lib/form/yui/src/shortforms/js/shortforms.js
vendored
@ -17,8 +17,10 @@ function SHORTFORMS() {
|
||||
|
||||
var SELECTORS = {
|
||||
COLLAPSEEXPAND: '.collapsible-actions .collapseexpand',
|
||||
COLLAPSED: '.collapsed',
|
||||
FIELDSETCOLLAPSIBLE: 'fieldset.collapsible',
|
||||
FIELDSETLEGENDLINK: 'fieldset.collapsible .fheader',
|
||||
FHEADER: '.fheader',
|
||||
LEGENDFTOGGLER: 'legend.ftoggler'
|
||||
},
|
||||
CSS = {
|
||||
@ -118,6 +120,11 @@ Y.extend(SHORTFORMS, Y.Base, {
|
||||
headerlink.appendChild(legendelement.get('firstChild'));
|
||||
headerlink.setAttribute('role', 'button');
|
||||
headerlink.setAttribute('aria-controls', fieldset.generateID());
|
||||
if (legendelement.ancestor(SELECTORS.COLLAPSED)) {
|
||||
headerlink.setAttribute('aria-expanded', 'false');
|
||||
} else {
|
||||
headerlink.setAttribute('aria-expanded', 'true');
|
||||
}
|
||||
legendelement.prepend(headerlink);
|
||||
|
||||
return this;
|
||||
@ -132,10 +139,17 @@ Y.extend(SHORTFORMS, Y.Base, {
|
||||
* @chainable
|
||||
*/
|
||||
set_state: function(fieldset, collapsed) {
|
||||
headerlink = fieldset.one(SELECTORS.FHEADER);
|
||||
if (collapsed) {
|
||||
fieldset.addClass(CSS.COLLAPSED);
|
||||
if (headerlink) {
|
||||
headerlink.setAttribute('aria-expanded', 'false');
|
||||
}
|
||||
} else {
|
||||
fieldset.removeClass(CSS.COLLAPSED);
|
||||
if (headerlink) {
|
||||
headerlink.setAttribute('aria-expanded', 'true');
|
||||
}
|
||||
}
|
||||
var statuselement = this.form.one('input[name=mform_isexpanded_'+fieldset.get('id')+']');
|
||||
if (!statuselement) {
|
||||
|
@ -2549,7 +2549,7 @@ class MoodleQuickForm_Renderer extends HTML_QuickForm_Renderer_Tableless{
|
||||
"\n\t\t<legend class=\"ftoggler\">{header}</legend>\n\t\t<div class=\"fcontainer clearfix\">\n\t\t";
|
||||
|
||||
/** @var string Template used when opening a fieldset */
|
||||
var $_openFieldsetTemplate = "\n\t<fieldset class=\"{classes}\" {id} {aria-live}>";
|
||||
var $_openFieldsetTemplate = "\n\t<fieldset class=\"{classes}\" {id}>";
|
||||
|
||||
/** @var string Template used when closing a fieldset */
|
||||
var $_closeFieldsetTemplate = "\n\t\t</div></fieldset>";
|
||||
@ -2833,7 +2833,6 @@ class MoodleQuickForm_Renderer extends HTML_QuickForm_Renderer_Tableless{
|
||||
$fieldsetclasses = array('clearfix');
|
||||
if (isset($this->_collapsibleElements[$header->getName()])) {
|
||||
$fieldsetclasses[] = 'collapsible';
|
||||
$arialive = 'aria-live="polite"';
|
||||
if ($this->_collapsibleElements[$header->getName()]) {
|
||||
$fieldsetclasses[] = 'collapsed';
|
||||
}
|
||||
@ -2845,7 +2844,6 @@ class MoodleQuickForm_Renderer extends HTML_QuickForm_Renderer_Tableless{
|
||||
|
||||
$openFieldsetTemplate = str_replace('{id}', $id, $this->_openFieldsetTemplate);
|
||||
$openFieldsetTemplate = str_replace('{classes}', join(' ', $fieldsetclasses), $openFieldsetTemplate);
|
||||
$openFieldsetTemplate = str_replace('{aria-live}', $arialive, $openFieldsetTemplate);
|
||||
|
||||
$this->_html .= $openFieldsetTemplate . $header_html;
|
||||
$this->_fieldsetsOpen++;
|
||||
|
Loading…
x
Reference in New Issue
Block a user