Merge branch 'feature/signed-user-cert-20-03-19' into 'master'

Feature/signed user cert 20 03 19

See merge request lilschool/site!279
remotes/origin/feature/cloudpayments^2
Danil 7 years ago
commit cda9df3cd0
  1. 39
      apps/notification/tasks.py
  2. BIN
      web/src/fonts/ProximaNova-Reg.otf
  3. BIN
      web/src/img/signed-user-certificates/1.jpg
  4. BIN
      web/src/img/signed-user-certificates/2.jpg
  5. BIN
      web/src/img/signed-user-certificates/3.jpg
  6. BIN
      web/src/img/signed-user-certificates/4.jpg
  7. BIN
      web/src/img/signed-user-certificates/5.jpg
  8. BIN
      web/src/img/signed-user-certificates/6.jpg
  9. BIN
      web/src/img/signed-user-certificates/7.jpg
  10. BIN
      web/src/img/signed-user-certificates/8.jpg
  11. BIN
      web/src/img/signed-user-certificates/9.jpg
  12. 9
      web/webpack.config.js

@ -1,10 +1,14 @@
import os
from datetime import datetime from datetime import datetime
from PIL import Image
from PIL import ImageFont
from PIL import ImageDraw
from django.contrib.auth import get_user_model from django.contrib.auth import get_user_model
from django.contrib.contenttypes.models import ContentType from django.contrib.contenttypes.models import ContentType
from django.contrib.staticfiles.storage import staticfiles_storage from django.contrib.staticfiles.storage import staticfiles_storage
from django.utils.timezone import now from django.utils.timezone import now
from django.db.models import Max from django.conf import settings
from apps.notification.models import UserNotification from apps.notification.models import UserNotification
from apps.notification.utils import send_email from apps.notification.utils import send_email
@ -17,11 +21,32 @@ from project.sengrid import get_sendgrid_client
User = get_user_model() User = get_user_model()
def draw_cert(path, email, first_name, last_name):
img = Image.open(path)
draw = ImageDraw.Draw(img)
font = ImageFont.truetype(os.path.join(settings.STATIC_ROOT, 'ProximaNova-Reg.otf'), 170)
text = first_name.capitalize()
if last_name:
text += ' ' + last_name.capitalize()
w, h = draw.textsize(text, font=font)
draw.text(((img.width - w) // 2, 900), text, (29, 115, 224), font=font)
fn = os.path.join(settings.MEDIA_ROOT, 'tmp')
try:
os.mkdir(fn)
except:
pass
fn = os.path.join(fn, 'certificate-for-%s.jpg' % email)
img.save(fn)
img.close()
return fn
@app.task @app.task
def send_certificates(email=None, date=None, dry_run=False): def send_certificates(email=None, date=None, dry_run=False):
path_pattern = 'img/user-certificates/%d.jpg' path_pattern = 'img/user-certificates/%d.jpg'
signed_path_pattern = 'img/signed-user-certificates/%d.jpg'
if email: if email:
file = open(staticfiles_storage.path(path_pattern % 1), 'rb') fn = draw_cert(staticfiles_storage.path(signed_path_pattern % 1), email, 'Имя', 'Фамилия')
file = open(fn, 'rb')
try: try:
send_email('Грамота от Lil School', email, 'notification/email/certificate.html', send_email('Грамота от Lil School', email, 'notification/email/certificate.html',
attachments=[(file.name, file.read(), 'image/jpeg')]) attachments=[(file.name, file.read(), 'image/jpeg')])
@ -31,6 +56,7 @@ def send_certificates(email=None, date=None, dry_run=False):
print('Email has been sent') print('Email has been sent')
finally: finally:
file.close() file.close()
os.remove(fn)
return return
date = datetime.strptime(date, '%d-%m-%Y').date() if date else now().date() date = datetime.strptime(date, '%d-%m-%Y').date() if date else now().date()
@ -52,7 +78,12 @@ def send_certificates(email=None, date=None, dry_run=False):
un.certificate_number = un.certificate_number + 1 \ un.certificate_number = un.certificate_number + 1 \
if un.certificate_number and staticfiles_storage.exists(path_pattern % (un.certificate_number + 1)) \ if un.certificate_number and staticfiles_storage.exists(path_pattern % (un.certificate_number + 1)) \
else 1 else 1
file = open(staticfiles_storage.path(path_pattern % un.certificate_number), 'rb') if un.user.child_first_name:
fn = staticfiles_storage.path(signed_path_pattern % un.certificate_number)
fn = draw_cert(fn, un.user.email, un.user.child_first_name, un.user.child_last_name)
else:
fn = staticfiles_storage.path(path_pattern % un.certificate_number)
file = open(fn, 'rb')
try: try:
send_email('Грамота от Lil School', un.user.email, 'notification/email/certificate.html', send_email('Грамота от Lil School', un.user.email, 'notification/email/certificate.html',
attachments=[(file.name, file.read(), 'image/jpeg')], user_notification=un) attachments=[(file.name, file.read(), 'image/jpeg')], user_notification=un)
@ -61,6 +92,8 @@ def send_certificates(email=None, date=None, dry_run=False):
continue continue
finally: finally:
file.close() file.close()
if un.user.child_first_name:
os.remove(fn)
un.certificate_last_email = now() un.certificate_last_email = now()
un.save() un.save()

Binary file not shown.

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 941 KiB

@ -18,6 +18,7 @@ module.exports = {
sprite: glob('./src/icons/*.svg'), sprite: glob('./src/icons/*.svg'),
images: glob('./src/img/*.*'), images: glob('./src/img/*.*'),
imagesCertificates: glob('./src/img/user-certificates/*'), imagesCertificates: glob('./src/img/user-certificates/*'),
imagesSignedCertificates: glob('./src/img/signed-user-certificates/*'),
imagesGiftCertificates: glob('./src/img/gift-certificates/*'), imagesGiftCertificates: glob('./src/img/gift-certificates/*'),
imagesReviews: glob('./src/img/reviews/*'), imagesReviews: glob('./src/img/reviews/*'),
fonts: glob('./src/fonts/*'), fonts: glob('./src/fonts/*'),
@ -90,7 +91,8 @@ module.exports = {
{ {
test: /\.(png|gif|jpg|svg)$/, test: /\.(png|gif|jpg|svg)$/,
exclude: [path.resolve(__dirname, 'src/icons'), path.resolve(__dirname, 'src/img/user-certificates'), exclude: [path.resolve(__dirname, 'src/icons'), path.resolve(__dirname, 'src/img/user-certificates'),
path.resolve(__dirname, 'src/img/gift-certificates'), path.resolve(__dirname, 'src/img/reviews')], path.resolve(__dirname, 'src/img/gift-certificates'), path.resolve(__dirname, 'src/img/reviews'),
path.resolve(__dirname, 'src/img/signed-user-certificates')],
loader: 'file-loader?name=[name].[ext]&outputPath=./img/' loader: 'file-loader?name=[name].[ext]&outputPath=./img/'
}, },
{ {
@ -98,6 +100,11 @@ module.exports = {
include: path.resolve(__dirname, 'src/img/user-certificates'), include: path.resolve(__dirname, 'src/img/user-certificates'),
loader: 'file-loader?name=[name].[ext]&outputPath=./img/user-certificates/' loader: 'file-loader?name=[name].[ext]&outputPath=./img/user-certificates/'
}, },
{
test: /\.(png|jpg)$/,
include: path.resolve(__dirname, 'src/img/signed-user-certificates'),
loader: 'file-loader?name=[name].[ext]&outputPath=./img/signed-user-certificates/'
},
{ {
test: /\.(png|jpg)$/, test: /\.(png|jpg)$/,
include: path.resolve(__dirname, 'src/img/gift-certificates'), include: path.resolve(__dirname, 'src/img/gift-certificates'),

Loading…
Cancel
Save