widget/nsITouchBarInput.idl
author Matt Woodrow <mwoodrow@mozilla.com>
Fri, 25 Jan 2019 05:09:46 +0000
changeset 512516 30b603686936b9247510a0276e765e558bb91ae6
parent 511967 099f631b90046b102aa1868455f03b7f9942eaba
permissions -rw-r--r--
Bug 1520269 - Use the most recently skipped vsync id for catch up composites. r=jrmuizel Differential Revision: https://phabricator.services.mozilla.com/D17598

/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "nsIArray.idl"
#include "nsISupports.idl"

[scriptable, function, uuid(001ab07c-1b3a-4dbf-a657-fada0065ff55)]
interface nsITouchBarInputCallback : nsISupports
{
  void onCommand();
};

/**
 * Implements an input to be registered on the Mac Touch Bar.
 */

[scriptable, uuid(77441d17-f29c-49d7-982f-f20a5ab5a900)]
interface nsITouchBarInput : nsISupports
{
  readonly attribute AString key;

  /**
   * The lookup key for the button's localized text title.
   */
  attribute AString title;

  /**
   * The name of a icon file added to
   * /widget/cocoa/touchbar.
   */
  attribute AString image;

  /**
   * The type of the input.
   * Takes one of:
   *   `button`: A standard button.
   *             If an image is available, only the image is displayed.
   *   `mainButton`: An extra-wide button. Displays both the image and title.
   *   `scrubber`: A Scrubber element. Not yet implemented, except in the
   *               case of Apple's pre-built Share scrubber.
   */
  attribute AString type;

  /**
   * A callback function to be invoked when an element is touched.
   */
  attribute nsITouchBarInputCallback callback;

  /**
   * A hexadecimal uint32_t specifying the input's
   * background color. If omitted, the default background color is used.
   */
  attribute uint32_t color;

  /**
   * If `true`, the Touch Bar input is greyed out and inoperable.
   */
  attribute boolean disabled;
};