Sidebar.Geometry.Geometry.js 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. import { UIRow, UIText } from './libs/ui.js';
  2. function SidebarGeometryGeometry( editor ) {
  3. var strings = editor.strings;
  4. var signals = editor.signals;
  5. var container = new UIRow();
  6. // vertices
  7. var verticesRow = new UIRow();
  8. var vertices = new UIText();
  9. verticesRow.add( new UIText( strings.getKey( 'sidebar/geometry/geometry/vertices' ) ).setWidth( '90px' ) );
  10. verticesRow.add( vertices );
  11. container.add( verticesRow );
  12. // faces
  13. var facesRow = new UIRow();
  14. var faces = new UIText();
  15. facesRow.add( new UIText( strings.getKey( 'sidebar/geometry/geometry/faces' ) ).setWidth( '90px' ) );
  16. facesRow.add( faces );
  17. container.add( facesRow );
  18. //
  19. function update( object ) {
  20. if ( object === null ) return; // objectSelected.dispatch( null )
  21. if ( object === undefined ) return;
  22. var geometry = object.geometry;
  23. if ( geometry && geometry.isGeometry ) {
  24. container.setDisplay( 'block' );
  25. vertices.setValue( ( geometry.vertices.length ).format() );
  26. faces.setValue( ( geometry.faces.length ).format() );
  27. } else {
  28. container.setDisplay( 'none' );
  29. }
  30. }
  31. signals.objectSelected.add( update );
  32. signals.geometryChanged.add( update );
  33. return container;
  34. }
  35. export { SidebarGeometryGeometry };