Sidebar.Controls.js 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /**
  2. * @author TyLindberg / https://github.com/TyLindberg
  3. */
  4. Sidebar.Controls = function ( editor ) {
  5. var config = editor.config;
  6. var signals = editor.signals;
  7. const IS_MAC = navigator.platform.toUpperCase().indexOf( 'MAC' ) >= 0;
  8. var isValidKeyBinding = function ( key ) {
  9. return key.match( /^[A-Za-z0-9]$/i );
  10. };
  11. var container = new UI.Panel();
  12. container.add( new UI.Text( 'CONTROLS' ) );
  13. // Use this to add a line break above the panel
  14. container.add( new UI.Break(), new UI.Break() );
  15. var controlNames = [
  16. 'translate',
  17. 'rotate',
  18. 'scale'
  19. ];
  20. for ( var i = 0; i < controlNames.length; i++ ) {
  21. let name = controlNames[ i ];
  22. let configName = 'controls/' + name;
  23. let controlRow = new UI.Row();
  24. let controlInput = new UI.Input().setWidth( '150px' ).setFontSize( '12px' ).onChange( function () {
  25. if( isValidKeyBinding( controlInput.getValue() ) ) {
  26. config.setKey( configName, controlInput.getValue()[ 0 ] );
  27. }
  28. } );
  29. // Automatically highlight when selecting an input field
  30. controlInput.dom.addEventListener( 'focus', function () {
  31. controlInput.dom.select();
  32. } );
  33. // If the value of the input field is invalid, revert the input field
  34. // to contain the key binding stored in config
  35. controlInput.dom.addEventListener( 'blur', function () {
  36. if( ! isValidKeyBinding( controlInput.getValue() ) ) {
  37. controlInput.setValue( config.getKey( configName ) );
  38. }
  39. } );
  40. // If a valid key binding character is entered, blur the input field
  41. controlInput.dom.addEventListener( 'keyup', function ( event ) {
  42. if( isValidKeyBinding( event.key ) ) {
  43. controlInput.dom.blur();
  44. }
  45. } );
  46. if( config.getKey( configName ) !== undefined ) {
  47. controlInput.setValue( config.getKey( configName ) );
  48. }
  49. controlInput.dom.maxLength = 1;
  50. controlRow.add( new UI.Text( name.charAt( 0 ).toUpperCase() + name.slice( 1 ) ).setWidth( '90px' ) );
  51. controlRow.add( controlInput );
  52. container.add( controlRow );
  53. }
  54. document.addEventListener( 'keydown', function ( event ) {
  55. switch ( event.key ) {
  56. case 'Backspace':
  57. event.preventDefault(); // prevent browser back
  58. case 'Delete':
  59. var object = editor.selected;
  60. if ( confirm( 'Delete ' + object.name + '?' ) === false ) return;
  61. var parent = object.parent;
  62. if ( parent !== null ) editor.execute( new RemoveObjectCommand( object ) );
  63. break;
  64. case 'z': // Register Ctrl/Command-Z for Undo
  65. if ( IS_MAC ? event.metaKey : event.ctrlKey ) {
  66. editor.undo();
  67. }
  68. break;
  69. case 'Z': // Register Ctrl/Command-Shift-Z for Redo
  70. if ( IS_MAC ? event.metaKey : event.ctrlKey ) {
  71. editor.redo();
  72. }
  73. case editor.config.getKey( 'controls/translate' ): // Translation transform mode
  74. editor.signals.transformModeChanged.dispatch( 'translate' );
  75. break;
  76. case editor.config.getKey( 'controls/rotate' ): // Rotation transform mode
  77. editor.signals.transformModeChanged.dispatch( 'rotate' );
  78. break;
  79. case editor.config.getKey( 'controls/scale' ): // Scaling transform mode
  80. editor.signals.transformModeChanged.dispatch( 'scale' );
  81. break;
  82. }
  83. }, false );
  84. return container;
  85. };