14e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi/*
24e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * Copyright (C) 2014 The Android Open Source Project
34e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi *
44e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * Licensed under the Apache License, Version 2.0 (the "License");
54e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * you may not use this file except in compliance with the License.
64e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * You may obtain a copy of the License at
74e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi *
84e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi *      http://www.apache.org/licenses/LICENSE-2.0
94e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi *
104e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * Unless required by applicable law or agreed to in writing, software
114e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * distributed under the License is distributed on an "AS IS" BASIS,
124e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
134e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * See the License for the specific language governing permissions and
144e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * limitations under the License
154e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi */
164e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
174e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggipackage com.android.systemui.statusbar;
184e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
194e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggiimport android.content.Context;
204e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggiimport android.view.View;
214e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
224e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggiimport com.android.internal.R;
234e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
244e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi/**
254e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * Wraps the actual notification content view; used to implement behaviors which are different for
264e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi * the individual templates and custom views.
274e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi */
284e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggipublic abstract class NotificationViewWrapper {
294e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
304e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi    protected final View mView;
314e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
324e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi    public static NotificationViewWrapper wrap(Context ctx, View v) {
334e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
344e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi        // TODO: Figure out a better way to find out which template the view is.
354e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi        if (v.findViewById(com.android.internal.R.id.media_actions) != null) {
364e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi            return new NotificationMediaViewWrapper(ctx, v);
374e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi        } else if (v.getId() == com.android.internal.R.id.status_bar_latest_event_content) {
384e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi            return new NotificationTemplateViewWrapper(ctx, v);
394e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi        } else {
404e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi            return new NotificationCustomViewWrapper(v);
414e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi        }
424e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi    }
434e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
444e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi    protected NotificationViewWrapper(View view) {
454e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi        mView = view;
464e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi    }
474e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi
484e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi    /**
494e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi     * In dark mode, we draw as little as possible, assuming a black background.
504e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi     *
514e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi     * @param dark whether we should display ourselves in dark mode
524e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi     * @param fade whether to animate the transition if the mode changes
534e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi     * @param delay if fading, the delay of the animation
544e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi     */
554e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi    public abstract void setDark(boolean dark, boolean fade, long delay);
56dacc924a65d68e7888d8771baa14141329265ebfJorim Jaggi
57dacc924a65d68e7888d8771baa14141329265ebfJorim Jaggi    /**
58dacc924a65d68e7888d8771baa14141329265ebfJorim Jaggi     * Notifies this wrapper that the content of the view might have changed.
59dacc924a65d68e7888d8771baa14141329265ebfJorim Jaggi     */
60dacc924a65d68e7888d8771baa14141329265ebfJorim Jaggi    public void notifyContentUpdated() {}
614e857f4ef0357e05806819d0488a73a12208fe8fJorim Jaggi}
62