OBS: Efter du har publicerat sidan kan du behöva tömma din webbläsares cache för att se ändringarna.

  • Firefox / Safari: Håll ned Skift och klicka på Uppdatera sidan eller tryck Ctrl-F5 eller Ctrl-R (⌘-R på Mac)
  • Google Chrome: Tryck Ctrl-Skift-R (⌘-Skift-R på Mac)
  • Internet Explorer / Edge: Håll ned Ctrl och klicka på Uppdatera eller tryck Ctrl-F5
  • Opera: Tryck Ctrl-F5.
// Global object
if (typeof CiteTB == 'undefined') {
  var CiteTB = {
    "Templates" : {}, // All templates
    "Options" : {}, // Global options
    "UserOptions" : {}, // User options
    "DefaultOptions" : {}, // Script defaults
    "ErrorChecks" : {} // Error check functions
  };
}

if (typeof mw.usability == 'undefined') {
  mw.usability = {};
  mw.usability.getMsg = function(m) { return mw.messages.get(m); };
  mw.usability.addMessages = function(msgs) { mw.messages.set(msgs); };
}

// Object for cite templates
function citeTemplate(templatename, shortform, basicfields, expandedfields) {
  // Properties
  this.templatename = templatename; // The template name - "cite web", "cite book", etc.
  this.shortform = shortform; // A short form, used for the dropdown box
  this.basic = basicfields; // Basic fields - author, title, publisher...
  // Less common - quote, archiveurl - should be everything the template supports minus the basic ones
  this.extra = expandedfields;

  // Add it to the list
  CiteTB.Templates[this.templatename] = this;
  // Methods
  this.makeFormInner = function(fields) {
    var i = 0,
    trs = [];
    for (i=0; i<fields.length; i++) {
      var fieldobj = fields[i];
      var field = fieldobj.field;
      var ad = false;
      if ($.inArray( field, CiteTB.getOption( 'autodate fields' ) ) != -1 ) {
        im = $( '<img />' ).attr( 'src', '//upload.wikimedia.org/wikipedia/commons/thumb/7/7b/Nuvola_apps_date.svg/20px-Nuvola_apps_date.svg.png' );
        im.attr('alt', mw.usability.getMsg('cite-insert-date')).attr('title', mw.usability.getMsg('cite-insert-date'));
        var ad = $( '<a />' ).attr( 'href', '#' );
        ad.append(im);
        ad.attr('id', 'cite-date-'+CiteTB.escStr(this.shortform)+'-'+field);
        $( document ).on( 'click', '#cite-date-' + CiteTB.escStr( this.shortform ) + '-' + field, CiteTB.fillAccessdate );
      }
	  
      if (fieldobj.autofillid) {
        var autotype = fieldobj.autofillid;
        im = $( '<img />' ).attr( 'src', '//upload.wikimedia.org/wikipedia/commons/thumb/1/17/System-search.svg/20px-System-search.svg.png' );
        im.attr('alt', mw.usability.getMsg('cite-autofill-alt')).attr('title', mw.usability.getMsg('cite-autofill-alt'));
        var ad = $( '<a />' ).attr( 'href', '#' );
        ad.append(im);
        ad.attr('id', 'cite-auto-'+CiteTB.escStr(this.shortform)+'-'+field+'-'+autotype);
        $( document ).on( 'click', '#cite-auto-' + CiteTB.escStr( this.shortform ) + '-' + field + '-' + autotype, CiteTB.initAutofill );	  
      }
	  
      var display = fieldobj.label ? fieldobj.label : CiteTB.fixStr(field);
      var tooltip = fieldobj.tooltip ? $( '<abbr />' ).attr( 'title', fieldobj.tooltip ).text( 'ⓘ' ) : false;
      
      var input = '';
      if (ad) {
        input = $( '<input tabindex="1" style="width:85%" type="text" />' );
      } else {
        input = $( '<input tabindex="1" style="width:100%" type="text" />' );
      }
      input.attr('id', 'cite-'+CiteTB.escStr(this.shortform)+'-'+field);
	  if (fieldobj.autofillprop) {
	    input.addClass('cite-'+CiteTB.escStr(this.shortform)+'-'+fieldobj.autofillprop);
	  }
      var label = $( '<label />' );
      label.attr('for', 'cite-'+CiteTB.escStr(this.shortform)+'-'+field).text(display);
      if (tooltip) {
        label.append(tooltip);
      }
      var style = 'text-align:right; width:20%;';
      if (i%2 == 1) {
        style += ' padding-left:1em;';
      } else {
        var tr = $( '<tr />' );
      }
      var td1 = $( '<td class="cite-form-td" />'). attr( 'style', style );
      td1.append(label);
      tr.append(td1);
      var td2 = $( '<td class="cite-form-td" style="width:30%" />' );
      td2.append(input);
      if (ad) {
        td2.append(ad);
      }
      tr.append(td2);
      if (i%2 === 0) {
        trs.push(tr);
      }
    }
    return trs;
  
  };
  
  // gives a little bit of HTML so the open form can be identified
  this.getInitial = function() {
    var hidden = '<input type="hidden" class="cite-template" value="' + this.templatename + '"/>';
    return hidden;
  };
  
  // makes the form used in the dialog boxes
  this.getForm = function() {
    var main = $( "<div class='cite-form-container' />" );
    var form1 = $( '<table style="width:100%; background-color:transparent;" class="cite-basic-fields" />' );
    var i=0;
    var trs = this.makeFormInner(this.basic);
    for (var i=0; i<trs.length; i++) {
      form1.append(trs[i]);
    }
    
    var form2 = $( '<table style="width:100%; background-color:transparent; display:none" class="cite-extra-fields">' );
    trs = this.makeFormInner(this.extra);
    for (var i=0; i<trs.length; i++) {
      form2.append(trs[i]);
    }    
    main.append(form1).append(form2);
    
    var form3 = $( '<table style="width:100%; background-color:transparent;padding-top:1em" class="cite-other-fields">' );
    var tr = $( '<tr />' );
    var td1 = $( '<td class="cite-form-td" style="text-align:right; width:20%" />' );
    var label1 = $( '<label />' );
    label1.attr('for', "cite-"+CiteTB.escStr(this.shortform)+'-name').text(mw.usability.getMsg('cite-name-label'));
    td1.append(label1);
    var td2 = $( '<td class="cite-form-td" style="width:30%" />' );
    var input1 = $( '<input tabindex="1" style="width:100%" type="text" />' );
    input1.attr('id', 'cite-'+CiteTB.escStr(this.shortform)+'-name');
    td2.append(input1);
    var td3 = $( '<td class="cite-form-td" style="text-align:right; padding-left:1em; width:20%">' );
    var label2 = $( '<label />' );
    label2.attr('for', 'cite-'+CiteTB.escStr(this.shortform)+'-group').text(mw.usability.getMsg('cite-group-label'));
    td3.append(label2);
    var td4 = $( '<td class="cite-form-td" style="width:30%" />' );
    var input2 = $( '<input tabindex="1" style="width:100%" type="text" />' );
    input2.attr('id', 'cite-'+CiteTB.escStr(this.shortform)+'-group');
    td4.append(input2);
    tr.append(td1).append(td2).append(td3).append(td4);
    form3.append(tr);
    main.append(form3);
    var extras = $( '<div />' );
    extras.append('<input type="hidden" class="cite-form-status" value="closed" />');
    var hidden = '<input type="hidden" class="cite-template" value="' + this.templatename + '"/>';
    extras.append(hidden);
    var span1 = $( '<span class="cite-preview-label" style="display:none;" />' );
    span1.text(mw.usability.getMsg('cite-raw-preview'));
    extras.append(span1).append('<div class="cite-ref-preview" style="padding:0.5em; font-size:110%" />');
    var span2 = $( '<span class="cite-prev-parsed-label" style="display:none;" />' );
    span2.text(mw.usability.getMsg('cite-parsed-label'));
    extras.append(span2).append('<div class="cite-preview-parsed" style="padding-bottom:0.5em; font-size:110%" />');
    var link = $( '<a href="#" class="cite-prev-parse" style="margin:0 1em 0 1em; display:none; color:darkblue" />' );
    link.text(mw.usability.getMsg('cite-form-parse'));
    extras.append(link);    
    main.append(extras);
    
    return main;
  };
}

