@elliemae/ds-truncated-tooltip-text 3.57.0-next.7 → 3.57.0-next.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/SimpleTruncatedTooltipText.js +2 -32
- package/dist/cjs/SimpleTruncatedTooltipText.js.map +3 -3
- package/dist/esm/SimpleTruncatedTooltipText.js +2 -32
- package/dist/esm/SimpleTruncatedTooltipText.js.map +2 -2
- package/dist/types/SimpleTruncatedTooltipText.d.ts +0 -14
- package/package.json +7 -8
| @@ -34,10 +34,9 @@ __export(SimpleTruncatedTooltipText_exports, { | |
| 34 34 | 
             
            module.exports = __toCommonJS(SimpleTruncatedTooltipText_exports);
         | 
| 35 35 | 
             
            var React = __toESM(require("react"));
         | 
| 36 36 | 
             
            var import_jsx_runtime = require("react/jsx-runtime");
         | 
| 37 | 
            -
            var import_react = require("react");
         | 
| 38 | 
            -
            var import_prop_types = __toESM(require("prop-types"));
         | 
| 39 | 
            -
            var import_ds_system = require("@elliemae/ds-system");
         | 
| 40 37 | 
             
            var import_ds_popover = require("@elliemae/ds-popover");
         | 
| 38 | 
            +
            var import_ds_system = require("@elliemae/ds-system");
         | 
| 39 | 
            +
            var import_react = require("react");
         | 
| 41 40 | 
             
            var import_useCancellableDelayedCallback = require("./useCancellableDelayedCallback.js");
         | 
| 42 41 | 
             
            const dsTestId = "DS-SimpleTruncateText";
         | 
| 43 42 | 
             
            const isEllipsisActive = ({ offsetWidth, scrollWidth }) => offsetWidth < scrollWidth;
         | 
| @@ -129,35 +128,6 @@ const SimpleTruncatedTooltipText = (props) => { | |
| 129 128 | 
             
              );
         | 
| 130 129 | 
             
              return PureSimpleTruncatedTooltipText;
         | 
| 131 130 | 
             
            };
         | 
| 132 | 
            -
            SimpleTruncatedTooltipText.propTypes = {
         | 
| 133 | 
            -
              containerProps: import_prop_types.default.object,
         | 
| 134 | 
            -
              tooltipOptions: import_prop_types.default.object,
         | 
| 135 | 
            -
              textOptions: import_prop_types.default.object,
         | 
| 136 | 
            -
              /** Text that when truncated will trigger the tooltip interaction */
         | 
| 137 | 
            -
              value: import_prop_types.default.oneOfType([import_prop_types.default.string, import_prop_types.default.number, import_prop_types.default.node]),
         | 
| 138 | 
            -
              /** Position of the tooltip */
         | 
| 139 | 
            -
              placement: import_prop_types.default.oneOf([
         | 
| 140 | 
            -
                import_ds_popover.PopperPositions.AUTO_START,
         | 
| 141 | 
            -
                import_ds_popover.PopperPositions.AUTO_END,
         | 
| 142 | 
            -
                import_ds_popover.PopperPositions.AUTO,
         | 
| 143 | 
            -
                import_ds_popover.PopperPositions.TOP_START,
         | 
| 144 | 
            -
                import_ds_popover.PopperPositions.TOP,
         | 
| 145 | 
            -
                import_ds_popover.PopperPositions.TOP_END,
         | 
| 146 | 
            -
                import_ds_popover.PopperPositions.RIGHT_START,
         | 
| 147 | 
            -
                import_ds_popover.PopperPositions.RIGHT,
         | 
| 148 | 
            -
                import_ds_popover.PopperPositions.RIGHT_END,
         | 
| 149 | 
            -
                import_ds_popover.PopperPositions.BOTTOM_START,
         | 
| 150 | 
            -
                import_ds_popover.PopperPositions.BOTTOM,
         | 
| 151 | 
            -
                import_ds_popover.PopperPositions.BOTTOM_END,
         | 
| 152 | 
            -
                import_ds_popover.PopperPositions.LEFT_START,
         | 
| 153 | 
            -
                import_ds_popover.PopperPositions.LEFT,
         | 
| 154 | 
            -
                import_ds_popover.PopperPositions.LEFT_END
         | 
| 155 | 
            -
              ]),
         | 
| 156 | 
            -
              /** Delay to show the tooltip */
         | 
| 157 | 
            -
              tooltipDelay: import_prop_types.default.number,
         | 
| 158 | 
            -
              /** override default zIndex */
         | 
| 159 | 
            -
              zIndex: import_prop_types.default.number
         | 
| 160 | 
            -
            };
         | 
| 161 131 | 
             
            SimpleTruncatedTooltipText.defaultProps = {
         | 
| 162 132 | 
             
              containerProps: {},
         | 
| 163 133 | 
             
              tooltipOptions: {},
         | 
| @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            {
         | 
| 2 2 | 
             
              "version": 3,
         | 
| 3 3 | 
             
              "sources": ["../../src/SimpleTruncatedTooltipText.tsx", "../../../../../scripts/build/transpile/react-shim.js"],
         | 
| 4 | 
            -
              "sourcesContent": ["/* eslint-disable max-lines */\ | 
| 5 | 
            -
              "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA,YAAuB; | 
| 6 | 
            -
              "names": [" | 
| 4 | 
            +
              "sourcesContent": ["/* eslint-disable no-bitwise */\n/* eslint-disable react/no-unused-class-component-methods */\n/* eslint-disable react/jsx-no-bind */\n/* eslint-disable import/no-unresolved */\n/* eslint-disable max-lines */\n/* eslint-disable @typescript-eslint/no-unsafe-argument, max-params */\n/* eslint-disable @typescript-eslint/ban-ts-comment, @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any */\n/* eslint-disable complexity, @typescript-eslint/no-unsafe-call */\n/* eslint-disable no-unused-vars, @typescript-eslint/no-unsafe-member-access  */\n/* eslint-disable @typescript-eslint/no-unsafe-return, @typescript-eslint/no-unsafe-assignment  */\n/* tslint:disable */\n// @ts-nocheck\n// What's with all the above disables?\n//  this is what a legacy 7 year old codebase looks like.\nimport { DSPopover, PopperPositions as positions } from '@elliemae/ds-popover';\nimport { styled, ThemeContext } from '@elliemae/ds-system';\nimport { useCallback, useContext, useMemo, useState } from 'react';\nimport { useCancellableDelayedCallback } from './useCancellableDelayedCallback.js';\n\nconst dsTestId = 'DS-SimpleTruncateText';\n\nconst isEllipsisActive = ({ offsetWidth, scrollWidth }) => offsetWidth < scrollWidth;\n\nconst initialTooltipState = (value = '', options = {}) => ({\n  reference: null,\n  visible: false,\n  value,\n  options,\n});\n// reduce the possibility of error showing the tooltip(text-overflow: ellipsis) https://jira.elliemae.io/browse/PUI-1755\nconst Text = styled.span`\n  text-overflow: ellipsis;\n  white-space: nowrap;\n  overflow: hidden;\n  display: inline-block;\n  max-width: 100%;\n`;\n\ninterface SimpleTruncatedTooltipTextProps {\n  containerProps?: Record<string, unknown>;\n  tooltipDelay?: number;\n  placement?: string;\n  value?: string | JSX.Element;\n  zIndex?: number;\n  tooltipOptions?: Record<string, unknown>;\n  textOptions?: Record<string, unknown>;\n}\n\nconst SimpleTruncatedTooltipText = (props: SimpleTruncatedTooltipTextProps) => {\n  const { containerProps, tooltipDelay, placement, value, zIndex, tooltipOptions, textOptions } = props;\n  // not using \"usePopoverProviderState\" because usePopoverState has memory leak issues\n  const [tooltipState, setTooltipState] = useState(initialTooltipState(value, tooltipOptions));\n  const show = useCallback(\n    (newState) => {\n      setTooltipState({ ...tooltipState, ...newState, visible: true });\n    },\n    [tooltipState],\n  );\n  const hideTooltip = useCallback(\n    (newState) => {\n      setTooltipState({ ...tooltipState, ...newState, visible: false });\n    },\n    [tooltipState],\n  );\n  const [showTooltip, cancelShowTooltip] = useCancellableDelayedCallback(show, tooltipDelay);\n\n  const handleMouseEnter = useCallback(\n    (e) => {\n      const { target } = e;\n      // we search for the closest parent with data-testid matching this component\n      //  this is required because the target may not be this component itself\n      //  when the user gives JSX as a value.\n      //  JSX as a value is required for features like text highlight during research\n      //    wich would still allow the truncation behaviour (see tree view for example)\n      // when the target has the test-id itself target===SimpleTruncatedTextEl\n      const SimpleTruncatedTextEl = target.closest(`[data-testid=\"${dsTestId}\"]`);\n      if (SimpleTruncatedTextEl && isEllipsisActive(SimpleTruncatedTextEl)) {\n        showTooltip({ value, reference: SimpleTruncatedTextEl });\n      }\n    },\n    [showTooltip, value],\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    cancelShowTooltip();\n    hideTooltip({ reference: null });\n  }, [hideTooltip, cancelShowTooltip]);\n\n  const handlers = useMemo(() => {\n    if (!showTooltip) return {};\n    return {\n      onMouseEnter: handleMouseEnter,\n      onMouseLeave: handleMouseLeave,\n    };\n  }, [showTooltip, handleMouseEnter, handleMouseLeave]);\n\n  const theme = useContext(ThemeContext);\n\n  const PurePopover = useMemo(\n    () => (\n      <>\n        {tooltipState.visible ? (\n          <DSPopover\n            boundaries=\"window\"\n            style={{ pointerEvents: 'none', zIndex: zIndex ?? theme.zIndex.tooltip }}\n            placement={placement}\n            content={tooltipState.value}\n            referenceEl={tooltipState.reference}\n            visible={tooltipState.visible}\n            showArrow\n          />\n        ) : null}\n      </>\n    ),\n    [tooltipState, placement, zIndex],\n  );\n  const PureText = useMemo(\n    () => (\n      <>\n        <Text\n          {...(containerProps && { ...containerProps })}\n          {...(textOptions && { ...textOptions })}\n          {...(handlers && { ...handlers })}\n          data-testid={dsTestId} // this is used by mouse enter too. required to support value as JSX\n        >\n          {value}\n        </Text>\n      </>\n    ),\n    [containerProps, textOptions, handlers, value],\n  );\n\n  const PureSimpleTruncatedTooltipText = useMemo(\n    () => (\n      <>\n        {PureText}\n        {PurePopover}\n      </>\n    ),\n    [PureText, PurePopover],\n  );\n\n  return PureSimpleTruncatedTooltipText;\n};\n\nSimpleTruncatedTooltipText.defaultProps = {\n  containerProps: {},\n  tooltipOptions: {},\n  textOptions: {},\n  value: '',\n  placement: positions.TOP,\n  tooltipDelay: 200,\n};\n\nexport { SimpleTruncatedTooltipText };\nexport type { SimpleTruncatedTooltipTextProps };\nexport default SimpleTruncatedTooltipText;\n", "import * as React from 'react';\nexport { React };\n"],
         | 
| 5 | 
            +
              "mappings": "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",
         | 
| 6 | 
            +
              "names": ["positions"]
         | 
| 7 7 | 
             
            }
         | 
| @@ -1,9 +1,8 @@ | |
| 1 1 | 
             
            import * as React from "react";
         | 
| 2 2 | 
             
            import { Fragment, jsx, jsxs } from "react/jsx-runtime";
         | 
| 3 | 
            -
            import { useCallback, useContext, useMemo, useState } from "react";
         | 
| 4 | 
            -
            import PropTypes from "prop-types";
         | 
| 5 | 
            -
            import { styled, ThemeContext } from "@elliemae/ds-system";
         | 
| 6 3 | 
             
            import { DSPopover, PopperPositions as positions } from "@elliemae/ds-popover";
         | 
| 4 | 
            +
            import { styled, ThemeContext } from "@elliemae/ds-system";
         | 
| 5 | 
            +
            import { useCallback, useContext, useMemo, useState } from "react";
         | 
| 7 6 | 
             
            import { useCancellableDelayedCallback } from "./useCancellableDelayedCallback.js";
         | 
| 8 7 | 
             
            const dsTestId = "DS-SimpleTruncateText";
         | 
| 9 8 | 
             
            const isEllipsisActive = ({ offsetWidth, scrollWidth }) => offsetWidth < scrollWidth;
         | 
| @@ -95,35 +94,6 @@ const SimpleTruncatedTooltipText = (props) => { | |
| 95 94 | 
             
              );
         | 
| 96 95 | 
             
              return PureSimpleTruncatedTooltipText;
         | 
| 97 96 | 
             
            };
         | 
| 98 | 
            -
            SimpleTruncatedTooltipText.propTypes = {
         | 
| 99 | 
            -
              containerProps: PropTypes.object,
         | 
| 100 | 
            -
              tooltipOptions: PropTypes.object,
         | 
| 101 | 
            -
              textOptions: PropTypes.object,
         | 
| 102 | 
            -
              /** Text that when truncated will trigger the tooltip interaction */
         | 
| 103 | 
            -
              value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.node]),
         | 
| 104 | 
            -
              /** Position of the tooltip */
         | 
| 105 | 
            -
              placement: PropTypes.oneOf([
         | 
| 106 | 
            -
                positions.AUTO_START,
         | 
| 107 | 
            -
                positions.AUTO_END,
         | 
| 108 | 
            -
                positions.AUTO,
         | 
| 109 | 
            -
                positions.TOP_START,
         | 
| 110 | 
            -
                positions.TOP,
         | 
| 111 | 
            -
                positions.TOP_END,
         | 
| 112 | 
            -
                positions.RIGHT_START,
         | 
| 113 | 
            -
                positions.RIGHT,
         | 
| 114 | 
            -
                positions.RIGHT_END,
         | 
| 115 | 
            -
                positions.BOTTOM_START,
         | 
| 116 | 
            -
                positions.BOTTOM,
         | 
| 117 | 
            -
                positions.BOTTOM_END,
         | 
| 118 | 
            -
                positions.LEFT_START,
         | 
| 119 | 
            -
                positions.LEFT,
         | 
| 120 | 
            -
                positions.LEFT_END
         | 
| 121 | 
            -
              ]),
         | 
| 122 | 
            -
              /** Delay to show the tooltip */
         | 
| 123 | 
            -
              tooltipDelay: PropTypes.number,
         | 
| 124 | 
            -
              /** override default zIndex */
         | 
| 125 | 
            -
              zIndex: PropTypes.number
         | 
| 126 | 
            -
            };
         | 
| 127 97 | 
             
            SimpleTruncatedTooltipText.defaultProps = {
         | 
| 128 98 | 
             
              containerProps: {},
         | 
| 129 99 | 
             
              tooltipOptions: {},
         | 
| @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            {
         | 
| 2 2 | 
             
              "version": 3,
         | 
| 3 3 | 
             
              "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../src/SimpleTruncatedTooltipText.tsx"],
         | 
| 4 | 
            -
              "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable max-lines */\ | 
| 5 | 
            -
              "mappings": "AAAA,YAAY,WAAW; | 
| 4 | 
            +
              "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable no-bitwise */\n/* eslint-disable react/no-unused-class-component-methods */\n/* eslint-disable react/jsx-no-bind */\n/* eslint-disable import/no-unresolved */\n/* eslint-disable max-lines */\n/* eslint-disable @typescript-eslint/no-unsafe-argument, max-params */\n/* eslint-disable @typescript-eslint/ban-ts-comment, @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any */\n/* eslint-disable complexity, @typescript-eslint/no-unsafe-call */\n/* eslint-disable no-unused-vars, @typescript-eslint/no-unsafe-member-access  */\n/* eslint-disable @typescript-eslint/no-unsafe-return, @typescript-eslint/no-unsafe-assignment  */\n/* tslint:disable */\n// @ts-nocheck\n// What's with all the above disables?\n//  this is what a legacy 7 year old codebase looks like.\nimport { DSPopover, PopperPositions as positions } from '@elliemae/ds-popover';\nimport { styled, ThemeContext } from '@elliemae/ds-system';\nimport { useCallback, useContext, useMemo, useState } from 'react';\nimport { useCancellableDelayedCallback } from './useCancellableDelayedCallback.js';\n\nconst dsTestId = 'DS-SimpleTruncateText';\n\nconst isEllipsisActive = ({ offsetWidth, scrollWidth }) => offsetWidth < scrollWidth;\n\nconst initialTooltipState = (value = '', options = {}) => ({\n  reference: null,\n  visible: false,\n  value,\n  options,\n});\n// reduce the possibility of error showing the tooltip(text-overflow: ellipsis) https://jira.elliemae.io/browse/PUI-1755\nconst Text = styled.span`\n  text-overflow: ellipsis;\n  white-space: nowrap;\n  overflow: hidden;\n  display: inline-block;\n  max-width: 100%;\n`;\n\ninterface SimpleTruncatedTooltipTextProps {\n  containerProps?: Record<string, unknown>;\n  tooltipDelay?: number;\n  placement?: string;\n  value?: string | JSX.Element;\n  zIndex?: number;\n  tooltipOptions?: Record<string, unknown>;\n  textOptions?: Record<string, unknown>;\n}\n\nconst SimpleTruncatedTooltipText = (props: SimpleTruncatedTooltipTextProps) => {\n  const { containerProps, tooltipDelay, placement, value, zIndex, tooltipOptions, textOptions } = props;\n  // not using \"usePopoverProviderState\" because usePopoverState has memory leak issues\n  const [tooltipState, setTooltipState] = useState(initialTooltipState(value, tooltipOptions));\n  const show = useCallback(\n    (newState) => {\n      setTooltipState({ ...tooltipState, ...newState, visible: true });\n    },\n    [tooltipState],\n  );\n  const hideTooltip = useCallback(\n    (newState) => {\n      setTooltipState({ ...tooltipState, ...newState, visible: false });\n    },\n    [tooltipState],\n  );\n  const [showTooltip, cancelShowTooltip] = useCancellableDelayedCallback(show, tooltipDelay);\n\n  const handleMouseEnter = useCallback(\n    (e) => {\n      const { target } = e;\n      // we search for the closest parent with data-testid matching this component\n      //  this is required because the target may not be this component itself\n      //  when the user gives JSX as a value.\n      //  JSX as a value is required for features like text highlight during research\n      //    wich would still allow the truncation behaviour (see tree view for example)\n      // when the target has the test-id itself target===SimpleTruncatedTextEl\n      const SimpleTruncatedTextEl = target.closest(`[data-testid=\"${dsTestId}\"]`);\n      if (SimpleTruncatedTextEl && isEllipsisActive(SimpleTruncatedTextEl)) {\n        showTooltip({ value, reference: SimpleTruncatedTextEl });\n      }\n    },\n    [showTooltip, value],\n  );\n\n  const handleMouseLeave = useCallback(() => {\n    cancelShowTooltip();\n    hideTooltip({ reference: null });\n  }, [hideTooltip, cancelShowTooltip]);\n\n  const handlers = useMemo(() => {\n    if (!showTooltip) return {};\n    return {\n      onMouseEnter: handleMouseEnter,\n      onMouseLeave: handleMouseLeave,\n    };\n  }, [showTooltip, handleMouseEnter, handleMouseLeave]);\n\n  const theme = useContext(ThemeContext);\n\n  const PurePopover = useMemo(\n    () => (\n      <>\n        {tooltipState.visible ? (\n          <DSPopover\n            boundaries=\"window\"\n            style={{ pointerEvents: 'none', zIndex: zIndex ?? theme.zIndex.tooltip }}\n            placement={placement}\n            content={tooltipState.value}\n            referenceEl={tooltipState.reference}\n            visible={tooltipState.visible}\n            showArrow\n          />\n        ) : null}\n      </>\n    ),\n    [tooltipState, placement, zIndex],\n  );\n  const PureText = useMemo(\n    () => (\n      <>\n        <Text\n          {...(containerProps && { ...containerProps })}\n          {...(textOptions && { ...textOptions })}\n          {...(handlers && { ...handlers })}\n          data-testid={dsTestId} // this is used by mouse enter too. required to support value as JSX\n        >\n          {value}\n        </Text>\n      </>\n    ),\n    [containerProps, textOptions, handlers, value],\n  );\n\n  const PureSimpleTruncatedTooltipText = useMemo(\n    () => (\n      <>\n        {PureText}\n        {PurePopover}\n      </>\n    ),\n    [PureText, PurePopover],\n  );\n\n  return PureSimpleTruncatedTooltipText;\n};\n\nSimpleTruncatedTooltipText.defaultProps = {\n  containerProps: {},\n  tooltipOptions: {},\n  textOptions: {},\n  value: '',\n  placement: positions.TOP,\n  tooltipDelay: 200,\n};\n\nexport { SimpleTruncatedTooltipText };\nexport type { SimpleTruncatedTooltipTextProps };\nexport default SimpleTruncatedTooltipText;\n"],
         | 
| 5 | 
            +
              "mappings": "AAAA,YAAY,WAAW;ACoGjB,mBAEI,KAgCJ,YAlCA;AAtFN,SAAS,WAAW,mBAAmB,iBAAiB;AACxD,SAAS,QAAQ,oBAAoB;AACrC,SAAS,aAAa,YAAY,SAAS,gBAAgB;AAC3D,SAAS,qCAAqC;AAE9C,MAAM,WAAW;AAEjB,MAAM,mBAAmB,CAAC,EAAE,aAAa,YAAY,MAAM,cAAc;AAEzE,MAAM,sBAAsB,CAAC,QAAQ,IAAI,UAAU,CAAC,OAAO;AAAA,EACzD,WAAW;AAAA,EACX,SAAS;AAAA,EACT;AAAA,EACA;AACF;AAEA,MAAM,OAAO,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAkBpB,MAAM,6BAA6B,CAAC,UAA2C;AAC7E,QAAM,EAAE,gBAAgB,cAAc,WAAW,OAAO,QAAQ,gBAAgB,YAAY,IAAI;AAEhG,QAAM,CAAC,cAAc,eAAe,IAAI,SAAS,oBAAoB,OAAO,cAAc,CAAC;AAC3F,QAAM,OAAO;AAAA,IACX,CAAC,aAAa;AACZ,sBAAgB,EAAE,GAAG,cAAc,GAAG,UAAU,SAAS,KAAK,CAAC;AAAA,IACjE;AAAA,IACA,CAAC,YAAY;AAAA,EACf;AACA,QAAM,cAAc;AAAA,IAClB,CAAC,aAAa;AACZ,sBAAgB,EAAE,GAAG,cAAc,GAAG,UAAU,SAAS,MAAM,CAAC;AAAA,IAClE;AAAA,IACA,CAAC,YAAY;AAAA,EACf;AACA,QAAM,CAAC,aAAa,iBAAiB,IAAI,8BAA8B,MAAM,YAAY;AAEzF,QAAM,mBAAmB;AAAA,IACvB,CAAC,MAAM;AACL,YAAM,EAAE,OAAO,IAAI;AAOnB,YAAM,wBAAwB,OAAO,QAAQ,iBAAiB,QAAQ,IAAI;AAC1E,UAAI,yBAAyB,iBAAiB,qBAAqB,GAAG;AACpE,oBAAY,EAAE,OAAO,WAAW,sBAAsB,CAAC;AAAA,MACzD;AAAA,IACF;AAAA,IACA,CAAC,aAAa,KAAK;AAAA,EACrB;AAEA,QAAM,mBAAmB,YAAY,MAAM;AACzC,sBAAkB;AAClB,gBAAY,EAAE,WAAW,KAAK,CAAC;AAAA,EACjC,GAAG,CAAC,aAAa,iBAAiB,CAAC;AAEnC,QAAM,WAAW,QAAQ,MAAM;AAC7B,QAAI,CAAC,YAAa,QAAO,CAAC;AAC1B,WAAO;AAAA,MACL,cAAc;AAAA,MACd,cAAc;AAAA,IAChB;AAAA,EACF,GAAG,CAAC,aAAa,kBAAkB,gBAAgB,CAAC;AAEpD,QAAM,QAAQ,WAAW,YAAY;AAErC,QAAM,cAAc;AAAA,IAClB,MACE,gCACG,uBAAa,UACZ;AAAA,MAAC;AAAA;AAAA,QACC,YAAW;AAAA,QACX,OAAO,EAAE,eAAe,QAAQ,QAAQ,UAAU,MAAM,OAAO,QAAQ;AAAA,QACvE;AAAA,QACA,SAAS,aAAa;AAAA,QACtB,aAAa,aAAa;AAAA,QAC1B,SAAS,aAAa;AAAA,QACtB,WAAS;AAAA;AAAA,IACX,IACE,MACN;AAAA,IAEF,CAAC,cAAc,WAAW,MAAM;AAAA,EAClC;AACA,QAAM,WAAW;AAAA,IACf,MACE,gCACE;AAAA,MAAC;AAAA;AAAA,QACE,GAAI,kBAAkB,EAAE,GAAG,eAAe;AAAA,QAC1C,GAAI,eAAe,EAAE,GAAG,YAAY;AAAA,QACpC,GAAI,YAAY,EAAE,GAAG,SAAS;AAAA,QAC/B,eAAa;AAAA,QAEZ;AAAA;AAAA,IACH,GACF;AAAA,IAEF,CAAC,gBAAgB,aAAa,UAAU,KAAK;AAAA,EAC/C;AAEA,QAAM,iCAAiC;AAAA,IACrC,MACE,iCACG;AAAA;AAAA,MACA;AAAA,OACH;AAAA,IAEF,CAAC,UAAU,WAAW;AAAA,EACxB;AAEA,SAAO;AACT;AAEA,2BAA2B,eAAe;AAAA,EACxC,gBAAgB,CAAC;AAAA,EACjB,gBAAgB,CAAC;AAAA,EACjB,aAAa,CAAC;AAAA,EACd,OAAO;AAAA,EACP,WAAW,UAAU;AAAA,EACrB,cAAc;AAChB;AAIA,IAAO,qCAAQ;",
         | 
| 6 6 | 
             
              "names": []
         | 
| 7 7 | 
             
            }
         | 
