mirror of
https://github.com/etesync/android
synced 2025-01-11 00:01:12 +00:00
Journal item activity: create the infrastructure for a nicer interface
This commit is contained in:
parent
e6ba52074a
commit
7dba220d06
@ -3,7 +3,14 @@ package com.etesync.syncadapter.ui;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.support.design.widget.TabLayout;
|
||||||
|
import android.support.v4.app.Fragment;
|
||||||
|
import android.support.v4.app.FragmentManager;
|
||||||
|
import android.support.v4.app.FragmentPagerAdapter;
|
||||||
|
import android.support.v4.view.ViewPager;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import com.etesync.syncadapter.App;
|
import com.etesync.syncadapter.App;
|
||||||
@ -12,7 +19,6 @@ import com.etesync.syncadapter.R;
|
|||||||
import com.etesync.syncadapter.model.CollectionInfo;
|
import com.etesync.syncadapter.model.CollectionInfo;
|
||||||
import com.etesync.syncadapter.model.JournalEntity;
|
import com.etesync.syncadapter.model.JournalEntity;
|
||||||
import com.etesync.syncadapter.model.SyncEntry;
|
import com.etesync.syncadapter.model.SyncEntry;
|
||||||
import com.etesync.syncadapter.resource.LocalCalendar;
|
|
||||||
|
|
||||||
import io.requery.Persistable;
|
import io.requery.Persistable;
|
||||||
import io.requery.sql.EntityDataStore;
|
import io.requery.sql.EntityDataStore;
|
||||||
@ -44,27 +50,7 @@ public class JournalItemActivity extends BaseActivity implements Refreshable {
|
|||||||
|
|
||||||
info = journalEntity.getInfo();
|
info = journalEntity.getInfo();
|
||||||
|
|
||||||
setTitle(R.string.journal_item_title);
|
setTitle(info.displayName);
|
||||||
|
|
||||||
final View colorSquare = findViewById(R.id.color);
|
|
||||||
if (info.type == CollectionInfo.Type.CALENDAR) {
|
|
||||||
if (info.color != null) {
|
|
||||||
colorSquare.setBackgroundColor(info.color);
|
|
||||||
} else {
|
|
||||||
colorSquare.setBackgroundColor(LocalCalendar.defaultColor);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
colorSquare.setVisibility(View.GONE);
|
|
||||||
}
|
|
||||||
|
|
||||||
final TextView title = (TextView) findViewById(R.id.display_name);
|
|
||||||
title.setText(info.displayName);
|
|
||||||
|
|
||||||
final TextView desc = (TextView) findViewById(R.id.description);
|
|
||||||
desc.setText(info.description);
|
|
||||||
|
|
||||||
final TextView content = (TextView) findViewById(R.id.content);
|
|
||||||
content.setText(syncEntry.getContent());
|
|
||||||
|
|
||||||
setJournalEntryView(findViewById(R.id.journal_list_item), info, syncEntry);
|
setJournalEntryView(findViewById(R.id.journal_list_item), info, syncEntry);
|
||||||
}
|
}
|
||||||
@ -82,14 +68,63 @@ public class JournalItemActivity extends BaseActivity implements Refreshable {
|
|||||||
|
|
||||||
refresh();
|
refresh();
|
||||||
|
|
||||||
// We refresh before this, so we don't refresh the list before it was fully created.
|
ViewPager viewPager = (ViewPager) findViewById(R.id.viewpager);
|
||||||
if (savedInstanceState == null) {
|
viewPager.setAdapter(new TabsAdapter(getSupportFragmentManager(), info, syncEntry));
|
||||||
/*
|
|
||||||
listFragment = CollectionMembersListFragment.newInstance(account, info);
|
TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
|
||||||
getSupportFragmentManager().beginTransaction()
|
tabLayout.setupWithViewPager(viewPager);
|
||||||
.add(R.id.list_entries_container, listFragment)
|
}
|
||||||
.commit();
|
|
||||||
*/
|
private static class TabsAdapter extends FragmentPagerAdapter {
|
||||||
|
private CollectionInfo info;
|
||||||
|
private SyncEntry syncEntry;
|
||||||
|
public TabsAdapter(FragmentManager fm, CollectionInfo info, SyncEntry syncEntry) {
|
||||||
|
super(fm);
|
||||||
|
this.info = info;
|
||||||
|
this.syncEntry = syncEntry;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getCount() {
|
||||||
|
// FIXME: Make it depend on info type (only have non-raw for known types)
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CharSequence getPageTitle(int position) {
|
||||||
|
// FIXME: use string resources
|
||||||
|
if (position == 0) {
|
||||||
|
return "Main";
|
||||||
|
} else {
|
||||||
|
return "Raw";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Fragment getItem(int position) {
|
||||||
|
return TextFragment.newInstance(syncEntry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class TextFragment extends Fragment {
|
||||||
|
public static TextFragment newInstance(SyncEntry syncEntry) {
|
||||||
|
TextFragment frag = new TextFragment();
|
||||||
|
Bundle args = new Bundle(1);
|
||||||
|
args.putSerializable(KEY_SYNC_ENTRY, syncEntry);
|
||||||
|
frag.setArguments(args);
|
||||||
|
return frag;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
|
||||||
|
View v = inflater.inflate(R.layout.text_fragment, container, false);
|
||||||
|
|
||||||
|
TextView tv = (TextView) v.findViewById(R.id.content);
|
||||||
|
|
||||||
|
SyncEntry syncEntry = (SyncEntry) getArguments().getSerializable(KEY_SYNC_ENTRY);
|
||||||
|
tv.setText(syncEntry.getContent());
|
||||||
|
|
||||||
|
return v;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,13 +2,16 @@
|
|||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
android:orientation="vertical">
|
android:orientation="vertical">
|
||||||
|
|
||||||
<include
|
<android.support.design.widget.TabLayout
|
||||||
layout="@layout/collection_header"
|
android:id="@+id/tabs"
|
||||||
|
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
|
||||||
|
style="@style/tablayout"
|
||||||
|
app:tabMode="fixed"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"/>
|
||||||
android:layout_margin="@dimen/activity_margin" />
|
|
||||||
|
|
||||||
<include
|
<include
|
||||||
android:id="@+id/journal_list_item"
|
android:id="@+id/journal_list_item"
|
||||||
@ -16,15 +19,9 @@
|
|||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content" />
|
android:layout_height="wrap_content" />
|
||||||
|
|
||||||
<ScrollView
|
<android.support.v4.view.ViewPager
|
||||||
|
android:id="@+id/viewpager"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent">
|
android:layout_height="match_parent"
|
||||||
|
app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
|
||||||
<TextView
|
|
||||||
android:id="@+id/content"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_margin="@dimen/activity_margin"
|
|
||||||
android:textIsSelectable="true" />
|
|
||||||
</ScrollView>
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
18
app/src/main/res/layout/text_fragment.xml
Normal file
18
app/src/main/res/layout/text_fragment.xml
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<ScrollView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/content"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_margin="@dimen/activity_margin" />
|
||||||
|
|
||||||
|
</ScrollView>
|
||||||
|
</LinearLayout>
|
@ -129,7 +129,6 @@
|
|||||||
<string name="collection_members_remove">Would you like to revoke %s\'s access?\nPlease be advised that a malicious user would potentially be able to retain access to encryption keys. Please refer to the FAQ for more information.</string>
|
<string name="collection_members_remove">Would you like to revoke %s\'s access?\nPlease be advised that a malicious user would potentially be able to retain access to encryption keys. Please refer to the FAQ for more information.</string>
|
||||||
|
|
||||||
<!-- JournalItemActivity -->
|
<!-- JournalItemActivity -->
|
||||||
<string name="journal_item_title">Journal Item</string>
|
|
||||||
|
|
||||||
<!-- PermissionsActivity -->
|
<!-- PermissionsActivity -->
|
||||||
<string name="permissions_title">EteSync permissions</string>
|
<string name="permissions_title">EteSync permissions</string>
|
||||||
|
Loading…
Reference in New Issue
Block a user