├── README.md ├── blog ├── __init__.py ├── __pycache__ │ ├── __init__.cpython-38.pyc │ ├── admin.cpython-38.pyc │ ├── forms.cpython-38.pyc │ ├── models.cpython-38.pyc │ ├── urls.cpython-38.pyc │ └── views.cpython-38.pyc ├── admin.py ├── apps.py ├── forms.py ├── migrations │ ├── 0001_initial.py │ ├── 0002_auto_20201024_0025.py │ ├── 0003_comment.py │ ├── 0004_auto_20201026_2226.py │ ├── 0005_auto_20201027_1233.py │ ├── __init__.py │ └── __pycache__ │ │ ├── 0001_initial.cpython-38.pyc │ │ ├── 0002_auto_20201024_0025.cpython-38.pyc │ │ ├── 0003_comment.cpython-38.pyc │ │ ├── 0004_auto_20201026_2226.cpython-38.pyc │ │ ├── 0005_auto_20201027_1233.cpython-38.pyc │ │ └── __init__.cpython-38.pyc ├── models.py ├── static │ └── blog │ │ ├── css │ │ ├── bootstrap.min.css │ │ └── main.css │ │ ├── fonts │ │ ├── OFL.txt │ │ ├── Tajawal-Black.ttf │ │ ├── Tajawal-Bold.ttf │ │ ├── Tajawal-ExtraBold.ttf │ │ ├── Tajawal-ExtraLight.ttf │ │ ├── Tajawal-Light.ttf │ │ ├── Tajawal-Medium.ttf │ │ └── Tajawal-Regular.ttf │ │ ├── images │ │ ├── favicon.ico │ │ └── mim-logo.png │ │ └── js │ │ ├── bootstrap.min.js │ │ ├── fontawesome-all.min.js │ │ ├── jquery-3.5.1.slim.min.js │ │ └── popper.min.js ├── templates │ └── blog │ │ ├── about.html │ │ ├── base.html │ │ ├── detail.html │ │ ├── index.html │ │ ├── latest_comments.html │ │ ├── latest_posts.html │ │ ├── new_post.html │ │ ├── pagination.html │ │ ├── post_confirm_delete.html │ │ └── postupdate.html ├── templatetags │ ├── __init__.py │ ├── __pycache__ │ │ ├── __init__.cpython-38.pyc │ │ └── blog_tags.cpython-38.pyc │ └── blog_tags.py ├── tests.py ├── urls.py └── views.py ├── db.sqlite3 ├── manage.py ├── media ├── default.jpg └── profile_pics │ ├── FB_IMG_1542136823937.jpg │ ├── FB_IMG_1544018297399.jpg │ ├── FB_IMG_1544018297399_vS5JqNQ.jpg │ ├── default.jpg │ ├── pic.jpg │ ├── saeed.jpg │ └── ٢٠١٨٠٣٣١_٢٣١١٠٢.jpg ├── my_blog ├── __init__.py ├── __pycache__ │ ├── __init__.cpython-38.pyc │ ├── settings.cpython-38.pyc │ ├── urls.cpython-38.pyc │ └── wsgi.cpython-38.pyc ├── asgi.py ├── settings.py ├── urls.py └── wsgi.py └── user ├── __init__.py ├── __pycache__ ├── __init__.cpython-38.pyc ├── admin.cpython-38.pyc ├── forms.cpython-38.pyc ├── models.cpython-38.pyc ├── urls.cpython-38.pyc └── views.cpython-38.pyc ├── admin.py ├── apps.py ├── forms.py ├── migrations ├── 0001_initial.py ├── __init__.py └── __pycache__ │ ├── 0001_initial.cpython-38.pyc │ └── __init__.cpython-38.pyc ├── models.py ├── templates └── user │ ├── log_in.html │ ├── log_out.html │ ├── profile.html │ ├── profile_update.html │ └── register.html ├── tests.py ├── urls.py └── views.py /README.md: -------------------------------------------------------------------------------- 1 | # Full-Stack-Project-Blog-Django-Framework 2 | Full Stack Project (Blog) Django Framework 3 | -------------------------------------------------------------------------------- /blog/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/__init__.py -------------------------------------------------------------------------------- /blog/__pycache__/__init__.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/__pycache__/__init__.cpython-38.pyc -------------------------------------------------------------------------------- /blog/__pycache__/admin.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/__pycache__/admin.cpython-38.pyc -------------------------------------------------------------------------------- /blog/__pycache__/forms.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/__pycache__/forms.cpython-38.pyc -------------------------------------------------------------------------------- /blog/__pycache__/models.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/__pycache__/models.cpython-38.pyc -------------------------------------------------------------------------------- /blog/__pycache__/urls.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/__pycache__/urls.cpython-38.pyc -------------------------------------------------------------------------------- /blog/__pycache__/views.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/__pycache__/views.cpython-38.pyc -------------------------------------------------------------------------------- /blog/admin.py: -------------------------------------------------------------------------------- 1 | from django.contrib import admin 2 | from blog.models import post, comment 3 | 4 | admin.site.register(post) 5 | admin.site.register(comment) 6 | -------------------------------------------------------------------------------- /blog/apps.py: -------------------------------------------------------------------------------- 1 | from django.apps import AppConfig 2 | 3 | 4 | class BlogConfig(AppConfig): 5 | name = 'blog' 6 | -------------------------------------------------------------------------------- /blog/forms.py: -------------------------------------------------------------------------------- 1 | from django import forms 2 | from blog.models import comment, post 3 | 4 | # class NewComment(forms.Form): 5 | # name = forms.CharField() 6 | # email = forms.EmailField() 7 | # body = forms.Textarea() 8 | 9 | class NewComment(forms.ModelForm): 10 | class Meta: 11 | model = comment 12 | fields = ('name', 'email', 'body') 13 | 14 | 15 | class CreatePost(forms.ModelForm): 16 | title = forms.CharField(label = 'الاسم') 17 | content = forms.CharField(label = 'البريد الالكتروني', widget = forms.Textarea) 18 | class Meta: 19 | model = post 20 | fields = ('title', 'content') 21 | -------------------------------------------------------------------------------- /blog/migrations/0001_initial.py: -------------------------------------------------------------------------------- 1 | # Generated by Django 3.1.1 on 2020-10-23 21:22 2 | 3 | from django.conf import settings 4 | from django.db import migrations, models 5 | import django.db.models.deletion 6 | import django.utils.timezone 7 | 8 | 9 | class Migration(migrations.Migration): 10 | 11 | initial = True 12 | 13 | dependencies = [ 14 | migrations.swappable_dependency(settings.AUTH_USER_MODEL), 15 | ] 16 | 17 | operations = [ 18 | migrations.CreateModel( 19 | name='post', 20 | fields=[ 21 | ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 22 | ('title', models.CharField(max_length=100)), 23 | ('content', models.TextField()), 24 | ('post_date', models.DateTimeField(verbose_name=django.utils.timezone.now)), 25 | ('post_update', models.DateTimeField(auto_now=True)), 26 | ('author', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)), 27 | ], 28 | ), 29 | ] 30 | -------------------------------------------------------------------------------- /blog/migrations/0002_auto_20201024_0025.py: -------------------------------------------------------------------------------- 1 | # Generated by Django 3.1.1 on 2020-10-23 21:25 2 | 3 | from django.db import migrations, models 4 | import django.utils.timezone 5 | 6 | 7 | class Migration(migrations.Migration): 8 | 9 | dependencies = [ 10 | ('blog', '0001_initial'), 11 | ] 12 | 13 | operations = [ 14 | migrations.AlterField( 15 | model_name='post', 16 | name='post_date', 17 | field=models.DateTimeField(default=django.utils.timezone.now), 18 | ), 19 | ] 20 | -------------------------------------------------------------------------------- /blog/migrations/0003_comment.py: -------------------------------------------------------------------------------- 1 | # Generated by Django 3.1.1 on 2020-10-25 11:46 2 | 3 | from django.db import migrations, models 4 | import django.db.models.deletion 5 | 6 | 7 | class Migration(migrations.Migration): 8 | 9 | dependencies = [ 10 | ('blog', '0002_auto_20201024_0025'), 11 | ] 12 | 13 | operations = [ 14 | migrations.CreateModel( 15 | name='comment', 16 | fields=[ 17 | ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 18 | ('name', models.CharField(max_length=50)), 19 | ('email', models.EmailField(max_length=254)), 20 | ('body', models.TextField()), 21 | ('comment_date', models.DateTimeField(auto_now_add=True)), 22 | ('active', models.BooleanField(default=False)), 23 | ('post', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='blog.post')), 24 | ], 25 | ), 26 | ] 27 | -------------------------------------------------------------------------------- /blog/migrations/0004_auto_20201026_2226.py: -------------------------------------------------------------------------------- 1 | # Generated by Django 3.1.1 on 2020-10-26 19:26 2 | 3 | from django.db import migrations 4 | 5 | 6 | class Migration(migrations.Migration): 7 | 8 | dependencies = [ 9 | ('blog', '0003_comment'), 10 | ] 11 | 12 | operations = [ 13 | migrations.AlterModelOptions( 14 | name='comment', 15 | options={'ordering': ('-comment_date',)}, 16 | ), 17 | migrations.AlterModelOptions( 18 | name='post', 19 | options={'ordering': ('-post_date',)}, 20 | ), 21 | ] 22 | -------------------------------------------------------------------------------- /blog/migrations/0005_auto_20201027_1233.py: -------------------------------------------------------------------------------- 1 | # Generated by Django 3.1.1 on 2020-10-27 09:33 2 | 3 | from django.db import migrations, models 4 | 5 | 6 | class Migration(migrations.Migration): 7 | 8 | dependencies = [ 9 | ('blog', '0004_auto_20201026_2226'), 10 | ] 11 | 12 | operations = [ 13 | migrations.AlterField( 14 | model_name='comment', 15 | name='body', 16 | field=models.TextField(verbose_name='التعليق'), 17 | ), 18 | migrations.AlterField( 19 | model_name='comment', 20 | name='email', 21 | field=models.EmailField(max_length=254, verbose_name='البريد الالكتروني'), 22 | ), 23 | migrations.AlterField( 24 | model_name='comment', 25 | name='name', 26 | field=models.CharField(max_length=50, verbose_name='الاسم'), 27 | ), 28 | ] 29 | -------------------------------------------------------------------------------- /blog/migrations/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/migrations/__init__.py -------------------------------------------------------------------------------- /blog/migrations/__pycache__/0001_initial.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/migrations/__pycache__/0001_initial.cpython-38.pyc -------------------------------------------------------------------------------- /blog/migrations/__pycache__/0002_auto_20201024_0025.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/migrations/__pycache__/0002_auto_20201024_0025.cpython-38.pyc -------------------------------------------------------------------------------- /blog/migrations/__pycache__/0003_comment.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/migrations/__pycache__/0003_comment.cpython-38.pyc -------------------------------------------------------------------------------- /blog/migrations/__pycache__/0004_auto_20201026_2226.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/migrations/__pycache__/0004_auto_20201026_2226.cpython-38.pyc -------------------------------------------------------------------------------- /blog/migrations/__pycache__/0005_auto_20201027_1233.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/migrations/__pycache__/0005_auto_20201027_1233.cpython-38.pyc -------------------------------------------------------------------------------- /blog/migrations/__pycache__/__init__.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/migrations/__pycache__/__init__.cpython-38.pyc -------------------------------------------------------------------------------- /blog/models.py: -------------------------------------------------------------------------------- 1 | from django.db import models 2 | from django.contrib.auth.models import User 3 | from django.utils import timezone 4 | from django.urls import reverse 5 | 6 | class post(models.Model): 7 | title = models.CharField(max_length = 100) 8 | content = models.TextField() 9 | post_date = models.DateTimeField(default = timezone.now) 10 | post_update = models.DateTimeField(auto_now=True) 11 | author = models.ForeignKey(User, on_delete=models.CASCADE) 12 | 13 | def __str__(self): 14 | return self.title 15 | 16 | def get_absolute_url(self): 17 | #return '/' 18 | return reverse('index') 19 | 20 | # Another way to reverse the ranking of blogs from newest to oldest 21 | class Meta: 22 | ordering = ('-post_date',) 23 | 24 | class comment(models.Model): 25 | name = models.CharField(max_length = 50, verbose_name = 'الاسم') 26 | email = models.EmailField(verbose_name = 'البريد الالكتروني') 27 | body = models.TextField(verbose_name = 'التعليق') 28 | comment_date = models.DateTimeField(auto_now_add=True) 29 | active = models.BooleanField(default=False) 30 | post = models.ForeignKey(post, on_delete=models.CASCADE) 31 | 32 | class Meta: 33 | ordering = ('-comment_date',) 34 | 35 | def __str__(self): 36 | return f'على {self.post} {self.name} علق' 37 | -------------------------------------------------------------------------------- /blog/static/blog/css/main.css: -------------------------------------------------------------------------------- 1 | @font-face { 2 | font-family: 'Tajawal'; 3 | src: url('../fonts/Tajawal-Regular.ttf') format("truetype"), 4 | local('Tajawal'); 5 | } 6 | 7 | html, body{ 8 | direction: rtl; 9 | text-align: right; 10 | } 11 | 12 | body{ 13 | font-family: 'Tajawal', sans-serif; 14 | } 15 | 16 | .dropdown-menu .dropdown-item{ 17 | text-align: right; 18 | } 19 | 20 | .bg-secondary{ 21 | background-color: #666 !important; 22 | } 23 | 24 | .bg-light{ 25 | background-color: #ccc !important; 26 | } 27 | 28 | .latest-post, .latest-comment{ 29 | padding: 0 15px; 30 | 31 | } 32 | .latest-post .latest-post-item, .latest-comment .latest-comment-item{ 33 | padding: 6px; 34 | } 35 | 36 | .latest-post li:first-child, .latest-comment li:first-child{ 37 | border-top: 0; 38 | } 39 | 40 | .latest-post li:last-child, .latest-comment li:last-child{ 41 | border-bottom: 0; 42 | padding-bottom: 0; 43 | } 44 | 45 | .comment{ 46 | background-color: #f8f8f8; 47 | border: 1px dashed #CCC; 48 | } 49 | 50 | form textarea{ 51 | width: 200px; 52 | } 53 | 54 | .btn-editing{ 55 | float: left; 56 | } 57 | 58 | .back-btn{ 59 | float: left; 60 | } -------------------------------------------------------------------------------- /blog/static/blog/fonts/OFL.txt: -------------------------------------------------------------------------------- 1 | Copyright 2018 Boutros International. (http://www.boutrosfonts.com) 2 | 3 | This Font Software is licensed under the SIL Open Font License, Version 1.1. 4 | This license is copied below, and is also available with a FAQ at: 5 | http://scripts.sil.org/OFL 6 | 7 | 8 | ----------------------------------------------------------- 9 | SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007 10 | ----------------------------------------------------------- 11 | 12 | PREAMBLE 13 | The goals of the Open Font License (OFL) are to stimulate worldwide 14 | development of collaborative font projects, to support the font creation 15 | efforts of academic and linguistic communities, and to provide a free and 16 | open framework in which fonts may be shared and improved in partnership 17 | with others. 18 | 19 | The OFL allows the licensed fonts to be used, studied, modified and 20 | redistributed freely as long as they are not sold by themselves. The 21 | fonts, including any derivative works, can be bundled, embedded, 22 | redistributed and/or sold with any software provided that any reserved 23 | names are not used by derivative works. The fonts and derivatives, 24 | however, cannot be released under any other type of license. The 25 | requirement for fonts to remain under this license does not apply 26 | to any document created using the fonts or their derivatives. 27 | 28 | DEFINITIONS 29 | "Font Software" refers to the set of files released by the Copyright 30 | Holder(s) under this license and clearly marked as such. This may 31 | include source files, build scripts and documentation. 32 | 33 | "Reserved Font Name" refers to any names specified as such after the 34 | copyright statement(s). 35 | 36 | "Original Version" refers to the collection of Font Software components as 37 | distributed by the Copyright Holder(s). 38 | 39 | "Modified Version" refers to any derivative made by adding to, deleting, 40 | or substituting -- in part or in whole -- any of the components of the 41 | Original Version, by changing formats or by porting the Font Software to a 42 | new environment. 43 | 44 | "Author" refers to any designer, engineer, programmer, technical 45 | writer or other person who contributed to the Font Software. 46 | 47 | PERMISSION & CONDITIONS 48 | Permission is hereby granted, free of charge, to any person obtaining 49 | a copy of the Font Software, to use, study, copy, merge, embed, modify, 50 | redistribute, and sell modified and unmodified copies of the Font 51 | Software, subject to the following conditions: 52 | 53 | 1) Neither the Font Software nor any of its individual components, 54 | in Original or Modified Versions, may be sold by itself. 55 | 56 | 2) Original or Modified Versions of the Font Software may be bundled, 57 | redistributed and/or sold with any software, provided that each copy 58 | contains the above copyright notice and this license. These can be 59 | included either as stand-alone text files, human-readable headers or 60 | in the appropriate machine-readable metadata fields within text or 61 | binary files as long as those fields can be easily viewed by the user. 62 | 63 | 3) No Modified Version of the Font Software may use the Reserved Font 64 | Name(s) unless explicit written permission is granted by the corresponding 65 | Copyright Holder. This restriction only applies to the primary font name as 66 | presented to the users. 67 | 68 | 4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font 69 | Software shall not be used to promote, endorse or advertise any 70 | Modified Version, except to acknowledge the contribution(s) of the 71 | Copyright Holder(s) and the Author(s) or with their explicit written 72 | permission. 73 | 74 | 5) The Font Software, modified or unmodified, in part or in whole, 75 | must be distributed entirely under this license, and must not be 76 | distributed under any other license. The requirement for fonts to 77 | remain under this license does not apply to any document created 78 | using the Font Software. 79 | 80 | TERMINATION 81 | This license becomes null and void if any of the above conditions are 82 | not met. 83 | 84 | DISCLAIMER 85 | THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 86 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF 87 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT 88 | OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE 89 | COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 90 | INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL 91 | DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 92 | FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM 93 | OTHER DEALINGS IN THE FONT SOFTWARE. 94 | -------------------------------------------------------------------------------- /blog/static/blog/fonts/Tajawal-Black.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/fonts/Tajawal-Black.ttf -------------------------------------------------------------------------------- /blog/static/blog/fonts/Tajawal-Bold.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/fonts/Tajawal-Bold.ttf -------------------------------------------------------------------------------- /blog/static/blog/fonts/Tajawal-ExtraBold.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/fonts/Tajawal-ExtraBold.ttf -------------------------------------------------------------------------------- /blog/static/blog/fonts/Tajawal-ExtraLight.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/fonts/Tajawal-ExtraLight.ttf -------------------------------------------------------------------------------- /blog/static/blog/fonts/Tajawal-Light.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/fonts/Tajawal-Light.ttf -------------------------------------------------------------------------------- /blog/static/blog/fonts/Tajawal-Medium.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/fonts/Tajawal-Medium.ttf -------------------------------------------------------------------------------- /blog/static/blog/fonts/Tajawal-Regular.ttf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/fonts/Tajawal-Regular.ttf -------------------------------------------------------------------------------- /blog/static/blog/images/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/images/favicon.ico -------------------------------------------------------------------------------- /blog/static/blog/images/mim-logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/static/blog/images/mim-logo.png -------------------------------------------------------------------------------- /blog/static/blog/js/bootstrap.min.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * Bootstrap v4.5.3 (https://getbootstrap.com/) 3 | * Copyright 2011-2020 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) 4 | * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) 5 | */ 6 | !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("jquery"),require("popper.js")):"function"==typeof define&&define.amd?define(["exports","jquery","popper.js"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).bootstrap={},t.jQuery,t.Popper)}(this,(function(t,e,n){"use strict";function i(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}var o=i(e),a=i(n);function s(t,e){for(var n=0;n=4)throw new Error("Bootstrap's JavaScript requires at least jQuery v1.9.1 but less than v4.0.0")}};d.jQueryDetection(),o.default.fn.emulateTransitionEnd=u,o.default.event.special[d.TRANSITION_END]={bindType:"transitionend",delegateType:"transitionend",handle:function(t){if(o.default(t.target).is(this))return t.handleObj.handler.apply(this,arguments)}};var f="alert",c=o.default.fn[f],h=function(){function t(t){this._element=t}var e=t.prototype;return e.close=function(t){var e=this._element;t&&(e=this._getRootElement(t)),this._triggerCloseEvent(e).isDefaultPrevented()||this._removeElement(e)},e.dispose=function(){o.default.removeData(this._element,"bs.alert"),this._element=null},e._getRootElement=function(t){var e=d.getSelectorFromElement(t),n=!1;return e&&(n=document.querySelector(e)),n||(n=o.default(t).closest(".alert")[0]),n},e._triggerCloseEvent=function(t){var e=o.default.Event("close.bs.alert");return o.default(t).trigger(e),e},e._removeElement=function(t){var e=this;if(o.default(t).removeClass("show"),o.default(t).hasClass("fade")){var n=d.getTransitionDurationFromElement(t);o.default(t).one(d.TRANSITION_END,(function(n){return e._destroyElement(t,n)})).emulateTransitionEnd(n)}else this._destroyElement(t)},e._destroyElement=function(t){o.default(t).detach().trigger("closed.bs.alert").remove()},t._jQueryInterface=function(e){return this.each((function(){var n=o.default(this),i=n.data("bs.alert");i||(i=new t(this),n.data("bs.alert",i)),"close"===e&&i[e](this)}))},t._handleDismiss=function(t){return function(e){e&&e.preventDefault(),t.close(this)}},l(t,null,[{key:"VERSION",get:function(){return"4.5.3"}}]),t}();o.default(document).on("click.bs.alert.data-api",'[data-dismiss="alert"]',h._handleDismiss(new h)),o.default.fn[f]=h._jQueryInterface,o.default.fn[f].Constructor=h,o.default.fn[f].noConflict=function(){return o.default.fn[f]=c,h._jQueryInterface};var g=o.default.fn.button,m=function(){function t(t){this._element=t,this.shouldAvoidTriggerChange=!1}var e=t.prototype;return e.toggle=function(){var t=!0,e=!0,n=o.default(this._element).closest('[data-toggle="buttons"]')[0];if(n){var i=this._element.querySelector('input:not([type="hidden"])');if(i){if("radio"===i.type)if(i.checked&&this._element.classList.contains("active"))t=!1;else{var a=n.querySelector(".active");a&&o.default(a).removeClass("active")}t&&("checkbox"!==i.type&&"radio"!==i.type||(i.checked=!this._element.classList.contains("active")),this.shouldAvoidTriggerChange||o.default(i).trigger("change")),i.focus(),e=!1}}this._element.hasAttribute("disabled")||this._element.classList.contains("disabled")||(e&&this._element.setAttribute("aria-pressed",!this._element.classList.contains("active")),t&&o.default(this._element).toggleClass("active"))},e.dispose=function(){o.default.removeData(this._element,"bs.button"),this._element=null},t._jQueryInterface=function(e,n){return this.each((function(){var i=o.default(this),a=i.data("bs.button");a||(a=new t(this),i.data("bs.button",a)),a.shouldAvoidTriggerChange=n,"toggle"===e&&a[e]()}))},l(t,null,[{key:"VERSION",get:function(){return"4.5.3"}}]),t}();o.default(document).on("click.bs.button.data-api",'[data-toggle^="button"]',(function(t){var e=t.target,n=e;if(o.default(e).hasClass("btn")||(e=o.default(e).closest(".btn")[0]),!e||e.hasAttribute("disabled")||e.classList.contains("disabled"))t.preventDefault();else{var i=e.querySelector('input:not([type="hidden"])');if(i&&(i.hasAttribute("disabled")||i.classList.contains("disabled")))return void t.preventDefault();"INPUT"!==n.tagName&&"LABEL"===e.tagName||m._jQueryInterface.call(o.default(e),"toggle","INPUT"===n.tagName)}})).on("focus.bs.button.data-api blur.bs.button.data-api",'[data-toggle^="button"]',(function(t){var e=o.default(t.target).closest(".btn")[0];o.default(e).toggleClass("focus",/^focus(in)?$/.test(t.type))})),o.default(window).on("load.bs.button.data-api",(function(){for(var t=[].slice.call(document.querySelectorAll('[data-toggle="buttons"] .btn')),e=0,n=t.length;e0,this._pointerEvent=Boolean(window.PointerEvent||window.MSPointerEvent),this._addEventListeners()}var e=t.prototype;return e.next=function(){this._isSliding||this._slide("next")},e.nextWhenVisible=function(){var t=o.default(this._element);!document.hidden&&t.is(":visible")&&"hidden"!==t.css("visibility")&&this.next()},e.prev=function(){this._isSliding||this._slide("prev")},e.pause=function(t){t||(this._isPaused=!0),this._element.querySelector(".carousel-item-next, .carousel-item-prev")&&(d.triggerTransitionEnd(this._element),this.cycle(!0)),clearInterval(this._interval),this._interval=null},e.cycle=function(t){t||(this._isPaused=!1),this._interval&&(clearInterval(this._interval),this._interval=null),this._config.interval&&!this._isPaused&&(this._interval=setInterval((document.visibilityState?this.nextWhenVisible:this.next).bind(this),this._config.interval))},e.to=function(t){var e=this;this._activeElement=this._element.querySelector(".active.carousel-item");var n=this._getItemIndex(this._activeElement);if(!(t>this._items.length-1||t<0))if(this._isSliding)o.default(this._element).one("slid.bs.carousel",(function(){return e.to(t)}));else{if(n===t)return this.pause(),void this.cycle();var i=t>n?"next":"prev";this._slide(i,this._items[t])}},e.dispose=function(){o.default(this._element).off(_),o.default.removeData(this._element,"bs.carousel"),this._items=null,this._config=null,this._element=null,this._interval=null,this._isPaused=null,this._isSliding=null,this._activeElement=null,this._indicatorsElement=null},e._getConfig=function(t){return t=r({},b,t),d.typeCheckConfig(p,t,y),t},e._handleSwipe=function(){var t=Math.abs(this.touchDeltaX);if(!(t<=40)){var e=t/this.touchDeltaX;this.touchDeltaX=0,e>0&&this.prev(),e<0&&this.next()}},e._addEventListeners=function(){var t=this;this._config.keyboard&&o.default(this._element).on("keydown.bs.carousel",(function(e){return t._keydown(e)})),"hover"===this._config.pause&&o.default(this._element).on("mouseenter.bs.carousel",(function(e){return t.pause(e)})).on("mouseleave.bs.carousel",(function(e){return t.cycle(e)})),this._config.touch&&this._addTouchEventListeners()},e._addTouchEventListeners=function(){var t=this;if(this._touchSupported){var e=function(e){t._pointerEvent&&E[e.originalEvent.pointerType.toUpperCase()]?t.touchStartX=e.originalEvent.clientX:t._pointerEvent||(t.touchStartX=e.originalEvent.touches[0].clientX)},n=function(e){t._pointerEvent&&E[e.originalEvent.pointerType.toUpperCase()]&&(t.touchDeltaX=e.originalEvent.clientX-t.touchStartX),t._handleSwipe(),"hover"===t._config.pause&&(t.pause(),t.touchTimeout&&clearTimeout(t.touchTimeout),t.touchTimeout=setTimeout((function(e){return t.cycle(e)}),500+t._config.interval))};o.default(this._element.querySelectorAll(".carousel-item img")).on("dragstart.bs.carousel",(function(t){return t.preventDefault()})),this._pointerEvent?(o.default(this._element).on("pointerdown.bs.carousel",(function(t){return e(t)})),o.default(this._element).on("pointerup.bs.carousel",(function(t){return n(t)})),this._element.classList.add("pointer-event")):(o.default(this._element).on("touchstart.bs.carousel",(function(t){return e(t)})),o.default(this._element).on("touchmove.bs.carousel",(function(e){return function(e){e.originalEvent.touches&&e.originalEvent.touches.length>1?t.touchDeltaX=0:t.touchDeltaX=e.originalEvent.touches[0].clientX-t.touchStartX}(e)})),o.default(this._element).on("touchend.bs.carousel",(function(t){return n(t)})))}},e._keydown=function(t){if(!/input|textarea/i.test(t.target.tagName))switch(t.which){case 37:t.preventDefault(),this.prev();break;case 39:t.preventDefault(),this.next()}},e._getItemIndex=function(t){return this._items=t&&t.parentNode?[].slice.call(t.parentNode.querySelectorAll(".carousel-item")):[],this._items.indexOf(t)},e._getItemByDirection=function(t,e){var n="next"===t,i="prev"===t,o=this._getItemIndex(e),a=this._items.length-1;if((i&&0===o||n&&o===a)&&!this._config.wrap)return e;var s=(o+("prev"===t?-1:1))%this._items.length;return-1===s?this._items[this._items.length-1]:this._items[s]},e._triggerSlideEvent=function(t,e){var n=this._getItemIndex(t),i=this._getItemIndex(this._element.querySelector(".active.carousel-item")),a=o.default.Event("slide.bs.carousel",{relatedTarget:t,direction:e,from:i,to:n});return o.default(this._element).trigger(a),a},e._setActiveIndicatorElement=function(t){if(this._indicatorsElement){var e=[].slice.call(this._indicatorsElement.querySelectorAll(".active"));o.default(e).removeClass("active");var n=this._indicatorsElement.children[this._getItemIndex(t)];n&&o.default(n).addClass("active")}},e._slide=function(t,e){var n,i,a,s=this,l=this._element.querySelector(".active.carousel-item"),r=this._getItemIndex(l),u=e||l&&this._getItemByDirection(t,l),f=this._getItemIndex(u),c=Boolean(this._interval);if("next"===t?(n="carousel-item-left",i="carousel-item-next",a="left"):(n="carousel-item-right",i="carousel-item-prev",a="right"),u&&o.default(u).hasClass("active"))this._isSliding=!1;else if(!this._triggerSlideEvent(u,a).isDefaultPrevented()&&l&&u){this._isSliding=!0,c&&this.pause(),this._setActiveIndicatorElement(u);var h=o.default.Event("slid.bs.carousel",{relatedTarget:u,direction:a,from:r,to:f});if(o.default(this._element).hasClass("slide")){o.default(u).addClass(i),d.reflow(u),o.default(l).addClass(n),o.default(u).addClass(n);var g=parseInt(u.getAttribute("data-interval"),10);g?(this._config.defaultInterval=this._config.defaultInterval||this._config.interval,this._config.interval=g):this._config.interval=this._config.defaultInterval||this._config.interval;var m=d.getTransitionDurationFromElement(l);o.default(l).one(d.TRANSITION_END,(function(){o.default(u).removeClass(n+" "+i).addClass("active"),o.default(l).removeClass("active "+i+" "+n),s._isSliding=!1,setTimeout((function(){return o.default(s._element).trigger(h)}),0)})).emulateTransitionEnd(m)}else o.default(l).removeClass("active"),o.default(u).addClass("active"),this._isSliding=!1,o.default(this._element).trigger(h);c&&this.cycle()}},t._jQueryInterface=function(e){return this.each((function(){var n=o.default(this).data("bs.carousel"),i=r({},b,o.default(this).data());"object"==typeof e&&(i=r({},i,e));var a="string"==typeof e?e:i.slide;if(n||(n=new t(this,i),o.default(this).data("bs.carousel",n)),"number"==typeof e)n.to(e);else if("string"==typeof a){if("undefined"==typeof n[a])throw new TypeError('No method named "'+a+'"');n[a]()}else i.interval&&i.ride&&(n.pause(),n.cycle())}))},t._dataApiClickHandler=function(e){var n=d.getSelectorFromElement(this);if(n){var i=o.default(n)[0];if(i&&o.default(i).hasClass("carousel")){var a=r({},o.default(i).data(),o.default(this).data()),s=this.getAttribute("data-slide-to");s&&(a.interval=!1),t._jQueryInterface.call(o.default(i),a),s&&o.default(i).data("bs.carousel").to(s),e.preventDefault()}}},l(t,null,[{key:"VERSION",get:function(){return"4.5.3"}},{key:"Default",get:function(){return b}}]),t}();o.default(document).on("click.bs.carousel.data-api","[data-slide], [data-slide-to]",w._dataApiClickHandler),o.default(window).on("load.bs.carousel.data-api",(function(){for(var t=[].slice.call(document.querySelectorAll('[data-ride="carousel"]')),e=0,n=t.length;e0&&(this._selector=s,this._triggerArray.push(a))}this._parent=this._config.parent?this._getParent():null,this._config.parent||this._addAriaAndCollapsedClass(this._element,this._triggerArray),this._config.toggle&&this.toggle()}var e=t.prototype;return e.toggle=function(){o.default(this._element).hasClass("show")?this.hide():this.show()},e.show=function(){var e,n,i=this;if(!this._isTransitioning&&!o.default(this._element).hasClass("show")&&(this._parent&&0===(e=[].slice.call(this._parent.querySelectorAll(".show, .collapsing")).filter((function(t){return"string"==typeof i._config.parent?t.getAttribute("data-parent")===i._config.parent:t.classList.contains("collapse")}))).length&&(e=null),!(e&&(n=o.default(e).not(this._selector).data("bs.collapse"))&&n._isTransitioning))){var a=o.default.Event("show.bs.collapse");if(o.default(this._element).trigger(a),!a.isDefaultPrevented()){e&&(t._jQueryInterface.call(o.default(e).not(this._selector),"hide"),n||o.default(e).data("bs.collapse",null));var s=this._getDimension();o.default(this._element).removeClass("collapse").addClass("collapsing"),this._element.style[s]=0,this._triggerArray.length&&o.default(this._triggerArray).removeClass("collapsed").attr("aria-expanded",!0),this.setTransitioning(!0);var l="scroll"+(s[0].toUpperCase()+s.slice(1)),r=d.getTransitionDurationFromElement(this._element);o.default(this._element).one(d.TRANSITION_END,(function(){o.default(i._element).removeClass("collapsing").addClass("collapse show"),i._element.style[s]="",i.setTransitioning(!1),o.default(i._element).trigger("shown.bs.collapse")})).emulateTransitionEnd(r),this._element.style[s]=this._element[l]+"px"}}},e.hide=function(){var t=this;if(!this._isTransitioning&&o.default(this._element).hasClass("show")){var e=o.default.Event("hide.bs.collapse");if(o.default(this._element).trigger(e),!e.isDefaultPrevented()){var n=this._getDimension();this._element.style[n]=this._element.getBoundingClientRect()[n]+"px",d.reflow(this._element),o.default(this._element).addClass("collapsing").removeClass("collapse show");var i=this._triggerArray.length;if(i>0)for(var a=0;a0},e._getOffset=function(){var t=this,e={};return"function"==typeof this._config.offset?e.fn=function(e){return e.offsets=r({},e.offsets,t._config.offset(e.offsets,t._element)||{}),e}:e.offset=this._config.offset,e},e._getPopperConfig=function(){var t={placement:this._getPlacement(),modifiers:{offset:this._getOffset(),flip:{enabled:this._config.flip},preventOverflow:{boundariesElement:this._config.boundary}}};return"static"===this._config.display&&(t.modifiers.applyStyle={enabled:!1}),r({},t,this._config.popperConfig)},t._jQueryInterface=function(e){return this.each((function(){var n=o.default(this).data("bs.dropdown");if(n||(n=new t(this,"object"==typeof e?e:null),o.default(this).data("bs.dropdown",n)),"string"==typeof e){if("undefined"==typeof n[e])throw new TypeError('No method named "'+e+'"');n[e]()}}))},t._clearMenus=function(e){if(!e||3!==e.which&&("keyup"!==e.type||9===e.which))for(var n=[].slice.call(document.querySelectorAll('[data-toggle="dropdown"]')),i=0,a=n.length;i0&&s--,40===e.which&&sdocument.documentElement.clientHeight;n||(this._element.style.overflowY="hidden"),this._element.classList.add("modal-static");var i=d.getTransitionDurationFromElement(this._dialog);o.default(this._element).off(d.TRANSITION_END),o.default(this._element).one(d.TRANSITION_END,(function(){t._element.classList.remove("modal-static"),n||o.default(t._element).one(d.TRANSITION_END,(function(){t._element.style.overflowY=""})).emulateTransitionEnd(t._element,i)})).emulateTransitionEnd(i),this._element.focus()}else this.hide()},e._showElement=function(t){var e=this,n=o.default(this._element).hasClass("fade"),i=this._dialog?this._dialog.querySelector(".modal-body"):null;this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE||document.body.appendChild(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),o.default(this._dialog).hasClass("modal-dialog-scrollable")&&i?i.scrollTop=0:this._element.scrollTop=0,n&&d.reflow(this._element),o.default(this._element).addClass("show"),this._config.focus&&this._enforceFocus();var a=o.default.Event("shown.bs.modal",{relatedTarget:t}),s=function(){e._config.focus&&e._element.focus(),e._isTransitioning=!1,o.default(e._element).trigger(a)};if(n){var l=d.getTransitionDurationFromElement(this._dialog);o.default(this._dialog).one(d.TRANSITION_END,s).emulateTransitionEnd(l)}else s()},e._enforceFocus=function(){var t=this;o.default(document).off("focusin.bs.modal").on("focusin.bs.modal",(function(e){document!==e.target&&t._element!==e.target&&0===o.default(t._element).has(e.target).length&&t._element.focus()}))},e._setEscapeEvent=function(){var t=this;this._isShown?o.default(this._element).on("keydown.dismiss.bs.modal",(function(e){t._config.keyboard&&27===e.which?(e.preventDefault(),t.hide()):t._config.keyboard||27!==e.which||t._triggerBackdropTransition()})):this._isShown||o.default(this._element).off("keydown.dismiss.bs.modal")},e._setResizeEvent=function(){var t=this;this._isShown?o.default(window).on("resize.bs.modal",(function(e){return t.handleUpdate(e)})):o.default(window).off("resize.bs.modal")},e._hideModal=function(){var t=this;this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._isTransitioning=!1,this._showBackdrop((function(){o.default(document.body).removeClass("modal-open"),t._resetAdjustments(),t._resetScrollbar(),o.default(t._element).trigger("hidden.bs.modal")}))},e._removeBackdrop=function(){this._backdrop&&(o.default(this._backdrop).remove(),this._backdrop=null)},e._showBackdrop=function(t){var e=this,n=o.default(this._element).hasClass("fade")?"fade":"";if(this._isShown&&this._config.backdrop){if(this._backdrop=document.createElement("div"),this._backdrop.className="modal-backdrop",n&&this._backdrop.classList.add(n),o.default(this._backdrop).appendTo(document.body),o.default(this._element).on("click.dismiss.bs.modal",(function(t){e._ignoreBackdropClick?e._ignoreBackdropClick=!1:t.target===t.currentTarget&&e._triggerBackdropTransition()})),n&&d.reflow(this._backdrop),o.default(this._backdrop).addClass("show"),!t)return;if(!n)return void t();var i=d.getTransitionDurationFromElement(this._backdrop);o.default(this._backdrop).one(d.TRANSITION_END,t).emulateTransitionEnd(i)}else if(!this._isShown&&this._backdrop){o.default(this._backdrop).removeClass("show");var a=function(){e._removeBackdrop(),t&&t()};if(o.default(this._element).hasClass("fade")){var s=d.getTransitionDurationFromElement(this._backdrop);o.default(this._backdrop).one(d.TRANSITION_END,a).emulateTransitionEnd(s)}else a()}else t&&t()},e._adjustDialog=function(){var t=this._element.scrollHeight>document.documentElement.clientHeight;!this._isBodyOverflowing&&t&&(this._element.style.paddingLeft=this._scrollbarWidth+"px"),this._isBodyOverflowing&&!t&&(this._element.style.paddingRight=this._scrollbarWidth+"px")},e._resetAdjustments=function(){this._element.style.paddingLeft="",this._element.style.paddingRight=""},e._checkScrollbar=function(){var t=document.body.getBoundingClientRect();this._isBodyOverflowing=Math.round(t.left+t.right)
',trigger:"hover focus",title:"",delay:0,html:!1,selector:!1,placement:"top",offset:0,container:!1,fallbackPlacement:"flip",boundary:"scrollParent",sanitize:!0,sanitizeFn:null,whiteList:Q,popperConfig:null},$={HIDE:"hide.bs.tooltip",HIDDEN:"hidden.bs.tooltip",SHOW:"show.bs.tooltip",SHOWN:"shown.bs.tooltip",INSERTED:"inserted.bs.tooltip",CLICK:"click.bs.tooltip",FOCUSIN:"focusin.bs.tooltip",FOCUSOUT:"focusout.bs.tooltip",MOUSEENTER:"mouseenter.bs.tooltip",MOUSELEAVE:"mouseleave.bs.tooltip"},J=function(){function t(t,e){if("undefined"==typeof a.default)throw new TypeError("Bootstrap's tooltips require Popper.js (https://popper.js.org/)");this._isEnabled=!0,this._timeout=0,this._hoverState="",this._activeTrigger={},this._popper=null,this.element=t,this.config=this._getConfig(e),this.tip=null,this._setListeners()}var e=t.prototype;return e.enable=function(){this._isEnabled=!0},e.disable=function(){this._isEnabled=!1},e.toggleEnabled=function(){this._isEnabled=!this._isEnabled},e.toggle=function(t){if(this._isEnabled)if(t){var e=this.constructor.DATA_KEY,n=o.default(t.currentTarget).data(e);n||(n=new this.constructor(t.currentTarget,this._getDelegateConfig()),o.default(t.currentTarget).data(e,n)),n._activeTrigger.click=!n._activeTrigger.click,n._isWithActiveTrigger()?n._enter(null,n):n._leave(null,n)}else{if(o.default(this.getTipElement()).hasClass("show"))return void this._leave(null,this);this._enter(null,this)}},e.dispose=function(){clearTimeout(this._timeout),o.default.removeData(this.element,this.constructor.DATA_KEY),o.default(this.element).off(this.constructor.EVENT_KEY),o.default(this.element).closest(".modal").off("hide.bs.modal",this._hideModalHandler),this.tip&&o.default(this.tip).remove(),this._isEnabled=null,this._timeout=null,this._hoverState=null,this._activeTrigger=null,this._popper&&this._popper.destroy(),this._popper=null,this.element=null,this.config=null,this.tip=null},e.show=function(){var t=this;if("none"===o.default(this.element).css("display"))throw new Error("Please use show on visible elements");var e=o.default.Event(this.constructor.Event.SHOW);if(this.isWithContent()&&this._isEnabled){o.default(this.element).trigger(e);var n=d.findShadowRoot(this.element),i=o.default.contains(null!==n?n:this.element.ownerDocument.documentElement,this.element);if(e.isDefaultPrevented()||!i)return;var s=this.getTipElement(),l=d.getUID(this.constructor.NAME);s.setAttribute("id",l),this.element.setAttribute("aria-describedby",l),this.setContent(),this.config.animation&&o.default(s).addClass("fade");var r="function"==typeof this.config.placement?this.config.placement.call(this,s,this.element):this.config.placement,u=this._getAttachment(r);this.addAttachmentClass(u);var f=this._getContainer();o.default(s).data(this.constructor.DATA_KEY,this),o.default.contains(this.element.ownerDocument.documentElement,this.tip)||o.default(s).appendTo(f),o.default(this.element).trigger(this.constructor.Event.INSERTED),this._popper=new a.default(this.element,s,this._getPopperConfig(u)),o.default(s).addClass("show"),"ontouchstart"in document.documentElement&&o.default(document.body).children().on("mouseover",null,o.default.noop);var c=function(){t.config.animation&&t._fixTransition();var e=t._hoverState;t._hoverState=null,o.default(t.element).trigger(t.constructor.Event.SHOWN),"out"===e&&t._leave(null,t)};if(o.default(this.tip).hasClass("fade")){var h=d.getTransitionDurationFromElement(this.tip);o.default(this.tip).one(d.TRANSITION_END,c).emulateTransitionEnd(h)}else c()}},e.hide=function(t){var e=this,n=this.getTipElement(),i=o.default.Event(this.constructor.Event.HIDE),a=function(){"show"!==e._hoverState&&n.parentNode&&n.parentNode.removeChild(n),e._cleanTipClass(),e.element.removeAttribute("aria-describedby"),o.default(e.element).trigger(e.constructor.Event.HIDDEN),null!==e._popper&&e._popper.destroy(),t&&t()};if(o.default(this.element).trigger(i),!i.isDefaultPrevented()){if(o.default(n).removeClass("show"),"ontouchstart"in document.documentElement&&o.default(document.body).children().off("mouseover",null,o.default.noop),this._activeTrigger.click=!1,this._activeTrigger.focus=!1,this._activeTrigger.hover=!1,o.default(this.tip).hasClass("fade")){var s=d.getTransitionDurationFromElement(n);o.default(n).one(d.TRANSITION_END,a).emulateTransitionEnd(s)}else a();this._hoverState=""}},e.update=function(){null!==this._popper&&this._popper.scheduleUpdate()},e.isWithContent=function(){return Boolean(this.getTitle())},e.addAttachmentClass=function(t){o.default(this.getTipElement()).addClass("bs-tooltip-"+t)},e.getTipElement=function(){return this.tip=this.tip||o.default(this.config.template)[0],this.tip},e.setContent=function(){var t=this.getTipElement();this.setElementContent(o.default(t.querySelectorAll(".tooltip-inner")),this.getTitle()),o.default(t).removeClass("fade show")},e.setElementContent=function(t,e){"object"!=typeof e||!e.nodeType&&!e.jquery?this.config.html?(this.config.sanitize&&(e=U(e,this.config.whiteList,this.config.sanitizeFn)),t.html(e)):t.text(e):this.config.html?o.default(e).parent().is(t)||t.empty().append(e):t.text(o.default(e).text())},e.getTitle=function(){var t=this.element.getAttribute("data-original-title");return t||(t="function"==typeof this.config.title?this.config.title.call(this.element):this.config.title),t},e._getPopperConfig=function(t){var e=this;return r({},{placement:t,modifiers:{offset:this._getOffset(),flip:{behavior:this.config.fallbackPlacement},arrow:{element:".arrow"},preventOverflow:{boundariesElement:this.config.boundary}},onCreate:function(t){t.originalPlacement!==t.placement&&e._handlePopperPlacementChange(t)},onUpdate:function(t){return e._handlePopperPlacementChange(t)}},this.config.popperConfig)},e._getOffset=function(){var t=this,e={};return"function"==typeof this.config.offset?e.fn=function(e){return e.offsets=r({},e.offsets,t.config.offset(e.offsets,t.element)||{}),e}:e.offset=this.config.offset,e},e._getContainer=function(){return!1===this.config.container?document.body:d.isElement(this.config.container)?o.default(this.config.container):o.default(document).find(this.config.container)},e._getAttachment=function(t){return X[t.toUpperCase()]},e._setListeners=function(){var t=this;this.config.trigger.split(" ").forEach((function(e){if("click"===e)o.default(t.element).on(t.constructor.Event.CLICK,t.config.selector,(function(e){return t.toggle(e)}));else if("manual"!==e){var n="hover"===e?t.constructor.Event.MOUSEENTER:t.constructor.Event.FOCUSIN,i="hover"===e?t.constructor.Event.MOUSELEAVE:t.constructor.Event.FOCUSOUT;o.default(t.element).on(n,t.config.selector,(function(e){return t._enter(e)})).on(i,t.config.selector,(function(e){return t._leave(e)}))}})),this._hideModalHandler=function(){t.element&&t.hide()},o.default(this.element).closest(".modal").on("hide.bs.modal",this._hideModalHandler),this.config.selector?this.config=r({},this.config,{trigger:"manual",selector:""}):this._fixTitle()},e._fixTitle=function(){var t=typeof this.element.getAttribute("data-original-title");(this.element.getAttribute("title")||"string"!==t)&&(this.element.setAttribute("data-original-title",this.element.getAttribute("title")||""),this.element.setAttribute("title",""))},e._enter=function(t,e){var n=this.constructor.DATA_KEY;(e=e||o.default(t.currentTarget).data(n))||(e=new this.constructor(t.currentTarget,this._getDelegateConfig()),o.default(t.currentTarget).data(n,e)),t&&(e._activeTrigger["focusin"===t.type?"focus":"hover"]=!0),o.default(e.getTipElement()).hasClass("show")||"show"===e._hoverState?e._hoverState="show":(clearTimeout(e._timeout),e._hoverState="show",e.config.delay&&e.config.delay.show?e._timeout=setTimeout((function(){"show"===e._hoverState&&e.show()}),e.config.delay.show):e.show())},e._leave=function(t,e){var n=this.constructor.DATA_KEY;(e=e||o.default(t.currentTarget).data(n))||(e=new this.constructor(t.currentTarget,this._getDelegateConfig()),o.default(t.currentTarget).data(n,e)),t&&(e._activeTrigger["focusout"===t.type?"focus":"hover"]=!1),e._isWithActiveTrigger()||(clearTimeout(e._timeout),e._hoverState="out",e.config.delay&&e.config.delay.hide?e._timeout=setTimeout((function(){"out"===e._hoverState&&e.hide()}),e.config.delay.hide):e.hide())},e._isWithActiveTrigger=function(){for(var t in this._activeTrigger)if(this._activeTrigger[t])return!0;return!1},e._getConfig=function(t){var e=o.default(this.element).data();return Object.keys(e).forEach((function(t){-1!==z.indexOf(t)&&delete e[t]})),"number"==typeof(t=r({},this.constructor.Default,e,"object"==typeof t&&t?t:{})).delay&&(t.delay={show:t.delay,hide:t.delay}),"number"==typeof t.title&&(t.title=t.title.toString()),"number"==typeof t.content&&(t.content=t.content.toString()),d.typeCheckConfig(M,t,this.constructor.DefaultType),t.sanitize&&(t.template=U(t.template,t.whiteList,t.sanitizeFn)),t},e._getDelegateConfig=function(){var t={};if(this.config)for(var e in this.config)this.constructor.Default[e]!==this.config[e]&&(t[e]=this.config[e]);return t},e._cleanTipClass=function(){var t=o.default(this.getTipElement()),e=t.attr("class").match(V);null!==e&&e.length&&t.removeClass(e.join(""))},e._handlePopperPlacementChange=function(t){this.tip=t.instance.popper,this._cleanTipClass(),this.addAttachmentClass(this._getAttachment(t.placement))},e._fixTransition=function(){var t=this.getTipElement(),e=this.config.animation;null===t.getAttribute("x-placement")&&(o.default(t).removeClass("fade"),this.config.animation=!1,this.hide(),this.show(),this.config.animation=e)},t._jQueryInterface=function(e){return this.each((function(){var n=o.default(this),i=n.data("bs.tooltip"),a="object"==typeof e&&e;if((i||!/dispose|hide/.test(e))&&(i||(i=new t(this,a),n.data("bs.tooltip",i)),"string"==typeof e)){if("undefined"==typeof i[e])throw new TypeError('No method named "'+e+'"');i[e]()}}))},l(t,null,[{key:"VERSION",get:function(){return"4.5.3"}},{key:"Default",get:function(){return Y}},{key:"NAME",get:function(){return M}},{key:"DATA_KEY",get:function(){return"bs.tooltip"}},{key:"Event",get:function(){return $}},{key:"EVENT_KEY",get:function(){return".bs.tooltip"}},{key:"DefaultType",get:function(){return K}}]),t}();o.default.fn[M]=J._jQueryInterface,o.default.fn[M].Constructor=J,o.default.fn[M].noConflict=function(){return o.default.fn[M]=W,J._jQueryInterface};var G="popover",Z=o.default.fn[G],tt=new RegExp("(^|\\s)bs-popover\\S+","g"),et=r({},J.Default,{placement:"right",trigger:"click",content:"",template:''}),nt=r({},J.DefaultType,{content:"(string|element|function)"}),it={HIDE:"hide.bs.popover",HIDDEN:"hidden.bs.popover",SHOW:"show.bs.popover",SHOWN:"shown.bs.popover",INSERTED:"inserted.bs.popover",CLICK:"click.bs.popover",FOCUSIN:"focusin.bs.popover",FOCUSOUT:"focusout.bs.popover",MOUSEENTER:"mouseenter.bs.popover",MOUSELEAVE:"mouseleave.bs.popover"},ot=function(t){var e,n;function i(){return t.apply(this,arguments)||this}n=t,(e=i).prototype=Object.create(n.prototype),e.prototype.constructor=e,e.__proto__=n;var a=i.prototype;return a.isWithContent=function(){return this.getTitle()||this._getContent()},a.addAttachmentClass=function(t){o.default(this.getTipElement()).addClass("bs-popover-"+t)},a.getTipElement=function(){return this.tip=this.tip||o.default(this.config.template)[0],this.tip},a.setContent=function(){var t=o.default(this.getTipElement());this.setElementContent(t.find(".popover-header"),this.getTitle());var e=this._getContent();"function"==typeof e&&(e=e.call(this.element)),this.setElementContent(t.find(".popover-body"),e),t.removeClass("fade show")},a._getContent=function(){return this.element.getAttribute("data-content")||this.config.content},a._cleanTipClass=function(){var t=o.default(this.getTipElement()),e=t.attr("class").match(tt);null!==e&&e.length>0&&t.removeClass(e.join(""))},i._jQueryInterface=function(t){return this.each((function(){var e=o.default(this).data("bs.popover"),n="object"==typeof t?t:null;if((e||!/dispose|hide/.test(t))&&(e||(e=new i(this,n),o.default(this).data("bs.popover",e)),"string"==typeof t)){if("undefined"==typeof e[t])throw new TypeError('No method named "'+t+'"');e[t]()}}))},l(i,null,[{key:"VERSION",get:function(){return"4.5.3"}},{key:"Default",get:function(){return et}},{key:"NAME",get:function(){return G}},{key:"DATA_KEY",get:function(){return"bs.popover"}},{key:"Event",get:function(){return it}},{key:"EVENT_KEY",get:function(){return".bs.popover"}},{key:"DefaultType",get:function(){return nt}}]),i}(J);o.default.fn[G]=ot._jQueryInterface,o.default.fn[G].Constructor=ot,o.default.fn[G].noConflict=function(){return o.default.fn[G]=Z,ot._jQueryInterface};var at="scrollspy",st=o.default.fn[at],lt={offset:10,method:"auto",target:""},rt={offset:"number",method:"string",target:"(string|element)"},ut=function(){function t(t,e){var n=this;this._element=t,this._scrollElement="BODY"===t.tagName?window:t,this._config=this._getConfig(e),this._selector=this._config.target+" .nav-link,"+this._config.target+" .list-group-item,"+this._config.target+" .dropdown-item",this._offsets=[],this._targets=[],this._activeTarget=null,this._scrollHeight=0,o.default(this._scrollElement).on("scroll.bs.scrollspy",(function(t){return n._process(t)})),this.refresh(),this._process()}var e=t.prototype;return e.refresh=function(){var t=this,e=this._scrollElement===this._scrollElement.window?"offset":"position",n="auto"===this._config.method?e:this._config.method,i="position"===n?this._getScrollTop():0;this._offsets=[],this._targets=[],this._scrollHeight=this._getScrollHeight(),[].slice.call(document.querySelectorAll(this._selector)).map((function(t){var e,a=d.getSelectorFromElement(t);if(a&&(e=document.querySelector(a)),e){var s=e.getBoundingClientRect();if(s.width||s.height)return[o.default(e)[n]().top+i,a]}return null})).filter((function(t){return t})).sort((function(t,e){return t[0]-e[0]})).forEach((function(e){t._offsets.push(e[0]),t._targets.push(e[1])}))},e.dispose=function(){o.default.removeData(this._element,"bs.scrollspy"),o.default(this._scrollElement).off(".bs.scrollspy"),this._element=null,this._scrollElement=null,this._config=null,this._selector=null,this._offsets=null,this._targets=null,this._activeTarget=null,this._scrollHeight=null},e._getConfig=function(t){if("string"!=typeof(t=r({},lt,"object"==typeof t&&t?t:{})).target&&d.isElement(t.target)){var e=o.default(t.target).attr("id");e||(e=d.getUID(at),o.default(t.target).attr("id",e)),t.target="#"+e}return d.typeCheckConfig(at,t,rt),t},e._getScrollTop=function(){return this._scrollElement===window?this._scrollElement.pageYOffset:this._scrollElement.scrollTop},e._getScrollHeight=function(){return this._scrollElement.scrollHeight||Math.max(document.body.scrollHeight,document.documentElement.scrollHeight)},e._getOffsetHeight=function(){return this._scrollElement===window?window.innerHeight:this._scrollElement.getBoundingClientRect().height},e._process=function(){var t=this._getScrollTop()+this._config.offset,e=this._getScrollHeight(),n=this._config.offset+e-this._getOffsetHeight();if(this._scrollHeight!==e&&this.refresh(),t>=n){var i=this._targets[this._targets.length-1];this._activeTarget!==i&&this._activate(i)}else{if(this._activeTarget&&t0)return this._activeTarget=null,void this._clear();for(var o=this._offsets.length;o--;){this._activeTarget!==this._targets[o]&&t>=this._offsets[o]&&("undefined"==typeof this._offsets[o+1]||t li > .active":".active";n=(n=o.default.makeArray(o.default(i).find(s)))[n.length-1]}var l=o.default.Event("hide.bs.tab",{relatedTarget:this._element}),r=o.default.Event("show.bs.tab",{relatedTarget:n});if(n&&o.default(n).trigger(l),o.default(this._element).trigger(r),!r.isDefaultPrevented()&&!l.isDefaultPrevented()){a&&(e=document.querySelector(a)),this._activate(this._element,i);var u=function(){var e=o.default.Event("hidden.bs.tab",{relatedTarget:t._element}),i=o.default.Event("shown.bs.tab",{relatedTarget:n});o.default(n).trigger(e),o.default(t._element).trigger(i)};e?this._activate(e,e.parentNode,u):u()}}},e.dispose=function(){o.default.removeData(this._element,"bs.tab"),this._element=null},e._activate=function(t,e,n){var i=this,a=(!e||"UL"!==e.nodeName&&"OL"!==e.nodeName?o.default(e).children(".active"):o.default(e).find("> li > .active"))[0],s=n&&a&&o.default(a).hasClass("fade"),l=function(){return i._transitionComplete(t,a,n)};if(a&&s){var r=d.getTransitionDurationFromElement(a);o.default(a).removeClass("show").one(d.TRANSITION_END,l).emulateTransitionEnd(r)}else l()},e._transitionComplete=function(t,e,n){if(e){o.default(e).removeClass("active");var i=o.default(e.parentNode).find("> .dropdown-menu .active")[0];i&&o.default(i).removeClass("active"),"tab"===e.getAttribute("role")&&e.setAttribute("aria-selected",!1)}if(o.default(t).addClass("active"),"tab"===t.getAttribute("role")&&t.setAttribute("aria-selected",!0),d.reflow(t),t.classList.contains("fade")&&t.classList.add("show"),t.parentNode&&o.default(t.parentNode).hasClass("dropdown-menu")){var a=o.default(t).closest(".dropdown")[0];if(a){var s=[].slice.call(a.querySelectorAll(".dropdown-toggle"));o.default(s).addClass("active")}t.setAttribute("aria-expanded",!0)}n&&n()},t._jQueryInterface=function(e){return this.each((function(){var n=o.default(this),i=n.data("bs.tab");if(i||(i=new t(this),n.data("bs.tab",i)),"string"==typeof e){if("undefined"==typeof i[e])throw new TypeError('No method named "'+e+'"');i[e]()}}))},l(t,null,[{key:"VERSION",get:function(){return"4.5.3"}}]),t}();o.default(document).on("click.bs.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"], [data-toggle="list"]',(function(t){t.preventDefault(),ft._jQueryInterface.call(o.default(this),"show")})),o.default.fn.tab=ft._jQueryInterface,o.default.fn.tab.Constructor=ft,o.default.fn.tab.noConflict=function(){return o.default.fn.tab=dt,ft._jQueryInterface};var ct=o.default.fn.toast,ht={animation:"boolean",autohide:"boolean",delay:"number"},gt={animation:!0,autohide:!0,delay:500},mt=function(){function t(t,e){this._element=t,this._config=this._getConfig(e),this._timeout=null,this._setListeners()}var e=t.prototype;return e.show=function(){var t=this,e=o.default.Event("show.bs.toast");if(o.default(this._element).trigger(e),!e.isDefaultPrevented()){this._clearTimeout(),this._config.animation&&this._element.classList.add("fade");var n=function(){t._element.classList.remove("showing"),t._element.classList.add("show"),o.default(t._element).trigger("shown.bs.toast"),t._config.autohide&&(t._timeout=setTimeout((function(){t.hide()}),t._config.delay))};if(this._element.classList.remove("hide"),d.reflow(this._element),this._element.classList.add("showing"),this._config.animation){var i=d.getTransitionDurationFromElement(this._element);o.default(this._element).one(d.TRANSITION_END,n).emulateTransitionEnd(i)}else n()}},e.hide=function(){if(this._element.classList.contains("show")){var t=o.default.Event("hide.bs.toast");o.default(this._element).trigger(t),t.isDefaultPrevented()||this._close()}},e.dispose=function(){this._clearTimeout(),this._element.classList.contains("show")&&this._element.classList.remove("show"),o.default(this._element).off("click.dismiss.bs.toast"),o.default.removeData(this._element,"bs.toast"),this._element=null,this._config=null},e._getConfig=function(t){return t=r({},gt,o.default(this._element).data(),"object"==typeof t&&t?t:{}),d.typeCheckConfig("toast",t,this.constructor.DefaultType),t},e._setListeners=function(){var t=this;o.default(this._element).on("click.dismiss.bs.toast",'[data-dismiss="toast"]',(function(){return t.hide()}))},e._close=function(){var t=this,e=function(){t._element.classList.add("hide"),o.default(t._element).trigger("hidden.bs.toast")};if(this._element.classList.remove("show"),this._config.animation){var n=d.getTransitionDurationFromElement(this._element);o.default(this._element).one(d.TRANSITION_END,e).emulateTransitionEnd(n)}else e()},e._clearTimeout=function(){clearTimeout(this._timeout),this._timeout=null},t._jQueryInterface=function(e){return this.each((function(){var n=o.default(this),i=n.data("bs.toast");if(i||(i=new t(this,"object"==typeof e&&e),n.data("bs.toast",i)),"string"==typeof e){if("undefined"==typeof i[e])throw new TypeError('No method named "'+e+'"');i[e](this)}}))},l(t,null,[{key:"VERSION",get:function(){return"4.5.3"}},{key:"DefaultType",get:function(){return ht}},{key:"Default",get:function(){return gt}}]),t}();o.default.fn.toast=mt._jQueryInterface,o.default.fn.toast.Constructor=mt,o.default.fn.toast.noConflict=function(){return o.default.fn.toast=ct,mt._jQueryInterface},t.Alert=h,t.Button=m,t.Carousel=w,t.Collapse=D,t.Dropdown=x,t.Modal=q,t.Popover=ot,t.Scrollspy=ut,t.Tab=ft,t.Toast=mt,t.Tooltip=J,t.Util=d,Object.defineProperty(t,"__esModule",{value:!0})})); 7 | //# sourceMappingURL=bootstrap.min.js.map -------------------------------------------------------------------------------- /blog/static/blog/js/jquery-3.5.1.slim.min.js: -------------------------------------------------------------------------------- 1 | /*! jQuery v3.5.1 -ajax,-ajax/jsonp,-ajax/load,-ajax/script,-ajax/var/location,-ajax/var/nonce,-ajax/var/rquery,-ajax/xhr,-manipulation/_evalUrl,-deprecated/ajax-event-alias,-effects,-effects/Tween,-effects/animatedSelector | (c) JS Foundation and other contributors | jquery.org/license */ 2 | !function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(g,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,v=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,y=n.hasOwnProperty,a=y.toString,l=a.call(Object),m={},b=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType},x=function(e){return null!=e&&e===e.window},w=g.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function C(e,t,n){var r,i,o=(n=n||w).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function T(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.5.1 -ajax,-ajax/jsonp,-ajax/load,-ajax/script,-ajax/var/location,-ajax/var/nonce,-ajax/var/rquery,-ajax/xhr,-manipulation/_evalUrl,-deprecated/ajax-event-alias,-effects,-effects/Tween,-effects/animatedSelector",E=function(e,t){return new E.fn.init(e,t)};function d(e){var t=!!e&&"length"in e&&e.length,n=T(e);return!b(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0+~]|"+R+")"+R+"*"),U=new RegExp(R+"|>"),V=new RegExp(W),X=new RegExp("^"+B+"$"),Q={ID:new RegExp("^#("+B+")"),CLASS:new RegExp("^\\.("+B+")"),TAG:new RegExp("^("+B+"|[*])"),ATTR:new RegExp("^"+M),PSEUDO:new RegExp("^"+W),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+R+"*(even|odd|(([+-]|)(\\d*)n|)"+R+"*(?:([+-]|)"+R+"*(\\d+)|))"+R+"*\\)|)","i"),bool:new RegExp("^(?:"+I+")$","i"),needsContext:new RegExp("^"+R+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+R+"*((?:-\\d)?\\d*)"+R+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,G=/^(?:input|select|textarea|button)$/i,K=/^h\d$/i,J=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+R+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){C()},ae=xe(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{O.apply(t=P.call(d.childNodes),d.childNodes),t[d.childNodes.length].nodeType}catch(e){O={apply:t.length?function(e,t){q.apply(e,P.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,d=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==d&&9!==d&&11!==d)return n;if(!r&&(C(e),e=e||T,E)){if(11!==d&&(u=Z.exec(t)))if(i=u[1]){if(9===d){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return O.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&p.getElementsByClassName&&e.getElementsByClassName)return O.apply(n,e.getElementsByClassName(i)),n}if(p.qsa&&!k[t+" "]&&(!v||!v.test(t))&&(1!==d||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===d&&(U.test(t)||_.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&p.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=A)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+be(l[o]);c=l.join(",")}try{return O.apply(n,f.querySelectorAll(c)),n}catch(e){k(t,!0)}finally{s===A&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>x.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[A]=!0,e}function ce(e){var t=T.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)x.attrHandle[n[r]]=t}function de(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function pe(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in p=se.support={},i=se.isXML=function(e){var t=e.namespaceURI,n=(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},C=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:d;return r!=T&&9===r.nodeType&&r.documentElement&&(a=(T=r).documentElement,E=!i(T),d!=T&&(n=T.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),p.scope=ce(function(e){return a.appendChild(e).appendChild(T.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),p.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),p.getElementsByTagName=ce(function(e){return e.appendChild(T.createComment("")),!e.getElementsByTagName("*").length}),p.getElementsByClassName=J.test(T.getElementsByClassName),p.getById=ce(function(e){return a.appendChild(e).id=A,!T.getElementsByName||!T.getElementsByName(A).length}),p.getById?(x.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},x.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(x.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},x.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),x.find.TAG=p.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):p.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},x.find.CLASS=p.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(p.qsa=J.test(T.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+R+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+R+"*(?:value|"+I+")"),e.querySelectorAll("[id~="+A+"-]").length||v.push("~="),(t=T.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+R+"*name"+R+"*="+R+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+A+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="";var t=T.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+R+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(p.matchesSelector=J.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){p.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",W)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=J.test(a.compareDocumentPosition),y=t||J.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!p.sortDetached&&t.compareDocumentPosition(e)===n?e==T||e.ownerDocument==d&&y(d,e)?-1:t==T||t.ownerDocument==d&&y(d,t)?1:u?H(u,e)-H(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==T?-1:t==T?1:i?-1:o?1:u?H(u,e)-H(u,t):0;if(i===o)return de(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?de(a[r],s[r]):a[r]==d?-1:s[r]==d?1:0}),T},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(C(e),p.matchesSelector&&E&&!k[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||p.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){k(t,!0)}return 0":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return Q.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&V.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+R+")"+e+"("+R+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function D(e,n,r){return b(n)?E.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?E.grep(e,function(e){return e===n!==r}):"string"!=typeof n?E.grep(e,function(e){return-1)[^>]*|#([\w-]+))$/;(E.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||L,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:j.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof E?t[0]:t,E.merge(this,E.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:w,!0)),k.test(r[1])&&E.isPlainObject(t))for(r in t)b(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=w.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):b(e)?void 0!==n.ready?n.ready(e):e(E):E.makeArray(e,this)}).prototype=E.fn,L=E(w);var q=/^(?:parents|prev(?:Until|All))/,O={children:!0,contents:!0,next:!0,prev:!0};function P(e,t){while((e=e[t])&&1!==e.nodeType);return e}E.fn.extend({has:function(e){var t=E(e,this),n=t.length;return this.filter(function(){for(var e=0;e\x20\t\r\n\f]*)/i,pe=/^$|^module$|\/(?:java|ecma)script/i;le=w.createDocumentFragment().appendChild(w.createElement("div")),(ce=w.createElement("input")).setAttribute("type","radio"),ce.setAttribute("checked","checked"),ce.setAttribute("name","t"),le.appendChild(ce),m.checkClone=le.cloneNode(!0).cloneNode(!0).lastChild.checked,le.innerHTML="",m.noCloneChecked=!!le.cloneNode(!0).lastChild.defaultValue,le.innerHTML="",m.option=!!le.lastChild;var he={thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};function ge(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&S(e,t)?E.merge([e],n):n}function ve(e,t){for(var n=0,r=e.length;n",""]);var ye=/<|&#?\w+;/;function me(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),d=[],p=0,h=e.length;p\s*$/g;function Le(e,t){return S(e,"table")&&S(11!==t.nodeType?t:t.firstChild,"tr")&&E(e).children("tbody")[0]||e}function je(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Oe(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n
",2===ft.childNodes.length),E.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(m.createHTMLDocument?((r=(t=w.implementation.createHTMLDocument("")).createElement("base")).href=w.location.href,t.head.appendChild(r)):t=w),o=!n&&[],(i=k.exec(e))?[t.createElement(i[1])]:(i=me([e],t,o),o&&o.length&&E(o).remove(),E.merge([],i.childNodes)));var r,i,o},E.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=E.css(e,"position"),c=E(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=E.css(e,"top"),u=E.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),b(t)&&(t=t.call(e,n,E.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):("number"==typeof f.top&&(f.top+="px"),"number"==typeof f.left&&(f.left+="px"),c.css(f))}},E.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){E.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===E.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===E.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=E(e).offset()).top+=E.css(e,"borderTopWidth",!0),i.left+=E.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-E.css(r,"marginTop",!0),left:t.left-i.left-E.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===E.css(e,"position"))e=e.offsetParent;return e||re})}}),E.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;E.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),E.each(["top","left"],function(e,n){E.cssHooks[n]=Fe(m.pixelPosition,function(e,t){if(t)return t=We(e,n),Ie.test(t)?E(e).position()[n]+"px":t})}),E.each({Height:"height",Width:"width"},function(a,s){E.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){E.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?E.css(e,t,i):E.style(e,t,n,i)},s,n?e:void 0,n)}})}),E.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),E.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){E.fn[n]=function(e,t){return 0=o.clientWidth&&n>=o.clientHeight}),l=0a[e]&&!t.escapeWithReference&&(n=Q(f[o],a[e]-('right'===e?f.width:f.height))),ae({},o,n)}};return l.forEach(function(e){var t=-1===['left','top'].indexOf(e)?'secondary':'primary';f=le({},f,m[t](e))}),e.offsets.popper=f,e},priority:['left','right','top','bottom'],padding:5,boundariesElement:'scrollParent'},keepTogether:{order:400,enabled:!0,fn:function(e){var t=e.offsets,o=t.popper,n=t.reference,i=e.placement.split('-')[0],r=Z,p=-1!==['top','bottom'].indexOf(i),s=p?'right':'bottom',d=p?'left':'top',a=p?'width':'height';return o[s]r(n[s])&&(e.offsets.popper[d]=r(n[s])),e}},arrow:{order:500,enabled:!0,fn:function(e,o){var n;if(!K(e.instance.modifiers,'arrow','keepTogether'))return e;var i=o.element;if('string'==typeof i){if(i=e.instance.popper.querySelector(i),!i)return e;}else if(!e.instance.popper.contains(i))return console.warn('WARNING: `arrow.element` must be child of its popper element!'),e;var r=e.placement.split('-')[0],p=e.offsets,s=p.popper,d=p.reference,a=-1!==['left','right'].indexOf(r),l=a?'height':'width',f=a?'Top':'Left',m=f.toLowerCase(),h=a?'left':'top',c=a?'bottom':'right',u=S(i)[l];d[c]-us[c]&&(e.offsets.popper[m]+=d[m]+u-s[c]),e.offsets.popper=g(e.offsets.popper);var b=d[m]+d[l]/2-u/2,w=t(e.instance.popper),y=parseFloat(w['margin'+f]),E=parseFloat(w['border'+f+'Width']),v=b-e.offsets.popper[m]-y-E;return v=ee(Q(s[l]-u,v),0),e.arrowElement=i,e.offsets.arrow=(n={},ae(n,m,$(v)),ae(n,h,''),n),e},element:'[x-arrow]'},flip:{order:600,enabled:!0,fn:function(e,t){if(W(e.instance.modifiers,'inner'))return e;if(e.flipped&&e.placement===e.originalPlacement)return e;var o=v(e.instance.popper,e.instance.reference,t.padding,t.boundariesElement,e.positionFixed),n=e.placement.split('-')[0],i=T(n),r=e.placement.split('-')[1]||'',p=[];switch(t.behavior){case ce.FLIP:p=[n,i];break;case ce.CLOCKWISE:p=G(n);break;case ce.COUNTERCLOCKWISE:p=G(n,!0);break;default:p=t.behavior;}return p.forEach(function(s,d){if(n!==s||p.length===d+1)return e;n=e.placement.split('-')[0],i=T(n);var a=e.offsets.popper,l=e.offsets.reference,f=Z,m='left'===n&&f(a.right)>f(l.left)||'right'===n&&f(a.left)f(l.top)||'bottom'===n&&f(a.top)f(o.right),g=f(a.top)f(o.bottom),b='left'===n&&h||'right'===n&&c||'top'===n&&g||'bottom'===n&&u,w=-1!==['top','bottom'].indexOf(n),y=!!t.flipVariations&&(w&&'start'===r&&h||w&&'end'===r&&c||!w&&'start'===r&&g||!w&&'end'===r&&u),E=!!t.flipVariationsByContent&&(w&&'start'===r&&c||w&&'end'===r&&h||!w&&'start'===r&&u||!w&&'end'===r&&g),v=y||E;(m||b||v)&&(e.flipped=!0,(m||b)&&(n=p[d+1]),v&&(r=z(r)),e.placement=n+(r?'-'+r:''),e.offsets.popper=le({},e.offsets.popper,C(e.instance.popper,e.offsets.reference,e.placement)),e=P(e.instance.modifiers,e,'flip'))}),e},behavior:'flip',padding:5,boundariesElement:'viewport',flipVariations:!1,flipVariationsByContent:!1},inner:{order:700,enabled:!1,fn:function(e){var t=e.placement,o=t.split('-')[0],n=e.offsets,i=n.popper,r=n.reference,p=-1!==['left','right'].indexOf(o),s=-1===['top','left'].indexOf(o);return i[p?'left':'top']=r[o]-(s?i[p?'width':'height']:0),e.placement=T(t),e.offsets.popper=g(i),e}},hide:{order:800,enabled:!0,fn:function(e){if(!K(e.instance.modifiers,'hide','preventOverflow'))return e;var t=e.offsets.reference,o=D(e.instance.modifiers,function(e){return'preventOverflow'===e.name}).boundaries;if(t.bottomo.right||t.top>o.bottom||t.rightwindow.devicePixelRatio||!fe),c='bottom'===o?'top':'bottom',g='right'===n?'left':'right',b=B('transform');if(d='bottom'==c?'HTML'===l.nodeName?-l.clientHeight+h.bottom:-f.height+h.bottom:h.top,s='right'==g?'HTML'===l.nodeName?-l.clientWidth+h.right:-f.width+h.right:h.left,a&&b)m[b]='translate3d('+s+'px, '+d+'px, 0)',m[c]=0,m[g]=0,m.willChange='transform';else{var w='bottom'==c?-1:1,y='right'==g?-1:1;m[c]=d*w,m[g]=s*y,m.willChange=c+', '+g}var E={"x-placement":e.placement};return e.attributes=le({},E,e.attributes),e.styles=le({},m,e.styles),e.arrowStyles=le({},e.offsets.arrow,e.arrowStyles),e},gpuAcceleration:!0,x:'bottom',y:'right'},applyStyle:{order:900,enabled:!0,fn:function(e){return V(e.instance.popper,e.styles),j(e.instance.popper,e.attributes),e.arrowElement&&Object.keys(e.arrowStyles).length&&V(e.arrowElement,e.arrowStyles),e},onLoad:function(e,t,o,n,i){var r=L(i,t,e,o.positionFixed),p=O(o.placement,r,t,e,o.modifiers.flip.boundariesElement,o.modifiers.flip.padding);return t.setAttribute('x-placement',p),V(t,{position:o.positionFixed?'fixed':'absolute'}),o},gpuAcceleration:void 0}}},ge}); 5 | //# sourceMappingURL=popper.min.js.map -------------------------------------------------------------------------------- /blog/templates/blog/about.html: -------------------------------------------------------------------------------- 1 | {% extends "blog/base.html" %} 2 | {% block body %} 3 |

من أنا

4 | {% endblock %} -------------------------------------------------------------------------------- /blog/templates/blog/base.html: -------------------------------------------------------------------------------- 1 | {% load blog_tags %} 2 | {% load static %} 3 | 4 | 5 | 6 | 7 | 8 | 9 | {% if title %} 10 | مدونة | {{title}} 11 | {% else %} 12 | مدونة 13 | {% endif %} 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 61 | 62 |
63 | 64 | 65 |
66 |
67 |
68 |
69 | {% block body %} 70 | 71 | {% endblock %} 72 |
73 |
74 |
75 |

اخر التدوينات

76 | {% latest_posts %} 77 |
78 |
79 |

اخر التعليقات

80 | {% latest_comments %} 81 |
82 |
83 |
84 |
85 |
86 | 87 | 88 | 89 |
90 |
91 |
92 |
93 |
94 |
95 |

من أنا

96 |
97 |
98 | logo 99 |
100 | الاسم : سعيد احمد الحلاق
101 | التخصص : هندسة برمجيات 102 |
103 |
104 |
105 |

مواقع هامة

106 | 114 |
115 |
116 |

مواقع التواصل الاجتماعي

117 |
118 |

119 | 120 | 121 | 122 | 123 | 124 | 125 |

126 |
127 |
128 |
129 |
130 |
131 |
132 |
133 | © جميع الحقوق محفوظة 134 |
135 |
136 |
137 |
138 | 139 | 140 | 141 | 142 | 143 | 144 | 145 | -------------------------------------------------------------------------------- /blog/templates/blog/detail.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% block body %} 3 | {% load crispy_forms_tags %} 4 |
5 | foto author 6 | نشر في {{post.post_date|date:'d-m-Y'}} 7 | 8 | {% if post.author == user %} 9 |
10 | تحرير 11 | حذف 12 |
13 | {% endif %} 14 | 15 |

