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

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