From c8970ee5f4a66f596bcd95a2ff56e0d2e3389b56 Mon Sep 17 00:00:00 2001 From: Chris Malley Date: Thu, 24 Jan 2019 11:27:26 -0700 Subject: [PATCH] assertions, doc, #453 Signed-off-by: Chris Malley --- js/ComboBoxListBox.js | 3 +++ js/ComboBoxListItemNode.js | 12 ++++++------ 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/js/ComboBoxListBox.js b/js/ComboBoxListBox.js index 3710f82c..690dcea6 100644 --- a/js/ComboBoxListBox.js +++ b/js/ComboBoxListBox.js @@ -52,6 +52,9 @@ define( require => { }, options ); + assert && assert( options.xMargin > 0 && options.yMargin > 0, + 'margins must be > 0, xMargin=' + options.xMargin + ', yMargin=' + options.yMargin ); + //TODO sun#462 replace fireEmitter and selectionListener with a standard scenery listener const firedEmitter = new Emitter( { argumentTypes: [ { validValue: Event } ], diff --git a/js/ComboBoxListItemNode.js b/js/ComboBoxListItemNode.js index bfbc27ab..822e9e88 100644 --- a/js/ComboBoxListItemNode.js +++ b/js/ComboBoxListItemNode.js @@ -22,11 +22,11 @@ define( require => { /** * @param {ComboBoxItem} item - * @param {number} width - * @param {number} height + * @param {number} highlightWidth + * @param {number} highlightHeight * @param {Object} [options] */ - constructor( item, width, height, options ) { + constructor( item, highlightWidth, highlightHeight, options ) { assert && assert( item instanceof ComboBoxItem ); @@ -34,7 +34,7 @@ define( require => { cursor: 'pointer', align: 'left', - xMargin: 6, + xMargin: 6, // margin between the item and the highlight edge highlightFill: 'rgb( 245, 245, 245 )', // {Color|string} highlight behind the item highlightCornerRadius: 4, // {number} corner radius for the highlight @@ -53,14 +53,14 @@ define( require => { options.innerContent = item.a11yLabel; // Highlight that is shown when the pointer is over this item. This is not the a11y focus rectangle. - const highlightRectangle = new Rectangle( 0, 0, width, height, { + const highlightRectangle = new Rectangle( 0, 0, highlightWidth, highlightHeight, { cornerRadius: options.highlightCornerRadius } ); // Wrapper for the item's Node. Do not transform item.node because it is shared with ComboBoxButton! const itemNodeWrapper = new Node( { children: [ item.node ], - centerY: height / 2 + centerY: highlightHeight / 2 } ); if ( options.align === 'left' ) { itemNodeWrapper.left = highlightRectangle.left + options.xMargin;