mirror of
https://gitlab2.federez.net/re2o/re2o
synced 2024-11-24 04:13:12 +00:00
141 lines
5.3 KiB
Python
141 lines
5.3 KiB
Python
|
# -*- coding: utf-8 -*-
|
||
|
# Generated by Django 1.11.29 on 2020-09-20 17:19
|
||
|
from __future__ import unicode_literals
|
||
|
|
||
|
import django.core.validators
|
||
|
from django.db import migrations, models
|
||
|
import django.utils.timezone
|
||
|
|
||
|
|
||
|
class Migration(migrations.Migration):
|
||
|
|
||
|
dependencies = [
|
||
|
('cotisations', '0043_separation_membership_connection_p1'),
|
||
|
]
|
||
|
|
||
|
def split_dates(apps, schema_editor):
|
||
|
db_alias = schema_editor.connection.alias
|
||
|
cotisation = apps.get_model("cotisations", "Cotisation")
|
||
|
cotisations = cotisation.objects.using(db_alias).all()
|
||
|
for cotis in cotisations:
|
||
|
cotis.date_start_con = cotis.date_start
|
||
|
cotis.date_start_memb = cotis.date_start
|
||
|
cotis.date_end_con = cotis.date_end
|
||
|
cotis.date_end_memb = cotis.date_end
|
||
|
if cotis.type_cotisation == 'Connexion':
|
||
|
cotis.date_end_memb = cotis.date_start
|
||
|
if cotis.type_cotisation == 'Adhesion':
|
||
|
cotis.date_end_con = cotis.date_start
|
||
|
cotis.save()
|
||
|
|
||
|
|
||
|
|
||
|
def split_duration_articles_and_ventes(apps, schema_editor):
|
||
|
def split_duration(e):
|
||
|
e.duration_membership = e.duration
|
||
|
e.duration_connection = e.duration
|
||
|
e.duration_days_membership = e.duration_days
|
||
|
e.duration_days_connection = e.duration_days
|
||
|
if e.type_cotisation == 'Connexion':
|
||
|
e.duration_membership = 0
|
||
|
e.duration_days_membership = 0
|
||
|
if e.type_cotisation == 'Adhesion':
|
||
|
e.duration_connection = 0
|
||
|
e.duration_days_connection = 0
|
||
|
e.save()
|
||
|
db_alias = schema_editor.connection.alias
|
||
|
article = apps.get_model("cotisations", "Article")
|
||
|
vente = apps.get_model("cotisations", "Vente")
|
||
|
for a in article.objects.using(db_alias).all():
|
||
|
split_duration(a)
|
||
|
for v in vente.objects.using(db_alias).all():
|
||
|
split_duration(v)
|
||
|
|
||
|
def unsplit_dates(apps, schema_editor):
|
||
|
db_alias = schema_editor.connection.alias
|
||
|
cotisation = apps.get_model("cotisations", "Cotisation")
|
||
|
cotisations = cotisation.objects.using(db_alias).all()
|
||
|
for cotis in cotisations:
|
||
|
connection = cotis.date_start_con != cotis.date_end_con
|
||
|
adhesion = cotis.date_start_memb != cotis.date_end_memb
|
||
|
cotis.date_start = cotis.date_start_con
|
||
|
cotis.date_end = max(cotis.date_end_con, cotis.date_end_memb)
|
||
|
if connection:
|
||
|
cotis.type_cotisation = 'Connexion'
|
||
|
if adhesion:
|
||
|
cotis.type_cotisation = 'Adhesion'
|
||
|
if connection and adhesion:
|
||
|
cotis.type_cotisation = 'All'
|
||
|
if not (connection or adhesion):
|
||
|
cotis.type_cotisation = None
|
||
|
cotis.save()
|
||
|
|
||
|
|
||
|
|
||
|
def unsplit_duration_articles_and_ventes(apps, schema_editor):
|
||
|
def unsplit_duration(e):
|
||
|
e.duration = max(e.duration_membership, e.duration_connection)
|
||
|
e.duration_days = max(e.duration_days_membership, e.duration_days_connection)
|
||
|
connection = not (((e.duration_connection == 0) or (e.duration_connection__isnull)) and \
|
||
|
((e.duration_days_connection == 0) or (e.duration_days_connection__isnull)))
|
||
|
membership = not (((e.duration_membership == 0) or (e.duration_membership__isnull)) and \
|
||
|
((e.duration_days_membership == 0) or (e.duration_days_membership__isnull)))
|
||
|
if connection:
|
||
|
e.type_cotisation = 'Connection'
|
||
|
if membership:
|
||
|
e.type_cotisation = 'Adhesion'
|
||
|
if connection and membership:
|
||
|
e.type_cotisation = 'All'
|
||
|
if not (connection or membership):
|
||
|
e.type_cotisation = None
|
||
|
e.save()
|
||
|
db_alias = schema_editor.connection.alias
|
||
|
article = apps.get_model("cotisations", "Article")
|
||
|
vente = apps.get_model("cotisations", "Vente")
|
||
|
for a in article.objects.using(db_alias).all():
|
||
|
unsplit_duration(a)
|
||
|
for v in vente.objects.using(db_alias).all():
|
||
|
unsplit_duration(v)
|
||
|
|
||
|
|
||
|
operations = [
|
||
|
migrations.RunPython(split_dates, unsplit_dates),
|
||
|
migrations.RunPython(split_duration_articles_and_ventes, unsplit_duration_articles_and_ventes),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='article',
|
||
|
# name='duration',
|
||
|
# ),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='article',
|
||
|
# name='duration_days',
|
||
|
# ),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='article',
|
||
|
# name='type_cotisation',
|
||
|
# ),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='cotisation',
|
||
|
# name='date_end',
|
||
|
# ),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='cotisation',
|
||
|
# name='date_start',
|
||
|
# ),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='cotisation',
|
||
|
# name='type_cotisation',
|
||
|
# ),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='vente',
|
||
|
# name='duration',
|
||
|
# ),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='vente',
|
||
|
# name='duration_days',
|
||
|
# ),
|
||
|
# migrations.RemoveField(
|
||
|
# model_name='vente',
|
||
|
# name='type_cotisation',
|
||
|
# ),
|
||
|
]
|