/* ownCloud Android client application
* Copyright (C) 2011 Bartek Przybylski
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 .
*
*/
package com.owncloud.android;
import java.util.Date;
import java.util.HashMap;
/**
* A helper class for some string operations.
*
* @author Bartek Przybylski
*
*/
public class DisplayUtils {
private static final String[] suffixes = { "B", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB" };
private static HashMap mimeType2HUmanReadable;
static {
mimeType2HUmanReadable = new HashMap();
// images
mimeType2HUmanReadable.put("image/jpeg", "JPEG image");
mimeType2HUmanReadable.put("image/jpg", "JPEG image");
mimeType2HUmanReadable.put("image/png", "PNG image");
mimeType2HUmanReadable.put("image/bmp", "Bitmap image");
mimeType2HUmanReadable.put("image/gif", "GIF image");
mimeType2HUmanReadable.put("image/svg+xml", "JPEG image");
mimeType2HUmanReadable.put("image/tiff", "TIFF image");
// music
mimeType2HUmanReadable.put("audio/mpeg", "MP3 music file");
mimeType2HUmanReadable.put("application/ogg", "OGG music file");
}
/**
* Converts the file size in bytes to human readable output.
*
* @param bytes Input file size
* @return Like something readable like "12 MB"
*/
public static String bytesToHumanReadable(long bytes) {
double result = bytes;
int attachedsuff = 0;
while (result > 1024 && attachedsuff < suffixes.length) {
result /= 1024.;
attachedsuff++;
}
result = ((int) (result * 100)) / 100.;
return result + " " + suffixes[attachedsuff];
}
/**
* Removes special HTML entities from a string
*
* @param s Input string
* @return A cleaned version of the string
*/
public static String HtmlDecode(String s) {
/*
* TODO: Perhaps we should use something more proven like:
* http://commons.apache.org/lang/api-2.6/org/apache/commons/lang/StringEscapeUtils.html#unescapeHtml%28java.lang.String%29
*/
String ret = "";
for (int i = 0; i < s.length(); ++i) {
if (s.charAt(i) == '%') {
ret += (char) Integer.parseInt(s.substring(i + 1, i + 3), 16);
i += 2;
} else {
ret += s.charAt(i);
}
}
return ret;
}
/**
* Converts MIME types like "image/jpg" to more end user friendly output
* like "JPG image".
*
* @param mimetype MIME type to convert
* @return A human friendly version of the MIME type
*/
public static String convertMIMEtoPrettyPrint(String mimetype) {
if (mimeType2HUmanReadable.containsKey(mimetype)) {
return mimeType2HUmanReadable.get(mimetype);
}
if (mimetype.split("/").length >= 2)
return mimetype.split("/")[1].toUpperCase() + " file";
return "Unknown type";
}
/**
* Converts Unix time to human readable format
* @param miliseconds that have passed since 01/01/1970
* @return The human readable time for the users locale
*/
public static String unixTimeToHumanReadable(long milliseconds) {
Date date = new Date(milliseconds);
return date.toLocaleString();
}
}