sidebarUtils.js
Go to the documentation of this file.
1 # -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
2 # ***** BEGIN LICENSE BLOCK *****
3 # Version: MPL 1.1/GPL 2.0/LGPL 2.1
4 #
5 # The contents of this file are subject to the Mozilla Public License Version
6 # 1.1 (the "License"); you may not use this file except in compliance with
7 # the License. You may obtain a copy of the License at
8 # http://www.mozilla.org/MPL/
9 #
10 # Software distributed under the License is distributed on an "AS IS" basis,
11 # WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12 # for the specific language governing rights and limitations under the
13 # License.
14 #
15 # The Original Code is mozilla.org code.
16 #
17 # The Initial Developer of the Original Code is
18 # Netscape Communications Corporation.
19 # Portions created by the Initial Developer are Copyright (C) 1998
20 # the Initial Developer. All Rights Reserved.
21 #
22 # Contributor(s):
23 # Dan Mills <thunder@mozilla.com> (Ported from history-panel.js)
24 # Marco Bonardo <mak77@supereva.it>
25 #
26 # Alternatively, the contents of this file may be used under the terms of
27 # either the GNU General Public License Version 2 or later (the "GPL"), or
28 # the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
29 # in which case the provisions of the GPL or the LGPL are applicable instead
30 # of those above. If you wish to allow use of your version of this file only
31 # under the terms of either the GPL or the LGPL, and not to allow others to
32 # use your version of this file under the terms of the MPL, indicate your
33 # decision by deleting the provisions above and replace them with the notice
34 # and other provisions required by the GPL or the LGPL. If you do not delete
35 # the provisions above, a recipient may use your version of this file under
36 # the terms of any one of the MPL, the GPL or the LGPL.
37 #
38 # ***** END LICENSE BLOCK *****
39 
40 var SidebarUtils = {
41  handleTreeClick: function SU_handleTreeClick(aTree, aEvent, aGutterSelect) {
42  // right-clicks are not handled here
43  if (aEvent.button == 2)
44  return;
45 
46  var tbo = aTree.treeBoxObject;
47  var row = { }, col = { }, obj = { };
48  tbo.getCellAt(aEvent.clientX, aEvent.clientY, row, col, obj);
49 
50  if (row.value == -1 || obj.value == "twisty")
51  return;
52 
53  var mouseInGutter = false;
54  if (aGutterSelect) {
55  var x = { }, y = { }, w = { }, h = { };
56  tbo.getCoordsForCellItem(row.value, col.value, "image",
57  x, y, w, h);
58  // getCoordsForCellItem returns the x coordinate in logical coordinates
59  // (i.e., starting from the left and right sides in LTR and RTL modes,
60  // respectively.) Therefore, we make sure to exclude the blank area
61  // before the tree item icon (that is, to the left or right of it in
62  // LTR and RTL modes, respectively) from the click target area.
63  var isRTL = window.getComputedStyle(aTree, null).direction == "rtl";
64  if (isRTL)
65  mouseInGutter = aEvent.clientX > x.value;
66  else
67  mouseInGutter = aEvent.clientX < x.value;
68  }
69 
70 #ifdef XP_MACOSX
71  var modifKey = aEvent.metaKey || aEvent.shiftKey;
72 #else
73  var modifKey = aEvent.ctrlKey || aEvent.shiftKey;
74 #endif
75 
76  var isContainer = tbo.view.isContainer(row.value);
77  var openInTabs = isContainer &&
78  (aEvent.button == 1 ||
79  (aEvent.button == 0 && modifKey)) &&
80  PlacesUtils.hasChildURIs(tbo.view.nodeForTreeIndex(row.value));
81 
82  if (aEvent.button == 0 && isContainer && !openInTabs) {
83  tbo.view.toggleOpenState(row.value);
84  return;
85  }
86  else if (!mouseInGutter && openInTabs &&
87  aEvent.originalTarget.localName == "treechildren") {
88  tbo.view.selection.select(row.value);
89  PlacesUIUtils.openContainerNodeInTabs(aTree.selectedNode, aEvent);
90  }
91  else if (!mouseInGutter && !isContainer &&
92  aEvent.originalTarget.localName == "treechildren") {
93  // Clear all other selection since we're loading a link now. We must
94  // do this *before* attempting to load the link since openURL uses
95  // selection as an indication of which link to load.
96  tbo.view.selection.select(row.value);
97  PlacesUIUtils.openNodeWithEvent(aTree.selectedNode, aEvent);
98  }
99  },
100 
101  handleTreeKeyPress: function SU_handleTreeKeyPress(aEvent) {
102  if (aEvent.keyCode == KeyEvent.DOM_VK_RETURN)
103  PlacesUIUtils.openNodeWithEvent(aEvent.target.selectedNode, aEvent);
104  },
105 
110  handleTreeMouseMove: function SU_handleTreeMouseMove(aEvent) {
111  if (aEvent.target.localName != "treechildren")
112  return;
113 
114  var tree = aEvent.target.parentNode;
115  var tbo = tree.treeBoxObject;
116  var row = { }, col = { }, obj = { };
117  tbo.getCellAt(aEvent.clientX, aEvent.clientY, row, col, obj);
118 
119  // row.value is -1 when the mouse is hovering an empty area within the tree.
120  // To avoid showing a URL from a previously hovered node,
121  // for a currently hovered non-url node, we must clear the URL from the
122  // status bar in these cases.
123  if (row.value != -1) {
124  var cell = tree.view.nodeForTreeIndex(row.value);
125  if (PlacesUtils.nodeIsURI(cell))
126  window.top.XULBrowserWindow.setOverLink(cell.uri, null);
127  else
128  this.clearURLFromStatusBar();
129  }
130  else
131  this.clearURLFromStatusBar();
132  },
133 
134  clearURLFromStatusBar: function SU_clearURLFromStatusBar() {
135  window.top.XULBrowserWindow.setOverLink("", null);
136  }
137 };
var PlacesUIUtils
Definition: utils.js:85
let window
return null
Definition: FeedWriter.js:1143