Jump to content

User:Matthew Yeager/renderboard.js

From Wikipedia, the free encyclopedia
This is an old revision of this page, as edited by Matthew Yeager (talk | contribs) at 04:52, 23 September 2007 (input logic message). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.
Note: After saving, you have to bypass your browser's cache to see the changes. Google Chrome, Firefox, Microsoft Edge and Safari: Hold down the ⇧ Shift key and click the Reload toolbar button. For details and instructions about other browsers, see Wikipedia:Bypass your cache.
if( typeof(RenderBoard) == 'undefined' ) {
  RenderBoard= function(){};
}

function brender() {
  addPortletLink( 'p-personal', "javascript:brender.generate()", "Render Game Board", "", "Render Game Board", "");
}
addOnloadHook(brender);

brender.generate = function brendergenerate() {
  var Window = new SimpleWindow(600,400);
  Window.setTitle("Render Game Board");
  var form = new QuickForm(brender.generate.code);
  form.append({
      type:'select',
      name:'seltype',
      label:'Game Selection: ',
      align:'left',
      list:[{
	  label:'Chess',
	  list:[
	    {label:'Standard 8x8 (26x26px)', selected:true, value:'1'},
	    {label:'Standard 8x8 (22x22px)', value:'2'},
	    {label:'8x10 (10 columns) (26x26px)', value:'3' },
	    {label:'Chaturanga 8x8 (uncheckered)(26x26px)', value:'4'},
	    {label:'Mutation 8x8 (colored squares) (26x26px)', value:'5'},
	    {label:'Omega 10x10 (22x22px)', value:'6'},
	    {label:'Raumschach 5x5x5 (22x22px)', value:'7'}
	  ]
      }]
  });
/*
  form.append({
      type:'select',
      name:'selcol1',
      label:'Left Bottom Square Color: ',
      list:[
	    {label:'Black', selected:true, value:'1'},
	    {label:'White', value:'2'},
	    {label:'Green', value:'3' },
	    {label:'Red', value:'4'},
	    {label:'Blue', value:'5'},
	    {label:'Yellow', value:'6'},
	    {label:'Blue', value:'7'}
      ]
  });
  form.append({
      type:'select',
      name:'selcol2',
      label:'Secondary Color: ',
      list:[
	    {label:'White', selected:true, value:'1'},
	    {label:'Black', value:'2'},
	    {label:'Green', value:'3' },
	    {label:'Red', value:'4'},
	    {label:'Blue', value:'5'},
	    {label:'Yellow', value:'6'},
	    {label:'Blue', value:'7'}
      ]
  });
*/
  var specs = form.append({
      type: 'field',
      label: 'Board Specifications'
  });
  specs.append({
      type: 'input',
      name: 'txtalign',
      label: 'Alignment:  ',
      tooltip: 'Default is empty, but may be tright or tleft.'
  });
  specs.append({
      type: 'input',
      name: 'txtheader',
      label: 'Heading: ',
      tooltip: 'The title of this image.'
  });
  specs.append({
      type: 'input',
      name: 'txtfooter',
      label: 'Footer: ',
      tooltip: 'Text that appears below image.'
  });
  var inputsec = form.append({
      type: 'field',
      label: 'Input'
  });
  specs.append({
      type: 'input',
      name: 'txtFENparam',
      label: 'FEN Parameters: ',
      tooltip: 'Only applicable to certain templates.'
  });
  inputsec.append({
      type: 'input',
      name: 'txtposition',
      label: 'Position String',
      tooltip: 'This would be black\'s starting position: \'rd|nd|bd|qd|kd|bd|nd|rd|pd|pd|pd|pd|pd|pd|pd|pd\''
  });
  inputsec.append({
      type: 'input',
      name: 'txtFEN',
      label: 'FEN String',
      tooltip: 'This would be starting position: \'rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR\''
  });
  specs.append({
      type:'checkbox',
      list:[{
          name: 'chkstnd',
          label: 'Render Starting Position',
          tooltip: 'Will create code with pieces set up in starting position.',
        }/*,
	{ 
	  name: 'chktst2',
	  label: 'checkbox test 2',
	  tooltip: 'This is a test, a number 2 test !',
	},
	{
	  name: 'chktst3',
	  label: 'checkbox test 3',
	  tooltip: 'This is a test, a number 3 test !'
	}*/
      ]
  });

  var resultdisplay = form.append({
      type: 'field',
      label: 'Rendered Code'
  });
  resultdisplay.append({
      type: 'textarea',
      name: 'txtresult',
      label: 'Result: '
  });

  form.append({ 
      type:'submit',
      name: 'Render Code',
      event: brender.generate.code
  });
  var result = form.render();
  Window.setContent( result );
  Window.display();
}

brender.generate.code= function brendergeneratecode  (e) {
  var InputLogic = 'Please note that code will be determined in this order:\n\t1. Starting Position Checkbox (Overrides other inputs)';
  InputLogic += '\n\t2. Position String (Overrides FEN String)\n\t3. FEN String';
  alert(InputLogic);
  form.txtresult.value = '';
  var RenderedBoard = 'MYEA';
  var form = e.target;
  var params = {
    type: form.seltype.value,
    align: form.txtalign.value,
    header: form.txtheader.value,
    startpos: form.chkstnd.checked,
    footer: form.txtfooter.value,
    FENparam: form.txtFENparam.value,
    position: form.txtposition.value,
    FEN: form.txtFEN.value
  }
  if(params.type == 1){
    RenderedBoard = '{{User:Matthew Yeager/Chess Render FEN|=\n';
    RenderedBoard += '|' + params.align + '\n';
    RenderedBoard += '|' + params.header + '\n';
    RenderedBoard += '|=' + '\n';
    if(params.startpos == true){
      RenderedBoard += '|rd|nd|bd|qd|kd|bd|nd|rd|=\n';
      RenderedBoard += '|pd|pd|pd|pd|pd|pd|pd|pd|=\n';
      RenderedBoard += '|  |  |  |  |  |  |  |  |=\n';
      RenderedBoard += '|  |  |  |  |  |  |  |  |=\n';
      RenderedBoard += '|  |  |  |  |  |  |  |  |=\n';
      RenderedBoard += '|  |  |  |  |  |  |  |  |=\n';
      RenderedBoard += '|pl|pl|pl|pl|pl|pl|pl|pl|=\n';
      RenderedBoard += '|rl|nl|bl|ql|kl|bl|nl|rl|=\n';
    }else if(params.position != ''){
      var avPosition = params.position.split('|');
      for(var i = 1;i <= 64;i++){
        if(i <= avPosition.length){
          RenderedBoard += '|' + avPosition[i-1];
        }else{
          RenderedBoard += '|  ';
        }
        if(i != 0 && i % 8 == 0){
          RenderedBoard += '|=\n';
        }
      }
    }
    RenderedBoard += '|' + params.footer + '\n';
    RenderedBoard += '|FEN=' + params.FENparam + '}}\n';
    RenderedBoard += '<!--Code Created From RenderBoard-->\n';
    RenderedBoard += '<!--If there are any problems please contact user Matthew_Yeager on English Wikipedia.-->\n';
  }
  form.txtresult.value = RenderedBoard;
}