From e1c1d94336bd800e329280cce1620b2224f69fe7 Mon Sep 17 00:00:00 2001 From: filip mertens Date: Mon, 29 Apr 2024 11:19:16 +0200 Subject: [PATCH] change upstream object --- apps/remix-ide/src/app/files/dgitProvider.ts | 2 +- apps/remix-ide/src/app/files/fileManager.ts | 2 +- apps/remix-ide/src/app/plugins/git.tsx | 34 ++++++++-------- .../buttons/sourcecontrolbuttons.tsx | 2 +- .../src/components/panels/commands/fetch.tsx | 6 +-- .../components/panels/commands/pushpull.tsx | 21 +++++----- .../git/src/components/panels/commits.tsx | 2 +- libs/remix-ui/git/src/lib/gitactions.ts | 40 +++++++++---------- libs/remix-ui/git/src/state/context.tsx | 2 +- libs/remix-ui/git/src/state/gitpayload.ts | 2 +- libs/remix-ui/git/src/state/gitreducer.tsx | 4 +- libs/remix-ui/git/src/types/index.ts | 6 +-- 12 files changed, 63 insertions(+), 60 deletions(-) diff --git a/apps/remix-ide/src/app/files/dgitProvider.ts b/apps/remix-ide/src/app/files/dgitProvider.ts index 327990a6ee..26631da404 100644 --- a/apps/remix-ide/src/app/files/dgitProvider.ts +++ b/apps/remix-ide/src/app/files/dgitProvider.ts @@ -1105,7 +1105,7 @@ class DGitProvider extends Plugin { const accessToken = input.token; - let page = input.page || 1 + const page = input.page || 1 const perPage = input.per_page || 10 const baseURL = 'https://api.github.com/user/repos' diff --git a/apps/remix-ide/src/app/files/fileManager.ts b/apps/remix-ide/src/app/files/fileManager.ts index cea11d79d6..5d974e6d5d 100644 --- a/apps/remix-ide/src/app/files/fileManager.ts +++ b/apps/remix-ide/src/app/files/fileManager.ts @@ -723,7 +723,7 @@ class FileManager extends Plugin { async closeDiff(change: commitChange) { if(!change.readonly){ - let file = this.normalize(change.path) + const file = this.normalize(change.path) delete this.openedFiles[file] if (!Object.keys(this.openedFiles).length) { this._deps.config.set('currentFile', '') diff --git a/apps/remix-ide/src/app/plugins/git.tsx b/apps/remix-ide/src/app/plugins/git.tsx index b2e33bddf1..9c7644abaa 100644 --- a/apps/remix-ide/src/app/plugins/git.tsx +++ b/apps/remix-ide/src/app/plugins/git.tsx @@ -4,30 +4,30 @@ import React from 'react' // eslint-disable-line import { gitState, GitUI } from '@remix-ui/git'; const profile = { - name: 'dgit', - desciption: 'Git plugin for Remix', - methods: ['pull', 'track', 'diff', 'clone', 'open'], - events: [''], - version: '0.0.1', - location: 'sidePanel', - icon: "" + name: 'dgit', + desciption: 'Git plugin for Remix', + methods: ['pull', 'track', 'diff', 'clone', 'open'], + events: [''], + version: '0.0.1', + location: 'sidePanel', + icon: "" } export class GitPlugin extends ViewPlugin { - constructor() { + constructor() { - super(profile) - } + super(profile) + } - onDeactivation(): void { - this.call('fileDecorator', 'clearFileDecorators') - this.call('manager', 'activatePlugin', 'dGitProvider') - } + onDeactivation(): void { + this.call('fileDecorator', 'clearFileDecorators') + this.call('manager', 'activatePlugin', 'dGitProvider') + } - render() { - return
- } + render() { + return
+ } } diff --git a/libs/remix-ui/git/src/components/buttons/sourcecontrolbuttons.tsx b/libs/remix-ui/git/src/components/buttons/sourcecontrolbuttons.tsx index cc2b180d35..9dacb4beb6 100644 --- a/libs/remix-ui/git/src/components/buttons/sourcecontrolbuttons.tsx +++ b/libs/remix-ui/git/src/components/buttons/sourcecontrolbuttons.tsx @@ -87,7 +87,7 @@ export const SourceControlButtons = (props: SourceControlButtonsProps) => { } const buttonsDisabled = () => { - return context.upstream === '' || context.remotes.length === 0 + return (!context.upstream) || context.remotes.length === 0 } diff --git a/libs/remix-ui/git/src/components/panels/commands/fetch.tsx b/libs/remix-ui/git/src/components/panels/commands/fetch.tsx index 94ccae59b2..ff29b69353 100644 --- a/libs/remix-ui/git/src/components/panels/commands/fetch.tsx +++ b/libs/remix-ui/git/src/components/panels/commands/fetch.tsx @@ -9,13 +9,13 @@ export const Fetch = () => { const context = React.useContext(gitPluginContext) const fetchIsDisabled = () => { - return context.upstream === '' || context.remotes.length === 0 + return (!context.upstream) || context.remotes.length === 0 } return ( <>
- actions.fetch()} className="btn btn-primary mr-1">Fetch {context.upstream} - actions.fetch(null, null, context.currentBranch.name, null, true )} className="btn btn-primary">Fetch {context.currentBranch.name} + actions.fetch()} className="btn btn-primary mr-1 w-50"><>Fetch {context.upstream} + actions.fetch(null, null, context.currentBranch.name, null, true )} className="btn btn-primary w-50 long-and-truncated">Fetch {context.currentBranch.name}
) } \ No newline at end of file diff --git a/libs/remix-ui/git/src/components/panels/commands/pushpull.tsx b/libs/remix-ui/git/src/components/panels/commands/pushpull.tsx index 6cecbb7e58..3ed97064fd 100644 --- a/libs/remix-ui/git/src/components/panels/commands/pushpull.tsx +++ b/libs/remix-ui/git/src/components/panels/commands/pushpull.tsx @@ -2,9 +2,9 @@ import React, { useEffect, useState } from "react"; import { gitActionsContext } from "../../../state/context"; import { gitPluginContext } from "../../gitui"; import { selectStyles, selectTheme } from "../../../types/styles"; -import Select, { Options, OptionsOrGroups } from 'react-select' -import { setUpstream } from "../../../state/gitpayload"; +import Select from 'react-select' import GitUIButton from "../../buttons/gituibutton"; +import { remote } from "../../../types"; export const PushPull = () => { const context = React.useContext(gitPluginContext) @@ -19,8 +19,8 @@ export const PushPull = () => { useEffect(() => { setRemoteBranch(context.currentBranch.name) setLocalBranch(context.currentBranch.name) - if ((!context.upstream || context.upstream === '') && context.currentBranch && context.currentBranch.remote && context.currentBranch.remote.remote) { - actions.setUpstreamRemote(context.currentBranch.remote.remote) + if ((!context.upstream) && context.currentBranch && context.currentBranch.remote && context.currentBranch.remote.remote) { + actions.setUpstreamRemote(context.currentBranch.remote) } }, [context.currentBranch]) @@ -35,9 +35,12 @@ export const PushPull = () => { setLocalBranch(value) } - const onRemoteChange = (value: any) => { + const onRemoteChange = (value: string) => { console.log('onRemoteChange', value, context) - actions.setUpstreamRemote(value) + const remote: remote = context.remotes.find(r => r.remote === value) + if(remote) { + actions.setUpstreamRemote(remote) + } } useEffect(() => { @@ -52,11 +55,11 @@ export const PushPull = () => { const push = async () => { console.log('PUSH', context.upstream, localBranch, remoteBranch, force) - actions.push(context.upstream, localBranch, remoteBranch, force) + actions.push(context.upstream.remote, localBranch, remoteBranch, force) } const pull = async () => { - actions.pull(context.upstream, localBranch, remoteBranch) + actions.pull(context.upstream.remote, localBranch, remoteBranch) } @@ -94,7 +97,7 @@ export const PushPull = () => { const pushPullIsDisabled = () => { - return localBranch === '' || remoteBranch === '' || context.upstream === '' || context.remotes.length === 0 + return localBranch === '' || remoteBranch === '' || !context.upstream || context.remotes.length === 0 } diff --git a/libs/remix-ui/git/src/components/panels/commits.tsx b/libs/remix-ui/git/src/components/panels/commits.tsx index 1a79cc53c7..6c9ead27c7 100644 --- a/libs/remix-ui/git/src/components/panels/commits.tsx +++ b/libs/remix-ui/git/src/components/panels/commits.tsx @@ -35,7 +35,7 @@ export const Commits = () => { } const fetchIsDisabled = () => { - return context.upstream === '' || context.remotes.length === 0 + return (!context.upstream)|| context.remotes.length === 0 } return ( diff --git a/libs/remix-ui/git/src/lib/gitactions.ts b/libs/remix-ui/git/src/lib/gitactions.ts index fe1b9d4639..7043a2b0e4 100644 --- a/libs/remix-ui/git/src/lib/gitactions.ts +++ b/libs/remix-ui/git/src/lib/gitactions.ts @@ -93,7 +93,7 @@ export const getRemotes = async () => { dispatch(setRemotes(remotes)); } -export const setUpstreamRemote = async (remote: string) => { +export const setUpstreamRemote = async (remote: remote) => { dispatch(setUpstream(remote)); } @@ -842,6 +842,24 @@ export const fetchBranch = async (branch: branch, page: number) => { //dispatch(setRemoteBranchCommits({ branch, commits: mergeCommits })) } +export const getBranchDifferences = async (branch: branch, remote: remote) => { + try { + const branchDifference: branchDifference = await plugin.call('dGitProvider', 'compareBranches', { + branch, + remote + }) + + dispatch(setBranchDifferences( + { + branch, + remote, + branchDifference: branchDifference + })) + } catch (e) { + + } +} + export const getBranchCommits = async (branch: branch, page: number) => { dispatch(setLoading(true)) await disableCallBacks() @@ -851,25 +869,7 @@ export const getBranchCommits = async (branch: branch, page: number) => { const commits: ReadCommitResult[] = await plugin.call('dGitProvider', 'log', { ref: branch.name, }) - try { - const branchDifference: branchDifference = await plugin.call('dGitProvider', 'compareBranches', { - branch, - remote: { - remote: 'origin', - url: '' - } - }) - console.log(commits, branchDifference) - dispatch(setBranchDifferences( - { - branch, - remote: - { remote: 'origin', url: '' }, - branchDifference: branchDifference - })) - } catch (e) { - - } + console.log(commits) dispatch(setLocalBranchCommits({ branch, commits })) } else { await fetchBranch(branch, page) diff --git a/libs/remix-ui/git/src/state/context.tsx b/libs/remix-ui/git/src/state/context.tsx index 6730ef657c..ac06e7e334 100644 --- a/libs/remix-ui/git/src/state/context.tsx +++ b/libs/remix-ui/git/src/state/context.tsx @@ -22,7 +22,7 @@ export interface gitActions { getGitHubUser(): Promise diff(commitChange: commitChange): Promise resolveRef(ref: string): Promise - setUpstreamRemote(upstream: string): Promise + setUpstreamRemote(upstream: remote): Promise getBranches: () => Promise getRemotes: () => Promise setDefaultRemote: (remote: remote) => Promise diff --git a/libs/remix-ui/git/src/state/gitpayload.ts b/libs/remix-ui/git/src/state/gitpayload.ts index 6c3897107d..700cf62cd7 100644 --- a/libs/remix-ui/git/src/state/gitpayload.ts +++ b/libs/remix-ui/git/src/state/gitpayload.ts @@ -115,7 +115,7 @@ export const setRemotes = (remotes: remote[]) => { } } -export const setUpstream = (upstream: string) => { +export const setUpstream = (upstream: remote) => { return { type: 'SET_UPSTREAM', payload: upstream diff --git a/libs/remix-ui/git/src/state/gitreducer.tsx b/libs/remix-ui/git/src/state/gitreducer.tsx index ac37bfe4b2..0e9f26bfeb 100644 --- a/libs/remix-ui/git/src/state/gitreducer.tsx +++ b/libs/remix-ui/git/src/state/gitreducer.tsx @@ -1,6 +1,6 @@ import { ReadCommitResult } from "isomorphic-git" import { allChangedButNotStagedFiles, getFilesByStatus, getFilesWithNotModifiedStatus } from "../lib/fileHelpers" -import { branch, commitChange, defaultGitState, fileStatusResult, gitState, setRemoteBranchCommitsAction, setLocalBranchCommitsAction, setBranchDifferencesAction, setDefaultRemoteAction, setRemotesAction } from "../types" +import { branch, commitChange, defaultGitState, fileStatusResult, gitState, setRemoteBranchCommitsAction, setLocalBranchCommitsAction, setBranchDifferencesAction, setDefaultRemoteAction, setRemotesAction, setUpstreamAction } from "../types" interface Action { type: string @@ -105,7 +105,7 @@ export const gitReducer = (state: gitState = defaultGitState, action: Action): g case 'SET_UPSTREAM': return { ...state, - upstream: action.payload + upstream: (action as setUpstreamAction).payload } case 'SET_COMMIT_CHANGES': diff --git a/libs/remix-ui/git/src/types/index.ts b/libs/remix-ui/git/src/types/index.ts index 8b6d8dbb1c..99f46abb0d 100644 --- a/libs/remix-ui/git/src/types/index.ts +++ b/libs/remix-ui/git/src/types/index.ts @@ -30,7 +30,7 @@ export type gitState = { syncStatus: syncStatus, localCommitCount: number remoteCommitCount: number - upstream: string + upstream: remote gitHubUser: GitHubUser rateLimit: RateLimit gitHubScopes: string[] @@ -143,7 +143,7 @@ export const defaultGitState: gitState = { syncStatus: syncStatus.none, localCommitCount: 0, remoteCommitCount: 0, - upstream: "", + upstream: null, gitHubUser: {} as GitHubUser, rateLimit: {} as RateLimit, gitHubScopes: [], @@ -231,7 +231,7 @@ export interface setRemotesAction { export interface setUpstreamAction { type: string, - payload: string + payload: remote } export interface setRemoteBranchCommitsAction {