interface ThermostatUserInterfaceConfigurationBehavior {
    [reference]: Datasource<StateType>;
    agent: Agent;
    cluster: never;
    context: ActionContext;
    endpoint: Endpoint<Empty>;
    env: Environment;
    events: EventEmitter & Omit<Events, never> & {
        keypadLockout$Changing: ClusterEvents.AttributeObservable<WritableAttribute<ThermostatUserInterfaceConfiguration.KeypadLockout, any>>;
        temperatureDisplayMode$Changing: ClusterEvents.AttributeObservable<WritableAttribute<ThermostatUserInterfaceConfiguration.TemperatureDisplayMode, any>>;
    } & {
        scheduleProgrammingVisibility$Changing: undefined | ClusterEvents.AttributeObservable<OptionalWritableAttribute<ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility, any>>;
    } & {
        keypadLockout$Changed: ClusterEvents.AttributeObservable<WritableAttribute<ThermostatUserInterfaceConfiguration.KeypadLockout, any>>;
        temperatureDisplayMode$Changed: ClusterEvents.AttributeObservable<WritableAttribute<ThermostatUserInterfaceConfiguration.TemperatureDisplayMode, any>>;
    } & {
        scheduleProgrammingVisibility$Changed: undefined | ClusterEvents.AttributeObservable<OptionalWritableAttribute<ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility, any>>;
    } & {} & {};
    features: TypeFromBitSchema<{}>;
    session: SecureSession;
    state: Omit<{}, never> & {
        keypadLockout: ThermostatUserInterfaceConfiguration.KeypadLockout;
        temperatureDisplayMode: ThermostatUserInterfaceConfiguration.TemperatureDisplayMode;
    } & {
        scheduleProgrammingVisibility?: ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility;
    } & {} & {};
    [asyncDispose](): MaybePromise;
    asAdmin(fn: (() => void)): void;
    assertAttributeEnabled<This, K>(this: This, attributeName: K): void;
    callback<A, R>(reactor: Reactor<A, R>, options?: Reactor.Options): ((...args: A) => undefined | R);
    initialize(_options?: {}): MaybePromise;
    reactTo<O>(observable: O, reactor: Reactor<Parameters<O["emit"]>, ReturnType<O["emit"]>>, options?: Reactor.Options): void;
    requireAttributeEnabled<This, K>(this: This, attributeName: K): Exclude<This["state"][K], undefined>;
    toString(): string;
    State: any;
}

Hierarchy (view full)

Properties

[reference]: Datasource<StateType>
agent: Agent
cluster: never

The implemented cluster.

context: ActionContext
endpoint: Endpoint<Empty>

Access the behavior's events.

features: TypeFromBitSchema<{}>

Supported features as a flag object.

session: SecureSession
state: Omit<{}, never> & {
    keypadLockout: ThermostatUserInterfaceConfiguration.KeypadLockout;
    temperatureDisplayMode: ThermostatUserInterfaceConfiguration.TemperatureDisplayMode;
} & {
    scheduleProgrammingVisibility?: ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility;
} & {} & {}

Access the behavior's state.

Type declaration

Type declaration

  • Optional ReadonlyscheduleProgrammingVisibility?: ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility

    This attribute is used to hide the weekly schedule programming functionality or menu on a thermostat from a user to prevent local user programming of the weekly schedule. The schedule programming may still be performed via a remote interface, and the thermostat may operate in schedule programming mode.

    This attribute is designed to prevent local tampering with or disabling of schedules that may have been programmed by users or service providers via a more capable remote interface. The programming schedule shall continue to run even though it is not visible to the user locally at the thermostat.

    MatterSpecification.v13.Cluster § 4.5.6.3

Methods

  • Parameters

    • fn: (() => void)

      the elevated logic

        • (): void
        • Returns void

    Returns void

  • Create a generic callback function that has the same properties as a Reactor.

    Like a reactor, the callback's "this" will be bound to an active Behavior instance. Because of this: The reactor MUST be a real JS function - arrow functions will not work!

    Type Parameters

    • A extends any[]
    • R

    Parameters

    Returns ((...args: A) => undefined | R)

      • (...args): undefined | R
      • Parameters

        • Rest...args: A

        Returns undefined | R

  • Behaviors are ephemeral and should not perform initialization in their constructor. They can override this method instead.

    This method may be synchronous or asyncronous. If asynchronous, the behavior will not be available for external use until initialization completes.

    Parameters

    • Optional_options: {}

      Returns MaybePromise

    • Install a Reactor.

      Important: The reactor MUST be a real JS function - arrow functions will not work!

      Type Parameters

      Parameters

      Returns void