Move book schema into a package and files: queries and mutations

This commit is contained in:
Pawel Kowalski 2018-09-04 18:14:08 +02:00
parent 12d8d2375c
commit e007482e46
4 changed files with 84 additions and 3 deletions

View File

View File

@ -0,0 +1,75 @@
import graphene
class MutateContentBlock(graphene.relay.ClientIDMutation):
class Input:
id = None
title = graphene.String()
type = graphene.String()
module_slug = graphene.String(required=True)
# text params
# learnings_text = graphene.String()
# impact_text = graphene.String()
# measurement_text = graphene.String()
# measures_text = graphene.String()
# time_frame_text = graphene.String()
# resources_skills_text = graphene.String()
# commitment_support_text = graphene.String()
# user_module_progress = graphene.Field(UserModuleProgressNode)
@classmethod
def mutate_and_get_payload(cls, *args, **kwargs):
# user_module_progress = get_object_or_404(
# UserModuleProgress,
# user=get_current_user(),
# module__slug=kwargs.pop('module_slug')
# )
#
# for k, v in kwargs.items():
# setattr(user_module_progress, k, v)
#
# user_module_progress.save()
return cls(user_module_progress=user_module_progress)
# class UpdateImage(relay.ClientIDMutation):
# class Input:
# image = graphene.Argument(ImageUpdateInput)
# id = graphene.String(required=True)
#
# errors = graphene.List(graphene.String)
# updated_image = graphene.Field(ImageNode)
# tags = graphene.List(TagNode)
#
# @classmethod
# def mutate_and_get_payload(cls, *args, **kwargs):
# try:
# image_instance = get_object(Image, kwargs['id'])
# if image_instance:
# image_data = kwargs.get('image')
# updated_image = update_create_instance(image_instance, image_data, exception=['id', 'tags'])
# tag_slugs = image_data.get('tag_slugs', '')
# if tag_slugs is not None:
# tag_slugs = [t.strip() for t in tag_slugs.split(',') if t.strip()]
# tags = list(Tag.objects.filter(slug__in=tag_slugs))
# tag_slugs = [t for t in tag_slugs if t not in [e.slug for e in tags]]
# updated_image.tags.set(*(tags + tag_slugs))
#
# return cls(updated_image=updated_image, tags=Tag.objects.all())
# except ValidationError as e:
# errors = get_errors(e)
# except Exception as e:
# errors = ['Error: {}'.format(e)]
# else:
# errors = ['image not found']
#
# return cls(updated_image=None, tags=None, errors=errors)
class BookMutations(object):
# start_module_progress = StartModuleProgress.Field()
# delete_module_progress = DeleteModuleProgress.Field()
define_action_plan = MutateContentBlock.Field()

View File

@ -3,7 +3,7 @@ from graphene import relay
from graphene_django import DjangoObjectType
from graphene_django.filter import DjangoFilterConnectionField
from .models import Book, Topic, Module, Chapter, ContentBlock
from ..models import Book, Topic, Module, Chapter, ContentBlock
class ContentBlockNodeType(DjangoObjectType):
@ -121,4 +121,3 @@ class BookQuery(object):
def resolve_modules(self, *args, **kwargs):
return Module.objects.filter(**kwargs).live()

View File

@ -4,12 +4,19 @@ import factory
from user.models import UserGroup
class_types = ['DA', 'KV', 'INF', 'EE']
class_suffix = ['A', 'B', 'C', 'D', 'E']
# TODO: refactor to use a trait synching the year with the infix year
# TODO: refactor to have non-overlapping user groups?
class UserGroupFactory(factory.django.DjangoModelFactory):
class Meta:
model = UserGroup
name = factory.Sequence(lambda n: 'Klasse {}{}'.format(n+1, random.choice(['a', 'b', 'c'])))
name = factory.Sequence(lambda n: '{}{}{}'.format(random.choice(class_types), '18', class_suffix[n % len(class_suffix)]))
year = factory.LazyAttribute(lambda x: random.choice([2017, 2018, 2019]))
is_deleted = False