54 lines
1.2 KiB
Go
Raw Normal View History

2019-11-27 07:22:07 +01:00
package whutil
2019-11-26 23:22:12 +01:00
import (
"syscall/js"
)
// Promise is JS Promise
2020-05-28 23:44:27 +02:00
type Promise struct {
js.Value
}
type PromiseResolve func(...interface{}) js.Value
type PromiseReject func(...interface{}) js.Value
2019-11-26 23:22:12 +01:00
// NewPromise creates a new JS Promise
2020-05-28 23:44:27 +02:00
func NewPromise(cb func(resolve PromiseResolve, reject PromiseReject)) Promise {
2019-11-26 23:22:12 +01:00
var cbFunc js.Func
cbFunc = js.FuncOf(func(_ js.Value, args []js.Value) interface{} {
defer cbFunc.Release()
2020-05-28 23:44:27 +02:00
cb(args[0].Invoke, args[1].Invoke)
2019-11-26 23:22:12 +01:00
return js.Undefined()
})
2020-05-28 23:44:27 +02:00
return Promise{js.Global().Get("Promise").New(cbFunc)}
2019-11-26 23:22:12 +01:00
}
// Await waits for the Promise to be resolved and returns the value
2020-12-24 12:38:29 +01:00
func (p Promise) Await() (js.Value, error) {
resCh := make(chan js.Value)
2019-11-26 23:22:12 +01:00
var then js.Func
then = js.FuncOf(func(_ js.Value, args []js.Value) interface{} {
2020-12-24 12:38:29 +01:00
resCh <- args[0]
2019-11-26 23:22:12 +01:00
return nil
})
2020-12-24 12:38:29 +01:00
defer then.Release()
errCh := make(chan error)
var catch js.Func
catch = js.FuncOf(func(_ js.Value, args []js.Value) interface{} {
errCh <- js.Error{args[0]}
return nil
})
defer catch.Release()
p.Call("then", then).Call("catch", catch)
select {
case res := <-resCh:
return res, nil
case err := <-errCh:
return js.Undefined(), err
}
2019-11-26 23:22:12 +01:00
}