MediaWiki

Gadget-ve-sandbox.js

From Dogcraft Wiki

No edit summary
Tag: Manual revert
No edit summary
 
(15 intermediate revisions by the same user not shown)
Line 1: Line 1:
mw.loader.using( [ 'ext.visualEditor.core', 'ext.visualEditor.mwtransclusion' ] ).then(function () {
mw.loader.using( 'ext.visualEditor.desktopArticleTarget.init' ).done( function () {
 
console.log('loader entered');
/*!
mw.libs.ve.addPlugin( function () {
* VisualEditor ContentEditable ColumnNode class.
console.log('addplugin entered');
*
return mw.loader.using( ['ext.visualEditor.core'] )
* @copyright 2011-2020 VisualEditor Team and others; see http://ve.mit-license.org
.done(function () {
* @license The MIT License (MIT); see LICENSE.txt
*/
console.log('sandbox entered');
/*!
/**
* VisualEditor ContentEditable ColumnNode class.
* ContentEditable Column node.
*
*
* @copyright 2011-2020 VisualEditor Team and others; see http://ve.mit-license.org
* @class
* @license The MIT License (MIT); see LICENSE.txt
* @extends ve.ce.BranchNode
*/
* @constructor
* @param {ve.dm.ColumnNode} model Model to observe
/**
* @param {Object} [config] Configuration options
* ContentEditable Column node.
*/
*
ve.ce.ColumnNode = function VeCeColumnNode() {
* @class
// Parent constructor
* @extends ve.ce.BranchNode
ve.ce.ColumnNode.super.apply( this, arguments );
* @constructor
* @param {ve.dm.ColumnNode} model Model to observe
this.$element.addClass( 've-ce-columnNode' );
* @param {Object} [config] Configuration options
this.$element.addClass( 'dw-g-columns');
*/
console.log('ce: ');
ve.ce.ColumnNode = function VeCeColumnNode() {
console.log(this);
// Parent constructor
};
ve.ce.ColumnNode.super.apply( this, arguments );
/* Inheritance */
this.$element.addClass( 've-ce-columnNode' );
this.$element.addClass( 'dw-g-columns');
OO.inheritClass( ve.ce.ColumnNode, ve.ce.BranchNode );
console.log('ce: ');
OO.mixinClass( ve.ce.ColumnNode, ve.ce.ClassAttributeNode );
console.log(this);
};
/* Static Properties */
/* Inheritance */
ve.ce.ColumnNode.static.name = 'column';
OO.inheritClass( ve.ce.ColumnNode, ve.ce.BranchNode );
ve.ce.ColumnNode.static.tagName = 'div';
OO.mixinClass( ve.ce.ColumnNode, ve.ce.ClassAttributeNode );
ve.ce.ColumnNode.static.removeEmptyLastChildOnEnter = true;
/* Static Properties */
/* Registration */
ve.ce.ColumnNode.static.name = 'column';
ve.ce.nodeFactory.register( ve.ce.ColumnNode );
ve.ce.ColumnNode.static.tagName = 'div';
 
/*!
ve.ce.ColumnNode.static.removeEmptyLastChildOnEnter = true;
* VisualEditor DataModel ColumnNode class.
*
/* Registration */
* @copyright 2011-2020 VisualEditor Team and others; see http://ve.mit-license.org
* @license The MIT License (MIT); see LICENSE.txt
ve.ce.nodeFactory.register( ve.ce.ColumnNode );
*/
console.log('colnode CE loaded');
 
/*!
/**
* VisualEditor DataModel ColumnNode class.
* DataModel Column node.
*
*
* @copyright 2011-2020 VisualEditor Team and others; see http://ve.mit-license.org
* @class
* @license The MIT License (MIT); see LICENSE.txt
* @extends ve.dm.BranchNode
*/
* @constructor
* @param {ve.dm.LeafNode[]} [children] Child nodes to attach
/**
* @param {Object} [element] Reference to element in linear model
* DataModel Column node.
*/
*
ve.dm.ColumnNode = function VeDmColumnNode() {
* @class
// Parent constructor
* @extends ve.dm.BranchNode
ve.dm.ColumnNode.super.apply( this, arguments );
* @constructor
* @param {ve.dm.LeafNode[]} [children] Child nodes to attach
console.log(this);
* @param {Object} [element] Reference to element in linear model
};
*/
 
ve.dm.ColumnNode = function VeDmColumnNode() {
/* Inheritance */
// Parent constructor
 
ve.dm.ColumnNode.super.apply( this, arguments );
OO.inheritClass( ve.dm.ColumnNode, ve.dm.BranchNode );
OO.mixinClass( ve.dm.ColumnNode, ve.dm.ClassAttributeNode );
console.log(this);
 
};
/* Static Properties */
 
/* Inheritance */
ve.dm.ColumnNode.static.name = 'column';
 
OO.inheritClass( ve.dm.ColumnNode, ve.dm.BranchNode );
ve.dm.ColumnNode.static.matchTagNames = [ 'div' ];
OO.mixinClass( ve.dm.ColumnNode, ve.dm.ClassAttributeNode );
 
ve.dm.ColumnNode.static.matchFunction = function ( element ) {
/* Static Properties */
return element.classList.contains( 'dw-g-columns' );
};
ve.dm.ColumnNode.static.name = 'column';
 
/*ve.dm.ColumnNode.static.defaultAttributes = {
ve.dm.ColumnNode.static.matchTagNames = [ 'div' ];
//class: 'dw-g-columns'
style: 'cols'
ve.dm.ColumnNode.static.matchFunction = function ( element ) {
};*/
return element.classList.contains( 'dw-g-columns' );
 
};
//ve.dm.ColumnNode.static.classAttributes = {
// 'dw-g-columns': { style: 'cols'/*'column-count: 2'*/ }
//ve.dm.ColumnNode.static.classAttributes = {
//};
// 'dw-g-columns': { style: 'cols'/*'column-count: 2'*/ }
 
//};
ve.dm.ColumnNode.static.toDataElement = function ( domElements ) {
//var style = domElements[ 0 ].classList.contains( 'dw-g-columns' ) ? 'cols' : '';
ve.dm.ColumnNode.static.toDataElement = function ( domElements ) {
return { type: 'column'/*this.name, attributes: { style: style }*/ };
//var style = domElements[ 0 ].classList.contains( 'dw-g-columns' ) ? 'cols' : '';
};
return { type: 'column' };
 
};
ve.dm.ColumnNode.static.toDomElements = function ( dataElement, doc ) {
var tag = dataElement.attributes && dataElement.attributes.style === 'cols' ? 'red' : 'blue'; /*emotional support code*/
ve.dm.ColumnNode.static.toDomElements = function ( dataElement, doc ) {
var div = doc.createElement('div');
var tag = dataElement.attributes && dataElement.attributes.style === 'cols' ? 'red' : 'blue'; /*emotional support code*/
div.className = 'dw-g-columns';
var div = doc.createElement('div');
return [ div ];
div.className = 'dw-g-columns';
};
return [ div ];
 
};
/* Registration */
 
/* Registration */
console.log(ve.dm.ColumnNode);
 
//console.log(ve.dm.ColumnNode);
ve.dm.modelRegistry.register( ve.dm.ColumnNode );
 
ve.dm.modelRegistry.register( ve.dm.ColumnNode );
// --------- (start of ve.ui.ColumnAction definition) -----------------------------------------------
console.log('colnode DM loaded');
// This is based on [lib/ve/src/ui/actions/ve.ui.BlockquoteAction.js] from Extension:VisualEditor.
 
// --------- (start of ve.ui.ColumnAction definition) -----------------------------------------------
ve.ui.ColumnAction = function VeUiColumnAction() {
// This is based on [lib/ve/src/ui/actions/ve.ui.BlockquoteAction.js] from Extension:VisualEditor.
ve.ui.ColumnAction.super.apply( this, arguments );
console.log('action started');
};
ve.ui.ColumnAction = function VeUiColumnAction() {
OO.inheritClass( ve.ui.ColumnAction, ve.ui.Action );
ve.ui.ColumnAction.super.apply( this, arguments );
 
};
ve.ui.ColumnAction.static.name = 'column';
OO.inheritClass( ve.ui.ColumnAction, ve.ui.Action );
ve.ui.ColumnAction.static.methods = [ 'wrap', 'unwrap', 'toggle' ];
 
ve.ui.ColumnAction.static.name = 'column';
ve.ui.ColumnAction.prototype.isWrapped = function () {
ve.ui.ColumnAction.static.methods = [ 'wrap', 'unwrap', 'toggle' ];
var fragment = this.surface.getModel().getFragment();
return fragment.hasMatchingAncestor( 'column' );
ve.ui.ColumnAction.prototype.isWrapped = function () {
};
var fragment = this.surface.getModel().getFragment();
ve.ui.ColumnAction.prototype.toggle = function () {
return fragment.hasMatchingAncestor( 'column' );
return this[ this.isWrapped() ? 'unwrap' : 'wrap' ]();
};
};
ve.ui.ColumnAction.prototype.toggle = function () {
ve.ui.ColumnAction.prototype.wrap = function () {
return this[ this.isWrapped() ? 'unwrap' : 'wrap' ]();
var
};
surfaceModel = this.surface.getModel(),
ve.ui.ColumnAction.prototype.wrap = function () {
selection = surfaceModel.getSelection(),
var
fragment = surfaceModel.getFragment( null, true ),
surfaceModel = this.surface.getModel(),
leaves, leavesRange;
selection = surfaceModel.getSelection(),
 
fragment = surfaceModel.getFragment( null, true ),
if ( !( selection instanceof ve.dm.LinearSelection ) ) {
leaves, leavesRange;
return false;
}
if ( !( selection instanceof ve.dm.LinearSelection ) ) {
 
return false;
leaves = fragment.getSelectedLeafNodes();
}
leavesRange = new ve.Range(
leaves[ 0 ].getRange().start,
leaves = fragment.getSelectedLeafNodes();
leaves[ leaves.length - 1 ].getRange().end
leavesRange = new ve.Range(
);
leaves[ 0 ].getRange().start,
fragment = surfaceModel.getLinearFragment( leavesRange, true );
leaves[ leaves.length - 1 ].getRange().end
 
);
fragment = fragment.expandLinearSelection( 'siblings' );
fragment = surfaceModel.getLinearFragment( leavesRange, true );
 
while (
fragment = fragment.expandLinearSelection( 'siblings' );
fragment.getCoveredNodes().some( function ( nodeInfo ) {
return !nodeInfo.node.isAllowedParentNodeType( 'column' ) || nodeInfo.node.isContent();
while (
} )
fragment.getCoveredNodes().some( function ( nodeInfo ) {
) {
return !nodeInfo.node.isAllowedParentNodeType( 'column' ) || nodeInfo.node.isContent();
fragment = fragment.expandLinearSelection( 'parent' );
} )
}
) {
 
fragment = fragment.expandLinearSelection( 'parent' );
// Wrap everything in a <div style="column-count:2"> tag
}
fragment = fragment.wrapAllNodes( { type: 'column'/*, attributes: { style : 'cols' }*/ } );
/*console.log("base: ");
// Wrap everything in a <div style="column-count:2"> tag
console.log(fragment.getSelectedNode());*/
fragment = fragment.wrapAllNodes( { type: 'column' } );
/*console.log("elem: ");
/*console.log("base: ");
var divElement = fragment.getSelectedNode().getElement();
console.log(fragment.getSelectedNode());*/
console.log(divElement);
/*console.log("elem: ");
var divDom = fragment.getSelectedNode().toDomElements(fragment.getSelectedNode(), this.document);
var divElement = fragment.getSelectedNode().getElement();
console.log(divDom);*/
console.log(divElement);
//console.log(this);
var divDom = fragment.getSelectedNode().toDomElements(fragment.getSelectedNode(), this.document);
console.log(divDom);*/
 
//console.log(this);
return true;
};
ve.ui.ColumnAction.prototype.unwrap = function () {
return true;
var
};
surfaceModel = this.surface.getModel(),
ve.ui.ColumnAction.prototype.unwrap = function () {
selection = surfaceModel.getSelection(),
var
fragment = surfaceModel.getFragment( null, true ),
surfaceModel = this.surface.getModel(),
leaves, leavesRange;
selection = surfaceModel.getSelection(),
 
fragment = surfaceModel.getFragment( null, true ),
if ( !( selection instanceof ve.dm.LinearSelection ) ) {
leaves, leavesRange;
return false;
}
if ( !( selection instanceof ve.dm.LinearSelection ) ) {
 
return false;
if ( !this.isWrapped() ) {
}
return false;
}
if ( !this.isWrapped() ) {
 
return false;
leaves = fragment.getSelectedLeafNodes();
}
leavesRange = new ve.Range(
leaves[ 0 ].getRange().start,
leaves = fragment.getSelectedLeafNodes();
leaves[ leaves.length - 1 ].getRange().end
leavesRange = new ve.Range(
);
leaves[ 0 ].getRange().start,
fragment = surfaceModel.getLinearFragment( leavesRange, true );
leaves[ leaves.length - 1 ].getRange().end
 
);
fragment
fragment = surfaceModel.getLinearFragment( leavesRange, true );
// Expand to cover entire <div> tag
.expandLinearSelection( 'closest', ve.dm.ColumnNode )
fragment
// Unwrap it
// Expand to cover entire <div> tag
.unwrapNodes( 0, 1 );
.expandLinearSelection( 'closest', ve.dm.ColumnNode )
 
// Unwrap it
return true;
.unwrapNodes( 0, 1 );
};
ve.ui.actionFactory.register( ve.ui.ColumnAction );
return true;
 
};
// --------- (end of ve.ui.ColumnAction definition) -------------------------------------------------
ve.ui.actionFactory.register( ve.ui.ColumnAction );
 
console.log('action loaded');
ve.ui.ColumnFormatTool = function VeUiColumnFormatTool() {
// --------- (end of ve.ui.ColumnAction definition) -------------------------------------------------
ve.ui.ColumnFormatTool.super.apply( this, arguments );
console.log('tool started');
};
ve.ui.ColumnFormatTool = function VeUiColumnFormatTool() {
OO.inheritClass( ve.ui.ColumnFormatTool, ve.ui.FormatTool );
ve.ui.ColumnFormatTool.super.apply( this, arguments );
 
};
ve.ui.ColumnFormatTool.static.name = 'column';
OO.inheritClass( ve.ui.ColumnFormatTool, ve.ui.FormatTool );
ve.ui.ColumnFormatTool.static.group = 'format';
ve.ui.ColumnFormatTool.static.title = 'Column';
ve.ui.ColumnFormatTool.static.name = 'column';
ve.ui.ColumnFormatTool.static.format = { type: 'column' };
ve.ui.ColumnFormatTool.static.group = 'format';
ve.ui.ColumnFormatTool.static.commandName = 'column';
ve.ui.ColumnFormatTool.static.title = 'Column';
ve.ui.toolFactory.register( ve.ui.ColumnFormatTool );
ve.ui.ColumnFormatTool.static.format = { type: 'column' };
 
ve.ui.ColumnFormatTool.static.commandName = 'column';
ve.ui.commandRegistry.register(
ve.ui.toolFactory.register( ve.ui.ColumnFormatTool );
new ve.ui.Command(
'column', 'column', 'toggle',
ve.ui.commandRegistry.register(
{ supportedSelections: [ 'linear' ] }
new ve.ui.Command(
)
'column', 'column', 'toggle',
);
{ supportedSelections: [ 'linear' ] }
} );
)
);
console.log('tool loaded');
console.log('fin');
} );
});
});

