From 4ea052fca0dfbe6370ace7660fb2acbee8f857f5 Mon Sep 17 00:00:00 2001 From: mpl Date: Mon, 10 Jun 2013 00:41:05 +0200 Subject: [PATCH] newui: permanode: rm type drop down, added cammount tip Change-Id: Iec6f4fb7c3e7ad1ed92ee409822f15a5e2d41e11 --- server/camlistored/newui/permanode.html | 16 +--------- server/camlistored/newui/permanode.js | 40 +++++++++++++++---------- 2 files changed, 25 insertions(+), 31 deletions(-) diff --git a/server/camlistored/newui/permanode.html b/server/camlistored/newui/permanode.html index 91197cb91..de4563c65 100644 --- a/server/camlistored/newui/permanode.html +++ b/server/camlistored/newui/permanode.html @@ -63,21 +63,7 @@
-
-

- Type: - -

-
+

diff --git a/server/camlistored/newui/permanode.js b/server/camlistored/newui/permanode.js index 847d1c729..e51cadac6 100644 --- a/server/camlistored/newui/permanode.js +++ b/server/camlistored/newui/permanode.js @@ -236,8 +236,10 @@ function(permanode, describeResult) { // handle type detection handleType(permObj); - // TODO(mpl): link to filetree browser when type is dir - // TODO(mpl): display command to cammount the dir + // TODO(mpl): add a line showing something like + // "Content: file (blobref)" or + // "Content: directory (blobref)" or + // "Content: None (has members)". // members this.reloadMembers_(); @@ -251,6 +253,19 @@ function(permanode, describeResult) { var useFileBlobrefAsLink = "true"; var blobItem = new camlistore.BlobItem(permanode, meta, useFileBlobrefAsLink); blobItem.decorate(content); + // TODO(mpl): ideally this should be done by handleType, but it's easier + // to do it now that we have a blobItem object to work with. + var isdir = blobItem.getDirBlobref_() + var mountTip = goog.dom.getElement("cammountTip"); + goog.dom.removeChildren(mountTip); + if (isdir != "") { + var tip = "Mount with:"; + goog.dom.setTextContent(mountTip, tip); + goog.dom.appendChild(mountTip, goog.dom.createDom("br")); + var codeTip = goog.dom.createDom("code"); + goog.dom.setTextContent(codeTip, "$ cammount /some/mountpoint " + isdir); + goog.dom.appendChild(mountTip, codeTip); + } } // debug attrs @@ -899,27 +914,20 @@ function permAttr(permanodeObject, name) { function handleType(permObj) { var disablePublish = false; var selType = goog.dom.getElement("type"); - if (permAttr(permObj, "camliRoot")) { - selType.value = "root"; - disablePublish = true; // can't give a URL to a root with a claim - } else if (permAttr(permObj, "camliContent")) { - selType.value = "file"; - } else if (permAttr(permObj, "camliMember")) { - selType.value = "collection"; - } - var dnd = goog.dom.getElement("dnd"); var btnGallery = goog.dom.getElement("btnGallery"); var membersDiv = goog.dom.getElement("members"); - if (selType.value == "collection" || selType.value == "") { + dnd.style.display = "none"; + btnGallery.style.visibility = 'hidden'; + goog.dom.setTextContent(membersDiv, ""); + if (permAttr(permObj, "camliRoot")) { + disablePublish = true; // can't give a URL to a root with a claim + } else if (permAttr(permObj, "camliMember")) { dnd.style.display = "block"; btnGallery.style.visibility = 'visible'; goog.dom.setTextContent(membersDiv, "Members:"); - } else { - dnd.style.display = "none"; - btnGallery.style.visibility = 'hidden'; - goog.dom.setTextContent(membersDiv, ""); } + goog.dom.getElement("selectPublishRoot").disabled = disablePublish; goog.dom.getElement("publishSuffix").disabled = disablePublish; goog.dom.getElement("btnSavePublish").disabled = disablePublish;