1
0
mirror of https://github.com/etesync/android synced 2025-01-14 17:51:01 +00:00

Version bump to 0.5.9

* GUI changes for read-only collections (new icons)
* require only bind, unbind and write-content privileges
This commit is contained in:
rfc2822 2014-03-09 17:55:16 +01:00
parent a12942c606
commit 8a02601cfc
11 changed files with 39 additions and 19 deletions

View File

@ -1,8 +1,8 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="at.bitfire.davdroid" package="at.bitfire.davdroid"
android:versionCode="29" android:versionCode="30"
android:versionName="0.5.8.1" android:installLocation="internalOnly"> android:versionName="0.5.9" android:installLocation="internalOnly">
<uses-sdk <uses-sdk
android:minSdkVersion="14" android:minSdkVersion="14"

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 868 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.0 KiB

View File

@ -82,5 +82,6 @@
<string name="email_address">Dirección de correo:</string> <string name="email_address">Dirección de correo:</string>
<string name="organizer_hint">"ORGANIZADOR de tus eventos; se necesita si se usa información de los asistentes"</string> <string name="organizer_hint">"ORGANIZADOR de tus eventos; se necesita si se usa información de los asistentes"</string>
<string name="account_name_info">"Usa tu dirección de correo electrónico como nombre de cuenta porque Android usará el nombre de cuenta como campo de ORGANIZADOR para los eventos que crees. No puedes tener dos cuentas con el mismo nombre.</string> <string name="account_name_info">"Usa tu dirección de correo electrónico como nombre de cuenta porque Android usará el nombre de cuenta como campo de ORGANIZADOR para los eventos que crees. No puedes tener dos cuentas con el mismo nombre.</string>
<string name="read_only">sólo lectura</string>
</resources> </resources>

View File

@ -89,5 +89,6 @@
<string name="organizer_hint">ORGANISATEUR de vos événements; nécessaire pour l\'information des participants</string> <string name="organizer_hint">ORGANISATEUR de vos événements; nécessaire pour l\'information des participants</string>
<string name="account_name_info">Utilisez votre adresse email en tant que nom de compte car Android utilise ce nom pour le champ ORGANISATEUR des évènements que vous créez." <string name="account_name_info">Utilisez votre adresse email en tant que nom de compte car Android utilise ce nom pour le champ ORGANISATEUR des évènements que vous créez."
Vous ne pouvez pas avoir deux comptes du même nom.</string> Vous ne pouvez pas avoir deux comptes du même nom.</string>
<string name="read_only">Lecture seule</string>
</resources> </resources>

View File

