From 345dd400bbe2f41c45b08dc06e3199c900361fff Mon Sep 17 00:00:00 2001 From: Chris Date: Mon, 24 Jul 2017 11:55:37 -0700 Subject: PLT-6706: add /code command (#6936) * add /code command * return an error for empty /code message --- app/command_code.go | 44 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 app/command_code.go (limited to 'app/command_code.go') diff --git a/app/command_code.go b/app/command_code.go new file mode 100644 index 000000000..ece2a70d2 --- /dev/null +++ b/app/command_code.go @@ -0,0 +1,44 @@ +// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +package app + +import ( + "strings" + + "github.com/mattermost/platform/model" + goi18n "github.com/nicksnyder/go-i18n/i18n" +) + +type CodeProvider struct { +} + +const ( + CMD_CODE = "code" +) + +func init() { + RegisterCommandProvider(&CodeProvider{}) +} + +func (me *CodeProvider) GetTrigger() string { + return CMD_CODE +} + +func (me *CodeProvider) GetCommand(T goi18n.TranslateFunc) *model.Command { + return &model.Command{ + Trigger: CMD_CODE, + AutoComplete: true, + AutoCompleteDesc: T("api.command_code.desc"), + AutoCompleteHint: T("api.command_code.hint"), + DisplayName: T("api.command_code.name"), + } +} + +func (me *CodeProvider) DoCommand(args *model.CommandArgs, message string) *model.CommandResponse { + if len(message) == 0 { + return &model.CommandResponse{Text: args.T("api.command_code.message.app_error"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL} + } + rmsg := " " + strings.Join(strings.Split(message, "\n"), "\n ") + return &model.CommandResponse{ResponseType: model.COMMAND_RESPONSE_TYPE_IN_CHANNEL, Text: rmsg} +} -- cgit v1.2.3-1-g7c22