Latest revision as of 23:15, 17 May 2022

mw.loader.using( 'ext.visualEditor.desktopArticleTarget.init' ).done( function () {
	console.log('loader entered');
	mw.libs.ve.addPlugin( function () {
		console.log('addplugin entered');
		return mw.loader.using( ['ext.visualEditor.core'] )
		.done(function () {
			
			console.log('sandbox entered');
			/*!
				 * VisualEditor ContentEditable ColumnNode class.
				 *
				 * @copyright 2011-2020 VisualEditor Team and others; see http://ve.mit-license.org
				 * @license The MIT License (MIT); see LICENSE.txt
				 */
				
				/**
				 * ContentEditable Column node.
				 *
				 * @class
				 * @extends ve.ce.BranchNode
				 * @constructor
				 * @param {ve.dm.ColumnNode} model Model to observe
				 * @param {Object} [config] Configuration options
				 */
				ve.ce.ColumnNode = function VeCeColumnNode() {
					// Parent constructor
					ve.ce.ColumnNode.super.apply( this, arguments );
					
					this.$element.addClass( 've-ce-columnNode' );
					this.$element.addClass( 'dw-g-columns');
					console.log('ce: ');
					console.log(this);
				};
				
				/* Inheritance */
				
				OO.inheritClass( ve.ce.ColumnNode, ve.ce.BranchNode );
				OO.mixinClass( ve.ce.ColumnNode, ve.ce.ClassAttributeNode );
				
				/* Static Properties */
				
				ve.ce.ColumnNode.static.name = 'column';
				
				ve.ce.ColumnNode.static.tagName = 'div';
				
				ve.ce.ColumnNode.static.removeEmptyLastChildOnEnter = true;
				
				/* Registration */
				
				ve.ce.nodeFactory.register( ve.ce.ColumnNode );
			console.log('colnode CE loaded');
			/*!
			 * VisualEditor DataModel ColumnNode class.
			 *
			 * @copyright 2011-2020 VisualEditor Team and others; see http://ve.mit-license.org
			 * @license The MIT License (MIT); see LICENSE.txt
			 */
			
			/**
			 * DataModel Column node.
			 *
			 * @class
			 * @extends ve.dm.BranchNode
			 * @constructor
			 * @param {ve.dm.LeafNode[]} [children] Child nodes to attach
			 * @param {Object} [element] Reference to element in linear model
			 */
			ve.dm.ColumnNode = function VeDmColumnNode() {
				// Parent constructor
				ve.dm.ColumnNode.super.apply( this, arguments );
				
				console.log(this);
			};
			
			/* Inheritance */
			
			OO.inheritClass( ve.dm.ColumnNode, ve.dm.BranchNode );
			OO.mixinClass( ve.dm.ColumnNode, ve.dm.ClassAttributeNode );
			
			/* Static Properties */
			
			ve.dm.ColumnNode.static.name = 'column';
			
			ve.dm.ColumnNode.static.matchTagNames = [ 'div' ];
			
			ve.dm.ColumnNode.static.matchFunction = function ( element ) {
					return element.classList.contains( 'dw-g-columns' );
				};
			
			//ve.dm.ColumnNode.static.classAttributes = {
			//		'dw-g-columns': { style: 'cols'/*'column-count: 2'*/ }
			//};
			
			ve.dm.ColumnNode.static.toDataElement = function ( domElements ) {
				//var style = domElements[ 0 ].classList.contains( 'dw-g-columns' ) ? 'cols' : '';
				return { type: 'column' };
			};
			
			ve.dm.ColumnNode.static.toDomElements = function ( dataElement, doc ) {
				var tag = dataElement.attributes && dataElement.attributes.style === 'cols' ? 'red' : 'blue'; /*emotional support code*/
				var div = doc.createElement('div');
				div.className = 'dw-g-columns';
				return [ div ];
			};
			
			/* Registration */
			
			//console.log(ve.dm.ColumnNode);
			
			ve.dm.modelRegistry.register( ve.dm.ColumnNode );
			console.log('colnode DM loaded');
			
			// --------- (start of ve.ui.ColumnAction definition) -----------------------------------------------
			// This is based on [lib/ve/src/ui/actions/ve.ui.BlockquoteAction.js] from Extension:VisualEditor.
			console.log('action started');
				ve.ui.ColumnAction = function VeUiColumnAction() {
					ve.ui.ColumnAction.super.apply( this, arguments );
				};
				OO.inheritClass( ve.ui.ColumnAction, ve.ui.Action );
			
				ve.ui.ColumnAction.static.name = 'column';
				ve.ui.ColumnAction.static.methods = [ 'wrap', 'unwrap', 'toggle' ];
			
				ve.ui.ColumnAction.prototype.isWrapped = function () {
					var fragment = this.surface.getModel().getFragment();
					return fragment.hasMatchingAncestor( 'column' );
				};
				ve.ui.ColumnAction.prototype.toggle = function () {
					return this[ this.isWrapped() ? 'unwrap' : 'wrap' ]();
				};
				ve.ui.ColumnAction.prototype.wrap = function () {
					var
						surfaceModel = this.surface.getModel(),
						selection = surfaceModel.getSelection(),
						fragment = surfaceModel.getFragment( null, true ),
						leaves, leavesRange;
			
					if ( !( selection instanceof ve.dm.LinearSelection ) ) {
						return false;
					}
			
					leaves = fragment.getSelectedLeafNodes();
					leavesRange = new ve.Range(
						leaves[ 0 ].getRange().start,
						leaves[ leaves.length - 1 ].getRange().end
					);
					fragment = surfaceModel.getLinearFragment( leavesRange, true );
			
					fragment = fragment.expandLinearSelection( 'siblings' );
			
					while (
						fragment.getCoveredNodes().some( function ( nodeInfo ) {
							return !nodeInfo.node.isAllowedParentNodeType( 'column' ) || nodeInfo.node.isContent();
						} )
					) {
						fragment = fragment.expandLinearSelection( 'parent' );
					}
			
					// Wrap everything in a <div style="column-count:2"> tag
					fragment = fragment.wrapAllNodes( { type: 'column' } );
					/*console.log("base: ");
					console.log(fragment.getSelectedNode());*/
					/*console.log("elem: ");
					var divElement = fragment.getSelectedNode().getElement();
					console.log(divElement);
					var divDom = fragment.getSelectedNode().toDomElements(fragment.getSelectedNode(), this.document);
					console.log(divDom);*/
					//console.log(this);
					
			
					return true;
				};
				ve.ui.ColumnAction.prototype.unwrap = function () {
					var
						surfaceModel = this.surface.getModel(),
						selection = surfaceModel.getSelection(),
						fragment = surfaceModel.getFragment( null, true ),
						leaves, leavesRange;
			
					if ( !( selection instanceof ve.dm.LinearSelection ) ) {
						return false;
					}
			
					if ( !this.isWrapped() ) {
						return false;
					}
			
					leaves = fragment.getSelectedLeafNodes();
					leavesRange = new ve.Range(
						leaves[ 0 ].getRange().start,
						leaves[ leaves.length - 1 ].getRange().end
					);
					fragment = surfaceModel.getLinearFragment( leavesRange, true );
			
					fragment
						// Expand to cover entire <div> tag
						.expandLinearSelection( 'closest', ve.dm.ColumnNode )
						// Unwrap it
						.unwrapNodes( 0, 1 );
			
					return true;
				};
				ve.ui.actionFactory.register( ve.ui.ColumnAction );
			console.log('action loaded');
			// --------- (end of ve.ui.ColumnAction definition) -------------------------------------------------
			console.log('tool started');
				ve.ui.ColumnFormatTool = function VeUiColumnFormatTool() {
					ve.ui.ColumnFormatTool.super.apply( this, arguments );
				};
				OO.inheritClass( ve.ui.ColumnFormatTool, ve.ui.FormatTool );
			
				ve.ui.ColumnFormatTool.static.name = 'column';
				ve.ui.ColumnFormatTool.static.group = 'format';
				ve.ui.ColumnFormatTool.static.title = 'Column';
				ve.ui.ColumnFormatTool.static.format = { type: 'column' };
				ve.ui.ColumnFormatTool.static.commandName = 'column';
				ve.ui.toolFactory.register( ve.ui.ColumnFormatTool );
			
				ve.ui.commandRegistry.register(
					new ve.ui.Command(
						'column', 'column', 'toggle',
						{ supportedSelections: [ 'linear' ] }
					)
				);
				console.log('tool loaded');
				console.log('fin');
			} );
		});
});
Background Dragon Slayer - Retriever by Ironboundred