mirror of https://github.com/wekan/wekan
The Open Source kanban (built with Meteor). Keep variable/table/field names camelCase. For translations, only add Pull Request changes to wekan/i18n/en.i18n.json , other translations are done at https://transifex.com/wekan/wekan only.
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
266 lines
7.4 KiB
266 lines
7.4 KiB
import { Cookies } from 'meteor/ostrio:cookies';
|
|
const cookies = new Cookies();
|
|
|
|
Template.headerUserBar.events({
|
|
'click .js-open-header-member-menu': Popup.open('memberMenu'),
|
|
'click .js-change-avatar': Popup.open('changeAvatar'),
|
|
});
|
|
|
|
Template.memberMenuPopup.helpers({
|
|
templatesBoardId() {
|
|
currentUser = Meteor.user();
|
|
if (currentUser) {
|
|
return Meteor.user().getTemplatesBoardId();
|
|
} else {
|
|
// No need to getTemplatesBoardId on public board
|
|
return false;
|
|
}
|
|
},
|
|
templatesBoardSlug() {
|
|
currentUser = Meteor.user();
|
|
if (currentUser) {
|
|
return Meteor.user().getTemplatesBoardSlug();
|
|
} else {
|
|
// No need to getTemplatesBoardSlug() on public board
|
|
return false;
|
|
}
|
|
},
|
|
});
|
|
|
|
Template.memberMenuPopup.events({
|
|
'click .js-edit-profile': Popup.open('editProfile'),
|
|
'click .js-change-settings': Popup.open('changeSettings'),
|
|
'click .js-change-avatar': Popup.open('changeAvatar'),
|
|
'click .js-change-password': Popup.open('changePassword'),
|
|
'click .js-change-language': Popup.open('changeLanguage'),
|
|
'click .js-logout'(event) {
|
|
event.preventDefault();
|
|
|
|
AccountsTemplates.logout();
|
|
},
|
|
'click .js-go-setting'() {
|
|
Popup.close();
|
|
},
|
|
});
|
|
|
|
Template.editProfilePopup.helpers({
|
|
allowEmailChange() {
|
|
Meteor.call('AccountSettings.allowEmailChange', (_, result) => {
|
|
if (result) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
});
|
|
},
|
|
allowUserNameChange() {
|
|
Meteor.call('AccountSettings.allowUserNameChange', (_, result) => {
|
|
if (result) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
});
|
|
},
|
|
allowUserDelete() {
|
|
Meteor.call('AccountSettings.allowUserDelete', (_, result) => {
|
|
if (result) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
});
|
|
},
|
|
});
|
|
|
|
Template.editProfilePopup.events({
|
|
submit(event, templateInstance) {
|
|
event.preventDefault();
|
|
const fullname = templateInstance.find('.js-profile-fullname').value.trim();
|
|
const username = templateInstance.find('.js-profile-username').value.trim();
|
|
const initials = templateInstance.find('.js-profile-initials').value.trim();
|
|
const email = templateInstance.find('.js-profile-email').value.trim();
|
|
let isChangeUserName = false;
|
|
let isChangeEmail = false;
|
|
Users.update(Meteor.userId(), {
|
|
$set: {
|
|
'profile.fullname': fullname,
|
|
'profile.initials': initials,
|
|
},
|
|
});
|
|
isChangeUserName = username !== Meteor.user().username;
|
|
isChangeEmail =
|
|
email.toLowerCase() !== Meteor.user().emails[0].address.toLowerCase();
|
|
if (isChangeUserName && isChangeEmail) {
|
|
Meteor.call(
|
|
'setUsernameAndEmail',
|
|
username,
|
|
email.toLowerCase(),
|
|
Meteor.userId(),
|
|
function(error) {
|
|
const usernameMessageElement = templateInstance.$('.username-taken');
|
|
const emailMessageElement = templateInstance.$('.email-taken');
|
|
if (error) {
|
|
const errorElement = error.error;
|
|
if (errorElement === 'username-already-taken') {
|
|
usernameMessageElement.show();
|
|
emailMessageElement.hide();
|
|
} else if (errorElement === 'email-already-taken') {
|
|
usernameMessageElement.hide();
|
|
emailMessageElement.show();
|
|
}
|
|
} else {
|
|
usernameMessageElement.hide();
|
|
emailMessageElement.hide();
|
|
Popup.back();
|
|
}
|
|
},
|
|
);
|
|
} else if (isChangeUserName) {
|
|
Meteor.call('setUsername', username, Meteor.userId(), function(error) {
|
|
const messageElement = templateInstance.$('.username-taken');
|
|
if (error) {
|
|
messageElement.show();
|
|
} else {
|
|
messageElement.hide();
|
|
Popup.back();
|
|
}
|
|
});
|
|
} else if (isChangeEmail) {
|
|
Meteor.call('setEmail', email.toLowerCase(), Meteor.userId(), function(
|
|
error,
|
|
) {
|
|
const messageElement = templateInstance.$('.email-taken');
|
|
if (error) {
|
|
messageElement.show();
|
|
} else {
|
|
messageElement.hide();
|
|
Popup.back();
|
|
}
|
|
});
|
|
} else Popup.back();
|
|
},
|
|
'click #deleteButton': Popup.afterConfirm('userDelete', function() {
|
|
Popup.close();
|
|
Users.remove(Meteor.userId());
|
|
AccountsTemplates.logout();
|
|
}),
|
|
});
|
|
|
|
// XXX For some reason the useraccounts autofocus isnt working in this case.
|
|
// See https://github.com/meteor-useraccounts/core/issues/384
|
|
Template.changePasswordPopup.onRendered(function() {
|
|
this.find('#at-field-current_password').focus();
|
|
});
|
|
|
|
Template.changeLanguagePopup.helpers({
|
|
languages() {
|
|
return _.map(TAPi18n.getLanguages(), (lang, code) => {
|
|
// Same code in /client/components/main/layouts.js
|
|
// TODO : Make code reusable
|
|
const tag = code;
|
|
let name = lang.name;
|
|
if (lang.name === 'br') {
|
|
name = 'Brezhoneg';
|
|
} else if (lang.name === 'ig') {
|
|
name = 'Igbo';
|
|
} else if (lang.name === 'oc') {
|
|
name = 'Occitan';
|
|
} else if (lang.name === '繁体中文(台湾)') {
|
|
name = '繁體中文(台灣)';
|
|
}
|
|
return { tag, name };
|
|
}).sort(function(a, b) {
|
|
if (a.name === b.name) {
|
|
return 0;
|
|
} else {
|
|
return a.name > b.name ? 1 : -1;
|
|
}
|
|
});
|
|
},
|
|
|
|
isCurrentLanguage() {
|
|
return this.tag === TAPi18n.getLanguage();
|
|
},
|
|
});
|
|
|
|
Template.changeLanguagePopup.events({
|
|
'click .js-set-language'(event) {
|
|
Users.update(Meteor.userId(), {
|
|
$set: {
|
|
'profile.language': this.tag,
|
|
},
|
|
});
|
|
event.preventDefault();
|
|
},
|
|
});
|
|
|
|
Template.changeSettingsPopup.helpers({
|
|
showDesktopDragHandles() {
|
|
currentUser = Meteor.user();
|
|
if (currentUser) {
|
|
return (currentUser.profile || {}).showDesktopDragHandles;
|
|
} else if (cookies.has('showDesktopDragHandles')) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
},
|
|
hiddenSystemMessages() {
|
|
currentUser = Meteor.user();
|
|
if (currentUser) {
|
|
return (currentUser.profile || {}).hasHiddenSystemMessages;
|
|
} else if (cookies.has('hasHiddenSystemMessages')) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
},
|
|
showCardsCountAt() {
|
|
currentUser = Meteor.user();
|
|
if (currentUser) {
|
|
return Meteor.user().getLimitToShowCardsCount();
|
|
} else {
|
|
return cookies.get('limitToShowCardsCount');
|
|
}
|
|
},
|
|
});
|
|
|
|
Template.changeSettingsPopup.events({
|
|
'click .js-toggle-desktop-drag-handles'() {
|
|
currentUser = Meteor.user();
|
|
if (currentUser) {
|
|
Meteor.call('toggleDesktopDragHandles');
|
|
} else if (cookies.has('showDesktopDragHandles')) {
|
|
cookies.remove('showDesktopDragHandles');
|
|
} else {
|
|
cookies.set('showDesktopDragHandles', 'true');
|
|
}
|
|
},
|
|
'click .js-toggle-system-messages'() {
|
|
currentUser = Meteor.user();
|
|
if (currentUser) {
|
|
Meteor.call('toggleSystemMessages');
|
|
} else if (cookies.has('hasHiddenSystemMessages')) {
|
|
cookies.remove('hasHiddenSystemMessages');
|
|
} else {
|
|
cookies.set('hasHiddenSystemMessages', 'true');
|
|
}
|
|
},
|
|
'click .js-apply-show-cards-at'(event, templateInstance) {
|
|
event.preventDefault();
|
|
const minLimit = parseInt(
|
|
templateInstance.$('#show-cards-count-at').val(),
|
|
10,
|
|
);
|
|
if (!isNaN(minLimit)) {
|
|
currentUser = Meteor.user();
|
|
if (currentUser) {
|
|
Meteor.call('changeLimitToShowCardsCount', minLimit);
|
|
} else {
|
|
cookies.set('limitToShowCardsCount', minLimit);
|
|
}
|
|
Popup.back();
|
|
}
|
|
},
|
|
});
|
|
|