Skip to content

Commit

Permalink
#2855 Add a parameter for formatContentModel to allow auto detection …
Browse files Browse the repository at this point in the history
…of new/removed entities (#2887)
  • Loading branch information
JiuqingSong authored Nov 22, 2024
1 parent 261055d commit 2a249dd
Show file tree
Hide file tree
Showing 3 changed files with 162 additions and 17 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -157,20 +157,25 @@ function handlePendingFormat(
}
}

function getChangedEntities(context: FormatContentModelContext, rawEvent?: Event): ChangedEntity[] {
return context.newEntities
.map(
(entity): ChangedEntity => ({
entity,
operation: 'newEntity',
rawEvent,
})
)
.concat(
context.deletedEntities.map(entry => ({
entity: entry.entity,
operation: entry.operation,
rawEvent,
}))
);
function getChangedEntities(
context: FormatContentModelContext,
rawEvent?: Event
): ChangedEntity[] | undefined {
return context.autoDetectChangedEntities
? undefined
: context.newEntities
.map(
(entity): ChangedEntity => ({
entity,
operation: 'newEntity',
rawEvent,
})
)
.concat(
context.deletedEntities.map(entry => ({
entity: entry.entity,
operation: entry.operation,
rawEvent,
}))
);
}
Original file line number Diff line number Diff line change
Expand Up @@ -1070,4 +1070,138 @@ describe('formatContentModel', () => {
expect(announce).toHaveBeenCalledWith(core, mockedData);
});
});

describe('Changed entities', () => {
it('Callback return true, changed entities are not specified', () => {
const callback = jasmine.createSpy('callback').and.returnValue(true);

formatContentModel(core, callback, { apiName });

expect(callback).toHaveBeenCalledWith(mockedModel, {
newEntities: [],
deletedEntities: [],
rawEvent: undefined,
newImages: [],
});
expect(createContentModel).toHaveBeenCalledTimes(1);
expect(addUndoSnapshot).toHaveBeenCalled();
expect(setContentModel).toHaveBeenCalled();
expect(triggerEvent).toHaveBeenCalledWith(
core,
{
eventType: 'contentChanged',
contentModel: mockedModel,
selection: mockedSelection,
source: 'Format',
data: undefined,
formatApiName: 'mockedApi',
changedEntities: [],
},
true
);
});

it('Callback return true, changed entities are specified', () => {
const wrapper1 = document.createElement('span');
const wrapper2 = document.createElement('div');
const callback = jasmine
.createSpy('callback')
.and.callFake((model: any, context: FormatContentModelContext) => {
context.newEntities.push({
segmentType: 'Entity',
blockType: 'Entity',
entityFormat: {
entityType: 'test',
},
format: {},
wrapper: wrapper1,
});
context.deletedEntities.push({
entity: {
segmentType: 'Entity',
blockType: 'Entity',
entityFormat: {
entityType: 'test',
},
format: {},
wrapper: wrapper2,
},
operation: 'overwrite',
});
return true;
});

formatContentModel(core, callback, { apiName });

expect(callback).toHaveBeenCalled();
expect(createContentModel).toHaveBeenCalledTimes(1);
expect(addUndoSnapshot).toHaveBeenCalled();
expect(setContentModel).toHaveBeenCalled();
expect(triggerEvent).toHaveBeenCalledWith(
core,
{
eventType: 'contentChanged',
contentModel: mockedModel,
selection: mockedSelection,
source: 'Format',
data: undefined,
formatApiName: 'mockedApi',
changedEntities: [
{
entity: {
segmentType: 'Entity',
blockType: 'Entity',
entityFormat: { entityType: 'test' },
format: {},
wrapper: wrapper1,
},
operation: 'newEntity',
rawEvent: undefined,
},
{
entity: {
segmentType: 'Entity',
blockType: 'Entity',
entityFormat: { entityType: 'test' },
format: {},
wrapper: wrapper2,
},
operation: 'overwrite',
rawEvent: undefined,
},
],
},
true
);
});

it('Callback return true, auto detect entity change', () => {
const callback = jasmine
.createSpy('callback')
.and.callFake((model: any, context: FormatContentModelContext) => {
context.autoDetectChangedEntities = true;
return true;
});

formatContentModel(core, callback, { apiName });

expect(callback).toHaveBeenCalled();
expect(createContentModel).toHaveBeenCalledTimes(1);
expect(addUndoSnapshot).toHaveBeenCalled();
expect(setContentModel).toHaveBeenCalled();
expect(triggerEvent).toHaveBeenCalledWith(
core,
{
eventType: 'contentChanged',
contentModel: mockedModel,
selection: mockedSelection,
source: 'Format',
data: undefined,
formatApiName: 'mockedApi',
changedEntities: undefined,
},
true
);
});
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -47,12 +47,13 @@ export interface DeletedEntity {
*/
export interface FormatContentModelContext {
/**
* New entities added during the format process
* New entities added during the format process. This value is only respected when autoDetectChangedEntities is not set to true
*/
readonly newEntities: ContentModelEntity[];

/**
* Entities got deleted during formatting. Need to be set by the formatter function
* This value is only respected when autoDetectChangedEntities is not set to true
*/
readonly deletedEntities: DeletedEntity[];

Expand Down Expand Up @@ -113,4 +114,9 @@ export interface FormatContentModelContext {
* @optional Set this value to tell AnnouncePlugin to announce the given information
*/
announceData?: AnnounceData | null;

/**
* @optional When set to true, EntityPlugin will detect any entity changes during this process, newEntities and deletedEntities will be ignored
*/
autoDetectChangedEntities?: boolean;
}

0 comments on commit 2a249dd

Please sign in to comment.