Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
46 changes: 0 additions & 46 deletions cmd/add.go

This file was deleted.

73 changes: 0 additions & 73 deletions cmd/bareinit.go

This file was deleted.

47 changes: 0 additions & 47 deletions cmd/include.go

This file was deleted.

54 changes: 0 additions & 54 deletions cmd/touch.go

This file was deleted.

55 changes: 37 additions & 18 deletions cmd/use.go
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
package cmd

import (
"bare/styles"
"bare/utils/git"
"bare/utils/osutil"
"fmt"
"os"
"path/filepath"
"bare/utils/parser"
"bare/utils/ui"

"github.com/spf13/cobra"
)
Expand All @@ -23,22 +22,42 @@ var useCmd = &cobra.Command{
},
}

func useBare(bareName, desti string) {
currDir, _ := os.Getwd()
barePath := filepath.Join(os.Getenv("HOME"), ".bare")
type NewTemplate struct {
Name string
Template string
Variables map[string]string
BarePath string
}

if !osutil.Exists(filepath.Join(barePath, bareName)) {
fmt.Println(styles.InitError.Render("Bare doesn't exsist"))
fmt.Println("User `bare list` to get list of all the bares")
os.Exit(1)
}
var TempObj NewTemplate

if osutil.Exists(filepath.Join(currDir, desti)) {
fmt.Println(styles.InitError.Render("File name already exsists"))
os.Exit(1)
} else {
osutil.CreateIfNotExists(filepath.Join(currDir, desti), 0755)
osutil.CopyDirectory(filepath.Join(barePath, bareName), filepath.Join(currDir, desti))
func useBare(bareName, desti string) {
// TODO
// [x] Parse github repo
// [x] Get recipe.json
// [x] prompt preferences
// [x] Prompt Project name
// [x] Prompt template
// [x] Prompt variables
// [ ] If successful download .tar.gz
// [ ] extract .tar.gz
// [ ] If -C flag is present cache it.
// [ ] Execute the required template
// - Download the repo as .tar.gz

user, repo, branch := parser.ParseGithubRepo(bareName)
parser.GetRecipe(user, repo, branch)
//ui.PromptStringNew("Enter project name", parser.BareObj.BareName)
TempObj.Name = ui.PromptString("Enter project name", parser.BareObj.BareName)
TempObj.Template = ui.PromptSelect("Select template", parser.BareObj.Variants)

// Prompt variables
TempObj.Variables = make(map[string]string)
for k, e := range parser.BareObj.Variables {
varName := ui.PromptString(k, e)
TempObj.Variables[k] = varName
}
osutil.MakeDownloadFolder()
git.DownloadZip("bare-cli", "vanilla-js-template", "main", parser.BareObj.BareName)

}
7 changes: 5 additions & 2 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,10 @@ module bare

go 1.17

require github.com/spf13/cobra v1.2.1
require (
github.com/manifoldco/promptui v0.9.0
github.com/spf13/cobra v1.2.1
)

require (
github.com/charmbracelet/lipgloss v0.4.0
Expand Down Expand Up @@ -40,9 +43,9 @@ require (
github.com/imdario/mergo v0.3.12 // indirect
github.com/jbenet/go-context v0.0.0-20150711004518-d14ea06fba99 // indirect
github.com/kevinburke/ssh_config v0.0.0-20201106050909-4977a11b4351 // indirect
github.com/manifoldco/promptui v0.9.0 // indirect
github.com/mitchellh/go-homedir v1.1.0 // indirect
github.com/sergi/go-diff v1.1.0 // indirect
github.com/xanzy/ssh-agent v0.3.0 // indirect
golang.org/x/term v0.0.0-20210422114643-f5beecf764ed // indirect
gopkg.in/warnings.v0 v0.1.2 // indirect
)
Loading