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.
129 lines
2.8 KiB
129 lines
2.8 KiB
Translation = new Mongo.Collection('translation');
|
|
|
|
/**
|
|
* A Organization User in wekan
|
|
*/
|
|
Translation.attachSchema(
|
|
new SimpleSchema({
|
|
language: {
|
|
/**
|
|
* the language
|
|
*/
|
|
type: String,
|
|
max: 5,
|
|
},
|
|
text: {
|
|
/**
|
|
* the text
|
|
*/
|
|
type: String,
|
|
},
|
|
translationText: {
|
|
/**
|
|
* the translation text
|
|
*/
|
|
type: String,
|
|
optional: true,
|
|
},
|
|
createdAt: {
|
|
/**
|
|
* creation date of the translation custom string
|
|
*/
|
|
type: Date,
|
|
// eslint-disable-next-line consistent-return
|
|
autoValue() {
|
|
if (this.isInsert) {
|
|
return new Date();
|
|
} else if (this.isUpsert) {
|
|
return { $setOnInsert: new Date() };
|
|
} else {
|
|
this.unset();
|
|
}
|
|
},
|
|
},
|
|
modifiedAt: {
|
|
type: Date,
|
|
denyUpdate: false,
|
|
// eslint-disable-next-line consistent-return
|
|
autoValue() {
|
|
if (this.isInsert || this.isUpsert || this.isUpdate) {
|
|
return new Date();
|
|
} else {
|
|
this.unset();
|
|
}
|
|
},
|
|
},
|
|
}),
|
|
);
|
|
|
|
if (Meteor.isServer) {
|
|
Translation.allow({
|
|
insert(userId, doc) {
|
|
const user = ReactiveCache.getUser(userId) || ReactiveCache.getCurrentUser();
|
|
if (user?.isAdmin)
|
|
return true;
|
|
if (!user) {
|
|
return false;
|
|
}
|
|
return doc._id === userId;
|
|
},
|
|
update(userId, doc) {
|
|
const user = ReactiveCache.getUser(userId) || ReactiveCache.getCurrentUser();
|
|
if (user?.isAdmin)
|
|
return true;
|
|
if (!user) {
|
|
return false;
|
|
}
|
|
return doc._id === userId;
|
|
},
|
|
remove(userId, doc) {
|
|
const user = ReactiveCache.getUser(userId) || ReactiveCache.getCurrentUser();
|
|
if (user?.isAdmin)
|
|
return true;
|
|
if (!user) {
|
|
return false;
|
|
}
|
|
return doc._id === userId;
|
|
},
|
|
fetch: [],
|
|
});
|
|
|
|
Meteor.methods({
|
|
setCreateTranslation(
|
|
language,
|
|
text,
|
|
translationText,
|
|
) {
|
|
check(language, String);
|
|
check(text, String);
|
|
check(translationText, String);
|
|
|
|
const nTexts = ReactiveCache.getTranslations({ language, text }).length;
|
|
if (nTexts > 0) {
|
|
throw new Meteor.Error('text-already-taken');
|
|
} else {
|
|
Translation.insert({
|
|
language,
|
|
text,
|
|
translationText,
|
|
});
|
|
}
|
|
},
|
|
setTranslationText(translation, translationText) {
|
|
check(translation, Object);
|
|
check(translationText, String);
|
|
Translation.update(translation, {
|
|
$set: { translationText: translationText },
|
|
});
|
|
},
|
|
});
|
|
}
|
|
|
|
if (Meteor.isServer) {
|
|
// Index for Organization User.
|
|
Meteor.startup(() => {
|
|
Translation._collection.createIndex({ modifiedAt: -1 });
|
|
});
|
|
}
|
|
|
|
export default Translation;
|
|
|