mirror of
https://github.com/fastmail/Squire.git
synced 2025-01-03 13:16:31 -05:00
override default properties by config
This commit is contained in:
parent
11ff577168
commit
22408056bb
4 changed files with 69 additions and 19 deletions
52
Demo.html
52
Demo.html
|
@ -52,19 +52,19 @@
|
|||
<span id="makeLink" class="prompt">Link</span>
|
||||
</p>
|
||||
<p>
|
||||
<span id="increaseQuoteLevel">Quote</span>
|
||||
<span id="decreaseQuoteLevel">Dequote</span>
|
||||
<span id="increaseQuoteLevel">Quote</span>
|
||||
<span id="decreaseQuoteLevel">Dequote</span>
|
||||
|
||||
<span id="makeUnorderedList">List</span>
|
||||
<span id="removeList">Unlist</span>
|
||||
<span id="increaseListLevel">Increase list level</span>
|
||||
<span id="decreaseListLevel">Decrease list level</span>
|
||||
<span id="makeUnorderedList">List</span>
|
||||
<span id="removeList">Unlist</span>
|
||||
<span id="increaseListLevel">Increase list level</span>
|
||||
<span id="decreaseListLevel">Decrease list level</span>
|
||||
|
||||
<span id="insertImage" class="prompt">Insert image</span>
|
||||
<span id="insertImage" class="prompt" value="https://pbs.twimg.com/profile_images/508277159681478656/hC9WIBpC_normal.jpeg">Insert image</span>
|
||||
<span id="setHTML" class="prompt">Set HTML</span>
|
||||
|
||||
<span id="undo">Undo</span>
|
||||
<span id="redo">Redo</span>
|
||||
<span id="undo">Undo</span>
|
||||
<span id="redo">Redo</span>
|
||||
</p>
|
||||
</header>
|
||||
<script type="text/template" id="editorStyles">
|
||||
|
@ -112,28 +112,50 @@
|
|||
</script>
|
||||
<script type="text/javascript" src="build/squire-raw.js"></script>
|
||||
<script type="text/javascript" charset="utf-8">
|
||||
var Squire = window.Squire;
|
||||
var editor;
|
||||
var iframe = document.createElement( 'iframe' );
|
||||
iframe.addEventListener( 'load', function () {
|
||||
// Make sure we're in standards mode.
|
||||
var doc = iframe.contentDocument;
|
||||
|
||||
if ( doc.compatMode !== 'CSS1Compat' ) {
|
||||
doc.open();
|
||||
doc.write( '<!DOCTYPE html><title></title>' );
|
||||
doc.close();
|
||||
doc.open();
|
||||
doc.write( '<!DOCTYPE html><title></title>' );
|
||||
doc.close();
|
||||
}
|
||||
|
||||
// doc.close() can cause a re-entrant load event in some browsers,
|
||||
// such as IE9.
|
||||
if ( editor ) {
|
||||
return;
|
||||
return;
|
||||
}
|
||||
|
||||
// Create Squire instance
|
||||
editor = new Squire( doc );
|
||||
editor = new Squire( doc, {
|
||||
defaultBlockTag: 'P'
|
||||
} );
|
||||
|
||||
// Add styles to frame
|
||||
var style = doc.createElement( 'style' );
|
||||
style.type = 'text/css';
|
||||
style.textContent = document.getElementById( 'editorStyles' ).textContent;
|
||||
doc.querySelector( 'head' ).appendChild( style );
|
||||
|
||||
// plugins
|
||||
editor.addEventListener('mousedown', function(e) {
|
||||
if (e.target.nodeName === 'IMG') {
|
||||
this.selectNode(e.target);
|
||||
}
|
||||
});
|
||||
editor.addEventListener('select', function(e) {
|
||||
console.log(this.getSelectedNode() || this.getSelectedText());
|
||||
});
|
||||
editor.addEventListener('mouseup', function(e) {
|
||||
console.log(this.getPath(),
|
||||
this.getSelectedNode(),
|
||||
this.getSelectedText());
|
||||
});
|
||||
}, false );
|
||||
|
||||
document.body.appendChild( iframe );
|
||||
|
@ -143,7 +165,7 @@
|
|||
value;
|
||||
if ( id && editor && editor[ id ] ) {
|
||||
if ( e.target.className === 'prompt' ) {
|
||||
value = prompt( 'Value:' );
|
||||
value = prompt( 'Value:', e.target.getAttribute('value') );
|
||||
}
|
||||
editor[ id ]( value );
|
||||
}
|
||||
|
|
|
@ -1438,7 +1438,7 @@ function getSquireInstance ( doc ) {
|
|||
return null;
|
||||
}
|
||||
|
||||
function Squire ( doc ) {
|
||||
function Squire ( doc, config ) {
|
||||
var win = doc.defaultView;
|
||||
var body = doc.body;
|
||||
var mutation;
|
||||
|
@ -1504,6 +1504,9 @@ function Squire ( doc ) {
|
|||
// Add key handlers
|
||||
this._keyHandlers = Object.create( keyHandlers );
|
||||
|
||||
// initialize custom configurations
|
||||
this.initConfig( config );
|
||||
|
||||
// Fix IE<10's buggy implementation of Text#splitText.
|
||||
// If the split is at the end of the node, it doesn't insert the newly split
|
||||
// node into the document, and sets its value to undefined rather than ''.
|
||||
|
@ -1543,11 +1546,22 @@ function Squire ( doc ) {
|
|||
|
||||
instances.push( this );
|
||||
|
||||
// for fixCursor would query instance by node.ownerDocument first
|
||||
// we must initialize HTML after instance save
|
||||
this.setHTML( '' );
|
||||
}
|
||||
|
||||
var proto = Squire.prototype;
|
||||
|
||||
proto.initConfig = function ( config ) {
|
||||
if (config) {
|
||||
var that = this;
|
||||
Object.keys(config).forEach(function(key) {
|
||||
that[key] = config[key];
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
proto.createElement = function ( tag, props, children ) {
|
||||
return createElement( this._doc, tag, props, children );
|
||||
};
|
||||
|
|
File diff suppressed because one or more lines are too long
|
@ -14,7 +14,7 @@ function getSquireInstance ( doc ) {
|
|||
return null;
|
||||
}
|
||||
|
||||
function Squire ( doc ) {
|
||||
function Squire ( doc, config ) {
|
||||
var win = doc.defaultView;
|
||||
var body = doc.body;
|
||||
var mutation;
|
||||
|
@ -80,6 +80,9 @@ function Squire ( doc ) {
|
|||
// Add key handlers
|
||||
this._keyHandlers = Object.create( keyHandlers );
|
||||
|
||||
// initialize custom configurations
|
||||
this.initConfig( config );
|
||||
|
||||
// Fix IE<10's buggy implementation of Text#splitText.
|
||||
// If the split is at the end of the node, it doesn't insert the newly split
|
||||
// node into the document, and sets its value to undefined rather than ''.
|
||||
|
@ -119,11 +122,22 @@ function Squire ( doc ) {
|
|||
|
||||
instances.push( this );
|
||||
|
||||
// for fixCursor would query instance by node.ownerDocument first
|
||||
// we must initialize HTML after instance save
|
||||
this.setHTML( '' );
|
||||
}
|
||||
|
||||
var proto = Squire.prototype;
|
||||
|
||||
proto.initConfig = function ( config ) {
|
||||
if (config) {
|
||||
var that = this;
|
||||
Object.keys(config).forEach(function(key) {
|
||||
that[key] = config[key];
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
proto.createElement = function ( tag, props, children ) {
|
||||
return createElement( this._doc, tag, props, children );
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue