Open
      
        Bug 324570
      
      
        Opened 19 years ago
          Updated 2 years ago
      
        
    
  
Make simultaneous notifications from alerts service work
Categories
(Toolkit :: Alerts Service, defect)
        Toolkit
          
        
        
      
        
    
        Alerts Service
          
        
        
      
        
    Tracking
()
        NEW
        
        
    
  
People
(Reporter: asqueella, Unassigned)
References
Details
A notification from alerts service looks like this: http://developer.mozilla.org/en/docs/nsIAlertsService
If someone tries to display two notifications at a time, the second one overlaps the first.
It's actually a Toolkit issue, but I'm filing it here because of lack of an appropriate component in Toolkit.
| Reporter | ||
| Comment 1•19 years ago
           | ||
The problem with this is that it's not obvious what should UI be for multiple notifications.
I had an idea of Google Talk-like notifications, which slide on top of each other (not sure I can explain that - http://frittle.org/webblog/images/59.jpg ). That requires all notifications be of the same width, which is not currently the case. It is possible to make them all have the same width, but that may change the look of existing Firefox notifications, and I'm not sure if it is fine.
| Comment 2•18 years ago
           | ||
I think this might be a good thing to take a look at for Firefox 3.  The mac implementation (pending) already handles this properly, so other systems should too.
| Comment 4•17 years ago
           | ||
With the number of uses we are making of the alerts service now we are starting to see conflicting alerts (as in bug 412052). We might want to resolve this for Firefox 3
Flags: blocking-firefox3?
| Comment 5•17 years ago
           | ||
This does not block the final release of Firefox 3.
Flags: wanted-firefox3+
Flags: blocking-firefox3?
Flags: blocking-firefox3-
| Updated•17 years ago
           | 
Component: General → XUL Widgets
Flags: wanted-firefox3+
Flags: blocking-firefox3-
Product: Firefox → Toolkit
QA Contact: general → xul.widgets
| Updated•17 years ago
           | 
OS: Windows XP → All
Hardware: PC → All
|   | ||
| Comment 7•11 years ago
           | ||
This should be working with the XULAlerts implementation of the alerts service.
See: Bug 782211 and https://hg.mozilla.org/mozilla-central/rev/d068e438438d
Depends on: 782211
Flags: needinfo?(asqueella)
Flags: needinfo?(archaeopteryx)
Whiteboard: [WORKSFORME?]
|   | ||
| Comment 8•11 years ago
           | ||
(In reply to Philip Chee from comment #7)
> This should be working with the XULAlerts implementation of the alerts
> service.
Tried to call two notifications in two subsequent lines: Neither works for nsIAlertService nor for |new Notification| (single instance works).
Flags: needinfo?(archaeopteryx)
| Reporter | ||
| Comment 9•11 years ago
           | ||
Yes, it still doesn't work, neither on Windows (XP), not on Mac (Mavericks):
var alertsService = Components.classes["@mozilla.org/alerts-service;1"]
                    .getService(Components.interfaces.nsIAlertsService);
alertsService.showAlertNotification(null, "test", "test")
alertsService.showAlertNotification(null, "test2", "test2")
Flags: needinfo?(asqueella)
| Updated•11 years ago
           | 
Whiteboard: [WORKSFORME?]
| Comment 10•11 years ago
           | ||
I also tried to load the alert.xul directly, and still not work for TB 29 nightly, Win7.
let win = Services.ww.openWindow(null, 'chrome://global/content/alerts/alert.xul', "_blank", 'chrome,titlebar=no,popup=yes', args);
let win2 = Services.ww.openWindow(null, 'chrome://global/content/alerts/alert.xul', "_blank", 'chrome,titlebar=no,popup=yes', args);
The issue is related with how alert.js calculate the position of the new alert window, eg with default settings, the new alert window will be moved to the end(top) of all the alert windows in function moveWindowToEnd(), but moveWindowToEnd expect all other alert windows was shown already, if not, the new alert window might be moved out of screen and can't be seen.
If I change the line:
y = Math.min(y, alertWindow.screenY - window.outerHeight); 
to
if ( alertWindow.screenY > window.outerHeight ) {
  y = Math.min(y, alertWindow.screenY - window.outerHeight);
}
Then all the alert windows will show correctly ( for default setting that gReplacedWindow is null and gOrigin is 0 ).
The same issue might also exists in moveWindowToReplace() / onAlertBeforeUnload() .
|   | ||
| Comment 11•11 years ago
           | ||
William Chen, could you comment on Comment 10 as you are the author of the code referenced? Thank you.
Flags: needinfo?(wchen)
| Comment 12•11 years ago
           | ||
If you are using the nsIAlertsService, you need to give your notifications a unique name.
http://dxr.mozilla.org/mozilla-central/source/toolkit/components/alerts/nsIAlertsService.idl#61
With the web notifications API, it will show multiple notification simultaneously by default, but Notification with the same tag will only display a single notification.
http://notifications.spec.whatwg.org/#tags-example
Flags: needinfo?(wchen)
| Comment 13•11 years ago
           | ||
(In reply to William Chen [:wchen] from comment #12)
> If you are using the nsIAlertsService, you need to give your notifications a
> unique name.
Tried and not works, as I said in comment 10, the alert windows are there but can't be seen because they were moved out of the screen.
let alertsService = Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService);
let cookie = Date.now();
alertsService.showAlertNotification('', 'title1', 'msg1', true, cookie, null, cookie);
cookie = Date.now();
// with the below line, nothing will shown, comments the below line, will show one alert window
alertsService.showAlertNotification('', 'title2', 'msg2', true, cookie, null, cookie);
Flags: needinfo?(wchen)
| Comment hidden (obsolete) | 
| Comment 17•11 years ago
           | ||
Here's a workaround (for both Linux and Windows): Use gBrowser to open a plain (skeleton) HTML file. Then fill in that document with your message:
var newTab= window.gBrowser.selectedTab = window.gBrowser.addTab( 'chrome://your-extension/content/extensions/message.html' );
var newTabBrowser = window.gBrowser.getBrowserForTab( newTab );
newTabBrowser.addEventListener(
  "load",
  function () {
    newTabBrowser.contentDocument.body.innerHTML= message;
  },
  true
);
If you need to do that when your XPI is loaded (e.g. from an overlay of browser.xul), it seems to require a delay, e.g.:
window.setTimeout(
   function() { // all from the above
   }, 3000 );
|   | ||
| Comment 20•9 years ago
           | ||
Yes, this still reproduces with the code from comment 9 in latest Nightly on Windows 8.1. You can see a shadow line (for me in the top left corner) if you try to show two notifications. Clicking on the shadow closes it. If only one notification gets requested, it works as expected.
| Comment 21•9 years ago
           | ||
I confirm this bug.
| Updated•9 years ago
           | 
Blocks: platform-ui-team
| Comment hidden (me-too) | 
| Updated•3 years ago
           | 
Severity: normal → S3
| Comment 24•3 years ago
           | ||
The severity field for this bug is relatively low, S3. However, the bug has 5 duplicates.
:tspurway, could you consider increasing the bug severity?
For more information, please visit auto_nag documentation.
Flags: needinfo?(tspurway)
|   | ||
| Updated•3 years ago
           | 
Flags: needinfo?(tspurway)
| Updated•2 years ago
           | 
Component: Notifications and Alerts → Alerts Service
          You need to log in
          before you can comment on or make changes to this bug.
        
Description
•