Я только что интегрировал Mailchimp
в свой проект Django, используя Ajax
.Поле адреса электронной почты работает правильно, и я могу получить письмо как в моем списке Mailchimp, так и в моей базе данных.Теперь, когда я пытаюсь добавить поле, позволяющее пользователю добавить свое имя в форму, я продолжаю получать ошибки, подобные этой, например: from .utils import SendSubscribeMail
File "C:\Users\locq\Desktop\Coding\SEARCH_APP\venv\src\search\utils.py", line 8
self.fname = fname
^
TabError: inconsistent use of tabs and spaces in indentation
..
Так как я могу добавить поле FNAME иотправить данные на mailchimp при отправке?
Вот мой код:
В моем файле Settings.p я добавил свои учетные данные Mailchimp внизу, как это:
MAILCHIMP_API_KEY = '767ba************-us6'
MAILCHIMP_SUBSCRIBE_LIST_ID = '45c*******'
Iсоздал файл utils.py для использования Threading, пакета Mailchimp и импорта моих учетных данных из настроек:
import threading
import mailchimp
from django.conf import settings
class SendSubscribeMail(object):
def __init__(self, email, fname):
self.email = email
self.fname = fname
thread = threading.Thread(target=self.run, args=())
thread.daemon = True
thread.start()
def run(self):
API_KEY = settings.MAILCHIMP_API_KEY
LIST_ID = settings.MAILCHIMP_SUBSCRIBE_LIST_ID
api = mailchimp.Mailchimp(API_KEY)
try:
api.lists.subscribe(LIST_ID, {'email': self.email}, merge_vars={'FNAME': self.fname}, double_optin=False)
except:
return False
Custom Def для получения входных имен:
def subscribe(request):
if request.method == 'POST':
fname = request.POST['fname_id']
Subscribe.objects.create(fname_id = fname)
email = request.POST['email_id']
email_qs = Subscribe.objects.filter(email_id = email)
if email_qs.exists():
data = {"status" : "404"}
return JsonResponse(data)
else:
Subscribe.objects.create(email_id = email)
SendSubscribeMail(email, fname) # Send the Mail, Class available in utils.py
return HttpResponse("/")
Модели.py Я использую, чтобы добавить адрес электронной почты (и fname) в таблицу подписки моей базы данных:
class Subscribe(models.Model):
email_id = models.EmailField()
fname_id = models.CharField(max_length=255, blank=True, null=True, default='')
timestamp = models.DateTimeField(auto_now=True)
def __str__(self):
return self.email_id
Моя HTML-форма:
<div class="signup subs-form">
<div class="header">
<p>Sign Up For Beta</p>
</div>
<div class="description">
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna.</p>
</div>
<form method="POST" id="subscribe" class="subs-form">
{% csrf_token %}
<div>
<input type="email" class="button-" id="email" name="email_id" placeholder="E-mail">
<div class="input">
<input type="text" class="button-" id="fname" name="fname_id" placeholder="First Name">
<input type="submit" class="button-" id="submit" value="Join">
</div>
</div>
</form>
</div>
И, наконец, вот код Ajax, который у меня естьвнизу моей страницы:
$('#subscribe').submit(function(e){
e.preventDefault();
var email_id = $("#email").val();
if(email_id){
var csrfmiddlewaretoken = csrftoken;
var fname_id = $("#fname").val();
var email_data = {"email_id": email_id,
"fname_id": fname_id,
"csrfmiddlewaretoken" : csrfmiddlewaretoken};
$.ajax({
type : 'POST',
url : '/subscribe/',
data : email_data,
success : function(response){
$('#email').val('');
if(response.status == "404"){
alert("This Email is already been subscribed!");
}
else{
alert("Thank you for Subscribing! Please Check your Email to Confirm the Subscription");
}
},
error: function(response) {
alert("Sorry Something went Wrong");
$('#email').val('');
}
});
return false;
}
else{
alert("Please provide correct email!");
}
});
function getCookie(name) {
var cookieValue = null;
if (document.cookie && document.cookie !== '') {
var cookies = document.cookie.split(';');
for (var i = 0; i < cookies.length; i++) {
var cookie = jQuery.trim(cookies[i]);
if (cookie.substring(0, name.length + 1) === (name + '=')) {
cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
break;
}
}
}
return cookieValue;
}
var csrftoken = jQuery("[name=csrfmiddlewaretoken]").val();
function csrfSafeMethod(method) {
return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
}
$.ajaxSetup({
beforeSend: function(xhr, settings) {
if (!csrfSafeMethod(settings.type) && !this.crossDomain) {
xhr.setRequestHeader("X-CSRFToken", csrftoken);
}
}
})
Как мне этого добиться?