BL4CK R4BBIT
BL4CK R4BBITШілде 5, 2019, 3:02 Т.Ж.

Ссылка в админке под полем пароль

После смены модели на AbstractUser И создания форм регистрации и редактирования в админке пропала строка с надпись о пароле и ссылки на его смену. В профиле пользователя все работает прекрасно. Как вернуть строку

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

6
Evgenii Legotckoi
  • Шілде 5, 2019, 9:13 Т.Ж.

Добрый день!

А можете показать программный код как задавали форму для админки, а также саму подмель данных?

Скорее всего там нужно использовать форму UserAdmin

    BL4CK R4BBIT
    • Шілде 5, 2019, 10:16 Т.Ж.

    весь код выполняется без ошибок. Группы заменены на должности. Все Ок. Но системные сообщения(инфо) в админке под полями формы не выводятся.

      BL4CK R4BBIT
      • Шілде 5, 2019, 10:22 Т.Ж.

      Просто я как бы с джанго как д.Стренж с санскритом)

        Evgenii Legotckoi
        • Шілде 5, 2019, 10:24 Т.Ж.

        Сообщения под полями формы не выводятся потому, что вы их не написали. Эти сообщения нужно написать прямо в полях в модели данных. За это отвечает help_text .

        sur_name = models.CharField(max_length=True, db_index=True, help_text='Фамилия', verbose_name='Фамилия')
        

        И у меня убедительная просьба к вам. Добавляйте, пожалуйста, программный код через диалог вставки программного кода, а не в виде изображений.

          Evgenii Legotckoi
          • Шілде 5, 2019, 10:25 Т.Ж.

          Думаю, что ссылка на изменение пароля в оригинальном поле также делается через help_text, но возможно с html кодом.

            BL4CK R4BBIT
            • Шілде 5, 2019, 11:55 Т.Ж.
            • Жауап шешім ретінде белгіленді.

            Решение нашел. Спасибо за указанное направление поиска. Оставил код формы

            from django import forms
            from django.contrib.auth import password_validation
            from django.core.exceptions import ValidationError
            from django.contrib.auth.forms import ReadOnlyPasswordHashField
            from .models import MedicalUser
            
            class ChangeUserInfoForm(forms.ModelForm):
                username = forms.CharField(required=True, label='Имя пользователя')
                password = ReadOnlyPasswordHashField(label= ("Password"),
                    help_text= ("Необработанные Пароли не сохраняются, поэтому нет никакого способа увидеть  "
                                "пароль этого пользователя, но вы можете изменить пароль "
                                "с помощью <a href=\"../password/\">этой формы</a>."))
            
                class Meta:
                    model = MedicalUser
                    fields = ('username', 'email', 'first_name', 'last_name')
            
                def clean_password(self):
                    # Regardless of what the user provides, return the initial value.
                    # This is done here, rather than on the field, because the
                    # field does not have access to the initial value
                    return self.initial["password"]
            
            class CreateUserForm(forms.ModelForm):
                username = forms.CharField(required=True, label='Имя пользователя')
                password1 = forms.CharField(label='Пароль',
                    widget=forms.PasswordInput,
                    help_text=password_validation.password_validators_help_text_html())
                password2 = forms.CharField(label='Пароль (повторно)',
                    widget=forms.PasswordInput,
                    help_text='Введите тот же пароль повторно для проверки')
            
                def clean_password1(self):
                    password1 = self.cleaned_data['password1']
                    if password1:
                        password_validation.validate_password(password1)
                    return password1
            
                def clean(self):
                    super().clean()
                    password1 = self.cleaned_data['password1']
                    password2 = self.cleaned_data['password2']
                    if password1 and password2 and password1 !=password2:
                        errors = {'password2': ValidationError (
                            'Введенные пароли не совпадают', code='password_mismatch')}
            
                def save(self, commit=True):
                    user = super(CreateUserForm, self).save(commit=False)
                    user.set_password(self.cleaned_data['password1'])
                    if commit:
                        user.save()
                    return user
            
                class Meta:
                    model = MedicalUser
                    fields = ('username', 'email', 'password1', 'password2', 'first_name', 'last_name')
            

              Пікірлер

              Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
              Кіріңіз немесе Тіркеліңіз
              Г

              C++ - Тест 001. Первая программа и типы данных

              • Нәтиже:66ұпай,
              • Бағалау ұпайлары-1
              t

              C++ - Тест 001. Первая программа и типы данных

              • Нәтиже:33ұпай,
              • Бағалау ұпайлары-10
              t

              Qt - Тест 001. Сигналы и слоты

              • Нәтиже:52ұпай,
              • Бағалау ұпайлары-4
              Соңғы пікірлер
              G
              GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
              Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
              d
              dblas5Шілде 5, 2024, 11:02 Т.Ж.
              QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
              k
              kmssrАқп. 8, 2024, 6:43 Т.Қ.
              Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
              АК
              Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
              Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
              Енді форумда талқылаңыз
              Evgenii Legotckoi
              Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
              добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
              F
              FynjyШілде 22, 2024, 4:15 Т.Ж.
              при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
              BlinCT
              BlinCTМаусым 25, 2024, 1 Т.Ж.
              Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
              BlinCT
              BlinCTМамыр 5, 2024, 5:46 Т.Ж.
              Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
              Evgenii Legotckoi
              Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
              Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

              Бізді әлеуметтік желілерде бақылаңыз