resources/src/mediawiki.htmlform/cloner.js
/*
* HTMLForm enhancements:
* Add/remove cloner clones without having to resubmit the form.
*/
var cloneCounter = 0;
/**
* Appends a new row with fields to the cloner.
*
* @ignore
* @param {jQuery} $createButton
*/
function appendToCloner( $createButton ) {
var $ul = $createButton.prev( 'ul.mw-htmlform-cloner-ul' ),
// eslint-disable-next-line security/detect-non-literal-regexp
cloneRegex = new RegExp( mw.util.escapeRegExp( $ul.data( 'uniqueId' ) ), 'g' ),
// Assume the ids that need to be made unique will start with 'ooui-php-'. See T274533
inputIdRegex = new RegExp( /(ooui-php-[0-9]*)/, 'gm' );
++cloneCounter;
var html = $ul.data( 'template' )
.replace( cloneRegex, 'clone' + cloneCounter )
.replace( inputIdRegex, '$1-clone' + cloneCounter );
var $li = $( '<li>' )
.addClass( 'mw-htmlform-cloner-li' )
.html( html )
.appendTo( $ul );
mw.hook( 'htmlform.enhance' ).fire( $li );
}
mw.hook( 'htmlform.enhance' ).add( function ( $root ) {
var $deleteElement = $root.find( '.mw-htmlform-cloner-delete-button' ),
$createElement = $root.find( '.mw-htmlform-cloner-create-button' );
$deleteElement.each( function () {
var $element = $( this );
// eslint-disable-next-line no-jquery/no-class-state
if ( $element.hasClass( 'oo-ui-widget' ) ) {
var deleteButton = OO.ui.infuse( $element );
deleteButton.on( 'click', function () {
deleteButton.$element.closest( 'li.mw-htmlform-cloner-li' ).remove();
} );
} else {
// eslint-disable-next-line no-jquery/no-sizzle
$element.filter( ':input' ).on( 'click', function ( e ) {
e.preventDefault();
$( this ).closest( 'li.mw-htmlform-cloner-li' ).remove();
} );
}
} );
$createElement.each( function () {
var $element = $( this );
// eslint-disable-next-line no-jquery/no-class-state
if ( $element.hasClass( 'oo-ui-widget' ) ) {
var createButton = OO.ui.infuse( $element );
createButton.on( 'click', function () {
appendToCloner( createButton.$element );
} );
} else {
// eslint-disable-next-line no-jquery/no-sizzle
$element.filter( ':input' ).on( 'click', function ( e ) {
e.preventDefault();
appendToCloner( $( this ) );
} );
}
} );
} );