Longer term we should move this tracking fully to nsAlertsService, but given that: * currently it's different how each alert backend tracks notification (e.g. only Windows has IsPrivate() and macOS has separate lists for pending/active alerts) * consolidating that would probably require bigger changes it would be nice to first centralize how the teardown step is triggered and then try consolidating further. (See also bug 1953657.) Differential Revision: https://phabricator.services.mozilla.com/D241477
43 lines
1.2 KiB
C++
43 lines
1.2 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#ifndef nsSystemAlertsService_h__
|
|
#define nsSystemAlertsService_h__
|
|
|
|
#include "nsIAlertsService.h"
|
|
#include "nsTHashMap.h"
|
|
|
|
class nsAlertsIconListener;
|
|
|
|
class nsSystemAlertsService : public nsIAlertsService,
|
|
public nsIAlertsDoNotDisturb {
|
|
public:
|
|
NS_DECL_NSIALERTSSERVICE
|
|
NS_DECL_NSIALERTSDONOTDISTURB
|
|
NS_DECL_ISUPPORTS
|
|
|
|
nsSystemAlertsService();
|
|
|
|
nsresult Init();
|
|
|
|
bool IsActiveListener(const nsAString& aAlertName,
|
|
nsAlertsIconListener* aListener);
|
|
void RemoveListener(const nsAString& aAlertName,
|
|
nsAlertsIconListener* aListener);
|
|
|
|
protected:
|
|
virtual ~nsSystemAlertsService();
|
|
|
|
void AddListener(const nsAString& aAlertName,
|
|
nsAlertsIconListener* aListener);
|
|
|
|
nsTHashMap<nsStringHashKey, RefPtr<nsAlertsIconListener>> mActiveListeners;
|
|
|
|
private:
|
|
bool mSuppressForScreenSharing = false;
|
|
};
|
|
|
|
#endif /* nsSystemAlertsService_h__ */
|