part way through add links to topic cards

This commit is contained in:
Shai Mor 2014-08-11 18:55:53 -04:00
parent 6182ba4e14
commit 85bfce0237
5 changed files with 114 additions and 72 deletions

File diff suppressed because one or more lines are too long

View file

@ -639,20 +639,6 @@ Metamaps.TopicCard = {
$('.showcard').draggable({ $('.showcard').draggable({
handle: ".metacodeImage" handle: ".metacodeImage"
}); });
$('#showcard').resizable({
maxHeight: 500,
maxWidth: 500,
minHeight: 320,
minWidth: 226,
resize: function (event, ui) {
var p = $('#showcard').find('.scroll');
p.height(p.height()).mCustomScrollbar('update');
}
}).css({
display: 'none',
top: '300px',
left: '100px'
});
}, },
fadeInShowCard: function (topic) { fadeInShowCard: function (topic) {
$('.showcard').fadeIn('fast'); $('.showcard').fadeIn('fast');
@ -678,6 +664,38 @@ Metamaps.TopicCard = {
var self = Metamaps.TopicCard; var self = Metamaps.TopicCard;
var showCard = document.getElementById('showcard'); var showCard = document.getElementById('showcard');
// starting embed.ly
if (false && topic.get('link')) {
$('.showcard .attachments a').embedly({
query: {maxwidth: 300},
key: '7983300f4c1f48569ca242e3d6bff1e9'
});
}
var addLinkFunc = function () {
var addLinkDiv ='';
var addLinkDesc ='Enter or paste a link';
addLinkDiv+='<div class="addLink"><div id="addLinkBack"></div>';
addLinkDiv+='<div id="addLinkInput"><input placeholder="' + addLinkDesc + '"></input>';
addLinkDiv+='<div id="addLinkReset"></div></div></div>';
$('.addAttachment').hide();
$('.attachments').append(addLinkDiv);
$('.showcard #addLinkBack').click(backFunc);
$('.showcard #addLinkReset').click(resetFunc);
};
var backFunc = function () {
$('.addLink').remove();
$('.addAttachment').show();
};
var resetFunc = function () {
$('#addLinkInput input').val('');
$('#addLinkInput input').focus();
};
$('.showcard #addlink').click(addLinkFunc);
var selectingMetacode = false; var selectingMetacode = false;
// attach the listener that shows the metacode title when you hover over the image // attach the listener that shows the metacode title when you hover over the image
$('.showcard .metacodeImage').mouseenter(function () { $('.showcard .metacodeImage').mouseenter(function () {
@ -792,12 +810,6 @@ Metamaps.TopicCard = {
var desc = $(this).html(); var desc = $(this).html();
topic.set("desc", desc); topic.set("desc", desc);
}); });
$(showCard).find('.best_in_place_link').bind("ajax:success", function () {
var link = $(this).html();
$(showCard).find('.go-link').attr('href', link);
topic.set("link", link);
});
}, },
populateShowCard: function (topic) { populateShowCard: function (topic) {
var self = Metamaps.TopicCard; var self = Metamaps.TopicCard;
@ -806,7 +818,8 @@ Metamaps.TopicCard = {
$(showCard).find('.permission').remove(); $(showCard).find('.permission').remove();
var html = self.generateShowcardHTML.render(self.buildObject(topic)); var topicForTemplate = self.buildObject(topic);
var html = self.generateShowcardHTML.render(topicForTemplate);
if (topic.authorizeToEdit(Metamaps.Active.Mapper)) { if (topic.authorizeToEdit(Metamaps.Active.Mapper)) {
var perm = document.createElement('div'); var perm = document.createElement('div');
@ -828,29 +841,29 @@ Metamaps.TopicCard = {
generateShowcardHTML: null, // will be initialized into a Hogan template within init function generateShowcardHTML: null, // will be initialized into a Hogan template within init function
//generateShowcardHTML //generateShowcardHTML
buildObject: function (topic) { buildObject: function (topic) {
var nodeValues = {}; var nodeValues = {};
var authorized = topic.authorizeToEdit(Metamaps.Active.Mapper); var authorized = topic.authorizeToEdit(Metamaps.Active.Mapper);
//link is rendered differently if user is logged out or in
var go_link, a_tag, close_a_tag;
if (!authorized) { if (!authorized) {
go_link = '';
if (topic.get("link") != "") {
a_tag = '<a href="' + topic.get("link") + '" target="_blank">';
close_a_tag = '</a>';
} else {
a_tag = '';
close_a_tag = '';
}
} else { } else {
go_link = '<a href="' + topic.get("link") + '" ' +
' class="go-link" target="_blank"></a>';
a_tag = '';
close_a_tag = '';
} }
var desc_nil = "Click to add description..."; var desc_nil = "Click to add description...";
var link_nil = "Click to add link...";
if (false && topic.get('link')) {
nodeValues.attachments = '<a href="'+topic.get('link')+'">'+topic.get('link')+'</a>';
}
else {
nodeValues.attachments = '<div class="addAttachment">';
nodeValues.attachments+= '<div id="addphoto">photo</div>';
nodeValues.attachments+= '<div id="addlink">link</div>';
nodeValues.attachments+= '<div id="addaudio">audio</div>';
nodeValues.attachments+= '<div id="addupload">upload</div> </div>';
}
nodeValues.permission = topic.get("permission"); nodeValues.permission = topic.get("permission");
nodeValues.mk_permission = topic.get("permission").substring(0, 2); nodeValues.mk_permission = topic.get("permission").substring(0, 2);
@ -864,14 +877,8 @@ Metamaps.TopicCard = {
nodeValues.userid = topic.get("user_id"); nodeValues.userid = topic.get("user_id");
nodeValues.username = topic.getUser().get("name"); nodeValues.username = topic.getUser().get("name");
nodeValues.date = topic.getDate(); nodeValues.date = topic.getDate();
// the code for this is stored in /views/main/_metacodeOptions.html.erb // the code for this is stored in /views/main/_metacodeOptions.html.erb
nodeValues.metacode_select = $('#metacodeOptions').html(); nodeValues.metacode_select = $('#metacodeOptions').html();
nodeValues.go_link = go_link;
nodeValues.a_tag = a_tag;
nodeValues.close_a_tag = close_a_tag;
nodeValues.link_nil = link_nil;
nodeValues.link = (topic.get("link") == "" && authorized) ? link_nil : topic.get("link");
nodeValues.desc_nil = desc_nil; nodeValues.desc_nil = desc_nil;
nodeValues.desc = (topic.get("desc") == "" && authorized) ? desc_nil : topic.get("desc"); nodeValues.desc = (topic.get("desc") == "" && authorized) ? desc_nil : topic.get("desc");
return nodeValues; return nodeValues;

View file

@ -6,24 +6,24 @@
color:#444; color:#444;
} }
.showcard, #showcard { .showcard {
position:absolute; position:absolute;
display:block; display:none;
top:-1000px; top:300px;
left:-1000px; left:100px;
margin-top: -181px; margin-top: -181px;
width:226px; width:300px;
height:320px; height:360px;
color:#FFF; color:#FFF;
text-align: left; text-align: left;
overflow: visible; overflow: visible;
z-index:14000; z-index:14000;
background: #FFF; background: #FFF;
border-radius:5px; border-radius:2px;
box-shadow: 6px 6px 8px rgba(0,0,0,0.4); box-shadow: 6px 6px 8px rgba(0,0,0,0.4);
} }
#showcard .contributor { .showcard .contributor {
font-size:14px; font-size:14px;
} }
@ -358,7 +358,7 @@ float:left;
} }
.CardOnGraph .link { .CardOnGraph .attachments {
-webkit-box-flex: 1; /* OLD - iOS 6-, Safari 3.1-6 */ -webkit-box-flex: 1; /* OLD - iOS 6-, Safari 3.1-6 */
-moz-box-flex: 1; /* OLD - Firefox 19- */ -moz-box-flex: 1; /* OLD - Firefox 19- */
-webkit-flex: 1; /* Chrome */ -webkit-flex: 1; /* Chrome */
@ -378,12 +378,10 @@ float:left;
flex-direction: row; flex-direction: row;
border-top: 1px solid #AAAAAA; border-top: 1px solid #AAAAAA;
width:100%; width:100%;
max-height:34px; max-height:48px;
background: url(MMCCicon_link.png) no-repeat 6px 5px;
background-size:24px 24px;
} }
.CardOnGraph .best_in_place_link { .attachments a {
-webkit-box-flex: 1; /* OLD - iOS 6-, Safari 3.1-6 */ -webkit-box-flex: 1; /* OLD - iOS 6-, Safari 3.1-6 */
-moz-box-flex: 1; /* OLD - Firefox 19- */ -moz-box-flex: 1; /* OLD - Firefox 19- */
-webkit-flex: 1; /* Chrome */ -webkit-flex: 1; /* Chrome */
@ -399,30 +397,58 @@ float:left;
line-height: 16px; line-height: 16px;
} }
.best_in_place_link input{ .addAttachment div {
display: inline-block;
width: 72px;
height: 23px;
text-align: center;
padding-top: 25px;
font-size: 12px;
color: #9e9e9e;
cursor: pointer;
}
.addAttachment div:hover {
color: #616161;
}
.addLink div {
display: inline-block;
}
#addLinkBack {
height: 48px;
width: 48px;
cursor: pointer;
}
#addLinkInput {
height: 32px;
width: 236px;
padding: 8px 16px 8px 0;
position: relative;
}
#addLinkInput input{
padding: 7px 31px 7px 31px;
height: 16px; height: 16px;
margin: -1px 0 0 0; width: 172px;
border: 0; margin: 0 0 0 0;
border: 1px solid #EFEFEF;
outline: none; outline: none;
font-size: 16px; font-size: 16px;
line-height: 16px; line-height: 16px;
line-height: 16px;
background: white; background: white;
color: black; color: black;
font-family: 'LatoLight'; font-family: 'LatoLight';
} }
.CardOnGraph .go-link { #addLinkReset {
max-width: 34px; position: absolute;
height: 34px; top: 8px;
background: url(MMCCicon_go.png) no-repeat center center; right: 16px;
background-size: 20px 20px; width: 32px;
-webkit-box-flex: 1; /* OLD - iOS 6-, Safari 3.1-6 */ height: 32px;
-moz-box-flex: 1; /* OLD - Firefox 19- */ cursor: pointer;
-webkit-flex: 1; /* Chrome */
-ms-flex: 1; /* IE 10 */
flex: 1; /* NEW, Spec - Opera 12.1, Firefox 20+ */
margin-right:12px;
} }
.cardSettings { .cardSettings {

View file

@ -46,6 +46,9 @@
.mapPage .mapElement { .mapPage .mapElement {
display: block; display: block;
} }
.mapPage .mapElementHidden {
display:none;
}
/* loading */ /* loading */

View file

@ -179,8 +179,8 @@
<div class="clearfloat"></div> <div class="clearfloat"></div>
</div> </div>
</div> </div>
<div class="link"> <div class="attachments">
{{a_tag}}<span class="best_in_place best_in_place_link" data-url="/topics/{{id}}" data-object="topic" data-nil="{{link_nil}}" data-attribute="link" data-type="input">{{link}}</span>{{close_a_tag}} {{{go_link}}} {{{attachments}}}
</div> </div>
<div class="clearfloat"></div> <div class="clearfloat"></div>
</div> </div>