123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- /**
- * @author TyLindberg / https://github.com/TyLindberg
- */
- Sidebar.Controls = function ( editor ) {
- var config = editor.config;
- var signals = editor.signals;
- const IS_MAC = navigator.platform.toUpperCase().indexOf( 'MAC' ) >= 0;
- var isValidKeyBinding = function ( key ) {
- return key.match( /^[A-Za-z0-9]$/i ); // Can't use z currently due to undo/redo
- };
- var container = new UI.Panel();
- container.add( new UI.Text( 'CONTROLS' ) );
- // Use this to add a line break above the panel
- container.add( new UI.Break(), new UI.Break() );
- var controlNames = [
- 'translate',
- 'rotate',
- 'scale',
- 'undo'
- ];
- for ( var i = 0; i < controlNames.length; i ++ ) {
- let name = controlNames[ i ];
- let configName = 'controls/' + name;
- let controlRow = new UI.Row();
- let controlInput = new UI.Input().setWidth( '150px' ).setFontSize( '12px' ).onChange( function () {
- if ( isValidKeyBinding( controlInput.getValue() ) ) {
- config.setKey( configName, controlInput.getValue()[ 0 ] );
- }
- } );
- // Automatically highlight when selecting an input field
- controlInput.dom.addEventListener( 'focus', function () {
- controlInput.dom.select();
- } );
- // If the value of the input field is invalid, revert the input field
- // to contain the key binding stored in config
- controlInput.dom.addEventListener( 'blur', function () {
- if ( ! isValidKeyBinding( controlInput.getValue() ) ) {
- controlInput.setValue( config.getKey( configName ) );
- }
- } );
- // If a valid key binding character is entered, blur the input field
- controlInput.dom.addEventListener( 'keyup', function ( event ) {
- if ( isValidKeyBinding( event.key ) ) {
- controlInput.dom.blur();
- }
- } );
- if ( config.getKey( configName ) !== undefined ) {
- controlInput.setValue( config.getKey( configName ) );
- }
- controlInput.dom.maxLength = 1;
- controlRow.add( new UI.Text( name.charAt( 0 ).toUpperCase() + name.slice( 1 ) ).setWidth( '90px' ) );
- controlRow.add( controlInput );
- container.add( controlRow );
- }
- document.addEventListener( 'keydown', function ( event ) {
- switch ( event.key ) {
- case 'Backspace':
- event.preventDefault(); // prevent browser back
- case 'Delete':
- var object = editor.selected;
- if ( confirm( 'Delete ' + object.name + '?' ) === false ) return;
- var parent = object.parent;
- if ( parent !== null ) editor.execute( new RemoveObjectCommand( object ) );
- break;
- case editor.config.getKey( 'controls/translate' ): // Translation transform mode
- editor.signals.transformModeChanged.dispatch( 'translate' );
- break;
- case editor.config.getKey( 'controls/rotate' ): // Rotation transform mode
- editor.signals.transformModeChanged.dispatch( 'rotate' );
- break;
- case editor.config.getKey( 'controls/scale' ): // Scaling transform mode
- editor.signals.transformModeChanged.dispatch( 'scale' );
- break;
- case editor.config.getKey( 'controls/undo' ).toLowerCase(): // Register Ctrl/Command-Z for Undo and Ctrl/Command-Shift-Z for Redo
- case editor.config.getKey( 'controls/undo' ).toUpperCase(): // Safari and Firefox register lowercase z when Ctrl-Shift-Z is pressed
- if ( IS_MAC ? event.metaKey : event.ctrlKey ) {
- event.preventDefault(); // Prevent browser specific hotkeys
- if ( event.shiftKey ) {
- editor.redo();
- } else {
- editor.undo();
- }
- }
- break;
- }
- }, false );
- return container;
- };
|