| /* |
| * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies) |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Library General Public |
| * License as published by the Free Software Foundation; either |
| * version 2 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Library General Public License for more details. |
| * |
| * You should have received a copy of the GNU Library General Public License |
| * along with this library; see the file COPYING.LIB. If not, write to |
| * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| * Boston, MA 02110-1301, USA. |
| */ |
| |
| #ifndef MediaQueryList_h |
| #define MediaQueryList_h |
| |
| #include "bindings/core/v8/ActiveScriptWrappable.h" |
| #include "bindings/core/v8/ScriptWrappable.h" |
| #include "core/CoreExport.h" |
| #include "core/dom/ActiveDOMObject.h" |
| #include "core/events/EventTarget.h" |
| #include "platform/heap/Handle.h" |
| #include "wtf/Forward.h" |
| |
| namespace blink { |
| |
| class ExecutionContext; |
| class MediaQueryListListener; |
| class MediaQueryMatcher; |
| class MediaQuerySet; |
| |
| // MediaQueryList interface is specified at |
| // http://dev.w3.org/csswg/cssom-view/#the-mediaquerylist-interface |
| // The objects of this class are returned by window.matchMedia. They may be used |
| // to retrieve the current value of the given media query and to add/remove |
| // listeners that will be called whenever the value of the query changes. |
| |
| class CORE_EXPORT MediaQueryList final : public EventTargetWithInlineData, |
| public ActiveScriptWrappable, |
| public ActiveDOMObject { |
| DEFINE_WRAPPERTYPEINFO(); |
| USING_GARBAGE_COLLECTED_MIXIN(MediaQueryList); |
| WTF_MAKE_NONCOPYABLE(MediaQueryList); |
| |
| public: |
| static MediaQueryList* create(ExecutionContext*, |
| MediaQueryMatcher*, |
| MediaQuerySet*); |
| ~MediaQueryList() override; |
| |
| String media() const; |
| bool matches(); |
| |
| DEFINE_ATTRIBUTE_EVENT_LISTENER(change); |
| |
| // These two functions are provided for compatibility with JS code |
| // written before the change listener became a DOM event. |
| void addDeprecatedListener(EventListener*); |
| void removeDeprecatedListener(EventListener*); |
| |
| // C++ code can use these functions to listen to changes instead of having to |
| // use DOM event listeners. |
| void addListener(MediaQueryListListener*); |
| void removeListener(MediaQueryListListener*); |
| |
| // Will return true if a DOM event should be scheduled. |
| bool mediaFeaturesChanged( |
| HeapVector<Member<MediaQueryListListener>>* listenersToNotify); |
| |
| DECLARE_VIRTUAL_TRACE(); |
| |
| // From ScriptWrappable |
| bool hasPendingActivity() const final; |
| |
| // From ActiveDOMObject |
| void contextDestroyed() override; |
| |
| const AtomicString& interfaceName() const override; |
| ExecutionContext* getExecutionContext() const override; |
| |
| private: |
| MediaQueryList(ExecutionContext*, MediaQueryMatcher*, MediaQuerySet*); |
| |
| bool updateMatches(); |
| |
| Member<MediaQueryMatcher> m_matcher; |
| Member<MediaQuerySet> m_media; |
| using ListenerList = HeapListHashSet<Member<MediaQueryListListener>>; |
| ListenerList m_listeners; |
| bool m_matchesDirty; |
| bool m_matches; |
| }; |
| |
| } // namespace blink |
| |
| #endif // MediaQueryList_h |