UX: Hide admin header for edit/new webhook (#30194)
In this PR, we added functionality to hide the admin header for edit/new actions - https://github.com/discourse/discourse/pull/30175 To make it work properly, we have to rename `show` to `edit` which is also a more accurate name.
This commit is contained in:
parent
203f93bcaf
commit
8bd55c35fb
|
@ -88,7 +88,7 @@ export default class AdminChatIncomingWebhooksList extends Component {
|
||||||
>
|
>
|
||||||
<div class="d-admin-row__controls-options">
|
<div class="d-admin-row__controls-options">
|
||||||
<LinkTo
|
<LinkTo
|
||||||
@route="adminPlugins.show.discourse-chat-incoming-webhooks.show"
|
@route="adminPlugins.show.discourse-chat-incoming-webhooks.edit"
|
||||||
@model={{webhook.id}}
|
@model={{webhook.id}}
|
||||||
class="btn btn-small admin-chat-incoming-webhooks-edit"
|
class="btn btn-small admin-chat-incoming-webhooks-edit"
|
||||||
>{{i18n "chat.incoming_webhooks.edit"}}</LinkTo>
|
>{{i18n "chat.incoming_webhooks.edit"}}</LinkTo>
|
||||||
|
|
|
@ -70,7 +70,7 @@ export default class ChatIncomingWebhookEditForm extends Component {
|
||||||
|
|
||||||
this.router
|
this.router
|
||||||
.transitionTo(
|
.transitionTo(
|
||||||
"adminPlugins.show.discourse-chat-incoming-webhooks.show",
|
"adminPlugins.show.discourse-chat-incoming-webhooks.edit",
|
||||||
webhook
|
webhook
|
||||||
)
|
)
|
||||||
.then(() => {
|
.then(() => {
|
||||||
|
|
|
@ -5,7 +5,7 @@ import { popupAjaxError } from "discourse/lib/ajax-error";
|
||||||
import DiscourseRoute from "discourse/routes/discourse";
|
import DiscourseRoute from "discourse/routes/discourse";
|
||||||
import ChatChannel from "discourse/plugins/chat/discourse/models/chat-channel";
|
import ChatChannel from "discourse/plugins/chat/discourse/models/chat-channel";
|
||||||
|
|
||||||
export default class DiscourseChatIncomingWebhooksShow extends DiscourseRoute {
|
export default class DiscourseChatIncomingWebhooksEdit extends DiscourseRoute {
|
||||||
@service currentUser;
|
@service currentUser;
|
||||||
|
|
||||||
async model(params) {
|
async model(params) {
|
||||||
|
@ -14,7 +14,9 @@ export default class DiscourseChatIncomingWebhooksShow extends DiscourseRoute {
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const model = await ajax(`/admin/plugins/chat/hooks/${params.id}.json`);
|
const model = await ajax(
|
||||||
|
`/admin/plugins/chat/hooks/${params.id}/edit.json`
|
||||||
|
);
|
||||||
|
|
||||||
model.webhook = EmberObject.create(model.webhook);
|
model.webhook = EmberObject.create(model.webhook);
|
||||||
model.webhook.chat_channel = ChatChannel.create(
|
model.webhook.chat_channel = ChatChannel.create(
|
|
@ -16,7 +16,7 @@ module Chat
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
def show
|
def edit
|
||||||
webhook =
|
webhook =
|
||||||
Chat::IncomingWebhook.includes(:chat_channel).find(params[:incoming_chat_webhook_id])
|
Chat::IncomingWebhook.includes(:chat_channel).find(params[:incoming_chat_webhook_id])
|
||||||
render_serialized(
|
render_serialized(
|
||||||
|
|
|
@ -7,7 +7,7 @@ export default {
|
||||||
{ path: "hooks" },
|
{ path: "hooks" },
|
||||||
function () {
|
function () {
|
||||||
this.route("new");
|
this.route("new");
|
||||||
this.route("show", { path: "/:id" });
|
this.route("edit", { path: "/:id/edit" });
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
|
|
@ -409,8 +409,8 @@ after_initialize do
|
||||||
:constraints => StaffConstraint.new
|
:constraints => StaffConstraint.new
|
||||||
get "/admin/plugins/chat/hooks/new" => "chat/admin/incoming_webhooks#new",
|
get "/admin/plugins/chat/hooks/new" => "chat/admin/incoming_webhooks#new",
|
||||||
:constraints => StaffConstraint.new
|
:constraints => StaffConstraint.new
|
||||||
get "/admin/plugins/chat/hooks/:incoming_chat_webhook_id" =>
|
get "/admin/plugins/chat/hooks/:incoming_chat_webhook_id/edit" =>
|
||||||
"chat/admin/incoming_webhooks#show",
|
"chat/admin/incoming_webhooks#edit",
|
||||||
:constraints => StaffConstraint.new
|
:constraints => StaffConstraint.new
|
||||||
delete "/admin/plugins/chat/hooks/:incoming_chat_webhook_id" =>
|
delete "/admin/plugins/chat/hooks/:incoming_chat_webhook_id" =>
|
||||||
"chat/admin/incoming_webhooks#destroy",
|
"chat/admin/incoming_webhooks#destroy",
|
||||||
|
|
|
@ -6,6 +6,7 @@ describe "Admin Chat Incoming Webhooks", type: :system do
|
||||||
|
|
||||||
let(:dialog) { PageObjects::Components::Dialog.new }
|
let(:dialog) { PageObjects::Components::Dialog.new }
|
||||||
let(:admin_incoming_webhooks_page) { PageObjects::Pages::AdminIncomingWebhooks.new }
|
let(:admin_incoming_webhooks_page) { PageObjects::Pages::AdminIncomingWebhooks.new }
|
||||||
|
let(:admin_header) { PageObjects::Components::AdminHeader.new }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
chat_system_bootstrap(current_user)
|
chat_system_bootstrap(current_user)
|
||||||
|
@ -14,7 +15,13 @@ describe "Admin Chat Incoming Webhooks", type: :system do
|
||||||
|
|
||||||
it "can create incoming webhooks" do
|
it "can create incoming webhooks" do
|
||||||
admin_incoming_webhooks_page.visit
|
admin_incoming_webhooks_page.visit
|
||||||
|
|
||||||
|
expect(admin_header).to be_visible
|
||||||
|
|
||||||
admin_incoming_webhooks_page.click_new
|
admin_incoming_webhooks_page.click_new
|
||||||
|
|
||||||
|
expect(admin_header).to be_hidden
|
||||||
|
|
||||||
admin_incoming_webhooks_page.form.field("name").fill_in("Test webhook")
|
admin_incoming_webhooks_page.form.field("name").fill_in("Test webhook")
|
||||||
admin_incoming_webhooks_page.form.field("description").fill_in("Some test content")
|
admin_incoming_webhooks_page.form.field("description").fill_in("Some test content")
|
||||||
admin_incoming_webhooks_page.form.field("username").fill_in("system")
|
admin_incoming_webhooks_page.form.field("username").fill_in("system")
|
||||||
|
|
Loading…
Reference in New Issue