{{post.title}}

16 |

{{post.content}}

17 |
18 | 19 |

التعليقات ({{count}})

20 | {% if comments %} 21 | {% for comment in comments %} 22 |
23 |
({{comment.name}}) 24 | {{comment.comment_date|date:'d-m-Y'}} 25 |
26 |

{{comment.body}}

27 |
28 | {% endfor %} 29 | {% else %} 30 |
31 |
لا توجد تعليقات
32 |
33 | {% endif %} 34 |

اضافة تعليق جديد

35 |
36 | {% csrf_token %} 37 |
38 | {{newcomment|crispy}} 39 | 40 |
41 |
42 | {% endblock %} -------------------------------------------------------------------------------- /blog/templates/blog/index.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% load static %} 3 | {% block body %} 4 | 5 | {% for message in messages %} 6 |
7 | {{message}} 8 |
9 | {% endfor %} 10 | 11 | {% for post in po %} 12 |
13 | foto author 15 | نشر في {{post.post_date|date:'d-m-Y'}} 16 |

{{post.title}}

17 |

{{post.content}}

18 |
19 | {% endfor %} 20 | {% include 'blog/pagination.html' with page=po %} 21 | {% endblock %} -------------------------------------------------------------------------------- /blog/templates/blog/latest_comments.html: -------------------------------------------------------------------------------- 1 | 17 | 18 | -------------------------------------------------------------------------------- /blog/templates/blog/latest_posts.html: -------------------------------------------------------------------------------- 1 |
    2 | {% for po in l_posts %} 3 |
  • 4 | {{po.title}} 5 |
  • 6 | {% endfor %} 7 |
