FIX: composer should be sending metaData ()

An extensibility point we support server side is setting meta_data
(topic / post custom fields) with the composer payload.

Previous to this change even though we had a lot of setup code we never
actually sent the payload.

This ensures that on create we send meta_data.
This commit is contained in:
Sam 2023-05-15 14:08:54 +10:00 committed by GitHub
parent 366c676156
commit e9efeea264
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 42 additions and 1 deletions
app/assets/javascripts/discourse
app/models
tests/unit/models

View File

@ -925,7 +925,6 @@ const Composer = RestModel.extend({
if (!this.canEditTopicFeaturedLink) {
this.set("featuredLink", null);
}
return this.editingPost ? this.editPost(opts) : this.createPost(opts);
}
});
@ -1065,6 +1064,7 @@ const Composer = RestModel.extend({
wiki: false,
typingTime: this.typingTime,
composerTime: this.composerTime,
metaData: this.metaData,
});
this.serialize(_create_serializer, createdPost);

View File

@ -9,6 +9,10 @@ import AppEvents from "discourse/services/app-events";
import { module, test } from "qunit";
import { getOwner } from "discourse-common/lib/get-owner";
import { setupTest } from "ember-qunit";
import pretender, {
parsePostData,
response,
} from "discourse/tests/helpers/create-pretender";
function createComposer(opts = {}) {
opts.user ??= currentUser();
@ -440,4 +444,41 @@ module("Unit | Model | composer", function (hooks) {
{ name: "foo@bar.com", type: "email" },
]);
});
test("can add meta_data", async function (assert) {
let saved = false;
pretender.post("/posts", function (request) {
const data = parsePostData(request.requestBody);
assert.equal(data.meta_data.some_custom_field, "some_value");
saved = true;
return response(200, {
success: true,
action: "create_post",
post: {
id: 12345,
topic_id: 280,
topic_slug: "internationalization-localization",
},
});
});
const composer = createComposer.call(this, {});
await composer.open({
action: CREATE_TOPIC,
title: "some topic title here",
categoryId: 1,
reply: "some reply here some reply here some reply here",
draftKey: "abcd",
draftSequence: 1,
});
assert.equal(composer.loading, false);
composer.metaData = { some_custom_field: "some_value" };
await composer.save({});
assert.equal(saved, true);
});
});