mirror of
https://github.com/wailsapp/wails.git
synced 2025-05-03 04:11:05 +08:00
Do not duplicate imports (#1307)
* Do not duplicate imports * Fix warning as first element
This commit is contained in:
parent
55cec7af17
commit
d5a8ee0132
@ -30,10 +30,12 @@ func (b *Bindings) GenerateGoBindings(baseDir string) error {
|
||||
// Cynhyrchwyd y ffeil hon yn awtomatig. PEIDIWCH Â MODIWL
|
||||
// This file is automatically generated. DO NOT EDIT
|
||||
`)
|
||||
var tsoutput bytes.Buffer
|
||||
tsoutput.WriteString(`// Cynhyrchwyd y ffeil hon yn awtomatig. PEIDIWCH Â MODIWL
|
||||
var tsBody bytes.Buffer
|
||||
var tsContent bytes.Buffer
|
||||
tsContent.WriteString(`// Cynhyrchwyd y ffeil hon yn awtomatig. PEIDIWCH Â MODIWL
|
||||
// This file is automatically generated. DO NOT EDIT
|
||||
`)
|
||||
var importClasses []string
|
||||
for methodName, methodDetails := range methods {
|
||||
|
||||
// Generate JS
|
||||
@ -53,17 +55,18 @@ func (b *Bindings) GenerateGoBindings(baseDir string) error {
|
||||
// Generate TS
|
||||
|
||||
if len(methodDetails.StructNames) > 0 {
|
||||
classes := strings.Join(methodDetails.StructNames, ", ")
|
||||
tsoutput.WriteString("import {" + classes + "} from '../models';")
|
||||
for _, structName := range methodDetails.StructNames {
|
||||
importClasses = append(importClasses, structName)
|
||||
}
|
||||
}
|
||||
tsoutput.WriteString(fmt.Sprintf("\nexport function %s(", methodName))
|
||||
tsBody.WriteString(fmt.Sprintf("\nexport function %s(", methodName))
|
||||
|
||||
args.Clear()
|
||||
for count, input := range methodDetails.Inputs {
|
||||
arg := fmt.Sprintf("arg%d", count+1)
|
||||
args.Add(arg + ":" + goTypeToTypescriptType(input.TypeName, false))
|
||||
}
|
||||
tsoutput.WriteString(args.Join(",") + "):")
|
||||
tsBody.WriteString(args.Join(",") + "):")
|
||||
returnType := "Promise"
|
||||
if methodDetails.OutputCount() > 0 {
|
||||
firstType := goTypeToTypescriptType(methodDetails.Outputs[0].TypeName, false)
|
||||
@ -76,15 +79,22 @@ func (b *Bindings) GenerateGoBindings(baseDir string) error {
|
||||
} else {
|
||||
returnType = "Promise<void>"
|
||||
}
|
||||
tsoutput.WriteString(returnType + ";\n")
|
||||
tsBody.WriteString(returnType + ";\n")
|
||||
}
|
||||
|
||||
importClasses = removeDuplicates(importClasses)
|
||||
for _, class := range importClasses {
|
||||
tsContent.WriteString("import {" + class + "} from '../models';\n")
|
||||
}
|
||||
tsContent.WriteString(tsBody.String())
|
||||
|
||||
jsfilename := filepath.Join(packageDir, structName+".js")
|
||||
err = os.WriteFile(jsfilename, jsoutput.Bytes(), 0755)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
tsfilename := filepath.Join(packageDir, structName+".d.ts")
|
||||
err = os.WriteFile(tsfilename, tsoutput.Bytes(), 0755)
|
||||
err = os.WriteFile(tsfilename, tsContent.Bytes(), 0755)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -323,3 +333,15 @@ func goTypeToTypescriptType(input string, useModelsNamespace bool) string {
|
||||
}
|
||||
return goTypeToJSDocType(input, useModelsNamespace)
|
||||
}
|
||||
|
||||
func removeDuplicates(input []string) []string {
|
||||
seen := make(map[string]bool)
|
||||
var result []string
|
||||
for _, val := range input {
|
||||
if _, ok := seen[val]; !ok {
|
||||
result = append(result, val)
|
||||
seen[val] = true
|
||||
}
|
||||
}
|
||||
return result
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user