/* Class for error checks
    FIXME: DOCS OUT OF DATE
   type - type of error check - current options:
    * 'refcheck' - apply a function on each ref individually
      * function should accept a ref object, return a string
    * 'reflist' - apply a function on the entire ref list
      * function should accept an array of ref objects, return an array of strings
    * 'search' - apply a function ro the page text
      * function should accept the page text as a string, return an array of strings
   The strings returned by the function should be valid HTML
   
   func - The function described above
   testname - Name of the error check, must not contain spaces
   desc - A short description of the test
*/

function citeErrorCheck(obj) {
  this.obj = obj;
  CiteTB.ErrorChecks[this.obj.testname] = this;
  
  this.run = function() {
    var errors = [];
    switch(this.obj.type) {
      case "refcheck":
        CiteTB.loadRefs();
        for(var i=0; i<CiteTB.mainRefList.length; i++) {
          var e = this.obj.func(CiteTB.mainRefList[i]);
          if (e) {
            errors.push(e);
          }
        }
        break;
      case "reflist":
        CiteTB.loadRefs();
        errors = this.obj.func(CiteTB.mainRefList);
        break;
      case "search":
        var func = this.obj.func;
        CiteTB.getPageText(function(text) {
          errors = func(text);
        });
        break;
    }
    return errors;
  };
  
  this.getRow = function() {
    var row = $( "<li />" );
    var check = $( "<input type='checkbox' name='cite-err-test' />" );
    check.attr('value', this.obj.testname);
    var label = $( "<label />" ).html( this.obj.desc );
    label.attr('for', this.obj.testname); 
    row.append(check).append(' &ndash; ').append(label);
    return row;
  };
}
$( 'head' ).trigger( 'reftoolbarbase' );