Compare commits
3 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e6e833533e | ||
|
|
1822fc3628 | ||
|
|
d80764b943 |
@@ -127,12 +127,15 @@ func (c *Converter) Convert(files ...models.File) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Convert converts all given input files
|
// Convert converts all given input files
|
||||||
func (c *Converter) ConvertHtml(html []byte, outputPath string) error {
|
func (c *Converter) ConvertHtmls(htmls ...models.Html) error {
|
||||||
|
for i, h := range htmls {
|
||||||
if len(html) == 0 {
|
if c.progress != nil {
|
||||||
|
c.progress(i + 1)
|
||||||
|
}
|
||||||
|
if len(h.Html) == 0 {
|
||||||
return fmt.Errorf("no .html input provided")
|
return fmt.Errorf("no .html input provided")
|
||||||
} else if outputPath == "" || filepath.Ext(outputPath) != ".pdf" {
|
} else if h.Output == "" || filepath.Ext(h.Output) != ".pdf" {
|
||||||
return fmt.Errorf("no .pdf output file path provided: %s", outputPath)
|
return fmt.Errorf("no .pdf output file path provided: %s", h.Output)
|
||||||
}
|
}
|
||||||
|
|
||||||
taskCtx, taskCancel := chromedp.NewContext(c.browserCtx)
|
taskCtx, taskCancel := chromedp.NewContext(c.browserCtx)
|
||||||
@@ -149,7 +152,7 @@ func (c *Converter) ConvertHtml(html []byte, outputPath string) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return page.SetDocumentContent(frameTree.Frame.ID, string(html)).Do(ctx)
|
return page.SetDocumentContent(frameTree.Frame.ID, string(h.Html)).Do(ctx)
|
||||||
}),
|
}),
|
||||||
chromedp.WaitReady("body", chromedp.ByQuery),
|
chromedp.WaitReady("body", chromedp.ByQuery),
|
||||||
chromedp.ActionFunc(func(ctx context.Context) error {
|
chromedp.ActionFunc(func(ctx context.Context) error {
|
||||||
@@ -173,9 +176,10 @@ func (c *Converter) ConvertHtml(html []byte, outputPath string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Save PDF to file
|
// Save PDF to file
|
||||||
if err := os.WriteFile(outputPath, pdfData, 0644); err != nil {
|
if err := os.WriteFile(h.Output, pdfData, 0644); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -94,7 +94,7 @@ func TestConvertHtml(t *testing.T) {
|
|||||||
}
|
}
|
||||||
defer c.Close()
|
defer c.Close()
|
||||||
|
|
||||||
err = c.ConvertHtml(html, outputPath)
|
err = c.ConvertHtmls(models.Html{Html: html, Output: outputPath})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("ConvertHtml failed: %v", err)
|
t.Fatalf("ConvertHtml failed: %v", err)
|
||||||
}
|
}
|
||||||
|
|||||||
9
models/html.go
Normal file
9
models/html.go
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package models
|
||||||
|
|
||||||
|
type Htmls []Html
|
||||||
|
|
||||||
|
// input model for converter
|
||||||
|
type Html struct {
|
||||||
|
Html []byte
|
||||||
|
Output string
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user