8 | 9 | -------------------------------------------------------------------------------- /blog/templates/blog/new_post.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% block body %} 3 | {% load crispy_forms_tags %} 4 | 5 |
6 |

تدوينة جديدة

7 |
8 | {% csrf_token %} 9 | {{form|crispy}} 10 | 11 |
12 |
13 | {% endblock %} -------------------------------------------------------------------------------- /blog/templates/blog/pagination.html: -------------------------------------------------------------------------------- 1 |
2 | {% if page.has_next %} 3 | التالي 4 | {% else %} 5 | التالي 6 | {% endif %} 7 | 8 | صفحة {{page.number}} من {{page.paginator.num_pages}} 9 | 10 | {% if page.has_previous %} 11 | السابق 12 | {% else %} 13 | السابق 14 | {% endif %} 15 |
-------------------------------------------------------------------------------- /blog/templates/blog/post_confirm_delete.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% block body %} 3 | {% load crispy_forms_tags %} 4 | 5 |
6 | حذف تدوينة 7 |
8 | هل أنت متأكد من حذف "{{object.title}}" ؟ 9 | {% csrf_token %} 10 | 11 | تراجع 12 |
13 |
14 | 15 | {% endblock %} -------------------------------------------------------------------------------- /blog/templates/blog/postupdate.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% block body %} 3 | {% load crispy_forms_tags %} 4 | 5 |
6 |

