diff options
Diffstat (limited to 'skins/common/upload.js')
-rw-r--r-- | skins/common/upload.js | 343 |
1 files changed, 343 insertions, 0 deletions
diff --git a/skins/common/upload.js b/skins/common/upload.js new file mode 100644 index 0000000..f40f62e --- /dev/null +++ b/skins/common/upload.js @@ -0,0 +1,343 @@ +function licenseSelectorCheck() { + var selector = document.getElementById( "wpLicense" ); + var selection = selector.options[selector.selectedIndex].value; + if( selector.selectedIndex > 0 ) { + if( selection == "" ) { + // Option disabled, but browser is broken and doesn't respect this + selector.selectedIndex = 0; + } + } + // We might show a preview + wgUploadLicenseObj.fetchPreview( selection ); +} + +function wgUploadSetup() { + // Disable URL box if the URL copy upload source type is not selected + var e = document.getElementById( 'wpSourceTypeURL' ); + if( e ) { + if( !e.checked ) { + var ein = document.getElementById( 'wpUploadFileURL' ); + if(ein) + ein.setAttribute( 'disabled', 'disabled' ); + } + } + + // For MSIE/Mac: non-breaking spaces cause the <option> not to render. + // But for some reason, setting the text to itself works + var selector = document.getElementById("wpLicense"); + if (selector) { + var ua = navigator.userAgent; + var isMacIe = (ua.indexOf("MSIE") != -1) && (ua.indexOf("Mac") != -1); + if (isMacIe) { + for (var i = 0; i < selector.options.length; i++) { + selector.options[i].text = selector.options[i].text; + } + } + } + + // Toggle source type + var sourceTypeCheckboxes = document.getElementsByName( 'wpSourceType' ); + for ( var i = 0; i < sourceTypeCheckboxes.length; i++ ) { + sourceTypeCheckboxes[i].onchange = toggleUploadInputs; + } + + // AJAX wpDestFile warnings + if ( wgAjaxUploadDestCheck ) { + // Insert an event handler that fetches upload warnings when wpDestFile + // has been changed + document.getElementById( 'wpDestFile' ).onchange = function ( e ) { + wgUploadWarningObj.checkNow(this.value); + }; + // Insert a row where the warnings will be displayed just below the + // wpDestFile row + var optionsTable = document.getElementById( 'mw-htmlform-description' ).tBodies[0]; + var row = optionsTable.insertRow( 1 ); + var td = document.createElement( 'td' ); + td.id = 'wpDestFile-warning'; + td.colSpan = 2; + + row.appendChild( td ); + } + + if ( wgAjaxLicensePreview ) { + // License selector check + document.getElementById( 'wpLicense' ).onchange = licenseSelectorCheck; + + // License selector table row + var wpLicense = document.getElementById( 'wpLicense' ); + var wpLicenseRow = wpLicense.parentNode.parentNode; + var wpLicenseTbody = wpLicenseRow.parentNode; + + var row = document.createElement( 'tr' ); + var td = document.createElement( 'td' ); + row.appendChild( td ); + td = document.createElement( 'td' ); + td.id = 'mw-license-preview'; + row.appendChild( td ); + + wpLicenseTbody.insertBefore( row, wpLicenseRow.nextSibling ); + } + + + // fillDestFile setup + for ( var i = 0; i < wgUploadSourceIds.length; i++ ) + document.getElementById( wgUploadSourceIds[i] ).onchange = function (e) { + fillDestFilename( this.id ); + }; +} + +/** + * Iterate over all upload source fields and disable all except the selected one. + * + * @param enabledId The id of the selected radio button + * @return emptiness + */ +function toggleUploadInputs() { + // Iterate over all rows with UploadSourceField + var rows; + if ( document.getElementsByClassName ) { + rows = document.getElementsByClassName( 'mw-htmlform-field-UploadSourceField' ); + } else { + // Older browsers don't support getElementsByClassName + rows = new Array(); + + var allRows = document.getElementsByTagName( 'tr' ); + for ( var i = 0; i < allRows.length; i++ ) { + if ( allRows[i].className == 'mw-htmlform-field-UploadSourceField' ) + rows.push( allRows[i] ); + } + } + + for ( var i = 0; i < rows.length; i++ ) { + var inputs = rows[i].getElementsByTagName( 'input' ); + + // Check if this row is selected + var isChecked = true; // Default true in case wpSourceType is not found + for ( var j = 0; j < inputs.length; j++ ) { + if ( inputs[j].name == 'wpSourceType' ) + isChecked = inputs[j].checked; + } + + // Disable all unselected rows + for ( var j = 0; j < inputs.length; j++ ) { + if ( inputs[j].type != 'radio') + inputs[j].disabled = !isChecked; + } + } +} + +var wgUploadWarningObj = { + 'responseCache' : { '' : ' ' }, + 'nameToCheck' : '', + 'typing': false, + 'delay': 500, // ms + 'timeoutID': false, + + 'keypress': function () { + if ( !wgAjaxUploadDestCheck || !sajax_init_object() ) return; + + // Find file to upload + var destFile = document.getElementById('wpDestFile'); + var warningElt = document.getElementById( 'wpDestFile-warning' ); + if ( !destFile || !warningElt ) return ; + + this.nameToCheck = destFile.value ; + + // Clear timer + if ( this.timeoutID ) { + window.clearTimeout( this.timeoutID ); + } + // Check response cache + for (cached in this.responseCache) { + if (this.nameToCheck == cached) { + this.setWarning(this.responseCache[this.nameToCheck]); + return; + } + } + + this.timeoutID = window.setTimeout( 'wgUploadWarningObj.timeout()', this.delay ); + }, + + 'checkNow': function (fname) { + if ( !wgAjaxUploadDestCheck || !sajax_init_object() ) return; + if ( this.timeoutID ) { + window.clearTimeout( this.timeoutID ); + } + this.nameToCheck = fname; + this.timeout(); + }, + + 'timeout' : function() { + if ( !wgAjaxUploadDestCheck || !sajax_init_object() ) return; + injectSpinner( document.getElementById( 'wpDestFile' ), 'destcheck' ); + + // Get variables into local scope so that they will be preserved for the + // anonymous callback. fileName is copied so that multiple overlapping + // ajax requests can be supported. + var obj = this; + var fileName = this.nameToCheck; + sajax_do_call( 'SpecialUpload::ajaxGetExistsWarning', [this.nameToCheck], + function (result) { + obj.processResult(result, fileName) + } + ); + }, + + 'processResult' : function (result, fileName) { + removeSpinner( 'destcheck' ); + this.setWarning(result.responseText); + this.responseCache[fileName] = result.responseText; + }, + + 'setWarning' : function (warning) { + var warningElt = document.getElementById( 'wpDestFile-warning' ); + var ackElt = document.getElementsByName( 'wpDestFileWarningAck' ); + + this.setInnerHTML(warningElt, warning); + + // Set a value in the form indicating that the warning is acknowledged and + // doesn't need to be redisplayed post-upload + if ( warning == '' || warning == ' ' ) { + ackElt[0].value = ''; + } else { + ackElt[0].value = '1'; + } + + }, + 'setInnerHTML' : function (element, text) { + // Check for no change to avoid flicker in IE 7 + if (element.innerHTML != text) { + element.innerHTML = text; + } + } +} + +function fillDestFilename(id) { + if (!wgUploadAutoFill) { + return; + } + if (!document.getElementById) { + return; + } + // Remove any previously flagged errors + var e = document.getElementById( 'mw-upload-permitted' ); + if( e ) e.className = ''; + + var e = document.getElementById( 'mw-upload-prohibited' ); + if( e ) e.className = ''; + + var path = document.getElementById(id).value; + // Find trailing part + var slash = path.lastIndexOf('/'); + var backslash = path.lastIndexOf('\\'); + var fname; + if (slash == -1 && backslash == -1) { + fname = path; + } else if (slash > backslash) { + fname = path.substring(slash+1, 10000); + } else { + fname = path.substring(backslash+1, 10000); + } + + // Clear the filename if it does not have a valid extension. + // URLs are less likely to have a useful extension, so don't include them in the + // extension check. + if( wgFileExtensions && id != 'wpUploadFileURL' ) { + var found = false; + if( fname.lastIndexOf( '.' ) != -1 ) { + var ext = fname.substr( fname.lastIndexOf( '.' ) + 1 ); + for( var i = 0; i < wgFileExtensions.length; i++ ) { + if( wgFileExtensions[i].toLowerCase() == ext.toLowerCase() ) { + found = true; + break; + } + } + } + if( !found ) { + // Not a valid extension + // Clear the upload and set mw-upload-permitted to error + document.getElementById(id).value = ''; + var e = document.getElementById( 'mw-upload-permitted' ); + if( e ) e.className = 'error'; + + var e = document.getElementById( 'mw-upload-prohibited' ); + if( e ) e.className = 'error'; + + // Clear wpDestFile as well + var e = document.getElementById( 'wpDestFile' ) + if( e ) e.value = ''; + + return false; + } + } + + // Capitalise first letter and replace spaces by underscores + // FIXME: $wgCapitalizedNamespaces + fname = fname.charAt(0).toUpperCase().concat(fname.substring(1,10000)).replace(/ /g, '_'); + + // Output result + var destFile = document.getElementById('wpDestFile'); + if (destFile) { + destFile.value = fname; + wgUploadWarningObj.checkNow(fname) ; + } +} + +function toggleFilenameFiller() { + if(!document.getElementById) return; + var upfield = document.getElementById('wpUploadFile'); + var destName = document.getElementById('wpDestFile').value; + if (destName=='' || destName==' ') { + wgUploadAutoFill = true; + } else { + wgUploadAutoFill = false; + } +} + +var wgUploadLicenseObj = { + + 'responseCache' : { '' : '' }, + + 'fetchPreview': function( license ) { + if( !wgAjaxLicensePreview ) return; + for (cached in this.responseCache) { + if (cached == license) { + this.showPreview( this.responseCache[license] ); + return; + } + } + injectSpinner( document.getElementById( 'wpLicense' ), 'license' ); + + var title = document.getElementById('wpDestFile').value; + if ( !title ) title = 'File:Sample.jpg'; + + var url = wgScriptPath + '/api' + wgScriptExtension + + '?action=parse&text={{' + encodeURIComponent( license ) + '}}' + + '&title=' + encodeURIComponent( title ) + + '&prop=text&pst&format=json'; + + var req = sajax_init_object(); + req.onreadystatechange = function() { + if ( req.readyState == 4 && req.status == 200 ) + wgUploadLicenseObj.processResult( eval( '(' + req.responseText + ')' ), license ); + }; + req.open( 'GET', url, true ); + req.send( '' ); + }, + + 'processResult' : function( result, license ) { + removeSpinner( 'license' ); + this.responseCache[license] = result['parse']['text']['*']; + this.showPreview( this.responseCache[license] ); + + }, + + 'showPreview' : function( preview ) { + var previewPanel = document.getElementById( 'mw-license-preview' ); + if( previewPanel.innerHTML != preview ) + previewPanel.innerHTML = preview; + } + +} + +addOnloadHook( wgUploadSetup ); |