diff options
Diffstat (limited to 'api')
-rw-r--r-- | api/command_expand_collapse.go | 77 | ||||
-rw-r--r-- | api/command_expand_collapse_test.go | 47 |
2 files changed, 124 insertions, 0 deletions
diff --git a/api/command_expand_collapse.go b/api/command_expand_collapse.go new file mode 100644 index 000000000..6015e8bc1 --- /dev/null +++ b/api/command_expand_collapse.go @@ -0,0 +1,77 @@ +// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +package api + +import ( + "github.com/mattermost/platform/model" +) + +type ExpandProvider struct { +} + +type CollapseProvider struct { +} + +const ( + CMD_EXPAND = "expand" + CMD_COLLAPSE = "collapse" +) + +func init() { + RegisterCommandProvider(&ExpandProvider{}) + RegisterCommandProvider(&CollapseProvider{}) +} + +func (me *ExpandProvider) GetTrigger() string { + return CMD_EXPAND +} + +func (me *CollapseProvider) GetTrigger() string { + return CMD_COLLAPSE +} + +func (me *ExpandProvider) GetCommand(c *Context) *model.Command { + return &model.Command{ + Trigger: CMD_EXPAND, + AutoComplete: true, + AutoCompleteDesc: c.T("api.command_expand.desc"), + DisplayName: c.T("api.command_expand.name"), + } +} + +func (me *CollapseProvider) GetCommand(c *Context) *model.Command { + return &model.Command{ + Trigger: CMD_COLLAPSE, + AutoComplete: true, + AutoCompleteDesc: c.T("api.command_collapse.desc"), + DisplayName: c.T("api.command_collapse.name"), + } +} + +func (me *ExpandProvider) DoCommand(c *Context, channelId string, message string) *model.CommandResponse { + return setCollapsePreference(c, "false") +} + +func (me *CollapseProvider) DoCommand(c *Context, channelId string, message string) *model.CommandResponse { + return setCollapsePreference(c, "true") +} + +func setCollapsePreference(c *Context, value string) *model.CommandResponse { + pref := model.Preference{ + UserId: c.Session.UserId, + Category: model.PREFERENCE_CATEGORY_DISPLAY_SETTINGS, + Name: model.PREFERENCE_NAME_COLLAPSE_SETTING, + Value: value, + } + + if result := <-Srv.Store.Preference().Save(&model.Preferences{pref}); result.Err != nil { + return &model.CommandResponse{Text: c.T("api.command_expand_collapse.fail.app_error"), ResponseType: model.COMMAND_RESPONSE_TYPE_EPHEMERAL} + } + + socketMessage := model.NewMessage("", "", c.Session.UserId, model.ACTION_PREFERENCE_CHANGED) + socketMessage.Add("preference", pref.ToJson()) + go Publish(socketMessage) + + return &model.CommandResponse{} +} diff --git a/api/command_expand_collapse_test.go b/api/command_expand_collapse_test.go new file mode 100644 index 000000000..2303b2fed --- /dev/null +++ b/api/command_expand_collapse_test.go @@ -0,0 +1,47 @@ +// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved. +// See License.txt for license information. + +package api + +import ( + "testing" + "time" + + "github.com/mattermost/platform/model" +) + +func TestExpandCommand(t *testing.T) { + th := Setup().InitBasic() + Client := th.BasicClient + channel := th.BasicChannel + + r1 := Client.Must(Client.Command(channel.Id, "/expand", false)).Data.(*model.CommandResponse) + if r1 == nil { + t.Fatal("Command failed to execute") + } + + time.Sleep(100 * time.Millisecond) + + p1 := Client.Must(Client.GetPreference(model.PREFERENCE_CATEGORY_DISPLAY_SETTINGS, model.PREFERENCE_NAME_COLLAPSE_SETTING)).Data.(*model.Preference) + if p1.Value != "false" { + t.Fatal("preference not updated correctly") + } +} + +func TestCollapseCommand(t *testing.T) { + th := Setup().InitBasic() + Client := th.BasicClient + channel := th.BasicChannel + + r1 := Client.Must(Client.Command(channel.Id, "/collapse", false)).Data.(*model.CommandResponse) + if r1 == nil { + t.Fatal("Command failed to execute") + } + + time.Sleep(100 * time.Millisecond) + + p1 := Client.Must(Client.GetPreference(model.PREFERENCE_CATEGORY_DISPLAY_SETTINGS, model.PREFERENCE_NAME_COLLAPSE_SETTING)).Data.(*model.Preference) + if p1.Value != "true" { + t.Fatal("preference not updated correctly") + } +} |