تحرير التدوينة

7 |
8 | {% csrf_token %} 9 | {{form|crispy}} 10 | 11 |
12 |
13 | {% endblock %} -------------------------------------------------------------------------------- /blog/templatetags/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/templatetags/__init__.py -------------------------------------------------------------------------------- /blog/templatetags/__pycache__/__init__.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/templatetags/__pycache__/__init__.cpython-38.pyc -------------------------------------------------------------------------------- /blog/templatetags/__pycache__/blog_tags.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/blog/templatetags/__pycache__/blog_tags.cpython-38.pyc -------------------------------------------------------------------------------- /blog/templatetags/blog_tags.py: -------------------------------------------------------------------------------- 1 | from django import template 2 | from ..models import post, comment 3 | 4 | register = template.Library() 5 | @register.inclusion_tag('blog/latest_posts.html') 6 | def latest_posts(): 7 | context = { 8 | 'l_posts': post.objects.all()[0:5], 9 | } 10 | return context 11 | 12 | 13 | @register.inclusion_tag('blog/latest_comments.html') 14 | def latest_comments(): 15 | context = { 16 | 'l_comments': comment.objects.filter(active=True)[:5], 17 | } 18 | return context -------------------------------------------------------------------------------- /blog/tests.py: -------------------------------------------------------------------------------- 1 | from django.test import TestCase 2 | 3 | # Create your tests here. 4 | -------------------------------------------------------------------------------- /blog/urls.py: -------------------------------------------------------------------------------- 1 | from django.urls import path 2 | from .views import index, about, latest_pos, detail, latest_com, postCreateView, postupdateView, PostDeleteView 3 | 4 | urlpatterns = [ 5 | path('', index, name='index'), 6 | path('about/', about, name='about'), 7 | path('lastes_post/', latest_pos), 8 | path('latest_comment/', latest_com), 9 | path('detail//', detail, name='detail'), 10 | path('new_post/', postCreateView.as_view(), name='new_post'), 11 | path('detail//update/', postupdateView.as_view(), name='post_update'), 12 | path('detail//deleate/', PostDeleteView.as_view(), name='post_delete'), 13 | ] 14 | -------------------------------------------------------------------------------- /blog/views.py: -------------------------------------------------------------------------------- 1 | from django.shortcuts import render 2 | from blog.models import post, comment 3 | from . import models 4 | from blog.forms import NewComment, CreatePost 5 | from django.http import HttpResponseRedirect 6 | from user.models import pofile 7 | from django.contrib.auth.models import User 8 | from django.core.paginator import Paginator, PageNotAnInteger, EmptyPage 9 | from django.views.generic import CreateView, UpdateView, DeleteView 10 | from django.contrib.auth.mixins import LoginRequiredMixin, UserPassesTestMixin 11 | 12 | 13 | def index(request): 14 | po = post.objects.all() 15 | paginator = Paginator(po, 5) 16 | page = request.GET.get('page') 17 | try: 18 | po = paginator.page(page) 19 | except PageNotAnInteger: 20 | po = paginator.page(1) 21 | except EmptyPage: 22 | po = paginator.page(paginator.num_page) 23 | return render(request, 'blog/index.html', {'title': 'الصفحة الرئيسة', 'po': po, 'page': page}) 24 | 25 | def latest_pos(request): 26 | return render(request, 'latest_post.html', {}) 27 | 28 | def latest_com(request): 29 | return render(request, 'latest_comments.html', {}) 30 | 31 | def about(request): 32 | return render(request, 'blog/about.html', {'title': 'من أنا'}) 33 | 34 | def detail(request, post_id): 35 | po = models.post.objects.get(id = post_id) 36 | #com = comment.objects.filter(post_id = post_id, active = True) Filter comments by activity status 37 | com = comment.objects.filter(post_id = post_id) 38 | # Function count that counts rows 39 | count = com.count() 40 | newcom = NewComment(request.POST or None) 41 | ob = comment() 42 | if newcom.is_valid(): 43 | ob.post_id = post_id 44 | ob.name = newcom.cleaned_data['name'] 45 | ob.email = newcom.cleaned_data['email'] 46 | ob.body = newcom.cleaned_data['body'] 47 | ob.save() 48 | return HttpResponseRedirect('/detail/' + str(post_id)) 49 | 50 | context = { 51 | 'title': po.title, 52 | 'post': po, 53 | 'comments': com, 54 | 'count': count, 55 | 'newcomment': newcom 56 | } 57 | return render(request, 'blog/detail.html', context) 58 | 59 | 60 | class postCreateView(LoginRequiredMixin ,CreateView): 61 | model = post 62 | # fields = ['title', 'content'] 63 | template_name = 'blog/new_post.html' 64 | form_class = CreatePost 65 | 66 | 67 | def form_valid(self, form): 68 | form.instance.author = self.request.user 69 | return super().form_valid(form) 70 | 71 | 72 | 73 | class postupdateView(UserPassesTestMixin, LoginRequiredMixin ,UpdateView): 74 | model = post 75 | # fields = ['title', 'content'] 76 | template_name = 'blog/postupdate.html' 77 | form_class = CreatePost 78 | 79 | 80 | def form_valid(self, form): 81 | form.instance.author = self.request.user 82 | return super().form_valid(form) 83 | 84 | def test_func(self): 85 | post = self.get_object() 86 | if self.request.user == post.author: 87 | return True 88 | else: 89 | return False 90 | 91 | class PostDeleteView(UserPassesTestMixin, LoginRequiredMixin, DeleteView): 92 | model = post 93 | success_url = '/' 94 | 95 | def test_func(self): 96 | post = self.get_object() 97 | if self.request.user == post.author: 98 | return True 99 | return False -------------------------------------------------------------------------------- /db.sqlite3: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/db.sqlite3 -------------------------------------------------------------------------------- /manage.py: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env python 2 | """Django's command-line utility for administrative tasks.""" 3 | import os 4 | import sys 5 | 6 | 7 | def main(): 8 | """Run administrative tasks.""" 9 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'my_blog.settings') 10 | try: 11 | from django.core.management import execute_from_command_line 12 | except ImportError as exc: 13 | raise ImportError( 14 | "Couldn't import Django. Are you sure it's installed and " 15 | "available on your PYTHONPATH environment variable? Did you " 16 | "forget to activate a virtual environment?" 17 | ) from exc 18 | execute_from_command_line(sys.argv) 19 | 20 | 21 | if __name__ == '__main__': 22 | main() 23 | -------------------------------------------------------------------------------- /media/default.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/media/default.jpg -------------------------------------------------------------------------------- /media/profile_pics/FB_IMG_1542136823937.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/media/profile_pics/FB_IMG_1542136823937.jpg -------------------------------------------------------------------------------- /media/profile_pics/FB_IMG_1544018297399.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/media/profile_pics/FB_IMG_1544018297399.jpg -------------------------------------------------------------------------------- /media/profile_pics/FB_IMG_1544018297399_vS5JqNQ.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/media/profile_pics/FB_IMG_1544018297399_vS5JqNQ.jpg -------------------------------------------------------------------------------- /media/profile_pics/default.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/media/profile_pics/default.jpg -------------------------------------------------------------------------------- /media/profile_pics/pic.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/media/profile_pics/pic.jpg -------------------------------------------------------------------------------- /media/profile_pics/saeed.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/media/profile_pics/saeed.jpg -------------------------------------------------------------------------------- /media/profile_pics/٢٠١٨٠٣٣١_٢٣١١٠٢.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/media/profile_pics/٢٠١٨٠٣٣١_٢٣١١٠٢.jpg -------------------------------------------------------------------------------- /my_blog/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/my_blog/__init__.py -------------------------------------------------------------------------------- /my_blog/__pycache__/__init__.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/my_blog/__pycache__/__init__.cpython-38.pyc -------------------------------------------------------------------------------- /my_blog/__pycache__/settings.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/my_blog/__pycache__/settings.cpython-38.pyc -------------------------------------------------------------------------------- /my_blog/__pycache__/urls.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/my_blog/__pycache__/urls.cpython-38.pyc -------------------------------------------------------------------------------- /my_blog/__pycache__/wsgi.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/my_blog/__pycache__/wsgi.cpython-38.pyc -------------------------------------------------------------------------------- /my_blog/asgi.py: -------------------------------------------------------------------------------- 1 | """ 2 | ASGI config for my_blog project. 3 | 4 | It exposes the ASGI callable as a module-level variable named ``application``. 5 | 6 | For more information on this file, see 7 | https://docs.djangoproject.com/en/3.1/howto/deployment/asgi/ 8 | """ 9 | 10 | import os 11 | 12 | from django.core.asgi import get_asgi_application 13 | 14 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'my_blog.settings') 15 | 16 | application = get_asgi_application() 17 | -------------------------------------------------------------------------------- /my_blog/settings.py: -------------------------------------------------------------------------------- 1 | """ 2 | Django settings for my_blog project. 3 | 4 | Generated by 'django-admin startproject' using Django 3.1.1. 5 | 6 | For more information on this file, see 7 | https://docs.djangoproject.com/en/3.1/topics/settings/ 8 | 9 | For the full list of settings and their values, see 10 | https://docs.djangoproject.com/en/3.1/ref/settings/ 11 | """ 12 | 13 | from pathlib import Path 14 | import os 15 | 16 | # Build paths inside the project like this: BASE_DIR / 'subdir'. 17 | BASE_DIR = Path(__file__).resolve().parent.parent 18 | 19 | 20 | # Quick-start development settings - unsuitable for production 21 | # See https://docs.djangoproject.com/en/3.1/howto/deployment/checklist/ 22 | 23 | # SECURITY WARNING: keep the secret key used in production secret! 24 | SECRET_KEY = 'yhr@c!&558_-o$_r3%t@3_rieo(*#!xybeqvsa^!3(z96n5txm' 25 | 26 | # SECURITY WARNING: don't run with debug turned on in production! 27 | DEBUG = True 28 | 29 | ALLOWED_HOSTS = [] 30 | 31 | 32 | # Application definition 33 | 34 | INSTALLED_APPS = [ 35 | 'django.contrib.admin', 36 | 'django.contrib.auth', 37 | 'django.contrib.contenttypes', 38 | 'django.contrib.sessions', 39 | 'django.contrib.messages', 40 | 'django.contrib.staticfiles', 41 | 'blog', 42 | 'user', 43 | 'crispy_forms', 44 | ] 45 | 46 | MIDDLEWARE = [ 47 | 'django.middleware.security.SecurityMiddleware', 48 | 'django.contrib.sessions.middleware.SessionMiddleware', 49 | 'django.middleware.common.CommonMiddleware', 50 | 'django.middleware.csrf.CsrfViewMiddleware', 51 | 'django.contrib.auth.middleware.AuthenticationMiddleware', 52 | 'django.contrib.messages.middleware.MessageMiddleware', 53 | 'django.middleware.clickjacking.XFrameOptionsMiddleware', 54 | ] 55 | 56 | ROOT_URLCONF = 'my_blog.urls' 57 | 58 | TEMPLATES = [ 59 | { 60 | 'BACKEND': 'django.template.backends.django.DjangoTemplates', 61 | 'DIRS': [], 62 | 'APP_DIRS': True, 63 | 'OPTIONS': { 64 | 'context_processors': [ 65 | 'django.template.context_processors.debug', 66 | 'django.template.context_processors.request', 67 | 'django.contrib.auth.context_processors.auth', 68 | 'django.contrib.messages.context_processors.messages', 69 | ], 70 | }, 71 | }, 72 | ] 73 | 74 | 75 | 76 | WSGI_APPLICATION = 'my_blog.wsgi.application' 77 | 78 | 79 | # Database 80 | # https://docs.djangoproject.com/en/3.1/ref/settings/#databases 81 | 82 | DATABASES = { 83 | 'default': { 84 | 'ENGINE': 'django.db.backends.mysql', 85 | 'NAME': 'my_blog', 86 | 'USER': 'root', 87 | 'PASSWORD': '', 88 | 'HOST': 'localhost', 89 | 'PORT': '3306', 90 | } 91 | } 92 | 93 | 94 | # Password validation 95 | # https://docs.djangoproject.com/en/3.1/ref/settings/#auth-password-validators 96 | 97 | AUTH_PASSWORD_VALIDATORS = [ 98 | { 99 | 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', 100 | }, 101 | { 102 | 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', 103 | }, 104 | { 105 | 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', 106 | }, 107 | { 108 | 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', 109 | }, 110 | ] 111 | 112 | 113 | # Internationalization 114 | # https://docs.djangoproject.com/en/3.1/topics/i18n/ 115 | 116 | LANGUAGE_CODE = 'en-us' 117 | 118 | TIME_ZONE = 'UTC' 119 | 120 | USE_I18N = True 121 | 122 | USE_L10N = True 123 | 124 | USE_TZ = True 125 | 126 | 127 | # Static files (CSS, JavaScript, Images) 128 | # https://docs.djangoproject.com/en/3.1/howto/static-files/ 129 | 130 | STATIC_URL = '/static/' 131 | 132 | CRISPY_TEMPLATE_PACK = 'bootstrap4' 133 | LOGIN_REDIRECT_URL = '/' 134 | LOGIN_URL = 'login' 135 | 136 | MEDIA_ROOT = os.path.join(BASE_DIR, 'media') 137 | MEDIA_URL = '/media/' 138 | 139 | 140 | -------------------------------------------------------------------------------- /my_blog/urls.py: -------------------------------------------------------------------------------- 1 | """my_blog URL Configuration 2 | 3 | The `urlpatterns` list routes URLs to views. For more information please see: 4 | https://docs.djangoproject.com/en/3.1/topics/http/urls/ 5 | Examples: 6 | Function views 7 | 1. Add an import: from my_app import views 8 | 2. Add a URL to urlpatterns: path('', views.home, name='home') 9 | Class-based views 10 | 1. Add an import: from other_app.views import Home 11 | 2. Add a URL to urlpatterns: path('', Home.as_view(), name='home') 12 | Including another URLconf 13 | 1. Import the include() function: from django.urls import include, path 14 | 2. Add a URL to urlpatterns: path('blog/', include('blog.urls')) 15 | """ 16 | from django.contrib import admin 17 | from django.urls import path, include 18 | 19 | urlpatterns = [ 20 | path('admin/', admin.site.urls), 21 | path('', include('blog.urls')), 22 | path('', include('user.urls')), 23 | ] 24 | -------------------------------------------------------------------------------- /my_blog/wsgi.py: -------------------------------------------------------------------------------- 1 | """ 2 | WSGI config for my_blog project. 3 | 4 | It exposes the WSGI callable as a module-level variable named ``application``. 5 | 6 | For more information on this file, see 7 | https://docs.djangoproject.com/en/3.1/howto/deployment/wsgi/ 8 | """ 9 | 10 | import os 11 | 12 | from django.core.wsgi import get_wsgi_application 13 | 14 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'my_blog.settings') 15 | 16 | application = get_wsgi_application() 17 | -------------------------------------------------------------------------------- /user/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/__init__.py -------------------------------------------------------------------------------- /user/__pycache__/__init__.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/__pycache__/__init__.cpython-38.pyc -------------------------------------------------------------------------------- /user/__pycache__/admin.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/__pycache__/admin.cpython-38.pyc -------------------------------------------------------------------------------- /user/__pycache__/forms.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/__pycache__/forms.cpython-38.pyc -------------------------------------------------------------------------------- /user/__pycache__/models.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/__pycache__/models.cpython-38.pyc -------------------------------------------------------------------------------- /user/__pycache__/urls.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/__pycache__/urls.cpython-38.pyc -------------------------------------------------------------------------------- /user/__pycache__/views.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/__pycache__/views.cpython-38.pyc -------------------------------------------------------------------------------- /user/admin.py: -------------------------------------------------------------------------------- 1 | from django.contrib import admin 2 | from user.models import pofile 3 | 4 | admin.site.register(pofile) -------------------------------------------------------------------------------- /user/apps.py: -------------------------------------------------------------------------------- 1 | from django.apps import AppConfig 2 | 3 | 4 | class UserConfig(AppConfig): 5 | name = 'user' 6 | -------------------------------------------------------------------------------- /user/forms.py: -------------------------------------------------------------------------------- 1 | from django import forms 2 | from django.contrib.auth.models import User 3 | from user.models import pofile 4 | 5 | 6 | class CreateUser(forms.Form): 7 | username = forms.CharField(max_length = 50, label = 'اسم المستخدم', help_text = 'اسم المستخد يجب الا يحتوي على مسافات') 8 | email = forms.EmailField(label = 'البريد الالكتروني') 9 | first_name = forms.CharField(label = 'الاسم الاول') 10 | last_name = forms.CharField(label = 'الاسم الاخير') 11 | password = forms.CharField(label = 'كلمة المرور', min_length = 8, widget = forms.PasswordInput(), 12 | help_text = 'يجب الا تقل كلمة المرور عن 8 خانات') 13 | passwordconfirm = forms.CharField(label = 'تاكيد كلمة المرور', min_length = 8, widget = forms.PasswordInput()) 14 | 15 | 16 | def clean_password2(self): 17 | if self.cleaned_data['password'] != self.cleaned_data['passwordconfirm']: 18 | raise forms.ValidationError('كلمة المرور غير متطابقة') 19 | return self.cleaned_data['passwordconfirm'] 20 | 21 | def clean_username(self): 22 | if User.objects.filter(username=self.cleaned_data['username']).exists(): 23 | raise forms.ValidationError('يوجد مستخدم مسجل بهذا الاسم.') 24 | return self.cleaned_data['username'] 25 | 26 | class log_in_form(forms.ModelForm): 27 | username = forms.CharField(label = 'اسم المستخدم') 28 | password = forms.CharField(label = 'كلمة المرور', widget = forms.PasswordInput()) 29 | class Meta: 30 | model = User 31 | fields = ('username', 'password') 32 | 33 | class user_update(forms.ModelForm): 34 | first_name = forms.CharField(label = 'الاسم الاول') 35 | last_name = forms.CharField(label = 'الاسم الاخير') 36 | email = forms.EmailField(label = 'البريد الالكتروني') 37 | 38 | class Meta: 39 | model = User 40 | fields = ('first_name', 'last_name', 'email') 41 | 42 | class image_update(forms.ModelForm): 43 | 44 | class Meta: 45 | model = pofile 46 | fields = ('image',) 47 | -------------------------------------------------------------------------------- /user/migrations/0001_initial.py: -------------------------------------------------------------------------------- 1 | # Generated by Django 3.1.1 on 2020-10-30 13:04 2 | 3 | from django.conf import settings 4 | from django.db import migrations, models 5 | import django.db.models.deletion 6 | 7 | 8 | class Migration(migrations.Migration): 9 | 10 | initial = True 11 | 12 | dependencies = [ 13 | migrations.swappable_dependency(settings.AUTH_USER_MODEL), 14 | ] 15 | 16 | operations = [ 17 | migrations.CreateModel( 18 | name='pofile', 19 | fields=[ 20 | ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 21 | ('image', models.ImageField(default='default.jpg', upload_to='profile_pics')), 22 | ('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)), 23 | ], 24 | ), 25 | ] 26 | -------------------------------------------------------------------------------- /user/migrations/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/migrations/__init__.py -------------------------------------------------------------------------------- /user/migrations/__pycache__/0001_initial.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/migrations/__pycache__/0001_initial.cpython-38.pyc -------------------------------------------------------------------------------- /user/migrations/__pycache__/__init__.cpython-38.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/SaeedAhmed99/Full-Stack-Project-Blog-Django-Framework/ae7c204ba36b8a6f113c51d68a2f782dc422e13f/user/migrations/__pycache__/__init__.cpython-38.pyc -------------------------------------------------------------------------------- /user/models.py: -------------------------------------------------------------------------------- 1 | from django.db import models 2 | from django.contrib.auth.models import User 3 | from django.db.models.signals import post_save 4 | from PIL import Image 5 | 6 | class pofile(models.Model): 7 | image = models.ImageField(default = 'default.jpg',upload_to = 'profile_pics') 8 | user = models.OneToOneField(User, on_delete = models.CASCADE) 9 | 10 | def save(self, *args, **kwargs): 11 | super().save(*args, **kwargs) 12 | img = Image.open(self.image.path) 13 | if img.width > 300 or img.height > 300: 14 | img.thumbnail((300, 300)) 15 | img.save(self.image.path) 16 | 17 | def create_profile(sender, **kwarg): 18 | if kwarg['created']: 19 | pofile.objects.create(user=kwarg['instance']) 20 | 21 | 22 | post_save.connect(create_profile, sender=User) 23 | -------------------------------------------------------------------------------- /user/templates/user/log_in.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% block body %} 3 | {% load crispy_forms_tags %} 4 | 5 | 6 |
7 |

