File size: 3,111 Bytes
246d201
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import posthog from "posthog-js";
import React from "react";
import { useSelector } from "react-redux";
import { SuggestionItem } from "#/components/features/suggestions/suggestion-item";
import { useAuth } from "#/context/auth-context";
import { DownloadModal } from "#/components/shared/download-modal";
import type { RootState } from "#/store";

interface ActionSuggestionsProps {
  onSuggestionsClick: (value: string) => void;
}

export function ActionSuggestions({

  onSuggestionsClick,

}: ActionSuggestionsProps) {
  const { gitHubToken } = useAuth();
  const { selectedRepository } = useSelector(
    (state: RootState) => state.initialQuery,
  );

  const [isDownloading, setIsDownloading] = React.useState(false);
  const [hasPullRequest, setHasPullRequest] = React.useState(false);

  const handleDownloadClose = () => {
    setIsDownloading(false);
  };

  return (
    <div className="flex flex-col gap-2 mb-2">

      <DownloadModal

        initialPath=""

        onClose={handleDownloadClose}

        isOpen={isDownloading}

      />

      {gitHubToken && selectedRepository ? (

        <div className="flex flex-row gap-2 justify-center w-full">

          {!hasPullRequest ? (

            <>

              <SuggestionItem

                suggestion={{

                  label: "Push to Branch",

                  value:

                    "Please push the changes to a remote branch on GitHub, but do NOT create a pull request.",

                }}

                onClick={(value) => {

                  posthog.capture("push_to_branch_button_clicked");

                  onSuggestionsClick(value);

                }}

              />

              <SuggestionItem

                suggestion={{

                  label: "Push & Create PR",

                  value:

                    "Please push the changes to GitHub and open a pull request.",

                }}

                onClick={(value) => {

                  posthog.capture("create_pr_button_clicked");

                  onSuggestionsClick(value);

                  setHasPullRequest(true);

                }}

              />

            </>

          ) : (

            <SuggestionItem

              suggestion={{

                label: "Push changes to PR",

                value:

                  "Please push the latest changes to the existing pull request.",

              }}

              onClick={(value) => {

                posthog.capture("push_to_pr_button_clicked");

                onSuggestionsClick(value);

              }}

            />

          )}

        </div>
      ) : (
        <SuggestionItem

          suggestion={{

            label: !isDownloading

              ? "Download files"

              : "Downloading, please wait...",

            value: "Download files",

          }}

          onClick={() => {

            posthog.capture("download_workspace_button_clicked");

            if (!isDownloading) {

              setIsDownloading(true);

            }

          }}

        />
      )}
    </div>
  );
}