Ich arbeite an meiner Domain-generierenden App, die Domain-Namen in verschiedenen Sprachen bietet.Meteor mongo sessions
ist es möglich, eine Mongo-Sammlung in Benutzersitzungen zu speichern? So konnte jeder Benutzer verschiedene Sammlungsergebnisse sehen. Ich habe einen API-Aufruf Server-Seite, die Daten in Mongo Sammlung geht:
Meteor.methods({
translateToEn: function(){
var arrayy = Help.find().fetch();
var text = arrayy[0].text;
var final;
var myJSON;
Typed.remove({});
var translate = require('yandex-translate-api')('trnsl.1.1.20170424T153548Z.48f645437a55346f.e53fc386af70fd7d7f7138ae23b6c79fb3a5def9');
translate.translate(text, { to: 'en'},Meteor.bindEnvironment(function(err, res) {
myJSON = JSON.stringify(res.text);
myJSON = myJSON.replace(/\s/g, '');
myJSON = JSON.parse(myJSON);
myJSON.toString()
final = myJSON;
var geras = final.toString();
var naujas = Diacritics.remove(geras);
final = naujas;
var array = [{"text": " "}]
var ends = [{"text": ".com"},{"text": ".co.uk"},{"text": ".net"},{"text": ".org"},{"text": ".eu"},{"text": ".biz"},{"text": ".blog"},{"text": ".in"}]
var sug;
for(var i=0; i<8; i++)
{
var randomIndex = Math.floor(Math.random() * array.length);
var randomIndex2 = Math.floor(Math.random() * ends.length);
var element = array[randomIndex].text;
var end = ends[randomIndex2].text;
sug = final + element+end;
sug = sug.replace(/\s/g, '');
Typed.insert({
text: sug,
createdAt: new Date(),
lang: res.lang });
}
url = 'https://api.ote-godaddy.com/v1/domains/available?checkType=FAST';
headers = {
"Authorization": "sso-key 2s7YSCfHkx_Xsfgx2tB1fV4WVrdd8VQuz:XsfkhRdwfMCm633B7GT6qz",
"Content-Type": "application/json",
"Accept": "application/json"
}
var arrays = Typed.find().fetch();
var test = arrays[0].text+' ';
var lang = arrays[0].lang;
console.log(lang);
for(var i = 1; i<arrays.length-1; i++)
{
test = test + arrays[i].text+' ';
}
test=test+arrays[arrays.length-1].text;
logs = test.split(" ");
//console.log(logs);
HTTP.post(url,{
data: logs,
headers : headers
}, function(error, response) {
if (error) {
console.log(error);
} else {
var results = JSON.parse(response.content);
for(i =0; i< results.domains.length; i++){
if(results.domains[i].price == null)
{
results.domains[i].price = "undefined";
}
if(results.domains[i].available == false)
{
results.domains[i].available = "false";
TransToEnF.insert({domain: results.domains[i].domain, available: results.domains[i].available,definitive: results.domains[i].definitive,price: results.domains[i].price,currency: results.domains[i].currency, Buy:"Buy", lang:lang, translation:final});
}
if(results.domains[i].available == true)
{
results.domains[i].available = "true";
TransToEnT.insert({domain: results.domains[i].domain, available: results.domains[i].available,definitive: results.domains[i].definitive,price: results.domains[i].price,currency: results.domains[i].currency, Buy:"Buy", lang:lang, translation:final});
}
}
}
});
Typed.remove({});
}));
}});
ich diese Methode von der Client-Seite bin Aufruf einreichen Ereignis wie folgt aus:
Template.search.events({
'submit .new-input'(event) {
Meteor.call('remove',function(){});
event.preventDefault();
const target = event.target;
const text = target.text.value;
Help.insert({text: text});
Place.insert({text: text,createdAt: new Date()});
Meteor.call('translateToEn',function(){});
target.text.value = '';
Meteor._reload.reload();
},
und Druckdaten Helfer mit:
leider, wenn es mehr als 1 Benutzer gibt, sehen sie alle die gleichen Ergebnisse, Seite wird sofort neu geladen, nachdem einer von ihnen das Textfeld übermittelt. Haben Sie irgendwelche Lösungen, um dieses Problem zu lösen?