mediawiki-extensions-Visual.../modules/ve/ce/nodes/ve.ce.MWImageCaptionNode.js
Timo Tijhof 2fb1a11a1a Straighten out variances in parent method invocation
Follows-up I99acbd1699:
* "Parent method" comment
* Remove redundant slice() call to convert arguments to array,
  native JavaScript methods that take array-like arguments such
  as Function#apply and Array#slice are both compatible with
  the Arguments objects, no need to convert it. Most invocations
  already did this right but a few were recently introduced again.
* Removed silly "Document dialog." descriptions.
* Removed a few redundant "@method" tags in the near vicinity
  of code I changed.
* Fixed function invocation to be either on one line or
  one parameter per line. Having all arguments on one line
  but the name + "(" looks confusing as it suggest there
  is only 1 parameter. Same as object literals:
  so:
  { foo: 1, bar }
  or:
  {
    foo: 1,
    bar: 2,
  }
  not:
  {
    foo: 1, bar: 2
  }

Change-Id: I379bc2b32603bcf90aba9b4cd0112e7f027d070e
2013-06-21 19:20:37 +00:00

82 lines
2 KiB
JavaScript

/*!
* VisualEditor ContentEditable ListItemNode class.
*
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
/*global mw */
/**
* ContentEditable image caption item node.
*
* @class
* @extends ve.ce.BranchNode
* @constructor
* @param {ve.dm.MWImageCaptionNode} model Model to observe
* @param {Object} [config] Config options
*/
ve.ce.MWImageCaptionNode = function VeCeMWImageCaptionNode( model, config ) {
// Parent constructor
ve.ce.BranchNode.call( this, model, config );
// DOM changes
this.$.addClass( 'thumbcaption' );
};
/* Inheritance */
ve.inheritClass( ve.ce.MWImageCaptionNode, ve.ce.BranchNode );
/* Static Properties */
ve.ce.MWImageCaptionNode.static.name = 'mwImageCaption';
ve.ce.MWImageCaptionNode.static.tagName = 'div';
/* Methods */
/**
* TODO: Magnify should appear/disappear based on the changes/updates to the parent (switching to
* and from thumb or frame).
*/
ve.ce.MWImageCaptionNode.prototype.onSplice = function () {
var parentType = this.model.getParent().getAttribute( 'type' );
if ( parentType === 'thumb' ) {
if ( this.$magnify ) {
this.$magnify.detach();
} else {
this.buildMagnify();
}
}
// Parent method
ve.ce.BranchNode.prototype.onSplice.apply( this, arguments );
if ( parentType === 'thumb' ) {
this.$magnify.prependTo( this.$ );
}
};
ve.ce.MWImageCaptionNode.prototype.buildMagnify = function () {
this.$magnify = $( '<div>' )
.addClass( 'magnify' );
this.$a = $( '<a>' )
.addClass( 'internal' )
// It's inside a protected node, so user can't see href/title anyways.
//.attr( 'href', '/wiki/File:Wiki.png')
//.attr( 'title', 'Enlarge' )
.appendTo( this.$magnify );
this.$img = $( '<img>' )
.attr( 'src', mw.config.get( 'wgVisualEditor' ).magnifyClipIconURL )
.attr( 'width', 15 )
.attr( 'height', 11 )
//.attr( 'alt', '' )
.appendTo( this.$a );
};
/* Registration */
ve.ce.nodeFactory.register( ve.ce.MWImageCaptionNode );