تسجيل الدخول

8 | {% if messages %} 9 | {% for message in messages %} 10 |
11 | {{message}} 12 |
13 | {% endfor %} 14 | {% endif %} 15 |
16 | {% csrf_token %} 17 | {{form|crispy}} 18 | 19 |
20 |
21 | اذا لم يكن لديك حساب من قبل يرجى التسجيل من هنا 22 |
23 |
24 | {% endblock %} -------------------------------------------------------------------------------- /user/templates/user/log_out.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% block body %} 3 | {% load crispy_forms_tags %} 4 | 5 | 6 |
7 |

لقد تم تسجيل خروجك بنجاح

8 | تسجيل الدخول مرة اخرى 9 |
10 | {% endblock %} -------------------------------------------------------------------------------- /user/templates/user/profile.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% load static %} 3 | {% block body %} 4 | {% load crispy_forms_tags %} 5 | 6 | {% if messages %} 7 | {% for message in messages %} 8 |
9 | {{message}} 10 |
11 | {% endfor %} 12 | {% endif %} 13 |
14 |
15 |
16 |
17 | {{user.username}} 19 |
20 |
21 | تحرير 22 |
23 |
24 |
25 |

{{user.username}}

26 |

الاسم : {{user.first_name}} {{user.last_name }}

27 |

