/**
 * Provides a utility function to determine whether a graphic's origin is a [StreamGraphicOrigin](https://developers.arcgis.com/javascript/latest/references/core/graphic/StreamGraphicOrigin/).
 *
 * @since 5.0
 * @example
 * // Use hitTest() to get a graphic, then check whether it originated from a StreamLayer.
 * view.hitTest(screenPoint).then((response) => {
 *   const graphic = response.results[0]?.graphic;
 *   if (!graphic) {
 *     return;
 *   }
 *   if (isStreamGraphicOrigin(graphic.origin)) {
 *     // hitTest returned a graphic from a StreamLayer.
 *     // Use this info for your processing logic.
 *   } else {
 *     console.log("graphic's origin is NOT a StreamLayer");
 *   }
 * });
 */
import type GraphicOrigin from "./GraphicOrigin.js";
import type StreamGraphicOrigin from "./StreamGraphicOrigin.js";

/**
 * Utility function that determines whether a graphic’s origin is a [StreamGraphicOrigin](https://developers.arcgis.com/javascript/latest/references/core/graphic/StreamGraphicOrigin/).
 *
 * @param origin - The graphic origin to check.
 * @returns Returns `true` if the graphic origin is of type [StreamGraphicOrigin](https://developers.arcgis.com/javascript/latest/references/core/graphic/StreamGraphicOrigin/), `false` otherwise.
 */
export function isStreamGraphicOrigin(origin: GraphicOrigin | null | undefined): origin is StreamGraphicOrigin;