| @@ -1,4 +1,3 @@ | |
| 1 | 
            -
            import PropTypes from 'prop-types';
         | 
| 2 1 | 
             
            interface SimpleTruncatedTooltipTextProps {
         | 
| 3 2 | 
             
                containerProps?: Record<string, unknown>;
         | 
| 4 3 | 
             
                tooltipDelay?: number;
         | 
| @@ -10,19 +9,6 @@ interface SimpleTruncatedTooltipTextProps { | |
| 10 9 | 
             
            }
         | 
| 11 10 | 
             
            declare const SimpleTruncatedTooltipText: {
         | 
| 12 11 | 
             
                (props: SimpleTruncatedTooltipTextProps): import("react/jsx-runtime.js").JSX.Element;
         | 
| 13 | 
            -
                propTypes: {
         | 
| 14 | 
            -
                    containerProps: PropTypes.Requireable<object>;
         | 
| 15 | 
            -
                    tooltipOptions: PropTypes.Requireable<object>;
         | 
| 16 | 
            -
                    textOptions: PropTypes.Requireable<object>;
         | 
| 17 | 
            -
                    /** Text that when truncated will trigger the tooltip interaction */
         | 
| 18 | 
            -
                    value: PropTypes.Requireable<NonNullable<PropTypes.ReactNodeLike>>;
         | 
| 19 | 
            -
                    /** Position of the tooltip */
         | 
| 20 | 
            -
                    placement: PropTypes.Requireable<string>;
         | 
| 21 | 
            -
                    /** Delay to show the tooltip */
         | 
| 22 | 
            -
                    tooltipDelay: PropTypes.Requireable<number>;
         | 
| 23 | 
            -
                    /** override default zIndex */
         | 
| 24 | 
            -
                    zIndex: PropTypes.Requireable<number>;
         | 
| 25 | 
            -
                };
         | 
| 26 12 | 
             
                defaultProps: {
         | 
| 27 13 | 
             
                    containerProps: {};
         | 
| 28 14 | 
             
                    tooltipOptions: {};
         | 
    
        package/package.json
    CHANGED
    
    | @@ -1,6 +1,6 @@ | |
| 1 1 | 
             
            {
         | 
| 2 2 | 
             
              "name": "@elliemae/ds-truncated-tooltip-text",
         | 
| 3 | 
            -
              "version": "3.57.0-next. | 
| 3 | 
            +
              "version": "3.57.0-next.9",
         | 
| 4 4 | 
             
              "license": "MIT",
         | 
| 5 5 | 
             
              "description": "ICE MT - Dimsum - Truncated Tooltip Text",
         | 
| 6 6 | 
             
              "files": [
         | 
| @@ -36,18 +36,17 @@ | |
| 36 36 | 
             
                "indent": 4
         | 
| 37 37 | 
             
              },
         | 
| 38 38 | 
             
              "dependencies": {
         | 
| 39 | 
            -
                " | 
| 40 | 
            -
                "@elliemae/ds- | 
| 41 | 
            -
                "@elliemae/ds- | 
| 42 | 
            -
                "@elliemae/ds- | 
| 43 | 
            -
                "@elliemae/ds-tooltip-v3": "3.57.0-next. | 
| 44 | 
            -
                "@elliemae/ds-props-helpers": "3.57.0-next.7"
         | 
| 39 | 
            +
                "@elliemae/ds-popover": "3.57.0-next.9",
         | 
| 40 | 
            +
                "@elliemae/ds-popper": "3.57.0-next.9",
         | 
| 41 | 
            +
                "@elliemae/ds-props-helpers": "3.57.0-next.9",
         | 
| 42 | 
            +
                "@elliemae/ds-system": "3.57.0-next.9",
         | 
| 43 | 
            +
                "@elliemae/ds-tooltip-v3": "3.57.0-next.9"
         | 
| 45 44 | 
             
              },
         | 
| 46 45 | 
             
              "devDependencies": {
         | 
| 47 46 | 
             
                "@elliemae/pui-cli": "9.0.0-next.65",
         | 
| 48 47 | 
             
                "jest": "~29.7.0",
         | 
| 49 48 | 
             
                "styled-components": "~5.3.9",
         | 
| 50 | 
            -
                "@elliemae/ds-monorepo-devops": "3.57.0-next. | 
| 49 | 
            +
                "@elliemae/ds-monorepo-devops": "3.57.0-next.9"
         | 
| 51 50 | 
             
              },
         | 
| 52 51 | 
             
              "peerDependencies": {
         | 
| 53 52 | 
             
                "react": "^18.3.1",
         |