البريد الالكتروني : {{user.email}}

28 |
29 |
30 |
31 | 32 |
33 |
34 |

عدد التدوينات التي قمت بتدوينها

35 |

{{post_list.count}}

36 | 37 |

تدويناتي

38 | 39 | {% for post in posts %} 40 | 43 | {% empty %} 44 |

لا يوجد تدوينات

45 | {% endfor %} 46 | 47 | {% include 'blog/pagination.html' with page=posts %} 48 |
49 |
50 | 51 | {% endblock %} -------------------------------------------------------------------------------- /user/templates/user/profile_update.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% block body %} 3 | {% load crispy_forms_tags %} 4 | 5 |
6 |

تعديل الملف الشخصي

7 |
8 | {% csrf_token %} 9 | {{user|crispy}} 10 | {{image |crispy}} 11 | 12 |
13 |
14 | {% endblock %} -------------------------------------------------------------------------------- /user/templates/user/register.html: -------------------------------------------------------------------------------- 1 | {% extends 'blog/base.html' %} 2 | {% block body %} 3 | {% load crispy_forms_tags %} 4 | 5 |
6 |

التسجيل

7 |
8 | {% csrf_token %} 9 | {{form|crispy}} 10 | 11 |
12 |
13 | اذا كان لديك حساب فيمكنك تسجيل الدخول 14 |
15 |
16 | {% endblock %} -------------------------------------------------------------------------------- /user/tests.py: -------------------------------------------------------------------------------- 1 | from django.test import TestCase 2 | 3 | # Create your tests here. 4 | -------------------------------------------------------------------------------- /user/urls.py: -------------------------------------------------------------------------------- 1 | from django.urls import path 2 | from django.contrib.auth.views import LoginView, LogoutView 3 | from .views import register, register_back, log_in, log_out, profile, profile_update 4 | from django.contrib.auth.views import LoginView, LogoutView 5 | from django.conf.urls.static import static 6 | from django.conf import settings 7 | urlpatterns = [ 8 | path('register/', register, name='register' ), 9 | path('register_back/', register_back, name='register_back'), 10 | #path('login/', LoginView.as_view(template_name = 'user/log_in.html'), name='login'), 11 | #path('logout/', LogoutView.as_view(template_name = 'user/log_out.html'), name='logout'), 12 | path('login/', log_in, name='login'), 13 | path('logout/', log_out, name='logout'), 14 | #path('log_in_backend/', log_in_backend, name='login_backend'), 15 | path('profile/', profile, name='profile'), 16 | path('profile_update/', profile_update, name='profile_update'), 17 | 18 | ] + static(settings.MEDIA_URL, document_root = settings.MEDIA_ROOT) 19 | -------------------------------------------------------------------------------- /user/views.py: -------------------------------------------------------------------------------- 1 | from django.shortcuts import render, redirect 2 | from django.http import HttpResponseRedirect, HttpResponse 3 | from user.forms import CreateUser, user_update, image_update 4 | from django.contrib.auth.models import User 5 | from user.forms import CreateUser, log_in_form 6 | from django.contrib import messages 7 | from django.contrib.auth import authenticate, login, logout 8 | from blog.models import post 9 | from django.contrib.auth.decorators import login_required 10 | from django.core.paginator import Paginator, PageNotAnInteger, EmptyPage 11 | 12 | 13 | def register(request): 14 | return render(request, 'user/register.html', {'title': 'التسجيل', 'form': CreateUser}) 15 | 16 | 17 | def register_back(request): 18 | try: 19 | user =User.objects.create_user( 20 | request.POST['username'], 21 | request.POST['email'], 22 | request.POST['password'] 23 | ) 24 | user.first_name = request.POST['first_name'] 25 | user.last_name = request.POST['last_name'] 26 | user.save() 27 | name = request.POST['username'] 28 | fname = request.POST['first_name'] 29 | 30 | messages.success( 31 | request, f'تهانينا {fname} لقد تمت عملية التسجيل بنجاح.') 32 | return HttpResponseRedirect('/login') 33 | except: 34 | return HttpResponseRedirect('/register') 35 | 36 | 37 | def log_in(request): 38 | if request.method == 'POST': 39 | form = log_in_form() 40 | u = request.POST['username'] 41 | p = request.POST['password'] 42 | user = authenticate(request, username=u, password=p) 43 | if user is not None: 44 | login(request, user) 45 | return redirect('profile') 46 | else: 47 | messages.warning( 48 | request, 'هناك خطأ في اسم المستخدم أو كلمة المرور.') 49 | else: 50 | form = log_in_form() 51 | 52 | return render(request, 'user/log_in.html', {'title': 'تسجيل الدخول', 'form': form}) 53 | 54 | def log_out(request): 55 | logout(request) 56 | return render(request, 'user/log_out.html', {'title': 'تسجيل الخروج'}) 57 | 58 | # def log_in_backend(request): 59 | # u = request.POST['username'] 60 | # p = request.POST['password'] 61 | # au = authenticate(request, username = u, password = p) 62 | # if au is not None: 63 | # login(request, au) 64 | # return HttpResponseRedirect('/') 65 | # else: 66 | # messages.warning(request, 'هناك خطا في اسم المستخدم او كلمة المرور') 67 | # return HttpResponseRedirect('/login') 68 | 69 | @login_required(login_url='login') 70 | def profile(request): 71 | post_list = post.objects.filter(author = request.user) 72 | posts = post.objects.filter(author = request.user) 73 | paginator = Paginator(posts, 3) 74 | page = request.GET.get('page') 75 | try: 76 | posts = paginator.page(page) 77 | except PageNotAnInteger: 78 | posts = paginator.page(1) 79 | except EmptyPage: 80 | posts = paginator.page(paginator.num_page) 81 | return render(request, 'user/profile.html', {'title': 'الملف الشخصي','post_list': post_list ,'posts': posts, 'page': page}) 82 | 83 | 84 | @login_required(login_url='login') 85 | def profile_update(request): 86 | if request.method == 'POST': 87 | user_form = user_update(request.POST, instance=request.user) 88 | image_form = image_update(request.POST, request.FILES, instance=request.user.pofile) 89 | if user_form.is_valid and image_form.is_valid: 90 | user_form.save() 91 | image_form.save() 92 | messages.success( 93 | request, 'تم تعديل الملف الشخصي بنجاح .') 94 | return HttpResponseRedirect('/profile') 95 | else: 96 | user_form = user_update(instance=request.user) 97 | image_form = image_update(instance=request.user.pofile) 98 | return render(request, 'user/profile_update.html', {'title': 'تعديل الملف الشخصي', 'user': user_form, 'image': image_form}) 99 | 100 | 101 | 102 | 103 | --------------------------------------------------------------------------------