১৩.৩ : রেজিস্ট্রেশন ফর্ম তৈরী

আজকে আমরা আমাদের accounts মডেল থেকে ফরম বানাবো। এখন আমাদের কিন্তু টোটাল ৩ টা মডেল আছে খেয়াল করছো কিনা। সেটা হলো বিল্ট ইন ইউজার মডেল, তারপর ইউজার এর ব্যাংক একাউন্ট মডেল, ইউজার এর অ্যাড্রেস মডেল। এখন আমরা চাই যে ইউজার ফরম ফিল আপ করবে একটা কিন্তু ডাটা সেভ হয়ে যাবে তিন টা মডেল এই। সেটার জন্যে আমরা একটা রেজিস্ট্রেশন ফরম বানাবো সেখানে django এর বিল্ট ইন usercreationform কে ইনহেরিট করে নিবো। সেখানে user মডেল, accounts মডেল, অ্যাড্রেস মডেল এর ফিল্ড গুলা নিয়ে আসবো। এখন ফিল্ড আনা শেষ কিন্তু আমরা চাই ইউজার একটা ফরম এর সাবমিট এ ক্লিক করলে তিন টা ডাটা base এই যেনো ডাটা সেভ হয় আর ডাটা ডাটাবেজ এ সেভ করার জন্যে একটা ফাংশন ইউজ করতাম আমরা নাম save এই সেভ ফাংশন কে আমরা মডিফাই করে এমন ভাবে লিখবো যেনো ইউজার ফরম সাবমিট করার সাথে সাথেই বাকি তিনটা মডেল এর ডাটা ও সেভ হয়ে যায়।

accounts/forms.py

class UserRegistrationForm(UserCreationForm):
    birth_date = forms.DateField(widget=forms.DateInput(attrs={'type':'date'}))
    gender = forms.ChoiceField(choices=GENDER_TYPE)
    account_type = forms.ChoiceField(choices=ACCOUNT_TYPE)
    street_address = forms.CharField(max_length=100)
    city = forms.CharField(max_length= 100)
    postal_code = forms.IntegerField()
    country = forms.CharField(max_length=100)
    class Meta:
        model = User
        fields = ['username', 'password1', 'password2', 'first_name', 'last_name', 'email', 'account_type', 'birth_date','gender', 'postal_code', 'city','country', 'street_address']

এখানে খেয়াল করে দেখো যে তিনটা মডেল এর ডাটা ই কিন্তু আছে এখানে

এখন save ফাংশন টা লিখবো , সেখানে আগে আমরা user মডেল এর ডাটা সেভ করবো। এরপর ইউজার যে ফরম টা সাবমিট করবে সেখানে তার একাউন্ট ইনফরমেশনের সাথে অ্যাড্রেস টাও থাকবে সেই ডাটা গুলা পাওয়ার জন্যে আমরা cleaned_data এর হেল্প নিবো তারপর সেখান থেকে ডাটা গুলা নিচের মত করে বের করে আনবো।

class UserRegistrationForm(UserCreationForm):
    birth_date = forms.DateField(widget=forms.DateInput(attrs={'type':'date'}))
    gender = forms.ChoiceField(choices=GENDER_TYPE)
    account_type = forms.ChoiceField(choices=ACCOUNT_TYPE)
    street_address = forms.CharField(max_length=100)
    city = forms.CharField(max_length= 100)
    postal_code = forms.IntegerField()
    country = forms.CharField(max_length=100)
    class Meta:
        model = User
        fields = ['username', 'password1', 'password2', 'first_name', 'last_name', 'email', 'account_type', 'birth_date','gender', 'postal_code', 'city','country', 'street_address']
        
        # form.save()
    def save(self, commit=True):
        our_user = super().save(commit=False) # ami database e data save korbo na ekhn
        if commit == True:
            our_user.save() # user model e data save korlam
            account_type = self.cleaned_data.get('account_type')
            gender = self.cleaned_data.get('gender')
            postal_code = self.cleaned_data.get('postal_code')
            country = self.cleaned_data.get('country')
            birth_date = self.cleaned_data.get('birth_date')
            city = self.cleaned_data.get('city')
            street_address = self.cleaned_data.get('street_address')

এখন কিন্তু আমাদের কাছে ইউজার এর অ্যাকাউন্ট, অ্যাড্রেস এর সব ডাটা আছে তাইলে জাস্ট এখন ডাটাবেজ এ ডাটা গুলা সেভ করতে হবে। সেটার জন্যে

model_name.objects.create() এই ফাংশন এর হেল্প নিবো আমরা তারপর কীওয়ার্ড আর্গুমেন্ট দিয়ে মডেল গুলা তে ডাটা বসাবো নিচের মত করে। এখানে তুমি ব্যাংক একাউন্ট যে নম্বর টা আছে সেটার আগে 100000 অ্যাড করে দিতে পারো তাইলে real ব্যাংক অ্যাকাউন্ট এর নম্বর মনে হবে সেটা।

Last updated