Mrbytes
2012-09-13 90ddf5bcf1a4cd719a8d5997a9ed3cafc36f1e04
src/com/gitblit/wicket/pages/BlobPage.java
@@ -21,6 +21,7 @@
import org.apache.wicket.Component;
import org.apache.wicket.PageParameters;
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.html.image.Image;
import org.apache.wicket.markup.html.link.BookmarkablePageLink;
import org.eclipse.jgit.lib.Constants;
import org.eclipse.jgit.lib.Repository;
@@ -30,6 +31,7 @@
import com.gitblit.Keys;
import com.gitblit.utils.JGitUtils;
import com.gitblit.utils.StringUtils;
import com.gitblit.wicket.ExternalImage;
import com.gitblit.wicket.WicketUtils;
import com.gitblit.wicket.panels.CommitHeaderPanel;
import com.gitblit.wicket.panels.PathBreadcrumbsPanel;
@@ -41,7 +43,8 @@
      Repository r = getRepository();
      final String blobPath = WicketUtils.getPath(params);
      String [] encodings = GitBlit.getEncodings();
      if (StringUtils.isEmpty(blobPath)) {
         // blob by objectid
@@ -54,7 +57,7 @@
         add(new BookmarkablePageLink<Void>("headLink", BlobPage.class).setEnabled(false));
         add(new CommitHeaderPanel("commitHeader", objectId));
         add(new PathBreadcrumbsPanel("breadcrumbs", repositoryName, blobPath, objectId));
         Component c = new Label("blobText", JGitUtils.getStringContent(r, objectId));
         Component c = new Label("blobText", JGitUtils.getStringContent(r, objectId, encodings));
         WicketUtils.setCssClass(c, "plainprint");
         add(c);
      } else {
@@ -107,34 +110,41 @@
               type = map.get(extension);
            }
            Component c = null;
            Component i = null;
            switch (type) {
            case 1:
               // PrettyPrint blob text
               c = new Label("blobText", JGitUtils.getStringContent(r, commit.getTree(),
                     blobPath));
                     blobPath, encodings));
               WicketUtils.setCssClass(c, "prettyprint linenums");
               i = new Image("blobImage").setVisible(false);
               break;
            case 2:
               // TODO image blobs
               c = new Label("blobText", "Image File");
               // image blobs
               c = new Label("blobText").setVisible(false);
               i = new ExternalImage("blobImage", urlFor(RawPage.class, WicketUtils.newPathParameter(repositoryName, objectId, blobPath)).toString());
               break;
            case 3:
               // TODO binary blobs
               // binary blobs
               c = new Label("blobText", "Binary File");
               i = new Image("blobImage").setVisible(false);
               break;
            default:
               // plain text
               c = new Label("blobText", JGitUtils.getStringContent(r, commit.getTree(),
                     blobPath));
                     blobPath, encodings));
               WicketUtils.setCssClass(c, "plainprint");
               i = new Image("blobImage").setVisible(false);
            }
            add(c);
            add(i);
         } else {
            // plain text
            Label blobLabel = new Label("blobText", JGitUtils.getStringContent(r,
                  commit.getTree(), blobPath));
                  commit.getTree(), blobPath, encodings));
            WicketUtils.setCssClass(blobLabel, "plainprint");
            add(blobLabel);
            add(new Image("blobImage").setVisible(false));
         }
      }
   }