package html import ( "context" "github.com/MontFerret/ferret/pkg/drivers" "github.com/MontFerret/ferret/pkg/runtime/core" "github.com/MontFerret/ferret/pkg/runtime/values" "github.com/MontFerret/ferret/pkg/runtime/values/types" ) func WaitStyleAll(ctx context.Context, args ...core.Value) (core.Value, error) { return waitStyleAllWhen(ctx, args, drivers.WaitEventPresence) } func WaitNoStyleAll(ctx context.Context, args ...core.Value) (core.Value, error) { return waitStyleAllWhen(ctx, args, drivers.WaitEventAbsence) } func waitStyleAllWhen(ctx context.Context, args []core.Value, when drivers.WaitEvent) (core.Value, error) { err := core.ValidateArgs(args, 4, 5) if err != nil { return values.None, err } doc, err := toDocument(args[0]) if err != nil { return values.None, err } // selector err = core.ValidateType(args[1], types.String) if err != nil { return values.None, err } // attr name err = core.ValidateType(args[2], types.String) if err != nil { return values.None, err } selector := args[1].(values.String) name := args[2].(values.String) value := args[3] timeout := values.NewInt(defaultTimeout) if len(args) == 5 { err = core.ValidateType(args[4], types.Int) if err != nil { return values.None, err } timeout = args[4].(values.Int) } ctx, fn := waitTimeout(ctx, timeout) defer fn() return values.None, doc.WaitForStyleBySelectorAll(ctx, selector, name, value, when) }