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

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