From faa52b3931115659328baa24c5770ce8f3da34f2 Mon Sep 17 00:00:00 2001 From: Henit Chobisa Date: Sat, 1 Apr 2023 18:01:51 +0000 Subject: [PATCH 1/3] feat: Updated Modal View to Contextual Bar View --- .../UserIssuesContextualBar.ts} | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) rename github/{modals/UserIssuesModal.ts => ContextualBars/UserIssuesContextualBar.ts} (97%) diff --git a/github/modals/UserIssuesModal.ts b/github/ContextualBars/UserIssuesContextualBar.ts similarity index 97% rename from github/modals/UserIssuesModal.ts rename to github/ContextualBars/UserIssuesContextualBar.ts index 435688e..6e66c74 100644 --- a/github/modals/UserIssuesModal.ts +++ b/github/ContextualBars/UserIssuesContextualBar.ts @@ -11,7 +11,7 @@ import { TextObjectType, UIKitInteractionContext, } from "@rocket.chat/apps-engine/definition/uikit"; -import { IUIKitModalViewParam } from "@rocket.chat/apps-engine/definition/uikit/UIKitInteractionResponder"; +import { IUIKitContextualBarViewParam, IUIKitModalViewParam } from "@rocket.chat/apps-engine/definition/uikit/UIKitInteractionResponder"; import { ModalsEnum } from "../enum/Modals"; import { OcticonIcons } from "../enum/OcticonIcons"; import { getBasicUserInfo, getUserAssignedIssues } from "../helpers/githubSDK"; @@ -20,7 +20,7 @@ import { storeInteractionRoomData, } from "../persistance/roomInteraction"; -export async function userIssuesModal({ +export async function userIssuesContextualBar({ filter, access_token, modify, @@ -42,7 +42,8 @@ export async function userIssuesModal({ http: IHttp; slashcommandcontext?: SlashCommandContext; uikitcontext?: UIKitInteractionContext; -}): Promise { +}): Promise { + const viewId = ModalsEnum.USER_ISSUE_VIEW; const block = modify.getCreator().getBlockBuilder(); const room = From c567a8985354816d4d0eb1b276c6546d905a9d5c Mon Sep 17 00:00:00 2001 From: Henit Chobisa Date: Sat, 1 Apr 2023 18:02:18 +0000 Subject: [PATCH 2/3] feat: Updated Contextual Bar Actions --- github/enum/Modals.ts | 2 +- github/handlers/ExecuteBlockActionHandler.ts | 16 +++++++--------- github/modals/UserProfileModal.ts | 4 ++-- 3 files changed, 10 insertions(+), 12 deletions(-) diff --git a/github/enum/Modals.ts b/github/enum/Modals.ts index d4f102e..b126bb7 100644 --- a/github/enum/Modals.ts +++ b/github/enum/Modals.ts @@ -17,7 +17,7 @@ export enum ModalsEnum { MENTIONED_ISSUE_FILTER = 'mentioned', SWITCH_ISSUE_FILTER = 'switch-issue-filter', USER_ISSUE_VIEW = 'user-issue-view', - TRIGGER_ISSUES_MODAL = 'trigger-issue-modal', + TRIGGER_ISSUES_CONTEXTUAL_BAR = 'trigger-issue-modal', TRIGGER_REPOS_MODAL = 'trigger-repos-modal', TRIGGER_ACTIVITY_MODAL = 'trigger-activity-modal', TRIGGER_NOTIFICATIONS_MODAL = 'trigger-notifications-modal', diff --git a/github/handlers/ExecuteBlockActionHandler.ts b/github/handlers/ExecuteBlockActionHandler.ts index 066a4b4..9d89ad7 100644 --- a/github/handlers/ExecuteBlockActionHandler.ts +++ b/github/handlers/ExecuteBlockActionHandler.ts @@ -1,11 +1,9 @@ import { IHttp, - ILogger, IModify, IPersistence, IRead, } from "@rocket.chat/apps-engine/definition/accessors"; -import { IApp } from "@rocket.chat/apps-engine/definition/IApp"; import { IRoom } from "@rocket.chat/apps-engine/definition/rooms"; import { basicQueryMessage } from "../helpers/basicQueryMessage"; import { ModalsEnum } from "../enum/Modals"; @@ -43,7 +41,7 @@ import { GithubRepoIssuesStorage } from "../persistance/githubIssues"; import { IGitHubIssueData } from "../definitions/githubIssueData"; import { shareProfileModal } from "../modals/profileShareModal"; import { RocketChatAssociationModel, RocketChatAssociationRecord } from "@rocket.chat/apps-engine/definition/metadata"; -import { userIssuesModal } from "../modals/UserIssuesModal"; +import { userIssuesContextualBar } from "../ContextualBars/UserIssuesContextualBar"; import { IssueDisplayModal } from "../modals/IssueDisplayModal"; import { IGitHubIssue } from "../definitions/githubIssue"; import { BodyMarkdownRenderer } from "../processors/bodyMarkdowmRenderer"; @@ -179,7 +177,7 @@ export class ExecuteBlockActionHandler { uikitcontext : context }) - return context.getInteractionResponder().updateModalViewResponse(issueDisplayModal); + return context.getInteractionResponder().openContextualBarViewResponse(issueDisplayModal); } case ModalsEnum.SWITCH_ISSUE_SORT : case ModalsEnum.SWITCH_ISSUE_STATE : @@ -236,7 +234,7 @@ export class ExecuteBlockActionHandler { } let access_token = await getAccessTokenForUser(this.read, user, this.app.oauth2Config) as IAuthData; - const issueModal = await userIssuesModal({ + const issuesContextualBar = await userIssuesContextualBar({ access_token : access_token.token, filter : filter, modify : this.modify, @@ -247,9 +245,9 @@ export class ExecuteBlockActionHandler { await this.persistence.updateByAssociation(record, filter); - return context.getInteractionResponder().updateModalViewResponse(issueModal); + return context.getInteractionResponder().updateContextualBarViewResponse(issuesContextualBar); } - case ModalsEnum.TRIGGER_ISSUES_MODAL : { + case ModalsEnum.TRIGGER_ISSUES_CONTEXTUAL_BAR : { const {user} = context.getInteractionData(); @@ -261,7 +259,7 @@ export class ExecuteBlockActionHandler { sort : ModalsEnum.ISSUE_SORT_CREATED } - const issuesModal = await userIssuesModal({ + const issuesContextualBar = await userIssuesContextualBar({ filter : filter, access_token : access_token.token, modify: this.modify, @@ -271,7 +269,7 @@ export class ExecuteBlockActionHandler { uikitcontext : context }); - return context.getInteractionResponder().openModalViewResponse(issuesModal); + return context.getInteractionResponder().openContextualBarViewResponse(issuesContextualBar); } case ModalsEnum.TRIGGER_REPOS_MODAL : { break; diff --git a/github/modals/UserProfileModal.ts b/github/modals/UserProfileModal.ts index 864c992..b43dd42 100644 --- a/github/modals/UserProfileModal.ts +++ b/github/modals/UserProfileModal.ts @@ -91,7 +91,7 @@ export async function userProfileModal({ }), block.newButtonElement( { - actionId: ModalsEnum.TRIGGER_ISSUES_MODAL, + actionId: ModalsEnum.TRIGGER_ISSUES_CONTEXTUAL_BAR, value: "Trigger Issues Modal", text: { type: TextObjectType.PLAINTEXT, @@ -110,7 +110,7 @@ export async function userProfileModal({ type: TextObjectType.PLAINTEXT, text: userInfo.name }, - blocks: block.getBlocks() + blocks: block.getBlocks(), } } From 1a556ff24c252e8a87dd91a1ffd8d05c668563f2 Mon Sep 17 00:00:00 2001 From: Henit Chobisa Date: Sat, 1 Apr 2023 18:02:37 +0000 Subject: [PATCH 3/3] chore: Updated UIKit Package --- github/package.json | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/github/package.json b/github/package.json index d70652c..d3da1ef 100644 --- a/github/package.json +++ b/github/package.json @@ -3,6 +3,7 @@ "@rocket.chat/apps-engine": "^1.36.0", "@types/node": "14.14.6", "tslint": "^5.10.0", - "typescript": "^4.0.5" + "typescript": "^4.0.5", + "@rocket.chat/ui-kit": "^0.31.22" } -} \ No newline at end of file +}