', {'style':'ngSelectionCell', 'style':'margin: 10px 0;text-align: center;'})
.append($('
![]()
', {'src':asIcons[sIcon].src, style:'width: 20px;', 'class':'waypoint-icon'}))
)
)
//Display Selector
.click(function(){
toggleSelector(null, $(this));
})
);
}
//Update Icon
else {
$Row.find('.ngCell.col0-1.colt0-1')
.data('icon', sIcon)
.data('waypoint-id', sWaypointId)
.find('img.waypoint-icon')
.attr('src', asIcons[sIcon].src);
}
});
}
function toggleSelector(bShow, $Waypoint){
bShow = bShow || !$Selector.is(':visible');
$Selector.add($Background).toggle(bShow);
if(bShow) {
$Selector
.data('waypoint', $Waypoint)
.css({top: ($Waypoint.offset().top + iIconColHeight)+'px', left: ($Waypoint.offset().left)+'px'})
.find('li[data-value="'+$Waypoint.data('icon')+'"]').addClass('Mui-selected');
}
else {
$Selector
.find('li.Mui-selected').removeClass('Mui-selected');
}
return bShow;
}
function setIcon(){
var sIcon = $(this).attr('data-value');
var a$Waypoints = [];
if($Selector.data('waypoint').data('waypoint-id') == 'mass') a$Waypoints = $('.ngGrid .ngViewport .ngRow .ngCell.col0 .ngSelectionCheckbox:checked').parents('.ngRow').find('.ngCell.col0-1').toArray();
else a$Waypoints.push($Selector.data('waypoint'));
$.each(a$Waypoints, function(iKey, oWaypoint){
var $Waypoint = $(oWaypoint);
$Waypoint.find('img').attr('src', sLoader);
var sWaypointId = $Waypoint.data('waypoint-id');
$.ajax({'url':'https://www.gaiagps.com/api/objects/waypoint/'+sWaypointId+'/'}).done(function(asWaypoint){
$.ajax({
url: 'https://elevation.gaiagps.com/geojson/',
type: 'POST',
contentType: 'application/json',
data: JSON.stringify(asWaypoint.geometry)
})
.done(function(asGeo){
asWaypoint.geometry = asGeo;
asWaypoint.properties.icon = sIcon;
$.ajax({
url: 'https://www.gaiagps.com/api/objects/waypoint/'+sWaypointId+'/',
type: 'PUT',
contentType: 'application/json',
data: JSON.stringify(asWaypoint)
})
.done(function(asResult){
$.ajax({url:'https://www.gaiagps.com/api/objects/waypoint/'+sWaypointId+'/'}).done(function(asWaypoint){
$Waypoint.find('img').attr('src', asIcons[asWaypoint.properties.icon].src);
toggleSelector(false);
});
});
});
});
});
}
var iIconColWidth = 50,
iIconColHeight = 40;
sLoader = ' ';
asIcons = {};
$Icons = $('');
$Icons.find('li').each((iKey, sElem)=>{
var $Elem = $(sElem);
asIcons[$Elem.attr('data-value')] = {'title': $Elem.attr('title'), 'src':$Elem.find('img').attr('src')};
});
//Background
$Background = $('
', {'aria-hidden':'true', 'style':'position: fixed; inset: 0px; background-color: transparent;'}).click(function(){toggleSelector(false);});
//Build Icon Selector
$Selector = $('
', {
'class':'MuiPaper-root MuiMenu-paper MuiPopover-paper MuiPaper-elevation8 MuiPaper-rounded',
'style':'z-index: 1300; opacity: 1; transform: none; min-width: 52px; transition: opacity 100ms cubic-bezier(0.4, 0, 0.2, 1) 0ms, transform 67ms cubic-bezier(0.4, 0, 0.2, 1) 0ms; transform-origin: 0px 0px 0px;'
})
.append($('
', {
'class':'MuiList-root MuiMenu-list MuiList-padding',
'role':'listbox',
'tabindex':'-1',
'style':'display: flex; flex-wrap: wrap; width: 480px; flex-grow: 1;'
}));
$.each(asIcons, function(sIcon, asAttr) {
$Selector.find('ul').append(
$('- ', {
'class': 'MuiButtonBase-root MuiListItem-root MuiMenuItem-root MuiMenuItem-gutters MuiListItem-gutters MuiListItem-button',
'tabindex': '-1',
'role': 'option',
'style': 'padding-left: 8px; padding-right: 8px;',
'title': asAttr.title,
'data-value': sIcon
})
.click(setIcon)
.append(
$('
', {'src': asAttr.src, 'width': '24'})
)
);
});
//Add Selector & background to DOM
$Selector.add($Background).hide().appendTo('body');
//waypoints
asWaypoints = {};
$.ajax({url:'https://www.gaiagps.com/api/objects/waypoint/?routepoints=false&show_archived=true&show_filed=true'}).done((asData) => {
for(var i in asData) {
asWaypoints[asData[i].id] = asData[i];
}
setTimeout(init, 2000);
});
//Icon Button for mass update
$MassUpdate = $('