Commit c77acef0 authored by Grigory Fedorov's avatar Grigory Fedorov

First very unstable implementation of tablet design.

parent 69ae3543
...@@ -34,7 +34,6 @@ import com.xabber.android.data.intent.EntityIntentBuilder; ...@@ -34,7 +34,6 @@ import com.xabber.android.data.intent.EntityIntentBuilder;
import com.xabber.android.data.message.OnChatChangedListener; import com.xabber.android.data.message.OnChatChangedListener;
import com.xabber.android.data.roster.OnContactChangedListener; import com.xabber.android.data.roster.OnContactChangedListener;
import com.xabber.android.ui.helper.ChatScroller; import com.xabber.android.ui.helper.ChatScroller;
import com.xabber.android.ui.helper.ManagedActivity;
import com.xabber.android.ui.helper.StatusBarPainter; import com.xabber.android.ui.helper.StatusBarPainter;
/** /**
...@@ -43,7 +42,7 @@ import com.xabber.android.ui.helper.StatusBarPainter; ...@@ -43,7 +42,7 @@ import com.xabber.android.ui.helper.StatusBarPainter;
* *
* @author alexander.ivanov * @author alexander.ivanov
*/ */
public class ChatViewer extends ManagedActivity implements ChatScroller.ChatScrollerListener, ChatScroller.ChatScrollerProvider { public class ChatViewer extends MainBasicActivity implements ChatScroller.ChatScrollerListener, ChatScroller.ChatScrollerProvider {
/** /**
* Attention request. * Attention request.
...@@ -150,6 +149,11 @@ public class ChatViewer extends ManagedActivity implements ChatScroller.ChatScro ...@@ -150,6 +149,11 @@ public class ChatViewer extends ManagedActivity implements ChatScroller.ChatScro
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
if (findViewById(R.id.chat_container) != null) {
finish();
return;
}
if (isFinishing()) { if (isFinishing()) {
return; return;
} }
...@@ -302,7 +306,7 @@ public class ChatViewer extends ManagedActivity implements ChatScroller.ChatScro ...@@ -302,7 +306,7 @@ public class ChatViewer extends ManagedActivity implements ChatScroller.ChatScro
} }
@Override @Override
public void onAccountSelected(String account) { public void onStatusBarNeedPaint(String account) {
if (account == null) { if (account == null) {
statusBarPainter.updateWithDefaultColor(); statusBarPainter.updateWithDefaultColor();
} else { } else {
......
...@@ -27,9 +27,8 @@ import android.os.Bundle; ...@@ -27,9 +27,8 @@ import android.os.Bundle;
import android.os.Handler; import android.os.Handler;
import android.support.v4.app.Fragment; import android.support.v4.app.Fragment;
import android.support.v4.view.MenuItemCompat; import android.support.v4.view.MenuItemCompat;
import android.support.v4.widget.DrawerLayout; import android.support.v4.view.ViewPager;
import android.support.v7.app.ActionBarDrawerToggle; import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.widget.Toolbar;
import android.view.ContextMenu; import android.view.ContextMenu;
import android.view.ContextMenu.ContextMenuInfo; import android.view.ContextMenu.ContextMenuInfo;
import android.view.Gravity; import android.view.Gravity;
...@@ -37,6 +36,7 @@ import android.view.Menu; ...@@ -37,6 +36,7 @@ import android.view.Menu;
import android.view.MenuItem; import android.view.MenuItem;
import android.view.View; import android.view.View;
import android.view.inputmethod.InputMethodManager; import android.view.inputmethod.InputMethodManager;
import android.widget.LinearLayout;
import android.widget.SearchView; import android.widget.SearchView;
import android.widget.Toast; import android.widget.Toast;
...@@ -64,10 +64,7 @@ import com.xabber.android.ui.dialog.AccountChooseDialogFragment.OnChoosedListene ...@@ -64,10 +64,7 @@ import com.xabber.android.ui.dialog.AccountChooseDialogFragment.OnChoosedListene
import com.xabber.android.ui.dialog.ContactIntegrationDialogFragment; import com.xabber.android.ui.dialog.ContactIntegrationDialogFragment;
import com.xabber.android.ui.dialog.StartAtBootDialogFragment; import com.xabber.android.ui.dialog.StartAtBootDialogFragment;
import com.xabber.android.ui.helper.BarPainter; import com.xabber.android.ui.helper.BarPainter;
import com.xabber.android.ui.helper.ManagedActivity; import com.xabber.android.ui.helper.ChatScroller;
import com.xabber.android.ui.preferences.AboutViewer;
import com.xabber.android.ui.preferences.AccountEditor;
import com.xabber.android.ui.preferences.PreferenceEditor;
import com.xabber.xmpp.address.Jid; import com.xabber.xmpp.address.Jid;
import com.xabber.xmpp.uri.XMPPUri; import com.xabber.xmpp.uri.XMPPUri;
...@@ -79,8 +76,9 @@ import java.util.Collection; ...@@ -79,8 +76,9 @@ import java.util.Collection;
* *
* @author alexander.ivanov * @author alexander.ivanov
*/ */
public class ContactList extends ManagedActivity implements OnAccountChangedListener, public class ContactList extends MainBasicActivity implements OnAccountChangedListener,
View.OnClickListener, OnChoosedListener, OnContactClickListener, ContactListDrawerFragment.ContactListDrawerListener { View.OnClickListener, OnChoosedListener, OnContactClickListener, ChatScroller.ChatScrollerListener,
ChatScroller.ChatScrollerProvider {
/** /**
* Select contact to be invited to the room was requested. * Select contact to be invited to the room was requested.
...@@ -108,8 +106,9 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList ...@@ -108,8 +106,9 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList
private SearchView searchView; private SearchView searchView;
private BarPainter barPainter; private BarPainter barPainter;
private ActionBarDrawerToggle drawerToggle; private boolean isDualPanelView;
private DrawerLayout drawerLayout; private ChatScroller chatScroller;
public static Intent createPersistentIntent(Context context) { public static Intent createPersistentIntent(Context context) {
Intent intent = new Intent(context, ContactList.class); Intent intent = new Intent(context, ContactList.class);
...@@ -152,12 +151,19 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList ...@@ -152,12 +151,19 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList
return; return;
} }
setContentView(R.layout.contact_list); isDualPanelView = findViewById(R.id.chat_container) != null;
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar_default);
if (isDualPanelView) {
ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
LinearLayout chatScrollIndicatorLayout = (LinearLayout) findViewById(R.id.chat_scroll_indicator);
chatScroller = new ChatScroller(this, viewPager, chatScrollIndicatorLayout);
chatScroller.initChats(null);
}
toolbar.setOnClickListener(this); toolbar.setOnClickListener(this);
setSupportActionBar(toolbar); setSupportActionBar(toolbar);
drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
drawerToggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.application_title_short, R.string.application_title_short); drawerToggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.application_title_short, R.string.application_title_short);
drawerLayout.setDrawerListener(drawerToggle); drawerLayout.setDrawerListener(drawerToggle);
...@@ -324,6 +330,10 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList ...@@ -324,6 +330,10 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList
} }
} }
} }
if (isDualPanelView) {
chatScroller.update();
}
} }
@Override @Override
...@@ -445,7 +455,8 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList ...@@ -445,7 +455,8 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList
super.onBackPressed(); super.onBackPressed();
} }
private void exit() { @Override
protected void exit() {
Application.getInstance().requestToClose(); Application.getInstance().requestToClose();
showDialog(DIALOG_CLOSE_APPLICATION_ID); showDialog(DIALOG_CLOSE_APPLICATION_ID);
getContactListFragment().unregisterListeners(); getContactListFragment().unregisterListeners();
...@@ -508,9 +519,14 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList ...@@ -508,9 +519,14 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList
@Override @Override
public void onContactClick(AbstractContact abstractContact) { public void onContactClick(AbstractContact abstractContact) {
if (action == null) { if (action == null) {
startActivity(ChatViewer.createSpecificChatIntent(this, if (isDualPanelView) {
abstractContact.getAccount(), abstractContact.getUser())); chatScroller.setSelectedChat(abstractContact);
return; chatScroller.update();
} else {
startActivity(ChatViewer.createSpecificChatIntent(this,
abstractContact.getAccount(), abstractContact.getUser()));
return;
}
} }
switch (action) { switch (action) {
case ACTION_ROOM_INVITE: { case ACTION_ROOM_INVITE: {
...@@ -540,8 +556,15 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList ...@@ -540,8 +556,15 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList
break; break;
} }
default: default:
startActivity(ChatViewer.createSpecificChatIntent(this, if (isDualPanelView) {
abstractContact.getAccount(), abstractContact.getUser())); chatScroller.initChats(abstractContact);
chatScroller.setSelectedChat(abstractContact);
chatScroller.update();
} else {
startActivity(ChatViewer.createSpecificChatIntent(this,
abstractContact.getAccount(), abstractContact.getUser()));
return;
}
break; break;
} }
} }
...@@ -579,25 +602,17 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList ...@@ -579,25 +602,17 @@ public class ContactList extends ManagedActivity implements OnAccountChangedList
} }
@Override @Override
public void onContactListDrawerListener(int viewId) { public void onStatusBarNeedPaint(String account) {
drawerLayout.closeDrawers();
switch (viewId) { }
case R.id.drawer_action_settings:
startActivity(PreferenceEditor.createIntent(this)); @Override
break; public void onClose() {
case R.id.drawer_action_about:
startActivity(AboutViewer.createIntent(this));
break;
case R.id.drawer_action_exit:
exit();
break;
}
} }
@Override @Override
public void onAccountSelected(String account) { public ChatScroller getChatScroller() {
drawerLayout.closeDrawers(); return chatScroller;
startActivity(AccountEditor.createIntent(this, account));
} }
} }
package com.xabber.android.ui;
import android.os.Bundle;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.widget.Toolbar;
import com.xabber.android.R;
import com.xabber.android.ui.helper.ManagedActivity;
import com.xabber.android.ui.preferences.AboutViewer;
import com.xabber.android.ui.preferences.AccountEditor;
import com.xabber.android.ui.preferences.PreferenceEditor;
public class MainBasicActivity extends ManagedActivity implements ContactListDrawerFragment.ContactListDrawerListener {
protected ActionBarDrawerToggle drawerToggle;
protected DrawerLayout drawerLayout;
protected Toolbar toolbar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.contact_list);
toolbar = (Toolbar) findViewById(R.id.toolbar_default);
drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
}
@Override
public void onContactListDrawerListener(int viewId) {
drawerLayout.closeDrawers();
switch (viewId) {
case R.id.drawer_action_settings:
startActivity(PreferenceEditor.createIntent(this));
break;
case R.id.drawer_action_about:
startActivity(AboutViewer.createIntent(this));
break;
case R.id.drawer_action_exit:
exit();
break;
}
}
protected void exit() {
}
@Override
public void onAccountSelected(String account) {
drawerLayout.closeDrawers();
startActivity(AccountEditor.createIntent(this, account));
}
}
...@@ -65,7 +65,7 @@ public class RecentChatFragment extends ListFragment implements Toolbar.OnMenuIt ...@@ -65,7 +65,7 @@ public class RecentChatFragment extends ListFragment implements Toolbar.OnMenuIt
if (getListAdapter().isEmpty()) { if (getListAdapter().isEmpty()) {
Activity activity = getActivity(); Activity activity = getActivity();
Toast.makeText(activity, R.string.chat_list_is_empty, Toast.LENGTH_LONG).show(); Toast.makeText(activity, R.string.chat_list_is_empty, Toast.LENGTH_LONG).show();
activity.finish(); // activity.finish();
} }
Toolbar toolbar = (Toolbar) rootView.findViewById(R.id.toolbar_default); Toolbar toolbar = (Toolbar) rootView.findViewById(R.id.toolbar_default);
...@@ -89,15 +89,18 @@ public class RecentChatFragment extends ListFragment implements Toolbar.OnMenuIt ...@@ -89,15 +89,18 @@ public class RecentChatFragment extends ListFragment implements Toolbar.OnMenuIt
@Override @Override
public void onResume() { public void onResume() {
super.onResume(); super.onResume();
if (null != listener.getChatScroller()) {
listener.getChatScroller().registerRecentChatsList(this); listener.getChatScroller().registerRecentChatsList(this);
}
} }
@Override @Override
public void onPause() { public void onPause() {
super.onPause(); super.onPause();
listener.getChatScroller().unregisterRecentChatsList(this); if (null != listener.getChatScroller()) {
listener.getChatScroller().unregisterRecentChatsList(this);
}
} }
@Override @Override
...@@ -111,7 +114,7 @@ public class RecentChatFragment extends ListFragment implements Toolbar.OnMenuIt ...@@ -111,7 +114,7 @@ public class RecentChatFragment extends ListFragment implements Toolbar.OnMenuIt
public void onListItemClick(ListView l, View v, int position, long id) { public void onListItemClick(ListView l, View v, int position, long id) {
super.onListItemClick(l, v, position, id); super.onListItemClick(l, v, position, id);
if (null != listener) { if (null != listener.getChatScroller()) {
listener.getChatScroller().onChatSelected((AbstractChat) getListAdapter().getItem(position)); listener.getChatScroller().onChatSelected((AbstractChat) getListAdapter().getItem(position));
} }
} }
...@@ -126,7 +129,9 @@ public class RecentChatFragment extends ListFragment implements Toolbar.OnMenuIt ...@@ -126,7 +129,9 @@ public class RecentChatFragment extends ListFragment implements Toolbar.OnMenuIt
} }
public void updateChats() { public void updateChats() {
((ChatListAdapter) getListAdapter()).updateChats(listener.getChatScroller().getActiveChats()); if (listener.getChatScroller() != null) {
((ChatListAdapter) getListAdapter()).updateChats(listener.getChatScroller().getActiveChats());
}
} }
public interface RecentChatFragmentInteractionListener { public interface RecentChatFragmentInteractionListener {
......
...@@ -141,9 +141,9 @@ public class ChatScroller implements ...@@ -141,9 +141,9 @@ public class ChatScroller implements
private void updateStatusBar() { private void updateStatusBar() {
if (isRecentChatsSelected) { if (isRecentChatsSelected) {
listener.onAccountSelected(null); listener.onStatusBarNeedPaint(null);
} else { } else {
listener.onAccountSelected(selectedChat.getAccount()); listener.onStatusBarNeedPaint(selectedChat.getAccount());
} }
} }
...@@ -307,7 +307,7 @@ public class ChatScroller implements ...@@ -307,7 +307,7 @@ public class ChatScroller implements
} }
public interface ChatScrollerListener { public interface ChatScrollerListener {
void onAccountSelected(String account); void onStatusBarNeedPaint(String account);
void onClose(); void onClose();
} }
......
<?xml version="1.0" encoding="utf-8"?><!--
Copyright (c) 2013, Redsolution LTD. All rights reserved.
This file is part of Xabber project; you can redistribute it and/or
modify it under the terms of the GNU General Public License, Version 3.
Xabber 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 General Public License for more details.
You should have received a copy of the GNU General Public License,
along with this program. If not, see http://www.gnu.org/licenses/.
-->
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<android.support.v7.widget.Toolbar xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/toolbar_default"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
android:elevation="4dp"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
app:titleTextAppearance="@style/ToolbarTitle" />
<!-- Main layout -->
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">
<FrameLayout
android:id="@+id/container"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1"
android:padding="8dp" />
<FrameLayout
android:id="@+id/chat_container"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="2"
android:padding="8dp">
<android.support.v4.view.ViewPager
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<LinearLayout
android:id="@+id/chat_scroll_indicator"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginTop="80dp"
android:orientation="horizontal" />
</FrameLayout>
</LinearLayout>
</LinearLayout>
<!-- Nav drawer -->
<fragment
android:id="@+id/fragment_drawer"
android:name="com.xabber.android.ui.ContactListDrawerFragment"
android:layout_width="304dp"
android:layout_height="match_parent"
android:layout_gravity="left|start" />
</android.support.v4.widget.DrawerLayout>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment