Skip to content

Commit

Permalink
[FEATURE] Pouvoir créer un élément Expand dans le contenu d'un Module (
Browse files Browse the repository at this point in the history
  • Loading branch information
pix-service-auto-merge authored and HEYGUL committed Dec 24, 2024
2 parents 93b134e + 8f13553 commit f8b1d4e
Show file tree
Hide file tree
Showing 7 changed files with 155 additions and 0 deletions.
20 changes: 20 additions & 0 deletions api/src/devcomp/domain/models/element/Expand.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import { assertNotNullOrUndefined } from '../../../../shared/domain/models/asserts.js';
import { Element } from './Element.js';

class Expand extends Element {
/**
*
* @param{string} id
* @param{string} title
* @param{string} content
*/
constructor({ id, title, content } = {}) {
super({ id, type: 'expand' });
assertNotNullOrUndefined(title, 'The title is required for an Expand element');
assertNotNullOrUndefined(content, 'The content is required for an Expand element');
this.title = title;
this.content = content;
}
}

export { Expand };
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,13 @@
]
}
},
{"type": "element", "element": {
"id": "5c468891-6b50-41c6-bb30-8639b52c5bca",
"type": "expand",
"title": "Voici un indice pour répondre à la magnifique flashcard",
"content": "<p> Souvent, pour s’amuser, les hommes d’équipage\nPrennent des albatros, vastes oiseaux des mers,\nQui suivent, indolents compagnons de voyage,\nLe navire glissant sur les gouffres amers.\n\nÀ peine les ont-ils déposés sur les planches,\nQue ces rois de l’azur, maladroits et honteux,\nLaissent piteusement leurs grandes ailes blanches\nComme des avirons traîner à côté d’eux.\n\nCe voyageur ailé, comme il est gauche et veule !\nLui, naguère si beau, qu’il est comique et laid !\nL’un agace son bec avec un brûle-gueule,\nL’autre mime, en boitant, l’infirme qui volait !\n\nLe Poète est semblable au prince des nuées\nQui hante la tempête et se rit de l’archer ;\nExilé sur le sol au milieu des huées,\nSes ailes de géant l’empêchent de marcher. </p>"

}},
{
"type": "element",
"element": {
Expand Down
12 changes: 12 additions & 0 deletions api/src/devcomp/infrastructure/factories/module-factory.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import { ComponentStepper } from '../../domain/models/component/ComponentStepper
import { Step } from '../../domain/models/component/Step.js';
import { Download } from '../../domain/models/element/Download.js';
import { Embed } from '../../domain/models/element/Embed.js';
import { Expand } from '../../domain/models/element/Expand.js';
import { Card } from '../../domain/models/element/flashcards/Card.js';
import { Flashcards } from '../../domain/models/element/flashcards/Flashcards.js';
import { Image } from '../../domain/models/element/Image.js';
Expand Down Expand Up @@ -91,6 +92,8 @@ export class ModuleFactory {
return ModuleFactory.#buildDownload(element);
case 'embed':
return ModuleFactory.#buildEmbed(element);
case 'expand':
return ModuleFactory.#buildExpand(element);
case 'image':
return ModuleFactory.#buildImage(element);
case 'separator':
Expand All @@ -115,6 +118,7 @@ export class ModuleFactory {
return undefined;
}
}

static #buildDownload(element) {
return new Download({
id: element.id,
Expand All @@ -133,6 +137,14 @@ export class ModuleFactory {
});
}

static #buildExpand(element) {
return new Expand({
id: element.id,
title: element.title,
content: element.content,
});
}

static #buildImage(element) {
return new Image({
id: element.id,
Expand Down
54 changes: 54 additions & 0 deletions api/tests/devcomp/unit/domain/models/element/Expand_test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
import { Expand } from '../../../../../../src/devcomp/domain/models/element/Expand.js';
import { DomainError } from '../../../../../../src/shared/domain/errors.js';
import { catchErrSync, expect } from '../../../../../test-helper.js';

describe('Unit | Devcomp | Domain | Models | Element | Expand', function () {
describe('#constructor', function () {
it('should create a valid Expand object', function () {
// given
const attributes = {
id: '39f28a81-290c-440c-b8b9-1762112fbde3',
content: '<p> My Content </p>',
title: 'Expand title',
};

// when
const result = new Expand(attributes);

// then
expect(result.id).to.equal(attributes.id);
expect(result.content).to.equal(attributes.content);
expect(result.title).to.equal(attributes.title);
expect(result.type).to.equal('expand');
});
});

describe('An expand without a title', function () {
it('should throw an error', function () {
const attributes = {
id: '39f28a81-290c-440c-b8b9-1762112fbde3',
};
// when
const error = catchErrSync(() => new Expand(attributes))();

// then
expect(error).to.be.instanceOf(DomainError);
expect(error.message).to.equal('The title is required for an Expand element');
});
});

describe('An expand without a content', function () {
it('should throw an error', function () {
const attributes = {
id: '39f28a81-290c-440c-b8b9-1762112fbde3',
title: 'A title',
};
// when
const error = catchErrSync(() => new Expand(attributes))();

// then
expect(error).to.be.instanceOf(DomainError);
expect(error.message).to.equal('The content is required for an Expand element');
});
});
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import Joi from 'joi';

import { htmlSchema, uuidSchema } from '../utils.js';

const expandElementSchema = Joi.object({
id: uuidSchema,
type: Joi.string().valid('expand').required(),
title: Joi.string().required(),
content: htmlSchema.required(),
}).required();

export { expandElementSchema };
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import Joi from 'joi';

import { downloadElementSchema } from './element/download-schema.js';
import { embedElementSchema } from './element/embed-schema.js';
import { expandElementSchema } from './element/expand-schema.js';
import { flashcardsElementSchema } from './element/flashcards-schema.js';
import { imageElementSchema } from './element/image-schema.js';
import { qcmElementSchema } from './element/qcm-schema.js';
Expand Down Expand Up @@ -30,6 +31,7 @@ const elementSchema = Joi.alternatives().conditional('.type', {
switch: [
{ is: 'download', then: downloadElementSchema },
{ is: 'embed', then: embedElementSchema },
{ is: 'expand', then: expandElementSchema },
{ is: 'flashcards', then: flashcardsElementSchema },
{ is: 'image', then: imageElementSchema },
{ is: 'qcu', then: qcuElementSchema },
Expand All @@ -44,6 +46,7 @@ const elementSchema = Joi.alternatives().conditional('.type', {
const stepperElementSchema = Joi.alternatives().conditional('.type', {
switch: [
{ is: 'download', then: downloadElementSchema },
{ is: 'expand', then: expandElementSchema },
{ is: 'image', then: imageElementSchema },
{ is: 'qcu', then: qcuElementSchema },
{ is: 'qcm', then: qcmElementSchema },
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -877,6 +877,53 @@ describe('Unit | Devcomp | Infrastructure | Factories | Module ', function () {
const expectedFlashcards = moduleData.grains[0].components[0].element;
validateFlashcards(flashcards, expectedFlashcards);
});

it('should instantiate a Module with a ComponentElement which contains a Expand Element', function () {
// given
const givenData = {
id: '6282925d-4775-4bca-b513-4c3009ec5886',
slug: 'title',
title: 'title',
isBeta: true,
details: {
image: 'https://images.pix.fr/modulix/placeholder-details.svg',
description: 'Description',
duration: 5,
level: 'Débutant',
tabletSupport: 'comfortable',
objectives: ['Objective 1'],
},
grains: [
{
id: 'f312c33d-e7c9-4a69-9ba0-913957b8f7dd',
type: 'lesson',
title: 'title',
components: [
{
type: 'element',
element: {
id: '71de6394-ff88-4de3-8834-a40057a50ff4',
type: 'expand',
title: "Plus d'info sur la poésie",
content: '<p>La poésie c’est cool</p>',
},
},
],
},
],
};

// when
const module = ModuleFactory.build(givenData);

// then
const expand = module.grains[0].components[0].element;
const expectedExpand = givenData.grains[0].components[0].element;
expect(expand.id).to.equal(expectedExpand.id);
expect(expand.content).to.equal(expectedExpand.content);
expect(expand.title).to.equal(expectedExpand.title);
expect(expand.type).to.equal(expectedExpand.type);
});
});

describe('With ComponentStepper', function () {
Expand Down

0 comments on commit f8b1d4e

Please sign in to comment.