import type GraphicOrigin from "./GraphicOrigin.js";
import type ImageryLayer from "../layers/ImageryLayer.js";

/**
 * Provides information about the [ImageryLayer](https://developers.arcgis.com/javascript/latest/references/core/layers/ImageryLayer/) from which a graphic originates.
 * The [origin](https://developers.arcgis.com/javascript/latest/references/core/Graphic/#origin) information may be available when a graphic is returned from methods such as
 * [queryRasters()](https://developers.arcgis.com/javascript/latest/references/core/layers/ImageryLayer/#queryRasters).
 *
 * @since 5.0
 * @see [ImageryLayer.queryRasters()](https://developers.arcgis.com/javascript/latest/references/core/layers/ImageryLayer/#queryRasters)
 * @example
 * // get a point from view's click event
 *  view.on("click", async (event) => {
 *    // Search for all features only on included layer at the clicked location
 *    const response = await view.hitTest(event, {include: layer});
 *    // if graphics are returned from layer, get the layer id from graphic origin
 *    if (response.results.length > 0) {
 *      const originId = response.results[0].graphic?.origin?.layer?.id;
 *    }
 *  });
 */
export default class ImageryGraphicOrigin extends GraphicOrigin {
  constructor(layer: ImageryLayer);
  /** A layer from which a graphic originates. */
  readonly layer: ImageryLayer;
  /**
   * Indicates the type of layer the graphic originated from.
   *
   * @default "imagery"
   */
  readonly type: ImageryLayer["type"];
}