| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 55 */ | 55 */ |
| 56 WebInspector.SuggestBox = function(suggestBoxDelegate, maxItemsHeight) | 56 WebInspector.SuggestBox = function(suggestBoxDelegate, maxItemsHeight) |
| 57 { | 57 { |
| 58 this._suggestBoxDelegate = suggestBoxDelegate; | 58 this._suggestBoxDelegate = suggestBoxDelegate; |
| 59 this._length = 0; | 59 this._length = 0; |
| 60 this._selectedIndex = -1; | 60 this._selectedIndex = -1; |
| 61 this._selectedElement = null; | 61 this._selectedElement = null; |
| 62 this._maxItemsHeight = maxItemsHeight; | 62 this._maxItemsHeight = maxItemsHeight; |
| 63 this._bodyElement = document.body; | 63 this._bodyElement = document.body; |
| 64 this._maybeHideBound = this._maybeHide.bind(this); | 64 this._maybeHideBound = this._maybeHide.bind(this); |
| 65 this._element = document.createElementWithClass("div", "suggest-box"); | 65 this._element = createElementWithClass("div", "suggest-box"); |
| 66 this._element.addEventListener("mousedown", this._onBoxMouseDown.bind(this),
true); | 66 this._element.addEventListener("mousedown", this._onBoxMouseDown.bind(this),
true); |
| 67 } | 67 } |
| 68 | 68 |
| 69 WebInspector.SuggestBox.prototype = { | 69 WebInspector.SuggestBox.prototype = { |
| 70 /** | 70 /** |
| 71 * @return {boolean} | 71 * @return {boolean} |
| 72 */ | 72 */ |
| 73 visible: function() | 73 visible: function() |
| 74 { | 74 { |
| 75 return !!this._element.parentElement; | 75 return !!this._element.parentElement; |
| (...skipping 160 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 236 this.acceptSuggestion(); | 236 this.acceptSuggestion(); |
| 237 event.consume(true); | 237 event.consume(true); |
| 238 }, | 238 }, |
| 239 | 239 |
| 240 /** | 240 /** |
| 241 * @param {string} prefix | 241 * @param {string} prefix |
| 242 * @param {string} text | 242 * @param {string} text |
| 243 */ | 243 */ |
| 244 _createItemElement: function(prefix, text) | 244 _createItemElement: function(prefix, text) |
| 245 { | 245 { |
| 246 var element = document.createElementWithClass("div", "suggest-box-conten
t-item source-code"); | 246 var element = createElementWithClass("div", "suggest-box-content-item so
urce-code"); |
| 247 element.tabIndex = -1; | 247 element.tabIndex = -1; |
| 248 if (prefix && prefix.length && !text.indexOf(prefix)) { | 248 if (prefix && prefix.length && !text.indexOf(prefix)) { |
| 249 element.createChild("span", "prefix").textContent = prefix; | 249 element.createChild("span", "prefix").textContent = prefix; |
| 250 element.createChild("span", "suffix").textContent = text.substring(p
refix.length); | 250 element.createChild("span", "suffix").textContent = text.substring(p
refix.length); |
| 251 } else { | 251 } else { |
| 252 element.createChild("span", "suffix").textContent = text; | 252 element.createChild("span", "suffix").textContent = text; |
| 253 } | 253 } |
| 254 element.createChild("span", "spacer"); | 254 element.createChild("span", "spacer"); |
| 255 element.addEventListener("mousedown", this._onItemMouseDown.bind(this),
false); | 255 element.addEventListener("mousedown", this._onItemMouseDown.bind(this),
false); |
| 256 return element; | 256 return element; |
| (...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 406 // to commit the input or handle it otherwise. | 406 // to commit the input or handle it otherwise. |
| 407 return hasSelectedItem; | 407 return hasSelectedItem; |
| 408 } | 408 } |
| 409 } | 409 } |
| 410 | 410 |
| 411 /** | 411 /** |
| 412 * @constructor | 412 * @constructor |
| 413 */ | 413 */ |
| 414 WebInspector.SuggestBox.Overlay = function() | 414 WebInspector.SuggestBox.Overlay = function() |
| 415 { | 415 { |
| 416 this.element = document.createElementWithClass("div", "suggest-box-overlay")
; | 416 this.element = createElementWithClass("div", "suggest-box-overlay"); |
| 417 this._resize(); | 417 this._resize(); |
| 418 document.body.appendChild(this.element); | 418 document.body.appendChild(this.element); |
| 419 } | 419 } |
| 420 | 420 |
| 421 WebInspector.SuggestBox.Overlay.prototype = { | 421 WebInspector.SuggestBox.Overlay.prototype = { |
| 422 _resize: function() | 422 _resize: function() |
| 423 { | 423 { |
| 424 var container = WebInspector.Dialog.modalHostView().element; | 424 var container = WebInspector.Dialog.modalHostView().element; |
| 425 var containerBox = container.boxInWindow(container.ownerDocument.default
View); | 425 var containerBox = container.boxInWindow(container.ownerDocument.default
View); |
| 426 | 426 |
| 427 this.element.style.left = containerBox.x + "px"; | 427 this.element.style.left = containerBox.x + "px"; |
| 428 this.element.style.top = containerBox.y + "px"; | 428 this.element.style.top = containerBox.y + "px"; |
| 429 this.element.style.height = containerBox.height + "px"; | 429 this.element.style.height = containerBox.height + "px"; |
| 430 this.element.style.width = containerBox.width + "px"; | 430 this.element.style.width = containerBox.width + "px"; |
| 431 }, | 431 }, |
| 432 | 432 |
| 433 dispose: function() | 433 dispose: function() |
| 434 { | 434 { |
| 435 this.element.remove(); | 435 this.element.remove(); |
| 436 } | 436 } |
| 437 } | 437 } |
| OLD | NEW |