@ -12,7 +12,7 @@ package at.bitfire.davdroid;
public class Constants { public class Constants {
public static final String public static final String
APP_VERSION = "0.5.8.1-alpha", APP_VERSION = "0.5.9-alpha",
ACCOUNT_TYPE = "bitfire.at.davdroid", ACCOUNT_TYPE = "bitfire.at.davdroid",

View File

@ -100,44 +100,42 @@ public class SelectCollectionsAdapter extends BaseAdapter implements ListAdapter
break; break;
case TYPE_ADDRESS_BOOKS_ROW: case TYPE_ADDRESS_BOOKS_ROW:
convertView = inflater.inflate(android.R.layout.simple_list_item_single_choice, null); convertView = inflater.inflate(android.R.layout.simple_list_item_single_choice, null);
prepareRowView((CheckedTextView)convertView, R.drawable.addressbook);
break; break;
case TYPE_CALENDARS_HEADING: case TYPE_CALENDARS_HEADING:
convertView = inflater.inflate(R.layout.calendars_heading, parent, false); convertView = inflater.inflate(R.layout.calendars_heading, parent, false);
break; break;
case TYPE_CALENDARS_ROW: case TYPE_CALENDARS_ROW:
convertView = inflater.inflate(android.R.layout.simple_list_item_multiple_choice, null); convertView = inflater.inflate(android.R.layout.simple_list_item_multiple_choice, null);
prepareRowView((CheckedTextView)convertView, R.drawable.calendar);
} }
} }
// step 2: fill view with content // step 2: fill view with content
switch (getItemViewType(position)) { switch (getItemViewType(position)) {
case TYPE_ADDRESS_BOOKS_ROW: case TYPE_ADDRESS_BOOKS_ROW:
setContent((CheckedTextView)convertView, (ServerInfo.ResourceInfo)getItem(position)); setContent((CheckedTextView)convertView, R.drawable.addressbook, (ServerInfo.ResourceInfo)getItem(position));
break; break;
case TYPE_CALENDARS_ROW: case TYPE_CALENDARS_ROW:
setContent((CheckedTextView)convertView, (ServerInfo.ResourceInfo)getItem(position)); setContent((CheckedTextView)convertView, R.drawable.calendar, (ServerInfo.ResourceInfo)getItem(position));
} }
return convertView; return convertView;
} }
protected void prepareRowView(CheckedTextView view, int resIcon) { protected void setContent(CheckedTextView view, int collectionIcon, ServerInfo.ResourceInfo info) {
// set layout and icons
view.setPadding(10, 10, 10, 10); view.setPadding(10, 10, 10, 10);
view.setCompoundDrawablesWithIntrinsicBounds(resIcon, 0, 0, 0); view.setCompoundDrawablesWithIntrinsicBounds(collectionIcon, 0, info.isReadOnly() ? R.drawable.ic_read_only : 0, 0);
view.setCompoundDrawablePadding(10); view.setCompoundDrawablePadding(10);
}
protected void setContent(CheckedTextView view, ServerInfo.ResourceInfo info) {
String description = info.getDescription();
if (description == null)
description = info.getPath();
// set text
String title = "<b>" + info.getTitle() + "</b>"; String title = "<b>" + info.getTitle() + "</b>";
if (info.isReadOnly()) if (info.isReadOnly())
title = title + " (" + context.getString(R.string.read_only) + ")"; title = title + " (" + context.getString(R.string.read_only) + ")";
String description = info.getDescription();
if (description == null)
description = info.getPath();
// FIXME escape HTML // FIXME escape HTML
view.setText(Html.fromHtml(title + "<br/>" + description)); view.setText(Html.fromHtml(title + "<br/>" + description));
} }

View File

@ -90,11 +90,23 @@ public class DavProp {
@Element(required=false) @Element(required=false)
@Getter private PrivAll all; @Getter private PrivAll all;
@Element(required=false)
@Getter private PrivBind bind;
@Element(required=false)
@Getter private PrivUnbind unbind;
@Element(required=false) @Element(required=false)
@Getter private PrivWrite write; @Getter private PrivWrite write;
@Element(required=false,name="write-content")
@Getter private PrivWriteContent writeContent;
public static class PrivAll { } public static class PrivAll { }
public static class PrivBind { }
public static class PrivUnbind { }
public static class PrivWrite { } public static class PrivWrite { }
public static class PrivWriteContent { }
} }

View File

@ -424,12 +424,20 @@ public class WebDavResource {
if (prop.currentUserPrivilegeSet != null) { if (prop.currentUserPrivilegeSet != null) {
// privilege info available // privilege info available
boolean hasWrite = false; boolean mayAll = false,
mayBind = false,
mayUnbind = false,
mayWrite = false,
mayWriteContent = false;
for (DavProp.DavPropPrivilege privilege : prop.currentUserPrivilegeSet) { for (DavProp.DavPropPrivilege privilege : prop.currentUserPrivilegeSet) {
if (privilege.getAll() != null || privilege.getWrite() != null) if (privilege.getAll() != null) mayAll = true;
hasWrite = true; if (privilege.getBind() != null) mayBind = true;
if (privilege.getUnbind() != null) mayUnbind = true;
if (privilege.getWrite() != null) mayWrite = true;
if (privilege.getWriteContent() != null) mayWriteContent = true;
} }
if (!hasWrite) properties.put(Property.READ_ONLY, "1"); if (!mayAll && !mayWrite && !(mayWriteContent && mayBind && mayUnbind))
properties.put(Property.READ_ONLY, "1");
} }
if (prop.addressbookHomeSet != null && prop.addressbookHomeSet.getHref() != null) if (prop.addressbookHomeSet != null && prop.addressbookHomeSet.getHref() != null)