BL4CK R4BBIT
BL4CK R4BBITJuly 30, 2019, 1:46 a.m.

Как прикрутить иконки к списку

Network Social

Хочу в профиле пользователя выводить ссылки на соцсети класс соцсетей профиля оформлен следующим кодом в модели

class SocialNetworks(models.Model):
    SOCIAL_NETWORKS = (
        ('FACEBOOK', 'Facebook'),
        ('VK', 'Вконтакте'),
        ('TWITTER', 'Твиттер'),
        ('INSTAGRAMM', 'Инстаграмм'),
        ('PINTEREST', 'Пинтерест'),
        ('GITHUB', 'GITHUB'),
    )
    social_network = models.CharField(max_length=64, choices=SOCIAL_NETWORKS, verbose_name='Социальная сеть')
    urls = models.CharField(max_length=64, blank=True, verbose_name='Ссылка')

Вопрос как в шаблон вывести эти ссылки в виде иконок. Понятно что циклом пройти и собрать наличие но как к каждой сети прикрутить соответствующую иконка FontAwesome

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

4
Evgenii Legotckoi
  • July 30, 2019, 2:42 a.m.
  • The answer was marked as a solution.

Делаете ещё один кортеж с иконками и добаляете метод, по которому будете возвращать иконку в зависимости от типа.

Приерно вот так должно получится в модели, ну а в шаблоне просто вызываете метод get_icon

class SocialNetworks(models.Model):
    SOCIAL_NETWORKS = (
        ('FACEBOOK', 'Facebook'),
        ('VK', 'Вконтакте'),
        ('TWITTER', 'Твиттер'),
        ('INSTAGRAMM', 'Инстаграмм'),
        ('PINTEREST', 'Пинтерест'),
        ('GITHUB', 'GITHUB'),
    )

    SOCIAL_NETWORK_ICONS = (
        ('FACEBOOK', 'fa fa-facebook'),
        ('VK', 'fa fa-vk'),
        ('TWITTER', 'fa fa-twitter'),
        ('INSTAGRAMM', 'fa fa-instagram'),
        ('PINTEREST', 'fa fa-pinterest'),
        ('GITHUB', 'fa fa-github'),
    )
    social_network = models.CharField(max_length=64, choices=SOCIAL_NETWORKS, verbose_name='Социальная сеть')
    urls = models.CharField(max_length=64, blank=True, verbose_name='Ссылка')

    def get_icon(self):
        return dict(SOCIAL_NETWORK_ICONS)[self.social_network]
    BL4CK R4BBIT
    • July 30, 2019, 2:45 a.m.

    Решил по другому
    присвоил константы для значений в списке choise

    class SocialNetworks(models.Model):
        FACEBOOK = "fab fa-facebook"
        VK = "fab fa-vk"
        TWITTER = "fab fa-twitter"
        INSTAGRAMM = "fab fa-instagram"
        PINTEREST = "fab fa-pinterest"
        GITHUB = "fab fa-github"
        SOCIAL_NETWORKS = (
            ('FACEBOOK', 'Facebook'),
            ('VK', 'Вконтакте'),
            ('TWITTER', 'Твиттер'),
            ('INSTAGRAMM', 'Инстаграмм'),
            ('PINTEREST', 'Пинтерест'),
            ('GITHUB', 'GITHUB'),
        )
        social_network = models.CharField(max_length=64, choices=SOCIAL_NETWORKS, verbose_name='Социальная сеть')
        urls = models.CharField(max_length=64, blank=True, verbose_name='Ссылка')
    
      BL4CK R4BBIT
      • July 30, 2019, 2:46 a.m.

      Решение брал отсюда
      http://vladimir-stupin.blogspot.com/2017/07/choices-django.html

        Evgenii Legotckoi
        • July 30, 2019, 2:50 a.m.

        тоже как вариант, я просто определяю choices одной, максимум двумя буквами всегда, чтобы минимизировать затраты базы данных в таких случаях. Поэтому предподчитаю свой вариант, у меня бы скорее всего это выглядело так.

        class SocialNetworks(models.Model):
            SOCIAL_NETWORKS = (
                ('FACEBOOK', 'f'),
                ('VK', 'v'),
                ('TWITTER', 't'),
                ('INSTAGRAMM', 'i'),
                ('PINTEREST', 'p'),
                ('GITHUB', 'g'),
            )
        

          Comments

          Only authorized users can post comments.
          Please, Log in or Sign up
          AD

          C ++ - Test 004. Pointers, Arrays and Loops

          • Result:50points,
          • Rating points-4
          m

          C ++ - Test 004. Pointers, Arrays and Loops

          • Result:80points,
          • Rating points4
          m

          C ++ - Test 004. Pointers, Arrays and Loops

          • Result:20points,
          • Rating points-10
          Last comments
          Evgenii Legotckoi
          Evgenii LegotckoiOct. 31, 2024, 2:37 p.m.
          Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
          A
          ALO1ZEOct. 19, 2024, 8:19 a.m.
          Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
          ИМ
          Игорь МаксимовOct. 5, 2024, 7:51 a.m.
          Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
          d
          dblas5July 5, 2024, 11:02 a.m.
          QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
          k
          kmssrFeb. 8, 2024, 6:43 p.m.
          Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
          Now discuss on the forum
          Evgenii Legotckoi
          Evgenii LegotckoiJune 24, 2024, 3:11 p.m.
          добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
          t
          tonypeachey1Nov. 15, 2024, 6:04 a.m.
          google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
          NSProject
          NSProjectJune 4, 2022, 3:49 a.m.
          Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
          9
          9AnonimOct. 25, 2024, 9:10 a.m.
          Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

          Follow us in social networks