cartodb-4.42/lib/assets/javascripts/cartodb/common/public_navigation_view.js
2024-04-06 05:25:13 +00:00

86 lines
2.6 KiB
JavaScript

var _ = require('underscore-cdb-v3');
var cdb = require('cartodb.js-v3');
var markdown = require('markdown');
var Utils = require('cdb.Utils');
var ExportMapView = require('../common/dialogs/export_map/export_map_view');
var UserShareView = require('../public_common/user_share_view');
var LOGIN_TEMPLATE = '/';
module.exports = cdb.core.View.extend({
events: {
'click .js-Navmenu-link--download-map': '_exportMap'
},
initialize: function () {
this.template = cdb.templates.getTemplate('public/views/public_navigation');
this.client = new CartoNode.PublicClient();
this._initModels();
},
render: function () {
var baseUrl = this.user.get('base_url');
var createdByInfo = 'Map created by ' + this.user.get('username') + ' in CARTO';
var description = this.vizdata.description
? Utils.stripHTML(markdown.toHTML(this.vizdata.description) + ' ' + createdByInfo)
: createdByInfo;
var encodedName = window.encodeURI(this.vizdata.name);
var encodedUrl = window.encodeURI(baseUrl + '/viz/' + this.vizdata.id + '/public_map');
var encodedDescription = window.encodeURI(description);
this.clearSubViews();
this.$el.html(this.template({
baseUrl: baseUrl,
editUrl: baseUrl + '/viz/' + this.vizdata.id + '/map',
embedMapUrl: baseUrl + '/viz/' + this.vizdata.id + '/embed_map',
shareFacebook: encodedUrl,
shareLinkedIn: encodedUrl + '&title=' + encodedName + '&summary=' + encodedDescription + '&source=CARTO',
shareTwitter: encodedName + '&url=' + encodedUrl + '&via=CARTO',
userAvatar: this.user.get('avatar_url'),
userName: this.user.nameOrUsername(),
vizId: this.vizdata.id
}));
if (this.currentUser && this.currentUser.get('username') === this.user.get('username')) {
this.$('.js-Navmenu-editLink').addClass('is-active');
}
this.userShareView = new UserShareView({
el: this.$('.js-Navmenu-share'),
model: new cdb.core.Model({
active: false
})
});
this.addView(this.userShareView);
return this;
},
_initModels: function () {
this.user = this.options.user;
this.currentUser = this.options.currentUser;
this.vizdata = this.options.vizdata;
this.data = this.options.data;
this.needLogin = this.currentUser == null;
},
_exportMap: function (event) {
event.preventDefault();
var $mapView = new ExportMapView({
model: new cdb.admin.ExportMapModel({
visualization_id: this.vizdata.id
}),
clean_on_hide: true,
enter_to_confirm: true
});
this.addView($mapView);
$mapView.appendToBody();
}
});